struct bus_attribute *bus_attrs; // 总线属性 struct device_attribute *dev_attrs; // 设备属性 struct driver_attribute *drv_attrs; // 驱动程序属性 const struct attribute_group **bus_groups; // 总线属性组 const struct attribute_group **dev_groups; // 设备属性组 const struct attribute_group **drv_groups; // 驱动程序属性组
时间: 2024-04-26 18:27:03 浏览: 255
这几个字段分别用于定义总线、设备和驱动程序的属性和属性组:
- `bus_attrs`:指向总线属性的指针,可以使用 `sysfs` 文件系统来读取和修改这些属性。
- `dev_attrs`:指向设备属性的指针,同样可以使用 `sysfs` 文件系统来读取和修改这些属性。
- `drv_attrs`:指向驱动程序属性的指针,也可以使用 `sysfs` 文件系统来读取和修改这些属性。
- `bus_groups`:指向总线属性组的指针,一个属性组是一组相关的属性,可以一次性添加到 `sysfs` 上。这个指针指向一个指针数组,每个指针指向一个属性组。
- `dev_groups`:指向设备属性组的指针,同样是一个指针数组,每个指针指向一个属性组。
- `drv_groups`:指向驱动程序属性组的指针,也是一个指针数组,每个指针指向一个属性组。
通过这些属性和属性组,可以方便地向 `sysfs` 中添加和管理设备和驱动程序的属性。
相关问题
还是刚刚那个问题,ops操作set_alarm 调用我的驱动里面的pm8xxx_rtc_set_alarm,我在另一个c文件中看到如下代码:static bool rtc_does_wakealarm(struct rtc_device *rtc) { return rtc->ops->set_alarm != NULL; } static umode_t rtc_attr_is_visible(struct kobject *kobj, struct attribute *attr, int n) { struct device *dev = container_of(kobj, struct device, kobj); struct rtc_device *rtc = to_rtc_device(dev); umode_t mode = attr->mode; if (attr == &dev_attr_wakealarm.attr) { if (!rtc_does_wakealarm(rtc)) mode = 0; } else if (attr == &dev_attr_offset.attr) { if (!rtc->ops->set_offset) mode = 0; } else if (attr == &dev_attr_range.attr) { if (!(rtc->range_max - rtc->range_min)) mode = 0; } return mode; } static struct attribute_group rtc_attr_group = { .is_visible = rtc_attr_is_visible, .attrs = rtc_attrs, }; static const struct attribute_group *rtc_attr_groups[] = { &rtc_attr_group, NULL }; 可是这里后面又不知道它是怎么被framwork调用的来了
这段代码是定义了 rtc 设备的属性组,包含了属性的可见性和属性本身。在 Linux 的设备模型中,设备属性可以通过 sysfs 接口进行访问和操作。这里定义了一个 attribute_group 结构体,其中包含了 is_visible 函数指针和 attrs 数组。is_visible 函数的作用是判断属性是否可见,如果不可见则返回 0,否则返回属性的 mode 值。attrs 数组则是属性的集合。
在 Linux 系统中,设备驱动通常会通过注册设备和属性来向框架注册自己。具体来说,设备驱动会调用函数如 device_register 和 sysfs_create_group 来将设备和属性注册到系统中。这些函数会将设备和属性添加到设备树和 sysfs 中,使得用户可以通过 sysfs 接口来访问和操作这些设备和属性。
struct device_driver结构体定义
在Linux内核中,struct device_driver结构体用于表示一个设备驱动程序。
它的定义如下:
```
struct device_driver {
const char *name;
struct bus_type *bus;
struct module *owner;
const char *mod_name; /* driver model name */
bool suppress_bind_attrs;
const struct of_device_id *of_match_table;
const struct acpi_device_id *acpi_match_table;
const struct platform_device_id *id_table;
int (*probe) (struct device *dev);
int (*remove) (struct device *dev);
void (*shutdown) (struct device *dev);
int (*suspend) (struct device *dev, pm_message_t state);
int (*resume) (struct device *dev);
const struct attribute_group **groups;
const struct dev_pm_ops *pm;
const struct driver_private *p;
};
```
其中,各个成员的含义如下:
- `name`:设备驱动程序的名称。
- `bus`:设备所连接的总线类型。
- `owner`:指向驱动程序模块的指针。
- `mod_name`:驱动程序的模块名。
- `suppress_bind_attrs`:是否禁用绑定属性。
- `of_match_table`:Open Firmware匹配表。
- `acpi_match_table`:ACPI匹配表。
- `id_table`:设备标识表。
- `probe`:设备探测函数指针。
- `remove`:设备移除函数指针。
- `shutdown`:设备关机函数指针。
- `suspend`:设备挂起函数指针。
- `resume`:设备恢复函数指针。
- `groups`:设备属性组。
- `pm`:设备电源管理操作函数指针。
- `p`:驱动程序的私有数据。
阅读全文