diff options
author | San Mehat <san@google.com> | 2009-05-21 14:10:06 -0700 |
---|---|---|
committer | Colin Cross <ccross@android.com> | 2011-06-14 09:09:13 -0700 |
commit | 1d38bc7d0523af2233b4280e2aeab34c6a076665 (patch) | |
tree | 16c8c61cd13cc2e0d4fd879cc0cd87c893e867d6 /kernel/sched.c | |
parent | 22e9cd9dc9b51f5ad96588ecbfde5f3221e0e6dd (diff) | |
download | kernel_samsung_crespo-1d38bc7d0523af2233b4280e2aeab34c6a076665.zip kernel_samsung_crespo-1d38bc7d0523af2233b4280e2aeab34c6a076665.tar.gz kernel_samsung_crespo-1d38bc7d0523af2233b4280e2aeab34c6a076665.tar.bz2 |
cgroup: Add generic cgroup subsystem permission checks.
Rather than using explicit euid == 0 checks when trying to move
tasks into a cgroup via CFS, move permission checks into each
specific cgroup subsystem. If a subsystem does not specify a
'can_attach' handler, then we fall back to doing our checks the old way.
This way non-root processes can add arbitrary processes to
a cgroup if all the registered subsystems on that cgroup agree.
Also change explicit euid == 0 check to CAP_SYS_ADMIN
Signed-off-by: San Mehat <san@google.com>
Diffstat (limited to 'kernel/sched.c')
-rw-r--r-- | kernel/sched.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/kernel/sched.c b/kernel/sched.c index ea7a385..13f13af 100644 --- a/kernel/sched.c +++ b/kernel/sched.c @@ -8803,6 +8803,15 @@ cpu_cgroup_destroy(struct cgroup_subsys *ss, struct cgroup *cgrp) static int cpu_cgroup_can_attach_task(struct cgroup *cgrp, struct task_struct *tsk) { + if ((current != tsk) && (!capable(CAP_SYS_NICE))) { + const struct cred *cred = current_cred(), *tcred; + + tcred = __task_cred(tsk); + + if (cred->euid != tcred->uid && cred->euid != tcred->suid) + return -EPERM; + } + #ifdef CONFIG_RT_GROUP_SCHED if (!sched_rt_can_attach(cgroup_tg(cgrp), tsk)) return -EINVAL; |