diff options
Diffstat (limited to 'ipc/util.c')
-rw-r--r-- | ipc/util.c | 53 |
1 files changed, 10 insertions, 43 deletions
diff --git a/ipc/util.c b/ipc/util.c index 0b652387d169..0ad5b1c3ca01 100644 --- a/ipc/util.c +++ b/ipc/util.c | |||
@@ -85,53 +85,20 @@ err_mem: | |||
85 | return ERR_PTR(err); | 85 | return ERR_PTR(err); |
86 | } | 86 | } |
87 | 87 | ||
88 | int unshare_ipcs(unsigned long unshare_flags, struct ipc_namespace **new_ipc) | 88 | struct ipc_namespace *copy_ipcs(unsigned long flags, struct ipc_namespace *ns) |
89 | { | 89 | { |
90 | struct ipc_namespace *new; | ||
91 | |||
92 | if (unshare_flags & CLONE_NEWIPC) { | ||
93 | if (!capable(CAP_SYS_ADMIN)) | ||
94 | return -EPERM; | ||
95 | |||
96 | new = clone_ipc_ns(current->nsproxy->ipc_ns); | ||
97 | if (IS_ERR(new)) | ||
98 | return PTR_ERR(new); | ||
99 | |||
100 | *new_ipc = new; | ||
101 | } | ||
102 | |||
103 | return 0; | ||
104 | } | ||
105 | |||
106 | int copy_ipcs(unsigned long flags, struct task_struct *tsk) | ||
107 | { | ||
108 | struct ipc_namespace *old_ns = tsk->nsproxy->ipc_ns; | ||
109 | struct ipc_namespace *new_ns; | 90 | struct ipc_namespace *new_ns; |
110 | int err = 0; | ||
111 | 91 | ||
112 | if (!old_ns) | 92 | BUG_ON(!ns); |
113 | return 0; | 93 | get_ipc_ns(ns); |
114 | |||
115 | get_ipc_ns(old_ns); | ||
116 | 94 | ||
117 | if (!(flags & CLONE_NEWIPC)) | 95 | if (!(flags & CLONE_NEWIPC)) |
118 | return 0; | 96 | return ns; |
119 | 97 | ||
120 | if (!capable(CAP_SYS_ADMIN)) { | 98 | new_ns = clone_ipc_ns(ns); |
121 | err = -EPERM; | ||
122 | goto out; | ||
123 | } | ||
124 | 99 | ||
125 | new_ns = clone_ipc_ns(old_ns); | 100 | put_ipc_ns(ns); |
126 | if (!new_ns) { | 101 | return new_ns; |
127 | err = -ENOMEM; | ||
128 | goto out; | ||
129 | } | ||
130 | |||
131 | tsk->nsproxy->ipc_ns = new_ns; | ||
132 | out: | ||
133 | put_ipc_ns(old_ns); | ||
134 | return err; | ||
135 | } | 102 | } |
136 | 103 | ||
137 | void free_ipc_ns(struct kref *kref) | 104 | void free_ipc_ns(struct kref *kref) |
@@ -145,11 +112,11 @@ void free_ipc_ns(struct kref *kref) | |||
145 | kfree(ns); | 112 | kfree(ns); |
146 | } | 113 | } |
147 | #else | 114 | #else |
148 | int copy_ipcs(unsigned long flags, struct task_struct *tsk) | 115 | struct ipc_namespace *copy_ipcs(unsigned long flags, struct ipc_namespace *ns) |
149 | { | 116 | { |
150 | if (flags & CLONE_NEWIPC) | 117 | if (flags & CLONE_NEWIPC) |
151 | return -EINVAL; | 118 | return ERR_PTR(-EINVAL); |
152 | return 0; | 119 | return ns; |
153 | } | 120 | } |
154 | #endif | 121 | #endif |
155 | 122 | ||