X-Git-Url: http://nsz.repo.hu/git/?p=musl;a=blobdiff_plain;f=include%2Fsignal.h;h=1b5890897803958c6f6cc6b8daa224c0c0e0a691;hp=f5e87c783c059c32d9538ee5ea348bbdfe87dd86;hb=202911435b56fe007ca62fc6e573fa3ea238d337;hpb=855df698c49610696c562979790381414243c63c diff --git a/include/signal.h b/include/signal.h index f5e87c78..1b589089 100644 --- a/include/signal.h +++ b/include/signal.h @@ -17,6 +17,7 @@ extern "C" { #define __NEED_uid_t #define __NEED_struct_timespec #define __NEED_pthread_t +#define __NEED_pthread_attr_t #define __NEED_time_t #define __NEED_clock_t #define __NEED_sigset_t @@ -24,8 +25,7 @@ extern "C" { #include -struct sigaction -{ +struct sigaction { union { void (*sa_handler)(int); void (*sa_sigaction)(int, siginfo_t *, void *); @@ -37,19 +37,29 @@ struct sigaction #define sa_handler __sa_handler.sa_handler #define sa_sigaction __sa_handler.sa_sigaction -typedef struct -{ +typedef struct { void *ss_sp; int ss_flags; size_t ss_size; } stack_t; -union sigval -{ +union sigval { int sival_int; void *sival_ptr; }; +struct sigevent { + union sigval sigev_value; + int sigev_signo; + int sigev_notify; + void (*sigev_notify_function)(union sigval); + pthread_attr_t *sigev_notify_attributes; +}; + +#define SIGEV_SIGNAL 0 +#define SIGEV_NONE 1 +#define SIGEV_THREAD 2 + int __libc_current_sigrtmin(void); int __libc_current_sigrtmax(void); @@ -90,8 +100,9 @@ void (*sigset(int, void (*)(int)))(int); #endif #ifdef _GNU_SOURCE -typedef int (*sighandler_t)(int); +typedef void (*sighandler_t)(int); void (*bsd_signal(int, void (*)(int)))(int); +#define SA_NOMASK SA_NODEFER #endif #include