summaryrefslogtreecommitdiffstats
path: root/ipc
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2014-12-10 21:31:59 -0500
committerAl Viro <viro@zeniv.linux.org.uk>2014-12-10 21:31:59 -0500
commit707c5960f102f8cdafb9406047b158abc71b391f (patch)
tree31d195b1c48cefa2d04da7cc801824f87a0a9887 /ipc
parentba00410b8131b23edfb0e09f8b6dd26c8eb621fb (diff)
parent3d3d35b1e94ec918fc0ae670663235bf197d8609 (diff)
Merge branch 'nsfs' into for-next
Diffstat (limited to 'ipc')
-rw-r--r--ipc/msgutil.c5
-rw-r--r--ipc/namespace.c32
2 files changed, 19 insertions, 18 deletions
diff --git a/ipc/msgutil.c b/ipc/msgutil.c
index 7e7095974d54..2b491590ebab 100644
--- a/ipc/msgutil.c
+++ b/ipc/msgutil.c
@@ -31,7 +31,10 @@ DEFINE_SPINLOCK(mq_lock);
31struct ipc_namespace init_ipc_ns = { 31struct ipc_namespace init_ipc_ns = {
32 .count = ATOMIC_INIT(1), 32 .count = ATOMIC_INIT(1),
33 .user_ns = &init_user_ns, 33 .user_ns = &init_user_ns,
34 .proc_inum = PROC_IPC_INIT_INO, 34 .ns.inum = PROC_IPC_INIT_INO,
35#ifdef CONFIG_IPC_NS
36 .ns.ops = &ipcns_operations,
37#endif
35}; 38};
36 39
37atomic_t nr_ipc_ns = ATOMIC_INIT(1); 40atomic_t nr_ipc_ns = ATOMIC_INIT(1);
diff --git a/ipc/namespace.c b/ipc/namespace.c
index b54468e48e32..382e2aa42d8a 100644
--- a/ipc/namespace.c
+++ b/ipc/namespace.c
@@ -26,16 +26,17 @@ static struct ipc_namespace *create_ipc_ns(struct user_namespace *user_ns,
26 if (ns == NULL) 26 if (ns == NULL)
27 return ERR_PTR(-ENOMEM); 27 return ERR_PTR(-ENOMEM);
28 28
29 err = proc_alloc_inum(&ns->proc_inum); 29 err = ns_alloc_inum(&ns->ns);
30 if (err) { 30 if (err) {
31 kfree(ns); 31 kfree(ns);
32 return ERR_PTR(err); 32 return ERR_PTR(err);
33 } 33 }
34 ns->ns.ops = &ipcns_operations;
34 35
35 atomic_set(&ns->count, 1); 36 atomic_set(&ns->count, 1);
36 err = mq_init_ns(ns); 37 err = mq_init_ns(ns);
37 if (err) { 38 if (err) {
38 proc_free_inum(ns->proc_inum); 39 ns_free_inum(&ns->ns);
39 kfree(ns); 40 kfree(ns);
40 return ERR_PTR(err); 41 return ERR_PTR(err);
41 } 42 }
@@ -119,7 +120,7 @@ static void free_ipc_ns(struct ipc_namespace *ns)
119 */ 120 */
120 ipcns_notify(IPCNS_REMOVED); 121 ipcns_notify(IPCNS_REMOVED);
121 put_user_ns(ns->user_ns); 122 put_user_ns(ns->user_ns);
122 proc_free_inum(ns->proc_inum); 123 ns_free_inum(&ns->ns);
123 kfree(ns); 124 kfree(ns);
124} 125}
125 126
@@ -149,7 +150,12 @@ void put_ipc_ns(struct ipc_namespace *ns)
149 } 150 }
150} 151}
151 152
152static void *ipcns_get(struct task_struct *task) 153static inline struct ipc_namespace *to_ipc_ns(struct ns_common *ns)
154{
155 return container_of(ns, struct ipc_namespace, ns);
156}
157
158static struct ns_common *ipcns_get(struct task_struct *task)
153{ 159{
154 struct ipc_namespace *ns = NULL; 160 struct ipc_namespace *ns = NULL;
155 struct nsproxy *nsproxy; 161 struct nsproxy *nsproxy;
@@ -160,17 +166,17 @@ static void *ipcns_get(struct task_struct *task)
160 ns = get_ipc_ns(nsproxy->ipc_ns); 166 ns = get_ipc_ns(nsproxy->ipc_ns);
161 task_unlock(task); 167 task_unlock(task);
162 168
163 return ns; 169 return ns ? &ns->ns : NULL;
164} 170}
165 171
166static void ipcns_put(void *ns) 172static void ipcns_put(struct ns_common *ns)
167{ 173{
168 return put_ipc_ns(ns); 174 return put_ipc_ns(to_ipc_ns(ns));
169} 175}
170 176
171static int ipcns_install(struct nsproxy *nsproxy, void *new) 177static int ipcns_install(struct nsproxy *nsproxy, struct ns_common *new)
172{ 178{
173 struct ipc_namespace *ns = new; 179 struct ipc_namespace *ns = to_ipc_ns(new);
174 if (!ns_capable(ns->user_ns, CAP_SYS_ADMIN) || 180 if (!ns_capable(ns->user_ns, CAP_SYS_ADMIN) ||
175 !ns_capable(current_user_ns(), CAP_SYS_ADMIN)) 181 !ns_capable(current_user_ns(), CAP_SYS_ADMIN))
176 return -EPERM; 182 return -EPERM;
@@ -182,18 +188,10 @@ static int ipcns_install(struct nsproxy *nsproxy, void *new)
182 return 0; 188 return 0;
183} 189}
184 190
185static unsigned int ipcns_inum(void *vp)
186{
187 struct ipc_namespace *ns = vp;
188
189 return ns->proc_inum;
190}
191
192const struct proc_ns_operations ipcns_operations = { 191const struct proc_ns_operations ipcns_operations = {
193 .name = "ipc", 192 .name = "ipc",
194 .type = CLONE_NEWIPC, 193 .type = CLONE_NEWIPC,
195 .get = ipcns_get, 194 .get = ipcns_get,
196 .put = ipcns_put, 195 .put = ipcns_put,
197 .install = ipcns_install, 196 .install = ipcns_install,
198 .inum = ipcns_inum,
199}; 197};