diff options
author | Matt Fleming <matt.fleming@intel.com> | 2012-01-10 18:11:17 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-01-10 19:30:54 -0500 |
commit | 5e6292c0f28f03dfdb8ea3d685f0b838a23bfba4 (patch) | |
tree | 8684833680054ab48f9da2bbc36c93e3d00a3391 /kernel/signal.c | |
parent | f350b1778f1b7713ef54fbc7e079e09e2fe098b9 (diff) |
signal: add block_sigmask() for adding sigmask to current->blocked
Abstract the code sequence for adding a signal handler's sa_mask to
current->blocked because the sequence is identical for all architectures.
Furthermore, in the past some architectures actually got this code wrong,
so introduce a wrapper that all architectures can use.
Signed-off-by: Matt Fleming <matt.fleming@intel.com>
Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: H. Peter Anvin <hpa@zytor.com>
Cc: Tejun Heo <tj@kernel.org>
Cc: "David S. Miller" <davem@davemloft.net>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'kernel/signal.c')
-rw-r--r-- | kernel/signal.c | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/kernel/signal.c b/kernel/signal.c index bb0efa5705ed..d532f1709fbf 100644 --- a/kernel/signal.c +++ b/kernel/signal.c | |||
@@ -2318,6 +2318,27 @@ relock: | |||
2318 | return signr; | 2318 | return signr; |
2319 | } | 2319 | } |
2320 | 2320 | ||
2321 | /** | ||
2322 | * block_sigmask - add @ka's signal mask to current->blocked | ||
2323 | * @ka: action for @signr | ||
2324 | * @signr: signal that has been successfully delivered | ||
2325 | * | ||
2326 | * This function should be called when a signal has succesfully been | ||
2327 | * delivered. It adds the mask of signals for @ka to current->blocked | ||
2328 | * so that they are blocked during the execution of the signal | ||
2329 | * handler. In addition, @signr will be blocked unless %SA_NODEFER is | ||
2330 | * set in @ka->sa.sa_flags. | ||
2331 | */ | ||
2332 | void block_sigmask(struct k_sigaction *ka, int signr) | ||
2333 | { | ||
2334 | sigset_t blocked; | ||
2335 | |||
2336 | sigorsets(&blocked, ¤t->blocked, &ka->sa.sa_mask); | ||
2337 | if (!(ka->sa.sa_flags & SA_NODEFER)) | ||
2338 | sigaddset(&blocked, signr); | ||
2339 | set_current_blocked(&blocked); | ||
2340 | } | ||
2341 | |||
2321 | /* | 2342 | /* |
2322 | * It could be that complete_signal() picked us to notify about the | 2343 | * It could be that complete_signal() picked us to notify about the |
2323 | * group-wide signal. Other threads should be notified now to take | 2344 | * group-wide signal. Other threads should be notified now to take |