[Devel] [PATCH RHEL7 COMMIT] ms/ns: allow ns_entries to have custom symlink content
Konstantin Khorenko
khorenko at virtuozzo.com
Fri May 12 04:46:37 PDT 2017
The commit is pushed to "branch-rh7-3.10.0-514.16.1.vz7.32.x-ovz" and will appear at https://src.openvz.org/scm/ovz/vzkernel.git
after rh7-3.10.0-514.16.1.vz7.32.1
------>
commit df355b3fc60fd97487e7d77f5f92b5617c2c95a6
Author: Kirill Tkhai <ktkhai at virtuozzo.com>
Date: Fri May 12 15:46:33 2017 +0400
ms/ns: allow ns_entries to have custom symlink content
ms commit: 25b14e92af1a563c7331466ca59188f88050bbf0
Patch series "Expose task pid_ns_for_children to userspace".
pid_ns_for_children set by a task is known only to the task itself, and
it's impossible to identify it from outside.
It's a big problem for checkpoint/restore software like CRIU, because it
can't correctly handle tasks, that do setns(CLONE_NEWPID) in proccess of
their work. If they have a custom pid_ns_for_children before dump, they
must have the same ns after restore. Otherwise, restored task bumped
into enviroment it does not expect.
This patchset solves the problem. It exposes pid_ns_for_children to ns
directory in standard way with the name "pid_for_children":
~# ls /proc/5531/ns -l | grep pid
lrwxrwxrwx 1 root root 0 Jan 14 16:38 pid -> pid:[4026531836]
lrwxrwxrwx 1 root root 0 Jan 14 16:38 pid_for_children -> pid:[4026532286]
This patch (of 2):
Make possible to have link content prefix yyy different from the link
name xxx:
$ readlink /proc/[pid]/ns/xxx
yyy:[4026531838]
This will be used in next patch.
Link: http://lkml.kernel.org/r/149201120318.6007.7362655181033883000.stgit@localhost.localdomain
Signed-off-by: Kirill Tkhai <ktkhai at virtuozzo.com>
Reviewed-by: Cyrill Gorcunov <gorcunov at openvz.org>
Acked-by: Andrei Vagin <avagin at virtuozzo.com>
Cc: Andreas Gruenbacher <agruenba at redhat.com>
Cc: Kees Cook <keescook at chromium.org>
Cc: Michael Kerrisk <mtk.manpages at googlemail.com>
Cc: Al Viro <viro at zeniv.linux.org.uk>
Cc: Oleg Nesterov <oleg at redhat.com>
Cc: Paul Moore <paul at paul-moore.com>
Cc: Eric Biederman <ebiederm at xmission.com>
Cc: Andy Lutomirski <luto at amacapital.net>
Cc: Ingo Molnar <mingo at kernel.org>
Cc: Serge Hallyn <serge at hallyn.com>
Signed-off-by: Andrew Morton <akpm at linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds at linux-foundation.org>
https://jira.sw.ru/browse/PSBM-58669
Signed-off-by: Kirill Tkhai <ktkhai at virtuozzo.com>
---
fs/proc/namespaces.c | 4 +++-
include/linux/proc_ns.h | 1 +
2 files changed, 4 insertions(+), 1 deletion(-)
diff --git a/fs/proc/namespaces.c b/fs/proc/namespaces.c
index 54bdc67..e70c2d3 100644
--- a/fs/proc/namespaces.c
+++ b/fs/proc/namespaces.c
@@ -150,6 +150,7 @@ static int proc_ns_readlink(struct dentry *dentry, char __user *buffer, int bufl
struct proc_inode *ei = PROC_I(inode);
const struct proc_ns_operations *ns_ops = ei->ns.ns_ops;
struct task_struct *task;
+ const char *link_name;
void *ns;
char name[50];
int len = -EACCES;
@@ -166,7 +167,8 @@ static int proc_ns_readlink(struct dentry *dentry, char __user *buffer, int bufl
if (!ns)
goto out_put_task;
- snprintf(name, sizeof(name), "%s:[%u]", ns_ops->name, ns_ops->inum(ns));
+ link_name = ns_ops->real_ns_name ? : ns_ops->name;
+ snprintf(name, sizeof(name), "%s:[%u]", link_name, ns_ops->inum(ns));
len = strlen(name);
if (len > buflen)
diff --git a/include/linux/proc_ns.h b/include/linux/proc_ns.h
index 5478e14..b8dc2bc 100644
--- a/include/linux/proc_ns.h
+++ b/include/linux/proc_ns.h
@@ -10,6 +10,7 @@ struct nsproxy;
struct proc_ns_operations {
const char *name;
+ const char *real_ns_name;
int type;
void *(*get)(struct task_struct *task);
void (*put)(void *ns);
More information about the Devel
mailing list