diff options
| author | Lennart Poettering <lennart@poettering.net> | 2016-01-26 22:34:46 +0100 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2016-01-27 02:22:58 +0100 | 
| commit | 0c5eb0562abec6f845f07c30b2ad2515900ec1e5 (patch) | |
| tree | 10a05b9191642ce96812a96ed53031b9338f3528 /src/basic/signal-util.h | |
| parent | fccd4b67b5fd296cb5840d1b8e0ea8455cb6a1ed (diff) | |
nss: block various signals while running NSS lookups
Let's make sure our poll() calls don't get interrupted where they shouldn't (SIGALRM, ...), but allow them to be
interrupted where they should (SIGINT, ...).
Fixes #1965
Diffstat (limited to 'src/basic/signal-util.h')
| -rw-r--r-- | src/basic/signal-util.h | 11 | 
1 files changed, 11 insertions, 0 deletions
| diff --git a/src/basic/signal-util.h b/src/basic/signal-util.h index e7393e2dac..5d94d1c363 100644 --- a/src/basic/signal-util.h +++ b/src/basic/signal-util.h @@ -41,3 +41,14 @@ int signal_from_string(const char *s) _pure_;  int signal_from_string_try_harder(const char *s);  void nop_signal_handler(int sig); + +static inline void block_signals_reset(sigset_t *ss) { +        assert_se(sigprocmask(SIG_SETMASK, ss, NULL) >= 0); +} + +#define BLOCK_SIGNALS(...)                                              \ +        _cleanup_(block_signals_reset) sigset_t _saved_sigset = ({      \ +                sigset_t t;                                             \ +                assert_se(sigprocmask_many(SIG_BLOCK, &t, __VA_ARGS__, -1) >= 0); \ +                t;                                                      \ +        }) | 
