From: Alexey Dobriyan Similar to get_task_mm(): get a reference to task's mnt namespace if any. Suggested by Pavel Emelianov. Signed-off-by: Alexey Dobriyan Acked-by: Serge Hallyn Cc: Herbert Poetzl Cc: "Eric W. Biederman" Signed-off-by: Andrew Morton --- fs/proc/base.c | 15 ++------------- include/linux/nsproxy.h | 1 + kernel/nsproxy.c | 14 ++++++++++++++ 3 files changed, 17 insertions(+), 13 deletions(-) diff -puN fs/proc/base.c~introduce-and-use-get_task_mnt_ns fs/proc/base.c --- a/fs/proc/base.c~introduce-and-use-get_task_mnt_ns +++ a/fs/proc/base.c @@ -370,13 +370,7 @@ static int mounts_open(struct inode *ino int ret = -EINVAL; if (task) { - task_lock(task); - if (task->nsproxy) { - ns = task->nsproxy->mnt_ns; - if (ns) - get_mnt_ns(ns); - } - task_unlock(task); + ns = get_task_mnt_ns(task); put_task_struct(task); } @@ -443,12 +437,7 @@ static int mountstats_open(struct inode struct task_struct *task = get_proc_task(inode); if (task) { - task_lock(task); - if (task->nsproxy) - mnt_ns = task->nsproxy->mnt_ns; - if (mnt_ns) - get_mnt_ns(mnt_ns); - task_unlock(task); + mnt_ns = get_task_mnt_ns(task); put_task_struct(task); } diff -puN include/linux/nsproxy.h~introduce-and-use-get_task_mnt_ns include/linux/nsproxy.h --- a/include/linux/nsproxy.h~introduce-and-use-get_task_mnt_ns +++ a/include/linux/nsproxy.h @@ -36,6 +36,7 @@ int copy_namespaces(int flags, struct ta void get_task_namespaces(struct task_struct *tsk); void free_nsproxy(struct nsproxy *ns); struct nsproxy *put_nsproxy(struct nsproxy *ns); +struct mnt_namespace *get_task_mnt_ns(struct task_struct *tsk); static inline void finalize_put_nsproxy(struct nsproxy *ns) { diff -puN kernel/nsproxy.c~introduce-and-use-get_task_mnt_ns kernel/nsproxy.c --- a/kernel/nsproxy.c~introduce-and-use-get_task_mnt_ns +++ a/kernel/nsproxy.c @@ -161,3 +161,17 @@ void free_nsproxy(struct nsproxy *ns) put_pid_ns(ns->pid_ns); kfree(ns); } + +struct mnt_namespace * get_task_mnt_ns(struct task_struct *tsk) +{ + struct mnt_namespace *mnt_ns = NULL; + + task_lock(tsk); + if (tsk->nsproxy) + mnt_ns = tsk->nsproxy->mnt_ns; + if (mnt_ns) + get_mnt_ns(mnt_ns); + task_unlock(tsk); + + return mnt_ns; +} _