diff options
| author | Kacper <kacper@mail.openlinux.dev> | 2025-12-07 20:10:31 +0100 |
|---|---|---|
| committer | Kacper <kacper@mail.openlinux.dev> | 2025-12-07 20:10:31 +0100 |
| commit | fc00c656c96528112d05cf0edf8631bd5eaea446 (patch) | |
| tree | a6e0e6c588191a8bd1c64afc3b7a258e3e66c236 /lib/libc/signal/pthread_sigmask.c | |
Add build system scaffolding and libc headers
Diffstat (limited to 'lib/libc/signal/pthread_sigmask.c')
| -rw-r--r-- | lib/libc/signal/pthread_sigmask.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/lib/libc/signal/pthread_sigmask.c b/lib/libc/signal/pthread_sigmask.c new file mode 100644 index 00000000..1b83e1fe --- /dev/null +++ b/lib/libc/signal/pthread_sigmask.c @@ -0,0 +1,23 @@ +#include <errno.h> +#include <asm-generic/signal.h> +#include <libc.h> + +int sigdelset(sigset_t *, int); +int sigismember(const sigset_t *, int); +int sigprocmask(int, const sigset_t *restrict, sigset_t *restrict); + +int pthread_sigmask(int how, const sigset_t *restrict set, + sigset_t *restrict oset) +{ + sigset_t lset; + + if (set != NULL && (unlikely(sigismember(set, SIGRTMIN)) || + unlikely(sigismember(set, SIGRTMIN + 1)))) { + lset = *set; + sigdelset(&lset, SIGRTMIN); + sigdelset(&lset, SIGRTMIN + 1); + set = &lset; + } + + return sigprocmask(how, set, oset) == -1 ? errno : 0; +} |
