diff options
Diffstat (limited to 'kernel/user_namespace.c')
| -rw-r--r-- | kernel/user_namespace.c | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/kernel/user_namespace.c b/kernel/user_namespace.c index d8c30db06c5b..6e50a44610ee 100644 --- a/kernel/user_namespace.c +++ b/kernel/user_namespace.c | |||
| @@ -105,16 +105,21 @@ int create_user_ns(struct cred *new) | |||
| 105 | int unshare_userns(unsigned long unshare_flags, struct cred **new_cred) | 105 | int unshare_userns(unsigned long unshare_flags, struct cred **new_cred) |
| 106 | { | 106 | { |
| 107 | struct cred *cred; | 107 | struct cred *cred; |
| 108 | int err = -ENOMEM; | ||
| 108 | 109 | ||
| 109 | if (!(unshare_flags & CLONE_NEWUSER)) | 110 | if (!(unshare_flags & CLONE_NEWUSER)) |
| 110 | return 0; | 111 | return 0; |
| 111 | 112 | ||
| 112 | cred = prepare_creds(); | 113 | cred = prepare_creds(); |
| 113 | if (!cred) | 114 | if (cred) { |
| 114 | return -ENOMEM; | 115 | err = create_user_ns(cred); |
| 116 | if (err) | ||
| 117 | put_cred(cred); | ||
| 118 | else | ||
| 119 | *new_cred = cred; | ||
| 120 | } | ||
| 115 | 121 | ||
| 116 | *new_cred = cred; | 122 | return err; |
| 117 | return create_user_ns(cred); | ||
| 118 | } | 123 | } |
| 119 | 124 | ||
| 120 | void free_user_ns(struct user_namespace *ns) | 125 | void free_user_ns(struct user_namespace *ns) |
