2

给定一个结构文件,是否可以在 linux 内核空间中获取关联的文件描述符?我正在尝试使用 sys_chmod 或 sys_fchmod 更改权限。一个接受文件描述符,另一个需要来自用户空间的文件名。我可以弄清楚如何获取文件名,但是如何将其转换为用户空间指针?

谢谢

4

1 回答 1

2

您追求的功能是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);

这一切都非常符合“你永远不应该在内核中做的事情”

于 2013-02-16T19:15:04.917 回答