首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >一种通过pid查找task_struct的有效方法

一种通过pid查找task_struct的有效方法
EN

Stack Overflow用户
提问于 2011-12-18 03:25:46
回答 4查看 26.1K关注 0票数 15

有没有一种有效的方法来查找指定PID的task_struct,而无需遍历task_struct列表?

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2011-12-18 03:44:29

使用以下方法之一有什么问题吗?

代码语言:javascript
运行
复制
extern struct task_struct *find_task_by_vpid(pid_t nr);
extern struct task_struct *find_task_by_pid_ns(pid_t nr,
            struct pid_namespace *ns);
票数 19
EN

Stack Overflow用户

发布于 2013-04-08 09:10:58

如果你想从一个模块中找到task_structfind_task_by_vpid(pid_t nr)等不会起作用,因为这些函数不会被导出。

在模块中,您可以使用以下函数:

代码语言:javascript
运行
复制
pid_task(find_vpid(pid), PIDTYPE_PID);
票数 15
EN

Stack Overflow用户

发布于 2020-03-15 19:04:17

有一种更好的方法可以从模块中获取task_struct的实例。总是尝试使用包装器函数/助手例程,因为它们是这样设计的,如果驱动程序程序员遗漏了什么,内核可以自己处理。用于错误处理、条件检查等。

代码语言:javascript
运行
复制
/* Use below API and you will get a pointer of (struct task_struct *) */

taskp = get_pid_task(pid, PIDTYPE_PID);

并获取pid_t类型的PID。您需要使用以下接口-

代码语言:javascript
运行
复制
find_get_pid(pid_no);

在调用这些接口时,您不需要使用"rcu_read_lock()“和"rcu_read_unlock()”,因为"get_pid_task()“在内部调用rcu_read_lock()、rcu_read_unlock()之后才调用"pid_task()”,并且可以正确地处理并发。这就是为什么我在上面说过总是使用这种包装器的原因。

下面是get_pid_task()和find_get_pid()函数的代码片段:

代码语言:javascript
运行
复制
struct task_struct *get_pid_task(struct pid *pid, enum pid_type type)
{
    struct task_struct *result;
    rcu_read_lock();
    result = pid_task(pid, type);
    if (result)
        get_task_struct(result);
    rcu_read_unlock();
    return result;
}
EXPORT_SYMBOL_GPL(get_pid_task);

struct pid *find_get_pid(pid_t nr)
{
    struct pid *pid;

    rcu_read_lock();
    pid = get_pid(find_vpid(nr));
    rcu_read_unlock();

    return pid;
}
EXPORT_SYMBOL_GPL(find_get_pid);

在内核模块中,您也可以通过以下方式使用wrapper函数:

代码语言:javascript
运行
复制
taskp = get_pid_task(find_get_pid(PID),PIDTYPE_PID);

PS:有关API的更多信息,可以查看kernel/pid.c

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8547332

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档