X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=include%2Fsignal.h;h=d4856a890c6b38617045642cb7853626f3720e9f;hp=cbbb42a74fa10877c0060255dc99a957eb7edd4f;hb=fcfba99503746e44585d7e318562dd425e8ff390;hpb=8c07f6eac843c2acb217083d48c4cef95f2b891c diff --git a/include/signal.h b/include/signal.h index cbbb42a7..d4856a89 100644 --- a/include/signal.h +++ b/include/signal.h @@ -6,7 +6,12 @@ extern "C" { #endif #if defined(_POSIX_SOURCE) || defined(_POSIX_C_SOURCE) \ - || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) + || defined(_XOPEN_SOURCE) || defined(_GNU_SOURCE) \ + || defined(_BSD_SOURCE) + +#ifdef _GNU_SOURCE +#define __siginfo siginfo +#endif #define __NEED_size_t #define __NEED_pid_t @@ -21,15 +26,12 @@ extern "C" { #include +#define SIG_HOLD ((void (*)(int)) 2) + #define SIG_BLOCK 0 #define SIG_UNBLOCK 1 #define SIG_SETMASK 2 -#define SIG_ERR ((void (*)(int))-1) -#define SIG_DFL ((void (*)(int)) 0) -#define SIG_IGN ((void (*)(int)) 1) -#define SIG_HOLD ((void (*)(int)) 2) - #define SI_ASYNCNL (-60) #define SI_TKILL (-6) #define SI_SIGIO (-5) @@ -44,7 +46,7 @@ extern "C" { #define FPE_INTOVF 2 #define FPE_FLTDIV 3 #define FPE_FLTOVF 4 -#define FPE_FLTUNT 5 +#define FPE_FLTUND 5 #define FPE_FLTRES 6 #define FPE_FLTINV 7 #define FPE_FLTSUB 8 @@ -79,7 +81,7 @@ struct sigaction { } __sa_handler; sigset_t sa_mask; int sa_flags; - void (*__sa_restorer)(void); + void (*sa_restorer)(void); }; #define sa_handler __sa_handler.sa_handler #define sa_sigaction __sa_handler.sa_sigaction @@ -95,12 +97,7 @@ union sigval { void *sival_ptr; }; -#ifdef _GNU_SOURCE -struct siginfo -#else -struct __siginfo -#endif -{ +struct __siginfo { int si_signo, si_errno, si_code; union { char __pad[128 - 3*sizeof(int)]; @@ -208,6 +205,10 @@ void (*sigset(int, void (*)(int)))(int); #define SIGSTKSZ 8192 #endif +#ifdef _BSD_SOURCE +typedef void (*sig_t)(int); +#endif + #ifdef _GNU_SOURCE typedef void (*sighandler_t)(int); void (*bsd_signal(int, void (*)(int)))(int); @@ -218,6 +219,10 @@ int sigisemptyset(const sigset_t *); #include +#define SIG_ERR ((void (*)(int))-1) +#define SIG_DFL ((void (*)(int)) 0) +#define SIG_IGN ((void (*)(int)) 1) + typedef int sig_atomic_t; void (*signal(int, void (*)(int)))(int);