diff options
author | Eric W. Biederman <ebiederm@xmission.com> | 2014-12-05 18:19:27 -0500 |
---|---|---|
committer | Eric W. Biederman <ebiederm@xmission.com> | 2014-12-05 18:19:27 -0500 |
commit | 7ff4d90b4c24a03666f296c3d4878cd39001e81e (patch) | |
tree | 757293c98c93eec1c5b7caae149c34e49bb824c5 /arch | |
parent | 4fed655c410cc56add64c7b1f7c85c7c56066ac2 (diff) |
groups: Consolidate the setgroups permission checks
Today there are 3 instances of setgroups and due to an oversight their
permission checking has diverged. Add a common function so that
they may all share the same permission checking code.
This corrects the current oversight in the current permission checks
and adds a helper to avoid this in the future.
A user namespace security fix will update this new helper, shortly.
Cc: stable@vger.kernel.org
Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/s390/kernel/compat_linux.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/s390/kernel/compat_linux.c b/arch/s390/kernel/compat_linux.c index ca38139423ae..437e61159279 100644 --- a/arch/s390/kernel/compat_linux.c +++ b/arch/s390/kernel/compat_linux.c | |||
@@ -249,7 +249,7 @@ COMPAT_SYSCALL_DEFINE2(s390_setgroups16, int, gidsetsize, u16 __user *, grouplis | |||
249 | struct group_info *group_info; | 249 | struct group_info *group_info; |
250 | int retval; | 250 | int retval; |
251 | 251 | ||
252 | if (!capable(CAP_SETGID)) | 252 | if (!may_setgroups()) |
253 | return -EPERM; | 253 | return -EPERM; |
254 | if ((unsigned)gidsetsize > NGROUPS_MAX) | 254 | if ((unsigned)gidsetsize > NGROUPS_MAX) |
255 | return -EINVAL; | 255 | return -EINVAL; |