常规接口
创建一个debugfs目录:
struct dentry *debugfs_create_dir(const char *name, struct dentry *parent);
创建一个debugfs文件:
struct dentry *debugfs_create_file(const char *name, umode_t mode,
struct dentry *parent, void *data,
const struct file_operations *fops);
创建一个debugfs链接:
struct dentry *debugfs_create_symlink(const char *name, struct dentry *parent, const char *dest);
删除一个debugfs文件/目录:
void debugfs_remove(struct dentry *dentry);
便捷接口
按照上面的创建接口来操作的话,必须要构建并且传入一个 struct file_operations
结构体才行,这其实是相当繁琐的,因此内核已经实现了更加便捷的debugfs接口,替我们实现了一些常用的file_operations结构,这样我们可以不必重复去造轮子了,极大简化了开发复杂度。
struct dentry *debugfs_create_u8(const char *name, umode_t mode,
struct dentry *parent, u8 *value);
struct dentry *debugfs_create_u16(const char *name, umode_t mode,
struct dentry *parent, u16 *value);
struct dentry *debugfs_create_u32(const char *name, umode_t mode,
struct dentry *parent, u32 *value);
struct dentry *debugfs_create_u64(const char *name, umode_t mode,
struct dentry *parent, u64 *value);
struct dentry *debugfs_create_ulong(const char *name, umode_t mode,
struct dentry *parent, unsigned long *value);
struct dentry *debugfs_create_x8(const char *name, umode_t mode,
struct dentry *parent, u8 *value);
struct dentry *debugfs_create_x16(const char *name, umode_t mode,
struct dentry *parent, u16 *value);
struct dentry *debugfs_create_x32(const char *name, umode_t mode,
struct dentry *parent, u32 *value);
struct dentry *debugfs_create_x64(const char *name, umode_t mode,
struct dentry *parent, u64 *value);
struct dentry *debugfs_create_size_t(const char *name, umode_t mode,
struct dentry *parent, size_t *value);
struct dentry *debugfs_create_atomic_t(const char *name, umode_t mode,
struct dentry *parent, atomic_t *value);
struct dentry *debugfs_create_bool(const char *name, umode_t mode,
struct dentry *parent, bool *value);
这一系列的函数,内核中只需要传入对应数据类型的value地址即可,注册完成后,应用层会在debugfs中会生成对应的debug文件节点,这个节点可以供应用层来读取和写入该value值。由此实现应用和内核的信息交互。文件节点的读取属性由mode来指定,内核会根据mode来执行不同的file_operations。分为只读、只写、可读写类型。