diff options
Diffstat (limited to 'fs/open.c')
-rw-r--r-- | fs/open.c | 3 |
1 files changed, 2 insertions, 1 deletions
@@ -316,7 +316,8 @@ SYSCALL_DEFINE3(faccessat, int, dfd, const char __user *, filename, int, mode) | |||
316 | 316 | ||
317 | if (!issecure(SECURE_NO_SETUID_FIXUP)) { | 317 | if (!issecure(SECURE_NO_SETUID_FIXUP)) { |
318 | /* Clear the capabilities if we switch to a non-root user */ | 318 | /* Clear the capabilities if we switch to a non-root user */ |
319 | if (override_cred->uid) | 319 | kuid_t root_uid = make_kuid(override_cred->user_ns, 0); |
320 | if (!uid_eq(override_cred->uid, root_uid)) | ||
320 | cap_clear(override_cred->cap_effective); | 321 | cap_clear(override_cred->cap_effective); |
321 | else | 322 | else |
322 | override_cred->cap_effective = | 323 | override_cred->cap_effective = |