]> git.kernelconcepts.de Git - karo-tx-linux.git/blobdiff - kernel/exit.c
Merge branch 'upstream-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jikos/hid
[karo-tx-linux.git] / kernel / exit.c
index a85efd2348bd67f3d32a79eb540be01e09a40381..2f59cc334516a9b9e831bb54aa0375c999ae69b2 100644 (file)
@@ -64,6 +64,7 @@ static void exit_mm(struct task_struct * tsk);
 static void __unhash_process(struct task_struct *p, bool group_dead)
 {
        nr_threads--;
+       detach_pid(p, PIDTYPE_PID);
        if (group_dead) {
                detach_pid(p, PIDTYPE_PGID);
                detach_pid(p, PIDTYPE_SID);
@@ -78,13 +79,12 @@ static void __unhash_process(struct task_struct *p, bool group_dead)
                if (IS_ENABLED(CONFIG_PID_NS)) {
                        struct task_struct *parent = p->real_parent;
 
-                       if ((task_active_pid_ns(p)->child_reaper == parent) &&
+                       if ((task_active_pid_ns(parent)->child_reaper == parent) &&
                            list_empty(&parent->children) &&
                            (parent->flags & PF_EXITING))
                                wake_up_process(parent);
                }
        }
-       detach_pid(p, PIDTYPE_PID);
        list_del_rcu(&p->thread_group);
 }
 
@@ -732,12 +732,6 @@ static struct task_struct *find_new_reaper(struct task_struct *father)
 
                zap_pid_ns_processes(pid_ns);
                write_lock_irq(&tasklist_lock);
-               /*
-                * We can not clear ->child_reaper or leave it alone.
-                * There may by stealth EXIT_DEAD tasks on ->children,
-                * forget_original_parent() must move them somewhere.
-                */
-               pid_ns->child_reaper = init_pid_ns.child_reaper;
        } else if (father->signal->has_child_subreaper) {
                struct task_struct *reaper;