| Home » Mailing lists » Devel » [RFC][PATCH 0/15] Pid namespaces 
	| 
		
			| [PATCH 7/15] Helpers to obtain pid numbers [message #15301 is a reply to message #15293] | Thu, 26 July 2007 14:51   |  
			| 
				
				
					|  Pavel Emelianov Messages: 1149
 Registered: September 2006
 | Senior Member |  |  |  
	| When showing pid to user or getting the pid numerical id for in-kernel use the value of this id may differ depending on the namespace.
 
 This set of helpers is used to get the global pid nr, the virtual (i.e.
 seen by task in its namespace) nr and the nr as it is seen from the
 specified namespace.
 
 Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
 
 ---
 
 include/linux/pid.h   |   24 ++++++++++-
 include/linux/sched.h |  108 +++++++++++++++++++++++++++++++++++++++++++++-----
 kernel/pid.c          |    8 +++
 3 files changed, 129 insertions(+), 11 deletions(-)
 
 diff -upr linux-2.6.23-rc1-mm1.orig/include/linux/pid.h linux-2.6.23-rc1-mm1-7/include/linux/pid.h
 --- linux-2.6.23-rc1-mm1.orig/include/linux/pid.h	2007-07-26 16:34:45.000000000 +0400
 +++ linux-2.6.23-rc1-mm1-7/include/linux/pid.h	2007-07-26 16:36:37.000000000 +0400
 @@ -83,12 +92,34 @@ extern void FASTCALL(detach_pid(struct t
 
 extern struct pid *alloc_pid(struct pid_namespace *ns);
 extern void FASTCALL(free_pid(struct pid *pid));
 +
 +/*
 + * the helpers to get the pid's id seen from different namespaces
 + *
 + * pid_nr()    : global id, i.e. the id seen from the init namespace;
 + * pid_vnr()   : virtual id, i.e. the id seen from the namespace this pid
 + *               belongs to. this only makes sence when called in the
 + *               context of the task that belongs to the same namespace;
 + * pid_nr_ns() : id seen from the ns specified.
 + *
 + * see also task_xid_nr() etc in include/linux/sched.h
 + */
 
 static inline pid_t pid_nr(struct pid *pid)
 {
 pid_t nr = 0;
 if (pid)
 -		nr = pid->nr;
 +		nr = pid->numbers[0].nr;
 +	return nr;
 +}
 +
 +pid_t pid_nr_ns(struct pid *pid, struct pid_namespace *ns);
 +
 +static inline pid_t pid_vnr(struct pid *pid)
 +{
 +	pid_t nr = 0;
 +	if (pid)
 +		nr = pid->numbers[pid->level].nr;
 return nr;
 }
 
 diff -upr linux-2.6.23-rc1-mm1.orig/include/linux/sched.h linux-2.6.23-rc1-mm1-7/include/linux/sched.h
 --- linux-2.6.23-rc1-mm1.orig/include/linux/sched.h	2007-07-26 16:34:45.000000000 +0400
 +++ linux-2.6.23-rc1-mm1-7/include/linux/sched.h	2007-07-26 16:36:37.000000000 +0400
 @@ -1221,16 +1222,6 @@ static inline int rt_task(struct task_st
 return rt_prio(p->prio);
 }
 
 -static inline pid_t task_pgrp_nr(struct task_struct *tsk)
 -{
 -	return tsk->signal->pgrp;
 -}
 -
 -static inline pid_t task_session_nr(struct task_struct *tsk)
 -{
 -	return tsk->signal->__session;
 -}
 -
 static inline void set_task_session(struct task_struct *tsk, pid_t session)
 {
 tsk->signal->__session = session;
 @@ -1256,6 +1247,104 @@ static inline struct pid *task_session(s
 return task->group_leader->pids[PIDTYPE_SID].pid;
 }
 
 +struct pid_namespace;
 +
 +/*
 + * the helpers to get the task's different pids as they are seen
 + * from various namespaces
 + *
 + * task_xid_nr()     : global id, i.e. the id seen from the init namespace;
 + * task_xid_vnr()    : virtual id, i.e. the id seen from the namespace the task
 + *                     belongs to. this only makes sence when called in the
 + *                     context of the task that belongs to the same namespace;
 + * task_xid_nr_ns()  : id seen from the ns specified;
 + *
 + * set_task_vxid()   : assigns a virtual id to a task;
 + *
 + * task_ppid_nr_ns() : the parent's id as seen from the namespace specified.
 + *                     the result depends on the namespace and whether the
 + *                     task in question is the namespace's init. e.g. for the
 + *                     namespace's init this will return 0 when called from
 + *                     the namespace of this init, or appropriate id otherwise.
 + *
 + *
 + * see also pid_nr() etc in include/linux/pid.h
 + */
 +
 +static inline pid_t task_pid_nr(struct task_struct *tsk)
 +{
 +	return tsk->pid;
 +}
 +
 +static inline pid_t task_pid_nr_ns(struct task_struct *tsk,
 +		struct pid_namespace *ns)
 +{
 +	return pid_nr_ns(task_pid(tsk), ns);
 +}
 +
 +static inline pid_t task_pid_vnr(struct task_struct *tsk)
 +{
 +	return pid_vnr(task_pid(tsk));
 +}
 +
 +
 +static inline pid_t task_tgid_nr(struct task_struct *tsk)
 +{
 +	return tsk->tgid;
 +}
 +
 +static inline pid_t task_tgid_nr_ns(struct task_struct *tsk,
 +		struct pid_namespace *ns)
 +{
 +	return pid_nr_ns(task_tgid(tsk), ns);
 +}
 +
 +static inline pid_t task_tgid_vnr(struct task_struct *tsk)
 +{
 +	return pid_vnr(task_tgid(tsk));
 +}
 +
 +
 +static inline pid_t task_pgrp_nr(struct task_struct *tsk)
 +{
 +	return tsk->signal->pgrp;
 +}
 +
 +static inline pid_t task_pgrp_nr_ns(struct task_struct *tsk,
 +		struct pid_namespace *ns)
 +{
 +	return pid_nr_ns(task_pgrp(tsk), ns);
 +}
 +
 +static inline pid_t task_pgrp_vnr(struct task_struct *tsk)
 +{
 +	return pid_vnr(task_pgrp(tsk));
 +}
 +
 +
 +static inline pid_t task_session_nr(struct task_struct *tsk)
 +{
 +	return tsk->signal->__session;
 +}
 +
 +static inline pid_t task_session_nr_ns(struct task_struct *tsk,
 +		struct pid_namespace *ns)
 +{
 +	return pid_nr_ns(task_session(tsk), ns);
 +}
 +
 +static inline pid_t task_session_vnr(struct task_struct *tsk)
 +{
 +	return pid_vnr(task_session(tsk));
 +}
 +
 +
 +static inline pid_t task_ppid_nr_ns(struct task_struct *tsk,
 +		struct pid_namespace *ns)
 +{
 +	return pid_nr_ns(task_pid(rcu_dereference(tsk->real_parent)), ns);
 +}
 +
 /**
 * pid_alive - check that a task structure is not stale
 * @p: Task structure to be checked.
 diff -upr linux-2.6.23-rc1-mm1.orig/kernel/pid.c linux-2.6.23-rc1-mm1-7/kernel/pid.c
 --- linux-2.6.23-rc1-mm1.orig/kernel/pid.c	2007-07-26 16:34:45.000000000 +0400
 +++ linux-2.6.23-rc1-mm1-7/kernel/pid.c	2007-07-26 16:36:37.000000000 +0400
 @@ -352,6 +436,14 @@ struct pid *find_get_pid(pid_t nr)
 return pid;
 }
 
 +pid_t pid_nr_ns(struct pid *pid, struct pid_namespace *ns)
 +{
 +	pid_t nr = 0;
 +	if (pid && ns->level <= pid->level)
 +		nr = pid->numbers[ns->level].nr;
 +	return nr;
 +}
 +
 /*
 * Used by proc to find the first pid that is greater then or equal to nr.
 *
 |  
	|  |  | 
	Goto Forum:
	|  |  | [RFC][PATCH 0/15] Pid namespaces |  
	|  |  | [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() By: dev  on Thu, 26 July 2007 16:59 |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() By: xemul  on Fri, 27 July 2007 06:38 |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | Re: [PATCH 1/15] Move exit_task_namespaces() |  
	|  |  | [PATCH 2/15] Introduce MS_KERNMOUNT flag |  
	|  |  | [PATCH 3/15] kern_siginfo helper |  
	|  |  | Re: [PATCH 3/15] kern_siginfo helper |  
	|  |  | Re: [PATCH 3/15] kern_siginfo helper |  
	|  |  | Re: [PATCH 3/15] kern_siginfo helper |  
	|  |  | [PATCH 4/15] Make proc_flust_task() flush entries from multiple proc trees |  
	|  |  | [PATCH 5/15] Introduce struct upid |  
	|  |  | Re: [PATCH 5/15] Introduce struct upid |  
	|  |  | Re: [PATCH 5/15] Introduce struct upid |  
	|  |  | [PATCH 6/15] Make alloc_pid(), free_pid() and put_pid() work with struct upid |  
	|  |  | Re: [PATCH 6/15] Make alloc_pid(), free_pid() and put_pid() work with struct upid |  
	|  |  | Re: [PATCH 6/15] Make alloc_pid(), free_pid() and put_pid() work with struct upid |  
	|  |  | [PATCH 7/15] Helpers to obtain pid numbers |  
	|  |  | Re: [PATCH 7/15] Helpers to obtain pid numbers |  
	|  |  | Re: [PATCH 7/15] Helpers to obtain pid numbers |  
	|  |  | Re: [PATCH 7/15] Helpers to obtain pid numbers |  
	|  |  | Re: [PATCH 7/15] Helpers to obtain pid numbers |  
	|  |  | [PATCH 8/15] Helpers to find the task by its numerical ids |  
	|  |  | Re: [PATCH 8/15] Helpers to find the task by its numerical ids |  
	|  |  | Re: [PATCH 8/15] Helpers to find the task by its numerical ids |  
	|  |  | Re: [PATCH 8/15] Helpers to find the task by its numerical ids |  
	|  |  | Re: [PATCH 8/15] Helpers to find the task by its numerical ids |  
	|  |  | [PATCH 9/15] Move alloc_pid() after the namespace is cloned |  
	|  |  | Re: [PATCH 9/15] Move alloc_pid() after the namespace is cloned |  
	|  |  | Re: [PATCH 9/15] Move alloc_pid() after the namespace is cloned |  
	|  |  | Re: [PATCH 9/15] Move alloc_pid() after the namespace is cloned |  
	|  |  | Re: [PATCH 9/15] Move alloc_pid() after the namespace is cloned |  
	|  |  | [PATCH 10/15] Make each namespace has its own proc tree |  
	|  |  | Re: [PATCH 10/15] Make each namespace has its own proc tree |  
	|  |  | Re: [PATCH 10/15] Make each namespace has its own proc tree |  
	|  |  | Re: [PATCH 10/15] Make each namespace has its own proc tree |  
	|  |  | Re: [PATCH 10/15] Make each namespace has its own proc tree |  
	|  |  | [PATCH 11/15] Signal semantics |  
	|  |  | Re: [PATCH 11/15] Signal semantics |  
	|  |  | Re: [PATCH 11/15] Signal semantics |  
	|  |  | Re: [PATCH 11/15] Signal semantics By: serue  on Fri, 27 July 2007 19:59 |  
	|  |  | Re: [PATCH 11/15] Signal semantics |  
	|  |  | Re: [PATCH 11/15] Signal semantics |  
	|  |  | Re: [PATCH 11/15] Signal semantics |  
	|  |  | Re: [PATCH 11/15] Signal semantics By: serue  on Wed, 01 August 2007 16:13 |  
	|  |  | Re: [PATCH 11/15] Signal semantics By: dev  on Thu, 02 August 2007 08:35 |  
	|  |  | Re: [PATCH 11/15] Signal semantics By: serue  on Thu, 02 August 2007 20:09 |  
	|  |  | Re: [PATCH 11/15] Signal semantics |  
	|  |  | [PATCH 12/15] Miscelaneous stuff for pid namespaces |  
	|  |  | Re: [PATCH 12/15] Miscelaneous stuff for pid namespaces |  
	|  |  | Re: [PATCH 12/15] Miscelaneous stuff for pid namespaces |  
	|  |  | [PATCH 13/15] Clone the pid namespace |  
	|  |  | [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death By: dev  on Thu, 02 August 2007 08:37 |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death By: serue  on Thu, 02 August 2007 19:13 |  
	|  |  | Re: [PATCH 14/15] Destroy pid namespace on init's death |  
	|  |  | [PATCH 15/15] Hooks over the code to show correct values to user |  
	|  |  | Re: [PATCH 15/15] Hooks over the code to show correct values to user |  
	|  |  | Re: [PATCH 15/15] Hooks over the code to show correct values to user |  
	|  |  | Re: [PATCH 15/15] Hooks over the code to show correct values to user |  
	|  |  | Re: [PATCH 15/15] Hooks over the code to show correct values to user |  
	|  |  | Re: [PATCH 15/15] Hooks over the code to show correct values to user |  
	|  |  | Re: [RFC][PATCH 0/15] Pid namespaces |  
	|  |  | Re: [RFC][PATCH 0/15] Pid namespaces |  
	|  |  | Re: [RFC][PATCH 0/15] Pid namespaces |  
 
 Current Time: Wed Oct 22 07:51:36 GMT 2025 
 Total time taken to generate the page: 0.26262 seconds |