diff options
-rw-r--r-- | libc/sysdeps/linux/mips/bits/signum.h | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/libc/sysdeps/linux/mips/bits/signum.h b/libc/sysdeps/linux/mips/bits/signum.h index cf9b834c4..e83250e2d 100644 --- a/libc/sysdeps/linux/mips/bits/signum.h +++ b/libc/sysdeps/linux/mips/bits/signum.h @@ -53,7 +53,20 @@ #define SIGXCPU 30 /* CPU limit exceeded (4.2 BSD). */ #define SIGXFSZ 31 /* File size limit exceeded (4.2 BSD). */ -/* Biggest signal number + 1 (including real-time signals). */ -#define _NSIG 129 +/* MIPS is special by having 128 signals. + * All (?) other architectures have at most 64 signals. + * Having 128 signals is problematic because signal nos are 1-based + * and last signal number is then 128. + * This plays havoc with WIFSIGNALED and WCOREDUMP in waitpid status word, + * when process dies from signal 128. + * Linux kernel 3.9 accepts signal 128, with awful results :/ + * It is being fixed. + * + * glibc (accidentally?) papers over this issue by declaring _NSIG to be 128, + * not 129 (despite claiming that _NSIG is "biggest signal number + 1" + * in the comment above that definition). We follow suit. + * Note that this results in __SIGRTMAX == 127. It is intended. + */ +#define _NSIG 128 #endif /* <signal.h> included. */ |