sysfs接口函数的建立_DEVICE_ATTR

说道sysfs接口,就不得不提到函数宏 DEVICE_ATTR,原型是

#define DEVICE_ATTR(_name, _mode, _show, _store) \

struct device_attribute dev_attr_##_name = __ATTR(_name, _mode, _show, _store)

函数宏DEVICE_ATTR内封装的是__ATTR(_name,_mode,_show,_stroe)方法

_show:表示的是读方法,

_stroe表示的是写方法。

 

当然_ATTR不是独生子女,他还有一系列的姊妹__ATTR_RO宏只有读方法,__ATTR_NULL等等

如对设备的使用        DEVICE_ATTR   

对驱动使用               DRIVER_ATTR

对总线使用               BUS_ATTR 

对类别 (class) 使用  CLASS_ATTR

这四个高级的宏来自于<include/linux/device.h> 

DEVICE_ATTR  宏声明有四个参数,分别是名称、权限位、读函数、写函数。其中读函数和写函数是读写功能函数的函数名。

如果你完成了DEVICE_ATTR函数宏的填充,下面就需要创建接口了

例如:

    static DEVICE_ATTR(polling, S_IRUGO | S_IWUSR, show_polling, set_polling);
    static struct attribute *dev_attrs[] = {
            &dev_attr_polling.attr,
            NULL,
    };

当你想要实现的接口名字是polling的时候,需要实现结构体struct attribute *dev_attrs[]

其中成员变量的名字必须是&dev_attr_polling.attr

然后再封装

    static struct attribute_group dev_attr_grp = {
            .attrs = dev_attrs,
    };

在利用sysfs_create_group(&pdev->dev.kobj, &dev_attr_grp);创建接口

       通过以上简单的三个步骤,就可以在adb shell 终端查看到接口了。当我们将数据 echo 到接口中时,在上层实际上完成了一次 write 操作,对应到 kernel ,调用了驱动中的 “store”。同理,当我们cat 一个 接口时则会调用 “show” 。到这里,只是简单的建立了 android 层到 kernel 的桥梁,真正实现对硬件操作的,还是在 "show" 和 "store" 中完成的。


       其实呢?!用个proc文件系统的就知道,这个就和proc中的write和read一样的,以我的理解:proc有点老了,以后肯定会大量使用attribute,proc好比是Windows XP,attribute就像是Windows Seven
<think>我们正在讨论Linux内核中的设备属性接口。用户询问DEVICE_ATTR_WO是否是Linux系统中的接口。 根据Linux内核文档,`DEVICE_ATTR_WO`是一个宏,用于创建只写(write-only)的设备属性。它定义在`include/linux/device.h`中。 这个宏会生成一个`struct device_attribute`对象,该对象可以被用来在sysfs中创建一个只写文件。用户空间可以通过写这个文件来向设备驱动发送命令或数据。 使用示例: 假设我们有一个设备,我们想创建一个只写的属性"reset",那么我们可以这样定义: static DEVICE_ATTR_WO(reset); 然后,在设备创建时,使用`device_create_file`来创建这个属性文件。 注意:`DEVICE_ATTR_WO`是Linux内核版本4.11及以上引入的。在旧版本中,可以使用`DEVICE_ATTR`宏并指定只写权限(S_IWUSR)来达到类似效果。 因此,答案是:是的,`DEVICE_ATTR_WO`是Linux内核提供的一个接口。 接下来,按照要求生成相关问题。</think>是的,`DEVICE_ATTR_WO` 是 Linux 内核中用于创建设备属性的标准接口。这是 Linux 设备驱动模型的一部分,用于在 sysfs 文件系统中创建**只写(Write-Only)** 的设备属性文件[^1]。 ### 关键特性: 1. **功能作用** 用于在 `/sys/class/` 或 `/sys/devices/` 下生成只写文件节点,用户空间程序可通过写入该文件与内核交互(如触发设备操作、发送控制命令等)。 2. **语法定义** 在驱动代码中使用宏定义: ```c static DEVICE_ATTR_WO(attribute_name); ``` 其中 `attribute_name` 是自定义属性名,最终在 sysfs 中生成的文件名为 `attribute_name`。 3. **实现原理** 该宏会生成一个 `struct device_attribute` 结构体,包含: - `.attr`:设置文件权限为 `S_IWUSR | S_IWGRP`(用户和组可写) - `.store`:强制绑定到指定的写回调函数 - 无 `.show` 成员(禁止读操作) 4. **典型应用场景** ```c static ssize_t reset_store(struct device *dev, struct device_attribute *attr, const char *buf, size_t count) { // 解析buf并执行设备复位操作 return count; } static DEVICE_ATTR_WO(reset); // 创建/sys/class/xxx/reset文件 ``` 用户通过 `echo 1 > /sys/class/xxx/reset` 即可触发设备复位[^1]。 ### 版本依赖 该宏在较新的内核版本(4.11+)中引入,旧版本可使用 `DEVICE_ATTR` 手动指定权限: ```c static DEVICE_ATTR(reset, S_IWUSR, NULL, reset_store); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值