diff options
author | Oleg Nesterov <oleg@redhat.com> | 2017-08-21 11:35:02 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2017-08-21 15:47:31 -0400 |
commit | dd1c1f2f2028a7b851f701fc6a8ebe39dcb95e7c (patch) | |
tree | 96b5e5466504cc8c88b0f0435e80f70f0c627c58 /include/linux/pid.h | |
parent | 14ccee78fc82f5512908f4424f541549a5705b89 (diff) |
pids: make task_tgid_nr_ns() safe
This was reported many times, and this was even mentioned in commit
52ee2dfdd4f5 ("pids: refactor vnr/nr_ns helpers to make them safe") but
somehow nobody bothered to fix the obvious problem: task_tgid_nr_ns() is
not safe because task->group_leader points to nowhere after the exiting
task passes exit_notify(), rcu_read_lock() can not help.
We really need to change __unhash_process() to nullify group_leader,
parent, and real_parent, but this needs some cleanups. Until then we
can turn task_tgid_nr_ns() into another user of __task_pid_nr_ns() and
fix the problem.
Reported-by: Troy Kensinger <tkensinger@google.com>
Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'include/linux/pid.h')
-rw-r--r-- | include/linux/pid.h | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/include/linux/pid.h b/include/linux/pid.h index 4d179316e431..719582744a2e 100644 --- a/include/linux/pid.h +++ b/include/linux/pid.h | |||
@@ -8,7 +8,9 @@ enum pid_type | |||
8 | PIDTYPE_PID, | 8 | PIDTYPE_PID, |
9 | PIDTYPE_PGID, | 9 | PIDTYPE_PGID, |
10 | PIDTYPE_SID, | 10 | PIDTYPE_SID, |
11 | PIDTYPE_MAX | 11 | PIDTYPE_MAX, |
12 | /* only valid to __task_pid_nr_ns() */ | ||
13 | __PIDTYPE_TGID | ||
12 | }; | 14 | }; |
13 | 15 | ||
14 | /* | 16 | /* |