aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/signal.c
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2011-05-25 19:53:14 -0400
committerLinus Torvalds <torvalds@linux-foundation.org>2011-05-25 19:53:14 -0400
commit9720d75399fd2655a6b6fb06abcf548150f22362 (patch)
treea9c239d322420ad96afda07294d0c53295adcd3e /kernel/signal.c
parent0c63e38a129e7b1f625c6112439a4efc87b1635c (diff)
parentd92fcf0552a15891b25c343cee340d295e24109c (diff)
Merge branch 'for-2.6.40' of git://git.kernel.org/pub/scm/linux/kernel/git/oleg/misc
* 'for-2.6.40' of git://git.kernel.org/pub/scm/linux/kernel/git/oleg/misc: signal: sys_pause() should check signal_pending() ptrace: ptrace_resume() shouldn't wake up !TASK_TRACED thread
Diffstat (limited to 'kernel/signal.c')
-rw-r--r--kernel/signal.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/kernel/signal.c b/kernel/signal.c
index ad5e818baacc..86c32b884f8e 100644
--- a/kernel/signal.c
+++ b/kernel/signal.c
@@ -3023,8 +3023,10 @@ SYSCALL_DEFINE2(signal, int, sig, __sighandler_t, handler)
3023 3023
3024SYSCALL_DEFINE0(pause) 3024SYSCALL_DEFINE0(pause)
3025{ 3025{
3026 current->state = TASK_INTERRUPTIBLE; 3026 while (!signal_pending(current)) {
3027 schedule(); 3027 current->state = TASK_INTERRUPTIBLE;
3028 schedule();
3029 }
3028 return -ERESTARTNOHAND; 3030 return -ERESTARTNOHAND;
3029} 3031}
3030 3032