prevent sigprocmask/pthread_sigmask from blocking implementation signals
authorRich Felker <dalias@aerifal.cx>
Sat, 19 Feb 2011 15:51:13 +0000 (10:51 -0500)
committerRich Felker <dalias@aerifal.cx>
Sat, 19 Feb 2011 15:51:13 +0000 (10:51 -0500)
this code was wrongly disabled because the old version was trying to
be too clever and didn't work. replaced it with a simple version for
now.

src/signal/sigprocmask.c

index e89f8765bc93bb3394bb6204b10a6127069234f3..db27f12a8ff58782c388a5f4528d5e906cfaa2dc 100644 (file)
@@ -1,6 +1,7 @@
 #include <signal.h>
 #include "syscall.h"
 #include "libc.h"
+#include "pthread_impl.h"
 
 int __libc_sigprocmask(int how, const sigset_t *set, sigset_t *old)
 {
@@ -10,11 +11,12 @@ int __libc_sigprocmask(int how, const sigset_t *set, sigset_t *old)
 int __sigprocmask(int how, const sigset_t *set, sigset_t *old)
 {
        sigset_t tmp;
-       /* Quickly mask out bits 32 and 33 (thread control signals) */
-       if (0 && how != SIG_UNBLOCK && (set->__bits[4/sizeof *set->__bits] & 3UL<<(32&8*sizeof *set->__bits-1))) {
+       /* Disallow blocking thread control signals */
+       if (how != SIG_UNBLOCK) {
                tmp = *set;
                set = &tmp;
-               tmp.__bits[4/sizeof *set->__bits] &= ~(3UL<<(32&8*sizeof *set->__bits-1));
+               sigdelset(&tmp, SIGCANCEL);
+               sigdelset(&tmp, SIGSYSCALL);
        }
        return __libc_sigprocmask(how, set, old);
 }