X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=src%2Fsignal%2Fsigprocmask.c;h=66b17a4228d9c57496dce365cd660ff950426958;hp=db27f12a8ff58782c388a5f4528d5e906cfaa2dc;hb=aa398f56fa398f2202b04e82c67f822f3233786f;hpb=a49c119276742d7d212fb88f83a8f559ca549e72 diff --git a/src/signal/sigprocmask.c b/src/signal/sigprocmask.c index db27f12a..66b17a42 100644 --- a/src/signal/sigprocmask.c +++ b/src/signal/sigprocmask.c @@ -1,18 +1,23 @@ #include +#include #include "syscall.h" #include "libc.h" #include "pthread_impl.h" int __libc_sigprocmask(int how, const sigset_t *set, sigset_t *old) { - return syscall4(__NR_rt_sigprocmask, how, (long)set, (long)old, 8); + return syscall(SYS_rt_sigprocmask, how, set, old, 8); } 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 (how != SIG_UNBLOCK) { + if (set && how != SIG_UNBLOCK) { tmp = *set; set = &tmp; sigdelset(&tmp, SIGCANCEL); @@ -22,4 +27,3 @@ int __sigprocmask(int how, const sigset_t *set, sigset_t *old) } weak_alias(__sigprocmask, sigprocmask); -weak_alias(__sigprocmask, pthread_sigmask);