查看的参考文档
[内核官网介绍](https://www.kernel.org/doc/Documentation/filesystems/sysfs.txt)
Sysfs: 内部存储在kobject 是直接引入kernfs_node 对象来声明一个目录,在旧版本kobject 指针被sysfs用于应用计数判断文件打开关闭,在现在只是用于修改计数
第一种:
An attribute definition is simply:
struct attribute {
char * name;
struct module *owner;
umode_t mode;
};
int sysfs_create_file(struct kobject * kobj, const struct attribute * attr);
void sysfs_remove_file(struct kobject * kobj, const struct attribute * attr);
这种方式需要创建kobject 对象,然后在对象中创建文件属性,而对应的kobject 对象内部创建的文件都是使用
同一个store 跟show等操作接口,通过kobject 创建时候的kobj_type对象引入
设计到的接口:kobject_init_and_add、sysfs_create_group、sysfs_create_file
第二种:
Structure:
struct driver_attribute {
struct attribute attr;
ssize_t (*show)(struct device_driver *, char * buf);
ssize_t (*store)(struct device_driver *, const char * buf,
size_t count);
};
Declaring:
#define DRIVER_ATTR_RW(_name) \
struct driver_attribute driver_attr_##_name = __ATTR_RW(_name)
#define DRIVER_ATTR_RO(_name) \
struct driver_attribute driver_attr_##_name = __ATTR_RO(_name)
#define DRIVER_ATTR_WO(_name) \
struct driver_attribute driver_attr_##_name = __ATTR_WO(_name)
Creation/Removal:
int driver_create_file(struct device_driver *, const struct driver_attribute *);
void driver_remove_file(struct device_driver *, const struct driver_attribute *);
实例:
举个例子:drivers/usb/core/driver.c
首先系统会在drivers/usb/core/driver.c文件中声明私有变量static DRIVER_ATTR_RW(new_id);
然后在usb_create_newid_files函数中调用如下创建函数:
error = driver_create_file(&usb_drv->drvwrap.driver,
&driver_attr_new_id);
最后为usb驱动在sysfs 中创建对应的的文件目录用于查写
注意:
DRIVER_ATTR_RW(new_id)就是通过宏把接口给默认创建出来了:
#define __ATTR_RW(_name) __ATTR(_name, 0644, _name##_show, _name##_store)
所以后续只要定义对应的_name##_show, _name##_store实现就好了