以后如何更改 sysfs_create_file() 的权限?

How to change a sysfs_create_file()'s permissions later?

我正在为 Linux 内核编写一个模块。

此模块将一些 I/O 作为文件公开 /sys/kernel/mymodule/foo:

static struct kobj_attribute foo_attribute =__ATTR(foo, 0660, foo_show, foo_store);
...        
ret = sysfs_create_file(&mymodule->kobj, &foo_attribute.attr);

我希望能够在某些数据写入 /sys/kernel/mymodule/foo 后立即将 0660 权限更改为 0440。我将在 foo_store() 函数中执行此操作。

我调查了 __ATTR 宏 - 它会产生大量代码,主要是操纵权限。上面的代码展开为:

static struct foo_attribute = { .attr = {.name = "foo", .mode = ((sizeof(struct { int:-!!((0660) < 0); })) + (sizeof(struct { int:-!!((0660) > 0777); })) + (sizeof(struct { int:-!!(((0660) >> 6) < (((0660) >> 3) & 7)); })) + (sizeof(struct { int:-!!((((0660) >> 3) & 7) < ((0660) & 7)); })) + (sizeof(struct { int:-!!((0660) & 2); })) + (0660)) }, .show = foo_show, .store = foo_store, };
...
ret = sysfs_create_file(&vr2200pmu->kobj, &revision_attribute.attr);

通过使用模块目录中的 gcc -E mymodule.c -I../../include -I../../arch/arm/include -I../../arch/arm/include/generated

我怎样才能以干净、便携的方式实现这一点?

不确定,这是否是预期以编程方式修改 sysfs 文件权限的方式,但这应该可行:

// Obtain kernfs object for directory
struct kernfs_node* dir_knode = kobj->sd;
// Obtain kernfs object for file in the directory
struct kernfs_node* file_knode = sysfs_get_dirent(dir_knode, foo_attr.attr.name);
// Change permissions. Set only permissions-related bits.
file_knode->mode = (file_knode->mode & S_IFMT) | 0440;