summaryrefslogtreecommitdiff
path: root/kernel
diff options
context:
space:
mode:
authorRom Lemarchand <romlem@android.com>2014-11-07 12:48:17 -0800
committerMichael Bestas <mkbestas@lineageos.org>2022-04-19 00:51:42 +0300
commit55ab7be4f79903e7448d03ffbd2b6d59daad2ca1 (patch)
treec8ef357bc2a4a8242181951fcb3304826fad2cb6 /kernel
parenta2b6897af5af0c731fe0d4cd3dfb0c4342804b59 (diff)
cgroup: refactor allow_attach function into common code
move cpu_cgroup_allow_attach to a common subsys_cgroup_allow_attach. This allows any process with CAP_SYS_NICE to move tasks across cgroups if they use this function as their allow_attach handler. Bug: 18260435 Change-Id: I6bb4933d07e889d0dc39e33b4e71320c34a2c90f Signed-off-by: Rom Lemarchand <romlem@android.com> Signed-off-by: Chatur27 <jasonbright2709@gmail.com>
Diffstat (limited to 'kernel')
-rw-r--r--kernel/cgroup.c19
1 files changed, 19 insertions, 0 deletions
diff --git a/kernel/cgroup.c b/kernel/cgroup.c
index b3ad18420b42..59324034aefb 100644
--- a/kernel/cgroup.c
+++ b/kernel/cgroup.c
@@ -2825,6 +2825,25 @@ static int cgroup_attach_task(struct cgroup *dst_cgrp,
return ret;
}
+int subsys_cgroup_allow_attach(struct cgroup_subsys_state *css, struct cgroup_taskset *tset)
+{
+ const struct cred *cred = current_cred(), *tcred;
+ struct task_struct *task;
+
+ if (capable(CAP_SYS_NICE))
+ return 0;
+
+ cgroup_taskset_for_each(task, css, tset) {
+ tcred = __task_cred(task);
+
+ if (current != task && !uid_eq(cred->euid, tcred->uid) &&
+ !uid_eq(cred->euid, tcred->suid))
+ return -EACCES;
+ }
+
+ return 0;
+}
+
static int cgroup_procs_write_permission(struct task_struct *task,
struct cgroup *dst_cgrp,
struct kernfs_open_file *of)