aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--kernel/exit.c14
-rw-r--r--kernel/pid_namespace.c20
2 files changed, 33 insertions, 1 deletions
diff --git a/kernel/exit.c b/kernel/exit.c
index c0277d3f1aaa..a85efd2348bd 100644
--- a/kernel/exit.c
+++ b/kernel/exit.c
@@ -64,7 +64,6 @@ static void exit_mm(struct task_struct * tsk);
64static void __unhash_process(struct task_struct *p, bool group_dead) 64static void __unhash_process(struct task_struct *p, bool group_dead)
65{ 65{
66 nr_threads--; 66 nr_threads--;
67 detach_pid(p, PIDTYPE_PID);
68 if (group_dead) { 67 if (group_dead) {
69 detach_pid(p, PIDTYPE_PGID); 68 detach_pid(p, PIDTYPE_PGID);
70 detach_pid(p, PIDTYPE_SID); 69 detach_pid(p, PIDTYPE_SID);
@@ -72,7 +71,20 @@ static void __unhash_process(struct task_struct *p, bool group_dead)
72 list_del_rcu(&p->tasks); 71 list_del_rcu(&p->tasks);
73 list_del_init(&p->sibling); 72 list_del_init(&p->sibling);
74 __this_cpu_dec(process_counts); 73 __this_cpu_dec(process_counts);
74 /*
75 * If we are the last child process in a pid namespace to be
76 * reaped, notify the reaper sleeping zap_pid_ns_processes().
77 */
78 if (IS_ENABLED(CONFIG_PID_NS)) {
79 struct task_struct *parent = p->real_parent;
80
81 if ((task_active_pid_ns(p)->child_reaper == parent) &&
82 list_empty(&parent->children) &&
83 (parent->flags & PF_EXITING))
84 wake_up_process(parent);
85 }
75 } 86 }
87 detach_pid(p, PIDTYPE_PID);
76 list_del_rcu(&p->thread_group); 88 list_del_rcu(&p->thread_group);
77} 89}
78 90
diff --git a/kernel/pid_namespace.c b/kernel/pid_namespace.c
index 16b20e38c4a1..b3c7fd554250 100644
--- a/kernel/pid_namespace.c
+++ b/kernel/pid_namespace.c
@@ -184,11 +184,31 @@ void zap_pid_ns_processes(struct pid_namespace *pid_ns)
184 } 184 }
185 read_unlock(&tasklist_lock); 185 read_unlock(&tasklist_lock);
186 186
187 /* Firstly reap the EXIT_ZOMBIE children we may have. */
187 do { 188 do {
188 clear_thread_flag(TIF_SIGPENDING); 189 clear_thread_flag(TIF_SIGPENDING);
189 rc = sys_wait4(-1, NULL, __WALL, NULL); 190 rc = sys_wait4(-1, NULL, __WALL, NULL);
190 } while (rc != -ECHILD); 191 } while (rc != -ECHILD);
191 192
193 /*
194 * sys_wait4() above can't reap the TASK_DEAD children.
195 * Make sure they all go away, see __unhash_process().
196 */
197 for (;;) {
198 bool need_wait = false;
199
200 read_lock(&tasklist_lock);
201 if (!list_empty(&current->children)) {
202 __set_current_state(TASK_UNINTERRUPTIBLE);
203 need_wait = true;
204 }
205 read_unlock(&tasklist_lock);
206
207 if (!need_wait)
208 break;
209 schedule();
210 }
211
192 if (pid_ns->reboot) 212 if (pid_ns->reboot)
193 current->signal->group_exit_code = pid_ns->reboot; 213 current->signal->group_exit_code = pid_ns->reboot;
194 214