- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试为我在 android 中的实现创建一个 sysfs,并坚持在 CLASS
中创建我自己的文件夹。
我的要求:
/sys/class/example_class/my_sysfs_directory/file_one.
代码:
#include<linux/module.h>
#include<linux/kernel.h>
#include<linux/device.h>
#include <linux/err.h>
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Manoj");
static ssize_t sysfs_demo_show(struct class *class,
struct class_attribute *attr, char *buf)
{
pr_info("%s [%d]: \n", __func__, __LINE__);
return sprintf(buf, "%s \n", __func__);
}
static ssize_t sysfs_demo_store(struct class *class,
struct class_attribute *attr, const char *buf, size_t size)
{
pr_info("%s [%d]: \n", __func__, __LINE__);
return size;
}
static CLASS_ATTR(file_one, 0777, sysfs_demo_show, sysfs_demo_store);
int sysfs_my_dev_uevent(struct device *dev, struct kobj_uevent_env *env)
{
pr_info("%s [%d]: \n", __func__, __LINE__);
return 0;
}
struct class *example_class;
int sysfs_demo_init(void)
{
int ret;
pr_info("%s [%d]: \n", __func__, __LINE__);
example_class = class_create(THIS_MODULE, "demo");
if (IS_ERR(example_class)) {
pr_err("Failed to create sys_class\n");
return -1;
}
example_class->dev_uevent = sysfs_my_dev_uevent;
ret = class_create_file(example_class, &class_attr_file_one);
if (ret) {
pr_err("Failed to create class file @ parent class dirs\n");
return -1;
}
return 0;
}
void sysfs_demo_exit(void)
{
pr_info("%s [%d]: \n", __func__, __LINE__);
class_remove_file(example_class, &class_attr_file_one);
class_destroy(example_class);
}
module_init(sysfs_demo_init);
module_exit(sysfs_demo_exit);
我已经把我的代码贴在这里了,请在这方面帮助我。
最佳答案
不推荐“手动”创建 sysfs 目录/文件。
每个 sysfs 属性都应该关联到一个设备。如果您的目标是设备驱动程序,您迟早会使用结构device
。这里是related answer
关于android - 如何在 sysfs 中的文件夹中创建文件夹,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19653851/
我之前已经发布了查询,我正在重复同样的问题我想修改 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 和一个
我是一名优秀的程序员,十分优秀!