diff options
author | Oleg Nesterov <oleg@redhat.com> | 2019-10-09 11:02:30 -0400 |
---|---|---|
committer | Tejun Heo <tj@kernel.org> | 2019-10-11 11:39:57 -0400 |
commit | 937c6b27c73e02cd4114f95f5c37ba2c29fadba1 (patch) | |
tree | e88382aa1b7c257d8c57c43f46a9298e83d0bcdd | |
parent | 9e208aa06c2109b45eec6be049a8e47034748c20 (diff) |
cgroup: freezer: call cgroup_enter_frozen() with preemption disabled in ptrace_stop()
ptrace_stop() does preempt_enable_no_resched() to avoid the preemption,
but after that cgroup_enter_frozen() does spin_lock/unlock and this adds
another preemption point.
Reported-and-tested-by: Bruce Ashfield <bruce.ashfield@gmail.com>
Fixes: 76f969e8948d ("cgroup: cgroup v2 freezer")
Cc: stable@vger.kernel.org # v5.2+
Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Acked-by: Roman Gushchin <guro@fb.com>
Signed-off-by: Tejun Heo <tj@kernel.org>
-rw-r--r-- | kernel/signal.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/kernel/signal.c b/kernel/signal.c index c4da1ef56fdf..bcd46f547db3 100644 --- a/kernel/signal.c +++ b/kernel/signal.c | |||
@@ -2205,8 +2205,8 @@ static void ptrace_stop(int exit_code, int why, int clear_code, kernel_siginfo_t | |||
2205 | */ | 2205 | */ |
2206 | preempt_disable(); | 2206 | preempt_disable(); |
2207 | read_unlock(&tasklist_lock); | 2207 | read_unlock(&tasklist_lock); |
2208 | preempt_enable_no_resched(); | ||
2209 | cgroup_enter_frozen(); | 2208 | cgroup_enter_frozen(); |
2209 | preempt_enable_no_resched(); | ||
2210 | freezable_schedule(); | 2210 | freezable_schedule(); |
2211 | cgroup_leave_frozen(true); | 2211 | cgroup_leave_frozen(true); |
2212 | } else { | 2212 | } else { |