diff options
author | Adhemerval Zanella <adhemerval.zanella@linaro.org> | 2020-03-12 09:50:19 -0300 |
---|---|---|
committer | Adhemerval Zanella <adhemerval.zanella@linaro.org> | 2020-04-21 15:10:10 -0300 |
commit | 566e10aa7292bacd74d229ca6f2cd9e8c8ba8748 (patch) | |
tree | 8418dc7134fe1223d7f74db7d602521a4b5afa11 /signal/sigsetops.c | |
parent | 2f6fa80147f0cf74c0d411a0e07c5655deb436b3 (diff) | |
download | glibc-566e10aa7292bacd74d229ca6f2cd9e8c8ba8748.zip glibc-566e10aa7292bacd74d229ca6f2cd9e8c8ba8748.tar.gz glibc-566e10aa7292bacd74d229ca6f2cd9e8c8ba8748.tar.bz2 |
signal: Only handle on NSIG signals on signal functions (BZ #25657)
The upper bits of the sigset_t s not fully initialized in the signal
mask calls that return information from kernel (sigprocmask,
sigpending, and pthread_sigmask), since the exported sigset_t size
(1024 bits) is larger than Linux support one (64 or 128 bits).
It might make sigisemptyset/sigorset/sigandset fail if the mask
is filled prior the call.
This patch changes the internal signal function to handle up to
supported Linux signal number (_NSIG), the remaining bits are
untouched.
Checked on x86_64-linux-gnu and i686-linux-gnu.
Diffstat (limited to 'signal/sigsetops.c')
-rw-r--r-- | signal/sigsetops.c | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/signal/sigsetops.c b/signal/sigsetops.c index eb89e67..1165377 100644 --- a/signal/sigsetops.c +++ b/signal/sigsetops.c @@ -26,28 +26,28 @@ int attribute_compat_text_section -(__sigismember) (const __sigset_t *set, int sig) +__sigismember_compat (const __sigset_t *set, int sig) { return __sigismember (set, sig); } -compat_symbol (libc, __sigismember, __sigismember, GLIBC_2_0); +compat_symbol (libc, __sigismember_compat, __sigismember, GLIBC_2_0); int attribute_compat_text_section -(__sigaddset) (__sigset_t *set, int sig) +__sigaddset_compat (__sigset_t *set, int sig) { __sigaddset (set, sig); return 0; } -compat_symbol (libc, __sigaddset, __sigaddset, GLIBC_2_0); +compat_symbol (libc, __sigaddset_compat, __sigaddset, GLIBC_2_0); int attribute_compat_text_section -(__sigdelset) (__sigset_t *set, int sig) +__sigdelset_compat (__sigset_t *set, int sig) { __sigdelset (set, sig); return 0; } -compat_symbol (libc, __sigdelset, __sigdelset, GLIBC_2_0); +compat_symbol (libc, __sigdelset_compat, __sigdelset, GLIBC_2_0); #endif |