summaryrefslogtreecommitdiffstats
path: root/kernel/signal.c
diff options
context:
space:
mode:
authorRoland McGrath <roland@redhat.com>2005-09-29 14:54:42 -0700
committerLinus Torvalds <torvalds@g5.osdl.org>2005-09-29 15:20:47 -0700
commit5acbc5cb507e6c381b70093b1081854708e82b16 (patch)
tree504bf5b1a1079fedd424d130589a336745f803e9 /kernel/signal.c
parent4a8342d233a39ee582e9f7260e12d2f5fd194a05 (diff)
downloadlinux-5acbc5cb507e6c381b70093b1081854708e82b16.tar.gz
linux-5acbc5cb507e6c381b70093b1081854708e82b16.tar.bz2
linux-5acbc5cb507e6c381b70093b1081854708e82b16.zip
[PATCH] Fix task state testing properly in do_signal_stop()
Any tests using < TASK_STOPPED or the like are left over from the time when the TASK_ZOMBIE and TASK_DEAD bits were in the same word, and it served to check for "stopped or dead". I think this one in do_signal_stop is the only such case. It has been buggy ever since exit_state was separated, and isn't testing the exit_state value. Signed-off-by: Roland McGrath <roland@redhat.com> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'kernel/signal.c')
-rw-r--r--kernel/signal.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/kernel/signal.c b/kernel/signal.c
index 5a274705ba19..619b027e92b5 100644
--- a/kernel/signal.c
+++ b/kernel/signal.c
@@ -1763,7 +1763,8 @@ do_signal_stop(int signr)
* stop is always done with the siglock held,
* so this check has no races.
*/
- if (t->state < TASK_STOPPED) {
+ if (!t->exit_state &&
+ !(t->state & (TASK_STOPPED|TASK_TRACED))) {
stop_count++;
signal_wake_up(t, 0);
}