X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=src%2Fsignal%2Fsigprocmask.c;h=297e20c65f825c64d0b63bf4500595aa126e3642;hp=1bc5baa6c88809d49b7bf861c2b611ef4a370e1e;hb=6d861ac87491a207e4599c44b61d142f0a601c2d;hpb=96f2197494791f5884c01b5caa908074cc7e90a6 diff --git a/src/signal/sigprocmask.c b/src/signal/sigprocmask.c index 1bc5baa6..297e20c6 100644 --- a/src/signal/sigprocmask.c +++ b/src/signal/sigprocmask.c @@ -1,25 +1,10 @@ #include -#include "syscall.h" -#include "libc.h" -#include "pthread_impl.h" +#include -int __libc_sigprocmask(int how, const sigset_t *set, sigset_t *old) +int sigprocmask(int how, const sigset_t *restrict set, sigset_t *restrict old) { - return syscall4(__NR_rt_sigprocmask, how, (long)set, (long)old, 8); + int r = pthread_sigmask(how, set, old); + if (!r) return r; + errno = r; + return -1; } - -int __sigprocmask(int how, const sigset_t *set, sigset_t *old) -{ - sigset_t tmp; - /* Disallow blocking thread control signals */ - if (set && how != SIG_UNBLOCK) { - tmp = *set; - set = &tmp; - sigdelset(&tmp, SIGCANCEL); - sigdelset(&tmp, SIGSYSCALL); - } - return __libc_sigprocmask(how, set, old); -} - -weak_alias(__sigprocmask, sigprocmask); -weak_alias(__sigprocmask, pthread_sigmask);