123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114 |
- #include <errno.h>
- #include <signal.h>
- #include <string.h>
- #include <sys/syscall.h>
- #include <bits/kernel_sigaction.h>
- int __libc_sigaction (int sig, const struct sigaction *act, struct sigaction *oact);
- #if defined __NR_rt_sigaction
- int
- __libc_sigaction (sig, act, oact)
- int sig;
- const struct sigaction *act;
- struct sigaction *oact;
- {
- int result;
- struct kernel_sigaction kact, koact;
- if (act) {
- kact.k_sa_handler = act->sa_handler;
- __memcpy (&kact.sa_mask, &act->sa_mask, sizeof (kact.sa_mask));
- kact.sa_flags = act->sa_flags;
- # ifdef HAVE_SA_RESTORER
- kact.sa_restorer = act->sa_restorer;
- # endif
- }
-
-
- result = __syscall_rt_sigaction(sig,
- act ? __ptrvalue (&kact) : NULL,
- oact ? __ptrvalue (&koact) : NULL, _NSIG / 8);
- if (oact && result >= 0) {
- oact->sa_handler = koact.k_sa_handler;
- __memcpy (&oact->sa_mask, &koact.sa_mask, sizeof (oact->sa_mask));
- oact->sa_flags = koact.sa_flags;
- # ifdef HAVE_SA_RESTORER
- oact->sa_restorer = koact.sa_restorer;
- # endif
- }
- return result;
- }
- #else
- int
- __libc_sigaction (sig, act, oact)
- int sig;
- const struct sigaction *act;
- struct sigaction *oact;
- {
- int result;
- struct old_kernel_sigaction kact, koact;
- if (act) {
- kact.k_sa_handler = act->sa_handler;
- kact.sa_mask = act->sa_mask.__val[0];
- kact.sa_flags = act->sa_flags;
- # ifdef HAVE_SA_RESTORER
- kact.sa_restorer = act->sa_restorer;
- # endif
- }
- result = __syscall_sigaction(sig,
- act ? __ptrvalue (&kact) : NULL,
- oact ? __ptrvalue (&koact) : NULL);
- if (oact && result >= 0) {
- oact->sa_handler = koact.k_sa_handler;
- oact->sa_mask.__val[0] = koact.sa_mask;
- oact->sa_flags = koact.sa_flags;
- # ifdef HAVE_SA_RESTORER
- oact->sa_restorer = koact.sa_restorer;
- # endif
- }
- return result;
- }
- #endif
- weak_alias (__libc_sigaction, __sigaction)
- weak_alias (__libc_sigaction, sigaction)
|