X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=src%2Fsignal%2Fsigprocmask.c;h=67e2b82e2ba8362f0db5272477d6588132e28689;hp=66b17a4228d9c57496dce365cd660ff950426958;hb=fcaec912ed406659832f452e71a6c965308362dd;hpb=aa398f56fa398f2202b04e82c67f822f3233786f diff --git a/src/signal/sigprocmask.c b/src/signal/sigprocmask.c index 66b17a42..67e2b82e 100644 --- a/src/signal/sigprocmask.c +++ b/src/signal/sigprocmask.c @@ -1,29 +1,10 @@ #include #include -#include "syscall.h" -#include "libc.h" -#include "pthread_impl.h" -int __libc_sigprocmask(int how, const sigset_t *set, sigset_t *old) +int sigprocmask(int how, const sigset_t *set, sigset_t *old) { - return syscall(SYS_rt_sigprocmask, how, set, 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; - if (how > 2U) { - errno = EINVAL; - return -1; - } - /* 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);