Lines Matching full:ns

22 static struct ucounts *inc_ipc_namespaces(struct user_namespace *ns)  in inc_ipc_namespaces()  argument
24 return inc_ucount(ns, current_euid(), UCOUNT_IPC_NAMESPACES); in inc_ipc_namespaces()
35 struct ipc_namespace *ns; in create_ipc_ns() local
45 ns = kzalloc(sizeof(struct ipc_namespace), GFP_KERNEL_ACCOUNT); in create_ipc_ns()
46 if (ns == NULL) in create_ipc_ns()
49 err = ns_alloc_inum(&ns->ns); in create_ipc_ns()
52 ns->ns.ops = &ipcns_operations; in create_ipc_ns()
54 refcount_set(&ns->ns.count, 1); in create_ipc_ns()
55 ns->user_ns = get_user_ns(user_ns); in create_ipc_ns()
56 ns->ucounts = ucounts; in create_ipc_ns()
58 err = mq_init_ns(ns); in create_ipc_ns()
63 if (!setup_mq_sysctls(ns)) in create_ipc_ns()
66 if (!setup_ipc_sysctls(ns)) in create_ipc_ns()
69 err = msg_init_ns(ns); in create_ipc_ns()
73 sem_init_ns(ns); in create_ipc_ns()
74 shm_init_ns(ns); in create_ipc_ns()
76 return ns; in create_ipc_ns()
79 retire_mq_sysctls(ns); in create_ipc_ns()
82 put_user_ns(ns->user_ns); in create_ipc_ns()
83 ns_free_inum(&ns->ns); in create_ipc_ns()
85 kfree(ns); in create_ipc_ns()
93 struct user_namespace *user_ns, struct ipc_namespace *ns) in copy_ipcs() argument
96 return get_ipc_ns(ns); in copy_ipcs()
97 return create_ipc_ns(user_ns, ns); in copy_ipcs()
102 * @ns: the namespace to remove the ipcs from
108 void free_ipcs(struct ipc_namespace *ns, struct ipc_ids *ids, in free_ipcs() argument
125 free(ns, perm); in free_ipcs()
131 static void free_ipc_ns(struct ipc_namespace *ns) in free_ipc_ns() argument
136 mq_put_mnt(ns); in free_ipc_ns()
137 sem_exit_ns(ns); in free_ipc_ns()
138 msg_exit_ns(ns); in free_ipc_ns()
139 shm_exit_ns(ns); in free_ipc_ns()
141 retire_mq_sysctls(ns); in free_ipc_ns()
142 retire_ipc_sysctls(ns); in free_ipc_ns()
144 dec_ipc_namespaces(ns->ucounts); in free_ipc_ns()
145 put_user_ns(ns->user_ns); in free_ipc_ns()
146 ns_free_inum(&ns->ns); in free_ipc_ns()
147 kfree(ns); in free_ipc_ns()
167 * @ns: the namespace to put
181 void put_ipc_ns(struct ipc_namespace *ns) in put_ipc_ns() argument
183 if (refcount_dec_and_lock(&ns->ns.count, &mq_lock)) { in put_ipc_ns()
184 mq_clear_sbinfo(ns); in put_ipc_ns()
187 if (llist_add(&ns->mnt_llist, &free_ipc_list)) in put_ipc_ns()
192 static inline struct ipc_namespace *to_ipc_ns(struct ns_common *ns) in to_ipc_ns() argument
194 return container_of(ns, struct ipc_namespace, ns); in to_ipc_ns()
199 struct ipc_namespace *ns = NULL; in ipcns_get() local
205 ns = get_ipc_ns(nsproxy->ipc_ns); in ipcns_get()
208 return ns ? &ns->ns : NULL; in ipcns_get()
211 static void ipcns_put(struct ns_common *ns) in ipcns_put() argument
213 return put_ipc_ns(to_ipc_ns(ns)); in ipcns_put()
219 struct ipc_namespace *ns = to_ipc_ns(new); in ipcns_install() local
220 if (!ns_capable(ns->user_ns, CAP_SYS_ADMIN) || in ipcns_install()
225 nsproxy->ipc_ns = get_ipc_ns(ns); in ipcns_install()
229 static struct user_namespace *ipcns_owner(struct ns_common *ns) in ipcns_owner() argument
231 return to_ipc_ns(ns)->user_ns; in ipcns_owner()