diff options
author | Oleg Nesterov <oleg@tv-sign.ru> | 2008-04-30 03:53:12 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-04-30 11:29:38 -0400 |
commit | 2800d8d19e51414403df8144eaa214bb03400b87 (patch) | |
tree | d5b01302c7109d7ffdc140ce8d6e31cebcdb233a | |
parent | 376e1d2531860358c8a79fecf5f4f42994d03c4d (diff) |
document de_thread() with exit_notify() connection
Add a couple of small comments, it is not easy to see what this code does.
Signed-off-by: Oleg Nesterov <oleg@tv-sign.ru>
Cc: Roland McGrath <roland@redhat.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
-rw-r--r-- | fs/exec.c | 2 | ||||
-rw-r--r-- | kernel/exit.c | 1 |
2 files changed, 2 insertions, 1 deletions
@@ -798,7 +798,7 @@ static int de_thread(struct task_struct *tsk) | |||
798 | if (!thread_group_leader(tsk)) { | 798 | if (!thread_group_leader(tsk)) { |
799 | leader = tsk->group_leader; | 799 | leader = tsk->group_leader; |
800 | 800 | ||
801 | sig->notify_count = -1; | 801 | sig->notify_count = -1; /* for exit_notify() */ |
802 | for (;;) { | 802 | for (;;) { |
803 | write_lock_irq(&tasklist_lock); | 803 | write_lock_irq(&tasklist_lock); |
804 | if (likely(leader->exit_state)) | 804 | if (likely(leader->exit_state)) |
diff --git a/kernel/exit.c b/kernel/exit.c index 413c81ec858e..879ed6e1c883 100644 --- a/kernel/exit.c +++ b/kernel/exit.c | |||
@@ -877,6 +877,7 @@ static void exit_notify(struct task_struct *tsk, int group_dead) | |||
877 | state = EXIT_DEAD; | 877 | state = EXIT_DEAD; |
878 | tsk->exit_state = state; | 878 | tsk->exit_state = state; |
879 | 879 | ||
880 | /* mt-exec, de_thread() is waiting for us */ | ||
880 | if (thread_group_leader(tsk) && | 881 | if (thread_group_leader(tsk) && |
881 | tsk->signal->notify_count < 0 && | 882 | tsk->signal->notify_count < 0 && |
882 | tsk->signal->group_exit_task) | 883 | tsk->signal->group_exit_task) |