给定一个结构体文件,是否可以在Linux内核空间中获取关联的文件描述符?我正在尝试使用 sys_chmod 或 sys_fchmod 更改权限。一个获取文件描述符,另一个期望来自用户空间的文件名。我可以弄清楚如何获取文件名,但如何将其转换为用户空间指针?
谢谢
最佳答案
您需要的函数是chmod_common
:
static int chmod_common(struct path *path, umode_t mode)
它需要一个路径
和您想要设置的模式。不幸的是,正如您所注意到的,它是静态的并且显然没有导出。所以你可以采取多种方式:
- 在您自己的函数中复制它所做的任何事情
- 从
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);
关于c - 从内核空间的文件指针获取fd,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14913965/