在内核中通过current宏可以获取当前进程的task_struct,通过该结构体中的成员变量:
char comm[TASK_COMM_LEN];
可以方便的获取进程名,具体方法为调用函数:
char *get_task_comm(char *to, struct task_struct *tsk);
请注意:直接访问成员变量获取进程名会有乱码,需要用函数task_lock锁定task_struct后才能成功获取,函数get_task_comm内即有锁定与解锁操作。
上面的方法虽然简单直接,但存在2个问题:
- 由于TASK_COMM_LEN为16,如果进程名超过16,那么无法获取完整的名称;
- 如果进程是通过线程池pool启动的,那么获取的进程名总是pool而非真正的进程名称。
为解决以上2个问题,可以通过task_struct的成员变量active_mm来获取:
struct mm_struct *active_mm;
具体方法为:
current->active_mm->exe_file->f_path.dentry->d_name.name
名称长度为:
current->active_mm->exe_file->f_path.dentry->d_name.len
如果要获取进程完整路径,可通过d_path函数实现。