diff options
| author | Chen Hanxiao <[email protected]> | 2015-04-15 16:16:30 -0700 | 
|---|---|---|
| committer | Linus Torvalds <[email protected]> | 2015-04-15 16:35:22 -0700 | 
| commit | e4bc33245124db69b74a6d853ac76c2976f472d5 (patch) | |
| tree | 152f9f9d1219e7fabffe9c26f29195e0cc0930af /fs/proc/array.c | |
| parent | 201c7b72f0bf38d7f31fd229a01de035d0f10cd1 (diff) | |
/proc/PID/status: show all sets of pid according to ns
If some issues occurred inside a container guest, host user could not know
which process is in trouble just by guest pid: the users of container
guest only knew the pid inside containers.  This will bring obstacle for
trouble shooting.
This patch adds four fields: NStgid, NSpid, NSpgid and NSsid:
a) In init_pid_ns, nothing changed;
b) In one pidns, will tell the pid inside containers:
  NStgid: 21776   5       1
  NSpid:  21776   5       1
  NSpgid: 21776   5       1
  NSsid:  21729   1       0
  ** Process id is 21776 in level 0, 5 in level 1, 1 in level 2.
c) If pidns is nested, it depends on which pidns are you in.
  NStgid: 5       1
  NSpid:  5       1
  NSpgid: 5       1
  NSsid:  1       0
  ** Views from level 1
[[email protected]: add CONFIG_PID_NS ifdef]
Signed-off-by: Chen Hanxiao <[email protected]>
Acked-by: Serge Hallyn <[email protected]>
Acked-by: "Eric W. Biederman" <[email protected]>
Tested-by: Serge Hallyn <[email protected]>
Tested-by: Nathan Scott <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
Diffstat (limited to 'fs/proc/array.c')
| -rw-r--r-- | fs/proc/array.c | 18 | 
1 files changed, 18 insertions, 0 deletions
| diff --git a/fs/proc/array.c b/fs/proc/array.c index 1295a00ca316..a4490c0a4644 100644 --- a/fs/proc/array.c +++ b/fs/proc/array.c @@ -188,6 +188,24 @@ static inline void task_state(struct seq_file *m, struct pid_namespace *ns,  			   from_kgid_munged(user_ns, GROUP_AT(group_info, g)));  	put_cred(cred); +#ifdef CONFIG_PID_NS +	seq_puts(m, "\nNStgid:"); +	for (g = ns->level; g <= pid->level; g++) +		seq_printf(m, "\t%d", +			task_tgid_nr_ns(p, pid->numbers[g].ns)); +	seq_puts(m, "\nNSpid:"); +	for (g = ns->level; g <= pid->level; g++) +		seq_printf(m, "\t%d", +			task_pid_nr_ns(p, pid->numbers[g].ns)); +	seq_puts(m, "\nNSpgid:"); +	for (g = ns->level; g <= pid->level; g++) +		seq_printf(m, "\t%d", +			task_pgrp_nr_ns(p, pid->numbers[g].ns)); +	seq_puts(m, "\nNSsid:"); +	for (g = ns->level; g <= pid->level; g++) +		seq_printf(m, "\t%d", +			task_session_nr_ns(p, pid->numbers[g].ns)); +#endif  	seq_putc(m, '\n');  } |