time64_t                shm_atim;
        time64_t                shm_dtim;
        time64_t                shm_ctim;
-       pid_t                   shm_cprid;
-       pid_t                   shm_lprid;
+       struct pid              *shm_cprid;
+       struct pid              *shm_lprid;
        struct user_struct      *mlock_user;
 
        /* The task created the shm object.  NULL if the task is dead. */
                return PTR_ERR(shp);
 
        shp->shm_atim = ktime_get_real_seconds();
-       shp->shm_lprid = task_tgid_vnr(current);
+       ipc_update_pid(&shp->shm_lprid, task_tgid(current));
        shp->shm_nattch++;
        shm_unlock(shp);
        return 0;
                user_shm_unlock(i_size_read(file_inode(shm_file)),
                                shp->mlock_user);
        fput(shm_file);
+       ipc_update_pid(&shp->shm_cprid, NULL);
+       ipc_update_pid(&shp->shm_lprid, NULL);
        ipc_rcu_putref(&shp->shm_perm, shm_rcu_free);
 }
 
        if (WARN_ON_ONCE(IS_ERR(shp)))
                goto done; /* no-op */
 
-       shp->shm_lprid = task_tgid_vnr(current);
+       ipc_update_pid(&shp->shm_lprid, task_tgid(current));
        shp->shm_dtim = ktime_get_real_seconds();
        shp->shm_nattch--;
        if (shm_may_destroy(ns, shp))
        if (IS_ERR(file))
                goto no_file;
 
-       shp->shm_cprid = task_tgid_vnr(current);
-       shp->shm_lprid = 0;
+       shp->shm_cprid = get_pid(task_tgid(current));
+       shp->shm_lprid = NULL;
        shp->shm_atim = shp->shm_dtim = 0;
        shp->shm_ctim = ktime_get_real_seconds();
        shp->shm_segsz = size;
                user_shm_unlock(size, shp->mlock_user);
        fput(file);
 no_file:
+       ipc_update_pid(&shp->shm_cprid, NULL);
+       ipc_update_pid(&shp->shm_lprid, NULL);
        call_rcu(&shp->shm_perm.rcu, shm_rcu_free);
        return error;
 }
        tbuf->shm_atime = shp->shm_atim;
        tbuf->shm_dtime = shp->shm_dtim;
        tbuf->shm_ctime = shp->shm_ctim;
-       tbuf->shm_cpid  = shp->shm_cprid;
-       tbuf->shm_lpid  = shp->shm_lprid;
+       tbuf->shm_cpid  = pid_vnr(shp->shm_cprid);
+       tbuf->shm_lpid  = pid_vnr(shp->shm_lprid);
        tbuf->shm_nattch = shp->shm_nattch;
 
        ipc_unlock_object(&shp->shm_perm);
 #ifdef CONFIG_PROC_FS
 static int sysvipc_shm_proc_show(struct seq_file *s, void *it)
 {
+       struct pid_namespace *pid_ns = ipc_seq_pid_ns(s);
        struct user_namespace *user_ns = seq_user_ns(s);
        struct kern_ipc_perm *ipcp = it;
        struct shmid_kernel *shp;
                   shp->shm_perm.id,
                   shp->shm_perm.mode,
                   shp->shm_segsz,
-                  shp->shm_cprid,
-                  shp->shm_lprid,
+                  pid_nr_ns(shp->shm_cprid, pid_ns),
+                  pid_nr_ns(shp->shm_lprid, pid_ns),
                   shp->shm_nattch,
                   from_kuid_munged(user_ns, shp->shm_perm.uid),
                   from_kgid_munged(user_ns, shp->shm_perm.gid),