Hello Keno, On 08/03/2018 02:07 AM, Keno Fischer wrote:
The left-most pid namespace in a given procfs' `NStgid` does not change based on the pid namespace of the reading process. Rather, each procfs has an associated outer-most namespace, which gets set when the procfs is mounted: ``` static struct dentry *proc_mount(struct file_system_type *fs_type, int flags, const char *dev_name, void *data) { struct pid_namespace *ns; if (flags & MS_KERNMOUNT) { ns = data; data = NULL; } else { ns = task_active_pid_ns(current); } return mount_ns(fs_type, flags, data, ns, ns->user_ns, proc_fill_super); } ``` i.e. either the root namespace for kernel mounts or the namespace of the mounting process. This ns then gets saved in the fs' super block and is the basis for most operations. It is this ns that the left-most value of `NStgid` is relative to, not the reading process.
Yes, it's obvious as soon as you say it. I was not paying quite enough attention when O originally wrote that text. Patch applied. Thanks, Michael
Reported-by: Robert O'Callahan <robert@xxxxxxxxxxxxx> Signed-off-by: Keno Fischer <keno@xxxxxxxxxxxxxxxxxx> --- man5/proc.5 | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/man5/proc.5 b/man5/proc.5 index c01aed2b1..34cb957dd 100644 --- a/man5/proc.5 +++ b/man5/proc.5 @@ -2356,7 +2356,8 @@ Thread group ID (i.e., PID) in each of the PID namespaces of which .I [pid] is a member. The leftmost entry shows the value with respect to the PID namespace -of the reading process, +of the process that mounted this procfs (or the root namespace +if mounted by the kernel), followed by the value in successively nested inner namespaces. .\" commit e4bc33245124db69b74a6d853ac76c2976f472d5 (Since Linux 4.1.)
-- To unsubscribe from this list: send the line "unsubscribe linux-man" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html