您的位置:首页 > 其它

进程管理API之__task_pid_nr_ns

2017-11-21 14:31 495 查看
pid_t __task_pid_nr_ns(struct task_struct *task, enum pid_type type,struct pid_namespace *ns)
此函数用于根据task和pid_namespace得到符合条件的进程号也就是pid号。
使用的例子如下:
task_pid_nr_ns 函数通过调用__task_pid_nr_ns 得到符合task_struct *tsk和pid_namespace *ns的pid号
static inline pid_t task_pid_nr_ns(struct task_struct *tsk, struct pid_namespace *ns)
{
return __task_pid_nr_ns(tsk, PIDTYPE_PID, ns);
}
其源码分析如下:
pid_t __task_pid_nr_ns(struct task_struct *task, enum pid_type type,
struct pid_namespace *ns)
{
pid_t nr = 0;
//遍历task list需要通过rcu_read_lock来保护
rcu_read_lock();
//如果输入的ns为null,则取当前task的ns
if (!ns)
ns = task_active_pid_ns(current);
//判断当前task是否live,这个条件用like修饰,说明一般情况下都成立
if (likely(pid_alive(task))) {
//输入的enum pid_type type参数分两种情况,一种是PID,则返回当前ns下task的pid,一种是TGID,则返回
这个task 的领头的task的pid
if (type != PIDTYPE_PID) {
if (type == __PIDTYPE_TGID)
type = PIDTYPE_PID;
task = task->group_leader;
}
//根据task 对应的pid找到ns范围内的pid.
nr = pid_nr_ns(rcu_dereference(task->pids[type].pid), ns);
}
rcu_read_unlock();

return nr;
}

这里可能说的有点绕,看看下面的函数就明白了
pid_t pid_nr_ns(struct pid *pid, struct pid_namespace *ns)
{
struct upid *upid;
pid_t nr = 0;
// 如果当前pid的level 已经大于ns的level,则直接返回0,否则以ns->level 作为index找到对应upid,
如果upid 的name space等于我们的namespace,则返回upid的nr,作为__task_pid_nr_ns的最终返回值
if (pid && ns->level <= pid->level) {
upid = &pid->numbers[ns->level];
if (upid->ns == ns)
nr = upid->nr;
}
return nr;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: