aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/exit.c
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/exit.c')
-rw-r--r--kernel/exit.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/kernel/exit.c b/kernel/exit.c
index d49134a7f250..34d135f4fccc 100644
--- a/kernel/exit.c
+++ b/kernel/exit.c
@@ -820,6 +820,7 @@ static void forget_original_parent(struct task_struct *father)
820static void exit_notify(struct task_struct *tsk, int group_dead) 820static void exit_notify(struct task_struct *tsk, int group_dead)
821{ 821{
822 int signal; 822 int signal;
823 bool autoreap;
823 void *cookie; 824 void *cookie;
824 825
825 /* 826 /*
@@ -858,9 +859,11 @@ static void exit_notify(struct task_struct *tsk, int group_dead)
858 859
859 signal = tracehook_notify_death(tsk, &cookie, group_dead); 860 signal = tracehook_notify_death(tsk, &cookie, group_dead);
860 if (signal >= 0) 861 if (signal >= 0)
861 signal = do_notify_parent(tsk, signal); 862 autoreap = do_notify_parent(tsk, signal);
863 else
864 autoreap = (signal == DEATH_REAP);
862 865
863 tsk->exit_state = signal == DEATH_REAP ? EXIT_DEAD : EXIT_ZOMBIE; 866 tsk->exit_state = autoreap ? EXIT_DEAD : EXIT_ZOMBIE;
864 867
865 /* mt-exec, de_thread() is waiting for group leader */ 868 /* mt-exec, de_thread() is waiting for group leader */
866 if (unlikely(tsk->signal->notify_count < 0)) 869 if (unlikely(tsk->signal->notify_count < 0))
@@ -868,7 +871,7 @@ static void exit_notify(struct task_struct *tsk, int group_dead)
868 write_unlock_irq(&tasklist_lock); 871 write_unlock_irq(&tasklist_lock);
869 872
870 /* If the process is dead, release it - nobody will wait for it */ 873 /* If the process is dead, release it - nobody will wait for it */
871 if (signal == DEATH_REAP) 874 if (autoreap)
872 release_task(tsk); 875 release_task(tsk);
873} 876}
874 877