2011-01-19 Eric Blake <eblake@redhat.com>
+ c-stack: assume stack overflow if SA_SIGINFO unsupported
+ * lib/c-stack.c (SIGACTION_WORKS): Rename...
+ (SIGINFO_WORKS): ...since gnulib module guarantees that (most) of
+ sigaction will work.
+ (die): Assume stack overflow if siginfo doesn't work, to let Haiku
+ behavior match Linux.
+ * tests/test-c-stack.c (main): Prefer NULL for pointers.
+
stdbool-tests: accomodate Haiku
* tests/test-stdbool.c: Haiku's gcc 2.95 lacks native _Bool.
#include "ignore-value.h"
#if defined SA_ONSTACK && defined SA_SIGINFO
-# define SIGACTION_WORKS 1
+# define SIGINFO_WORKS 1
#else
-# define SIGACTION_WORKS 0
+# define SIGINFO_WORKS 0
# ifndef SA_ONSTACK
# define SA_ONSTACK 0
# endif
die (int signo)
{
char const *message;
+#if !SIGINFO_WORKS
+ /* We can't easily determine whether it is a stack overflow; so
+ assume that the rest of our program is perfect (!) and that
+ this segmentation violation is a stack overflow. */
+ signo = 0;
+#endif /* !SIGINFO_WORKS */
segv_action (signo);
message = signo ? program_error_message : stack_overflow_message;
ignore_value (write (STDERR_FILENO, program_name, strlen (program_name)));
# if STACK_DIRECTION
# define find_stack_direction(ptr) STACK_DIRECTION
# else
-# if ! SIGACTION_WORKS || HAVE_XSI_STACK_OVERFLOW_HEURISTIC
+# if ! SIGINFO_WORKS || HAVE_XSI_STACK_OVERFLOW_HEURISTIC
static int
find_stack_direction (char const *addr)
{
# endif
# endif
-# if SIGACTION_WORKS
+# if SIGINFO_WORKS
/* Handle a segmentation violation and exit. This function is
async-signal-safe. */
sigemptyset (&act.sa_mask);
-# if SIGACTION_WORKS
+# if SIGINFO_WORKS
/* POSIX 1003.1-2001 says SA_RESETHAND implies SA_NODEFER, but
this is not true on Solaris 8 at least. It doesn't hurt to use
SA_NODEFER here, so leave it in. */