diff options
| author | <jgarzik@pretzel.yyz.us> | 2005-05-26 01:47:10 -0400 |
|---|---|---|
| committer | Jeff Garzik <jgarzik@pobox.com> | 2005-05-26 01:47:10 -0400 |
| commit | 949d33e70f2c3e93bfe5265a50e40175b1ab1ec1 (patch) | |
| tree | ca88fd8f8f81b167dc4685ed34e9636f267db60d /kernel/signal.c | |
| parent | b095518ef51c37658c58367bd19240b8a113f25c (diff) | |
| parent | bef9c558841604116704e10b3d9ff3dbf4939423 (diff) | |
Automatic merge of rsync://rsync.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git branch HEAD
Diffstat (limited to 'kernel/signal.c')
| -rw-r--r-- | kernel/signal.c | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/kernel/signal.c b/kernel/signal.c index 8f3debc77c5b..b3c24c732c5a 100644 --- a/kernel/signal.c +++ b/kernel/signal.c | |||
| @@ -522,7 +522,16 @@ static int __dequeue_signal(struct sigpending *pending, sigset_t *mask, | |||
| 522 | { | 522 | { |
| 523 | int sig = 0; | 523 | int sig = 0; |
| 524 | 524 | ||
| 525 | sig = next_signal(pending, mask); | 525 | /* SIGKILL must have priority, otherwise it is quite easy |
| 526 | * to create an unkillable process, sending sig < SIGKILL | ||
| 527 | * to self */ | ||
| 528 | if (unlikely(sigismember(&pending->signal, SIGKILL))) { | ||
| 529 | if (!sigismember(mask, SIGKILL)) | ||
| 530 | sig = SIGKILL; | ||
| 531 | } | ||
| 532 | |||
| 533 | if (likely(!sig)) | ||
| 534 | sig = next_signal(pending, mask); | ||
| 526 | if (sig) { | 535 | if (sig) { |
| 527 | if (current->notifier) { | 536 | if (current->notifier) { |
| 528 | if (sigismember(current->notifier_mask, sig)) { | 537 | if (sigismember(current->notifier_mask, sig)) { |
