- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我想为 tmp102 温度传感器创建一个内核驱动程序。在一个项目中,我只有 1 个传感器,而在另一个项目中,我有 2 个传感器。我希望我的内核模块能够支持 N 个传感器,而不是固定数量。我在管理超过 1 个 struct i2c_client 并为每个 struct i2c_client 创建 sysfs 条目时遇到问题。这是我的做法:
在 probe()
函数中,我为每个提供 I2C_BOARD_INFO()
的设备获取 struct i2c_client*
.
然后我 kobject_create_and_add("tmp102", kernel_kobj)
获取 sysfs 中模块的主目录。
我正在为每个设备创建 sysfs_create_group()
,它获取指向静态创建的属性的指针。这些属性将 (*show)()
和 (*store)()
指针设置为静态函数,例如
static ssize_t tmp102_sysfs_thigh_get_one(struct kobject *kobj, struct kobj_attribute *attr, char *buf)
在这个函数中,我想通过 I2C 读取。问题是...我不知道如何为应该以某种方式链接到此 sysfs 条目的设备获取 struct i2c_client *
,I2C 地址是那里!
我应该如何正确地将 i2c_client 与 sysfs 条目“链接”起来,以便我可以获得函数内部的 I2C 地址?
理想情况下,我希望只有一组函数(每个属性一个)。 sysfs 树应该是这样的:
/sysfs/kernel/tmp102
|
|-> <hex i2c address, e.g. /48>
| |
| |-> temperature
|
|
|-> /49
|
|-> temperature
我希望两个“温度”属性都使用相同的函数,该函数能够确定它应该写入的 I2C 地址。
或者我的架构完全错误?如果是这样,对于需要处理多个 i2c_client
的驱动程序来说应该是什么样子?
编辑:
我决定使用 struct device_attribute
而不是常规的 attribute
。据我了解,使用常规属性时,获取struct device
指针并不容易,与struct i2c_client
一样。它们不容易与 /sys/kernel
中的 kobject
“链接”,我需要在该项目中拥有我的属性。 device_attribute
可以在 /sys/devices
中找到 - 我使用了 sysfs_create_group
并将我设备的 kobject
与 device_attribute
组。我使用了 sysfs_create_link
,并将我设备的 kobject
与 /sys/kernel/tmp102
链接起来。这样我就可以为每个设备创建一个文件夹(链接),它指向 /sys/devices
中的原始属性文件夹。
最佳答案
首先,您应该知道已经有一个具有 sysfs 接口(interface)的 tmp102 内核驱动程序。看看drivers/hwmon/tmp102.c .
现在,对于您的问题,您有一个传递给您的 sysfs 回调的 struct kobject
。您可以调用 kobj_to_dev()
来获取指向设备的指针。然后,例如,您可以使用 dev_get_drvdata()
获取指向您自己的私有(private)结构的指针,该结构将包含指向 i2c 客户端的指针。不要忘记首先在您的探测器中使用 dev_set_drvdata()
设置它。
您可以在 drivers/rtc/rtc-ds1343.c 中找到示例但它使用的是 spi_driver。
关于linux - 在一个驱动模块中处理多个 i2c_clients(使用 sysfs),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46283121/
我之前已经发布了查询,我正在重复同样的问题我想修改 kernel2.6 中内置的 igmpv3 (Linux)。-- 以便它从文件中读取一个值并适本地决定内部的保留 (res 1) 值主机发送的igm
在内核 4.0 上,当单步执行 sysfs_create_bin_file 的内核源代码时,我注意到它传递给了 sysfs_add_file(kobj->sd, &attr->attr, true);
我只是想为/sys 文件系统中的设备添加一个简单的属性。看起来很简单,但没有提到任何辅助方法 here或 here是从内核导出的,所以我不能从模块中使用它们?我一定遗漏了什么,任何人都可以提供一些见解
所以我一直在阅读 Linux API(系统调用和 libc)以及设备 ioctls,通过 create(dev_name) 和 ioctl(device_file_handle) 调用 ioctls
我想将大于 1024 个字符的字符串传递到我的模块(文件系统)。由于内核参数限制为 1024 个字符,someone recommended改为使用 sysfs。 我试图包括 this example
在用户空间中,我可以echo noop >/sys/block/sda/queue/scheduler。 如何在内核模块中做同样的事情? 我期待这样的事情(伪代码): struct dentry* e
我正在编写一个检查电池容量的守护进程。这是用于运行 Linux 的太阳能嵌入式设备。我读过使用 sleep() 是个坏主意在守护进程中,因此我正在尝试使用事件。所以我写了一些 PoC,但我没有收到任何
最近我正在查看 kobjects 和 sysfs 的内核。 我知道/理解以下.. 所有内核对象使用地址 > 0x80000000 kobjects 也不异常(exception) sysfs 只不过是
处理 sysfs阅读我需要创建一个 show添加到 kobj_attribute 的函数结构体。 the function is defined as的原型(prototype): ssize_t (
我已经成功地向我的设备驱动程序添加了一个设备属性,但在我发现的所有示例中,该属性都用于向内核注入(inject)数据,而我的目标是从内核导出一些数据以使其可见在用户空间。从内核空间写入该文件的正确方法
源自this question (和 my solution ),我已经意识到可能存在死锁,但我不明白为什么以及如何避免它。 简而言之,内核空间中有一个信号量,内核模块(它们实际上是在内核空间中运行的
我如何从用户应用程序读取 sysfs 属性。它与 cat 命令的内容类似。比如我有一个标签是亮度。如何获取亮度标签的值?因为我需要从我的应用程序读取 USB 信息,并且我看到它们被导出到 sysfs,
如何使用 sysfs 检测我的硬件模块(例如 MSR)是否执行事件或中断? 最佳答案 你的问题有点含糊。 对于中断,您可以查看 cat/proc/interrupts 的输出,看看您的驱动程序的中断计
我想知道..实际上什么是 sysfs 中的属性文件,..为什么我们需要在 sysfs 目录中为某些驱动程序而不是某些驱动程序创建属性文件.. 我们什么时候真正需要它? 我已经阅读了 LDD3 和其他一
我正在为多个定制硬件编写驱动程序。所有设备都通过 PCIe 连接到主机。为了方便起见,我想将所有这些自定义设备组合到一个 sysfs 类中(我认为这是可以接受的事情?)。不幸的是,LDD3 中的信息已
在我正在使用的设备上,我可以写入 /sys/class/leds 来打开/关闭 LED 灯。我可以在我的代码中保持文件打开并仅在进程退出时关闭,还是应该仅在需要写入文件时打开文件? 最佳答案 是的。这
我正在编写一个 linux 设备驱动程序,除其他外,它在 sysfs 中公开了一个只读二进制属性,其接口(interface)是 static ssize_t read_dump_fifo(struc
我正在尝试学习如何编写 sysfs 模块,但对基本的初始化感到困惑。在 this查看 kobject.h 文件的文档,有几个与创建 sysfs 条目相关的不同函数。 从外观上看,函数“kobject_
我正在使用 C 文件 IO 从 linux 中的 sysfs 接口(interface)读取值。寄存器的路径和样例值如下: cat /sys/class/powercap/intel-rapl/int
我的 FPGA 中有一个带有多个 I/O 寄存器的通用 AXI 从设备。我想使用 sysfs 接口(interface)访问我的寄存器。对于我想要访问的每个寄存器,我都创建了一个 _show 和一个
我是一名优秀的程序员,十分优秀!