|
@@ -50,7 +50,7 @@ static struct ipc_namespace *create_ipc_ns(struct user_namespace *user_ns,
|
|
goto fail_free;
|
|
goto fail_free;
|
|
ns->ns.ops = &ipcns_operations;
|
|
ns->ns.ops = &ipcns_operations;
|
|
|
|
|
|
- atomic_set(&ns->count, 1);
|
|
|
|
|
|
+ refcount_set(&ns->count, 1);
|
|
ns->user_ns = get_user_ns(user_ns);
|
|
ns->user_ns = get_user_ns(user_ns);
|
|
ns->ucounts = ucounts;
|
|
ns->ucounts = ucounts;
|
|
|
|
|
|
@@ -144,7 +144,7 @@ static void free_ipc_ns(struct ipc_namespace *ns)
|
|
*/
|
|
*/
|
|
void put_ipc_ns(struct ipc_namespace *ns)
|
|
void put_ipc_ns(struct ipc_namespace *ns)
|
|
{
|
|
{
|
|
- if (atomic_dec_and_lock(&ns->count, &mq_lock)) {
|
|
|
|
|
|
+ if (refcount_dec_and_lock(&ns->count, &mq_lock)) {
|
|
mq_clear_sbinfo(ns);
|
|
mq_clear_sbinfo(ns);
|
|
spin_unlock(&mq_lock);
|
|
spin_unlock(&mq_lock);
|
|
mq_put_mnt(ns);
|
|
mq_put_mnt(ns);
|