我向Linux内核添加了一个系统调用,如下所示:
#include
#include
#include
#include
#include
asmlinkage int sys_os_pid_to_uid(int pid, int* puid)
{
struct task_struct* task;
rcu_read_lock();
for_each_process(task)
{
if (task->pid == (pid_t) pid)
{
copy_to_user(puid, &(task->cred->uid.val), sizeof(task->cred->uid.val));
}
}
rcu_read_unlock();
return 0;
}
它获取进程ID(pid),并确定执行该进程的用户的用户ID(puid).
现在,我的问题开始了:我想向该系统调用添加另一个参数,即char * username,它将包含ID为puid的用户的用户名.我在cred.h标头中搜索,但找不到与用户名有关的任何内容.
谁能帮我解决这个问题?
解决方法:
您没有找到它的原因是因为没有一个:task_struct,通常来说,内核不保留有关给定用户ID的用户名的内存信息.这是完全不必要的,会给界面和代码增加混乱,并且会消耗内存,而没有任何额外的好处:与用户有关的所有内容都使用数字用户ID表示和存储.比较容易并且可以节省内存.
您不应该/不能在系统调用中执行此操作.
我建议您编写一个包装程序用户空间函数,该函数调用系统调用,然后调用getpwuid(3)或getpwuid_r(3)将用户ID转换为用户名.注意,这是在用户空间而不是内核空间中完成的.
标签:system-calls,kernel,linux
来源: https://codeday.me/bug/20191120/2041210.html