projects
/
musl
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fix fclose return status logic, again
[musl]
/
src
/
signal
/
sigprocmask.c
diff --git
a/src/signal/sigprocmask.c
b/src/signal/sigprocmask.c
index
e89f876
..
a272c10
100644
(file)
--- a/
src/signal/sigprocmask.c
+++ b/
src/signal/sigprocmask.c
@@
-1,23
+1,30
@@
#include <signal.h>
#include <signal.h>
+#include <errno.h>
#include "syscall.h"
#include "libc.h"
#include "syscall.h"
#include "libc.h"
+#include "pthread_impl.h"
int __libc_sigprocmask(int how, const sigset_t *set, sigset_t *old)
{
int __libc_sigprocmask(int how, const sigset_t *set, sigset_t *old)
{
- return syscall
4(__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;
}
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))) {
+ if (how > 2U) {
+ errno = EINVAL;
+ return -1;
+ }
+ /* Disallow blocking thread control signals */
+ if (set && how != SIG_UNBLOCK) {
tmp = *set;
set = &tmp;
tmp = *set;
set = &tmp;
- tmp.__bits[4/sizeof *set->__bits] &= ~(3UL<<(32&8*sizeof *set->__bits-1));
+ sigdelset(&tmp, SIGCANCEL);
+ sigdelset(&tmp, SIGSYSCALL);
+ sigdelset(&tmp, SIGTIMER);
}
return __libc_sigprocmask(how, set, old);
}
weak_alias(__sigprocmask, sigprocmask);
}
return __libc_sigprocmask(how, set, old);
}
weak_alias(__sigprocmask, sigprocmask);
-weak_alias(__sigprocmask, pthread_sigmask);