aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/signal.c
diff options
context:
space:
mode:
authorDavid Woodhouse <dwmw2@shinybook.infradead.org>2005-06-02 11:39:11 -0400
committerDavid Woodhouse <dwmw2@shinybook.infradead.org>2005-06-02 11:39:11 -0400
commit1c3f45ab2f7f879ea482501c83899505c31f7539 (patch)
tree672465b3b9b3e2e26a8caf74ed64aa6885c52c13 /kernel/signal.c
parent4bcff1b37e7c3aed914d1ce5b45994adc7dbf455 (diff)
parente0d6d71440a3a35c6fc2dde09f8e8d4d7bd44dda (diff)
Merge with master.kernel.org:/pub/scm/linux/kernel/git/torvalds/linux-2.6.git
Diffstat (limited to 'kernel/signal.c')
-rw-r--r--kernel/signal.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/kernel/signal.c b/kernel/signal.c
index 293e189d8bc3..c89821b69ae3 100644
--- a/kernel/signal.c
+++ b/kernel/signal.c
@@ -523,7 +523,16 @@ static int __dequeue_signal(struct sigpending *pending, sigset_t *mask,
523{ 523{
524 int sig = 0; 524 int sig = 0;
525 525
526 sig = next_signal(pending, mask); 526 /* SIGKILL must have priority, otherwise it is quite easy
527 * to create an unkillable process, sending sig < SIGKILL
528 * to self */
529 if (unlikely(sigismember(&pending->signal, SIGKILL))) {
530 if (!sigismember(mask, SIGKILL))
531 sig = SIGKILL;
532 }
533
534 if (likely(!sig))
535 sig = next_signal(pending, mask);
527 if (sig) { 536 if (sig) {
528 if (current->notifier) { 537 if (current->notifier) {
529 if (sigismember(current->notifier_mask, sig)) { 538 if (sigismember(current->notifier_mask, sig)) {