2011-02-12 00:22:29 -05:00
|
|
|
#include <signal.h>
|
2011-03-09 19:42:06 -05:00
|
|
|
#include <errno.h>
|
overhaul implementation-internal signal protections
the new approach relies on the fact that the only ways to create
sigset_t objects without invoking UB are to use the sig*set()
functions, or from the masks returned by sigprocmask, sigaction, etc.
or in the ucontext_t argument to a signal handler. thus, as long as
sigfillset and sigaddset avoid adding the "protected" signals, there
is no way the application will ever obtain a sigset_t including these
bits, and thus no need to add the overhead of checking/clearing them
when sigprocmask or sigaction is called.
note that the old code actually *failed* to remove the bits from
sa_mask when sigaction was called.
the new implementations are also significantly smaller, simpler, and
faster due to ignoring the useless "GNU HURD signals" 65-1024, which
are not used and, if there's any sanity in the world, never will be
used.
2011-05-07 23:23:58 -04:00
|
|
|
#include <stdint.h>
|
2011-02-12 00:22:29 -05:00
|
|
|
#include "syscall.h"
|
2012-08-09 22:52:13 -04:00
|
|
|
#include "pthread_impl.h"
|
2011-02-12 00:22:29 -05:00
|
|
|
|
|
|
|
int raise(int sig)
|
|
|
|
{
|
2011-03-09 19:42:06 -05:00
|
|
|
int pid, tid, ret;
|
2011-03-09 20:07:24 -05:00
|
|
|
sigset_t set;
|
2013-03-26 23:07:31 -04:00
|
|
|
__syscall(SYS_rt_sigprocmask, SIG_BLOCK, SIGALL_SET, &set, _NSIG/8);
|
2011-03-20 00:16:43 -04:00
|
|
|
tid = syscall(SYS_gettid);
|
|
|
|
pid = syscall(SYS_getpid);
|
|
|
|
ret = syscall(SYS_tgkill, pid, tid, sig);
|
2013-03-26 23:07:31 -04:00
|
|
|
__syscall(SYS_rt_sigprocmask, SIG_SETMASK, &set, 0, _NSIG/8);
|
2011-03-09 19:42:06 -05:00
|
|
|
return ret;
|
2011-02-12 00:22:29 -05:00
|
|
|
}
|