summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHeiko Carstens2005-11-14 01:07:14 +0100
committerLinus Torvalds2005-11-14 03:14:15 +0100
commitb17b0421d70f5b85a791afe145a16d5ca5f849aa (patch)
tree0aca6753added9c76681d6eb63294a1943597dd9
parent[PATCH] uml: fix daemon transport exit path bug (diff)
downloadkernel-qcow2-linux-b17b0421d70f5b85a791afe145a16d5ca5f849aa.tar.gz
kernel-qcow2-linux-b17b0421d70f5b85a791afe145a16d5ca5f849aa.tar.xz
kernel-qcow2-linux-b17b0421d70f5b85a791afe145a16d5ca5f849aa.zip
[PATCH] signal handling: revert sigkill priority fix
This patch reverts commit c33880aaddbbab1ccf36f4457ed1090621f2e39a since it's not needed anymore. As pointed out by Roland McGrath the real fix is to deliver all signals before returning to user space. See http://www.ussg.iu.edu/hypermail/linux/kernel/0509.2/0683.html A fix for s390 has been merged. Signed-off-by: Heiko Carstens <heiko.carstens@de.ibm.com> Cc: Roland McGrath <roland@redhat.com> Cc: Ingo Molnar <mingo@elte.hu> Cc: Linus Torvalds <torvalds@osdl.org> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
-rw-r--r--kernel/signal.c11
1 files changed, 1 insertions, 10 deletions
diff --git a/kernel/signal.c b/kernel/signal.c
index 80789a59b4db..d7611f189ef7 100644
--- a/kernel/signal.c
+++ b/kernel/signal.c
@@ -513,16 +513,7 @@ static int __dequeue_signal(struct sigpending *pending, sigset_t *mask,
{
int sig = 0;
- /* SIGKILL must have priority, otherwise it is quite easy
- * to create an unkillable process, sending sig < SIGKILL
- * to self */
- if (unlikely(sigismember(&pending->signal, SIGKILL))) {
- if (!sigismember(mask, SIGKILL))
- sig = SIGKILL;
- }
-
- if (likely(!sig))
- sig = next_signal(pending, mask);
+ sig = next_signal(pending, mask);
if (sig) {
if (current->notifier) {
if (sigismember(current->notifier_mask, sig)) {