给定一个结构文件,是否可以在 linux 内核空间中获取关联的文件描述符?我正在尝试使用 sys_chmod 或 sys_fchmod 更改权限。一个接受文件描述符,另一个需要来自用户空间的文件名。我可以弄清楚如何获取文件名,但是如何将其转换为用户空间指针?
谢谢
给定一个结构文件,是否可以在 linux 内核空间中获取关联的文件描述符?我正在尝试使用 sys_chmod 或 sys_fchmod 更改权限。一个接受文件描述符,另一个需要来自用户空间的文件名。我可以弄清楚如何获取文件名,但是如何将其转换为用户空间指针?
谢谢
您追求的功能是chmod_common
:
static int chmod_common(struct path *path, umode_t mode)
需要 apath
和您要设置的模式。不幸的是,正如您所注意到的,它是静态的,显然没有导出。所以你可以采取多种方式:
struct file
从(丑陋的)获取“文件描述符”sys_chmod
现在sys_chmod
需要一个用户指针,但您在内核中。您可以采取以下措施来欺骗它:
mm_segment_t oldfs = get_fs();
char __user *userptr;
userptr = (char __user __force *) kernptr;
set_fs(KERNEL_DS);
/* call sys_chmod */
set_fs(oldfs);
这一切都非常符合“你永远不应该在内核中做的事情”。