annotate lib/c-stack.c @ 10470:9867f4fee019

c-stack: work around Irix sigaltstack bug * m4/c-stack.m4 (AC_SYS_XSI_STACK_OVERFLOW_HEURISTIC): Check whether sigaltstack uses wrong end of stack_t (copied in part from libsigsegv). * lib/c-stack.c (c_stack_action) [!HAVE_LIBSIGSEGV]: Work around Irix bug, without requiring an over-allocation. * doc/posix-functions/sigaltstack.texi (sigaltstack): Document the bug. Signed-off-by: Eric Blake <ebb9@byu.net>
author Eric Blake <ebb9@byu.net>
date Tue, 23 Sep 2008 08:47:26 -0600
parents 37fd490ee38d
children d31da80e6c50
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
1 /* Stack overflow handling.
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
2
9613
c4fa39bf5223 Don't redefine __attribute__ without a need.
Bruno Haible <bruno@clisp.org>
parents: 9309
diff changeset
3 Copyright (C) 2002, 2004, 2006, 2008 Free Software Foundation, Inc.
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
4
9309
bbbbbf4cd1c5 Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents: 7302
diff changeset
5 This program is free software: you can redistribute it and/or modify
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
6 it under the terms of the GNU General Public License as published by
9309
bbbbbf4cd1c5 Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents: 7302
diff changeset
7 the Free Software Foundation; either version 3 of the License, or
bbbbbf4cd1c5 Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents: 7302
diff changeset
8 (at your option) any later version.
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
9
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
10 This program is distributed in the hope that it will be useful,
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
13 GNU General Public License for more details.
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
14
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
15 You should have received a copy of the GNU General Public License
9309
bbbbbf4cd1c5 Change copyright notice from GPLv2+ to GPLv3+.
Bruno Haible <bruno@clisp.org>
parents: 7302
diff changeset
16 along with this program. If not, see <http://www.gnu.org/licenses/>. */
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
17
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
18 /* Written by Paul Eggert. */
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
19
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
20 /* NOTES:
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
21
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
22 A program that uses alloca, dynamic arrays, or large local
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
23 variables may extend the stack by more than a page at a time. If
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
24 so, when the stack overflows the operating system may not detect
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
25 the overflow until the program uses the array, and this module may
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
26 incorrectly report a program error instead of a stack overflow.
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
27
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
28 To avoid this problem, allocate only small objects on the stack; a
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
29 program should be OK if it limits single allocations to a page or
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
30 less. Allocate larger arrays in static storage, or on the heap
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
31 (e.g., with malloc). Yes, this is a pain, but we don't know of any
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
32 better solution that is portable.
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
33
4915
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
34 No attempt has been made to deal with multithreaded applications. */
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
35
7302
8a1a9361108c * _fpending.c: Include <config.h> unconditionally, since we no
Paul Eggert <eggert@cs.ucla.edu>
parents: 6689
diff changeset
36 #include <config.h>
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
37
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
38 #ifndef __attribute__
9613
c4fa39bf5223 Don't redefine __attribute__ without a need.
Bruno Haible <bruno@clisp.org>
parents: 9309
diff changeset
39 # if __GNUC__ < 3
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
40 # define __attribute__(x)
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
41 # endif
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
42 #endif
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
43
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
44 #include "gettext.h"
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
45 #define _(msgid) gettext (msgid)
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
46
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
47 #include <errno.h>
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
48 #ifndef ENOTSUP
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
49 # define ENOTSUP EINVAL
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
50 #endif
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
51
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
52 #include <signal.h>
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
53 #if ! HAVE_STACK_T && ! defined stack_t
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
54 typedef struct sigaltstack stack_t;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
55 #endif
10276
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
56 #ifndef SIGSTKSZ
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
57 # define SIGSTKSZ 16384
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
58 #endif
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
59
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
60 #include <stdlib.h>
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
61 #include <string.h>
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
62
10214
6fcac230dda4 Simplify c-stack prerequisites.
Eric Blake <ebb9@byu.net>
parents: 10213
diff changeset
63 /* Posix 2001 declares ucontext_t in <ucontext.h>, Posix 200x in
6fcac230dda4 Simplify c-stack prerequisites.
Eric Blake <ebb9@byu.net>
parents: 10213
diff changeset
64 <signal.h>. */
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
65 #if HAVE_UCONTEXT_H
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
66 # include <ucontext.h>
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
67 #endif
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
68
6689
93d578c7aa44 * lib/c-stack.c: Include unistd.h unconditionally, since we now assume
Paul Eggert <eggert@cs.ucla.edu>
parents: 6259
diff changeset
69 #include <unistd.h>
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
70 #ifndef STDERR_FILENO
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
71 # define STDERR_FILENO 2
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
72 #endif
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
73
10276
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
74 #if HAVE_LIBSIGSEGV
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
75 # include <sigsegv.h>
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
76 #endif
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
77
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
78 #include "c-stack.h"
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
79 #include "exitfail.h"
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
80
10230
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
81 #if defined SA_ONSTACK && defined SA_SIGINFO
4969
0db24850c598 Fix c-stack.c portability bug on IRIX 5.3.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4915
diff changeset
82 # define SIGACTION_WORKS 1
0db24850c598 Fix c-stack.c portability bug on IRIX 5.3.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4915
diff changeset
83 #else
0db24850c598 Fix c-stack.c portability bug on IRIX 5.3.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4915
diff changeset
84 # define SIGACTION_WORKS 0
0db24850c598 Fix c-stack.c portability bug on IRIX 5.3.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4915
diff changeset
85 #endif
0db24850c598 Fix c-stack.c portability bug on IRIX 5.3.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4915
diff changeset
86
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
87 extern char *program_name;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
88
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
89 /* The user-specified action to take when a SEGV-related program error
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
90 or stack overflow occurs. */
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
91 static void (* volatile segv_action) (int);
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
92
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
93 /* Translated messages for program errors and stack overflow. Do not
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
94 translate them in the signal handler, since gettext is not
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
95 async-signal-safe. */
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
96 static char const * volatile program_error_message;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
97 static char const * volatile stack_overflow_message;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
98
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
99 /* Output an error message, then exit with status EXIT_FAILURE if it
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
100 appears to have been a stack overflow, or with a core dump
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
101 otherwise. This function is async-signal-safe. */
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
102
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
103 static void die (int) __attribute__ ((noreturn));
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
104 static void
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
105 die (int signo)
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
106 {
4915
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
107 char const *message;
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
108 segv_action (signo);
4915
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
109 message = signo ? program_error_message : stack_overflow_message;
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
110 write (STDERR_FILENO, program_name, strlen (program_name));
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
111 write (STDERR_FILENO, ": ", 2);
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
112 write (STDERR_FILENO, message, strlen (message));
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
113 write (STDERR_FILENO, "\n", 1);
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
114 if (! signo)
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
115 _exit (exit_failure);
10003
655ec8b9fbde Use 'raise'.
Bruno Haible <bruno@clisp.org>
parents: 9830
diff changeset
116 raise (signo);
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
117 abort ();
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
118 }
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
119
10358
37fd490ee38d c-stack: test that stack overflow can be caught
Eric Blake <ebb9@byu.net>
parents: 10279
diff changeset
120 #if (HAVE_SIGALTSTACK && HAVE_DECL_SIGALTSTACK \
37fd490ee38d c-stack: test that stack overflow can be caught
Eric Blake <ebb9@byu.net>
parents: 10279
diff changeset
121 && HAVE_STACK_OVERFLOW_HANDLING) || HAVE_LIBSIGSEGV
10276
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
122
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
123 /* Storage for the alternate signal stack. */
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
124 static union
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
125 {
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
126 char buffer[SIGSTKSZ];
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
127
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
128 /* These other members are for proper alignment. There's no
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
129 standard way to guarantee stack alignment, but this seems enough
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
130 in practice. */
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
131 long double ld;
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
132 long l;
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
133 void *p;
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
134 } alternate_signal_stack;
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
135
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
136 static void
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
137 null_action (int signo __attribute__ ((unused)))
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
138 {
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
139 }
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
140
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
141 #endif /* SIGALTSTACK || LIBSIGSEGV */
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
142
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
143 /* Only use libsigsegv if we need it; platforms like Solaris can
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
144 detect stack overflow without the overhead of an external
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
145 library. */
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
146 #if HAVE_LIBSIGSEGV && ! HAVE_XSI_STACK_OVERFLOW_HEURISTIC
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
147
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
148 /* Nonzero if general segv handler could not be installed. */
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
149 static volatile int segv_handler_missing;
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
150
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
151 /* Handle a segmentation violation and exit if it cannot be stack
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
152 overflow. This function is async-signal-safe. */
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
153
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
154 static int segv_handler (void *address __attribute__ ((unused)),
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
155 int serious)
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
156 {
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
157 # if DEBUG
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
158 {
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
159 char buf[1024];
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
160 sprintf (buf, "segv_handler serious=%d\n", serious);
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
161 write (STDERR_FILENO, buf, strlen (buf));
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
162 }
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
163 # endif
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
164
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
165 /* If this fault is not serious, return 0 to let the stack overflow
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
166 handler take a shot at it. */
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
167 if (!serious)
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
168 return 0;
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
169 die (SIGSEGV);
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
170 }
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
171
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
172 /* Handle a segmentation violation that is likely to be a stack
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
173 overflow and exit. This function is async-signal-safe. */
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
174
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
175 static void overflow_handler (int, stackoverflow_context_t)
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
176 __attribute__ ((noreturn));
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
177 static void
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
178 overflow_handler (int emergency,
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
179 stackoverflow_context_t context __attribute__ ((unused)))
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
180 {
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
181 # if DEBUG
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
182 {
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
183 char buf[1024];
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
184 sprintf (buf, "overflow_handler emergency=%d segv_handler_missing=%d\n",
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
185 emergency, segv_handler_missing);
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
186 write (STDERR_FILENO, buf, strlen (buf));
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
187 }
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
188 # endif
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
189
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
190 die ((!emergency || segv_handler_missing) ? 0 : SIGSEGV);
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
191 }
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
192
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
193 int
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
194 c_stack_action (void (*action) (int))
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
195 {
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
196 segv_action = action ? action : null_action;
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
197 program_error_message = _("program error");
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
198 stack_overflow_message = _("stack overflow");
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
199
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
200 /* Always install the overflow handler. */
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
201 if (stackoverflow_install_handler (overflow_handler,
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
202 alternate_signal_stack.buffer,
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
203 sizeof alternate_signal_stack.buffer))
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
204 {
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
205 errno = ENOTSUP;
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
206 return -1;
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
207 }
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
208 /* Try installing a general handler; if it fails, then treat all
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
209 segv as stack overflow. */
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
210 segv_handler_missing = sigsegv_install_handler (segv_handler);
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
211 return 0;
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
212 }
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
213
10358
37fd490ee38d c-stack: test that stack overflow can be caught
Eric Blake <ebb9@byu.net>
parents: 10279
diff changeset
214 #elif HAVE_SIGALTSTACK && HAVE_DECL_SIGALTSTACK && HAVE_STACK_OVERFLOW_HANDLING
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
215
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
216 /* Direction of the C runtime stack. This function is
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
217 async-signal-safe. */
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
218
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
219 # if STACK_DIRECTION
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
220 # define find_stack_direction(ptr) STACK_DIRECTION
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
221 # else
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
222 static int
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
223 find_stack_direction (char const *addr)
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
224 {
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
225 char dummy;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
226 return ! addr ? find_stack_direction (&dummy) : addr < &dummy ? 1 : -1;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
227 }
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
228 # endif
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
229
4969
0db24850c598 Fix c-stack.c portability bug on IRIX 5.3.
Paul Eggert <eggert@cs.ucla.edu>
parents: 4915
diff changeset
230 # if SIGACTION_WORKS
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
231
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
232 /* Handle a segmentation violation and exit. This function is
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
233 async-signal-safe. */
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
234
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
235 static void segv_handler (int, siginfo_t *, void *) __attribute__((noreturn));
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
236 static void
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
237 segv_handler (int signo, siginfo_t *info,
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
238 void *context __attribute__ ((unused)))
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
239 {
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
240 /* Clear SIGNO if it seems to have been a stack overflow. */
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
241 if (0 < info->si_code)
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
242 {
4915
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
243 # if ! HAVE_XSI_STACK_OVERFLOW_HEURISTIC
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
244 /* We can't easily determine whether it is a stack overflow; so
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
245 assume that the rest of our program is perfect (!) and that
10276
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
246 this segmentation violation is a stack overflow.
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
247
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
248 Note that although both Linux and Solaris provide
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
249 sigaltstack, SA_ONSTACK, and SA_SIGINFO, currently only
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
250 Solaris satisfies the XSI heueristic. This is because
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
251 Solaris populates uc_stack with the details of the
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
252 interrupted stack, while Linux populates it with the details
adfc5a204195 Make c-stack use libsigsegv, when available.
Eric Blake <ebb9@byu.net>
parents: 10230
diff changeset
253 of the current stack. */
4915
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
254 signo = 0;
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
255 # else
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
256 /* If the faulting address is within the stack, or within one
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
257 page of the stack end, assume that it is a stack
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
258 overflow. */
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
259 ucontext_t const *user_context = context;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
260 char const *stack_base = user_context->uc_stack.ss_sp;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
261 size_t stack_size = user_context->uc_stack.ss_size;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
262 char const *faulting_address = info->si_addr;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
263 size_t s = faulting_address - stack_base;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
264 size_t page_size = sysconf (_SC_PAGESIZE);
10230
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
265 if (find_stack_direction (NULL) < 0)
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
266 s += page_size;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
267 if (s < stack_size + page_size)
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
268 signo = 0;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
269
4915
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
270 # if DEBUG
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
271 {
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
272 char buf[1024];
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
273 sprintf (buf,
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
274 "segv_handler fault=%p base=%p size=%lx page=%lx signo=%d\n",
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
275 faulting_address, stack_base, (unsigned long) stack_size,
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
276 (unsigned long) page_size, signo);
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
277 write (STDERR_FILENO, buf, strlen (buf));
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
278 }
4915
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
279 # endif
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
280 # endif
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
281 }
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
282
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
283 die (signo);
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
284 }
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
285 # endif
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
286
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
287 int
4915
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
288 c_stack_action (void (*action) (int))
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
289 {
4915
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
290 int r;
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
291 stack_t st;
10230
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
292 struct sigaction act;
4915
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
293 st.ss_flags = 0;
10470
9867f4fee019 c-stack: work around Irix sigaltstack bug
Eric Blake <ebb9@byu.net>
parents: 10358
diff changeset
294 # if SIGALTSTACK_SS_REVERSED
9867f4fee019 c-stack: work around Irix sigaltstack bug
Eric Blake <ebb9@byu.net>
parents: 10358
diff changeset
295 /* Irix mistakenly treats ss_sp as the upper bound, rather than
9867f4fee019 c-stack: work around Irix sigaltstack bug
Eric Blake <ebb9@byu.net>
parents: 10358
diff changeset
296 lower bound, of the alternate stack. */
9867f4fee019 c-stack: work around Irix sigaltstack bug
Eric Blake <ebb9@byu.net>
parents: 10358
diff changeset
297 st.ss_sp = alternate_signal_stack.buffer + SIGSTKSZ - sizeof (void *);
9867f4fee019 c-stack: work around Irix sigaltstack bug
Eric Blake <ebb9@byu.net>
parents: 10358
diff changeset
298 st.ss_size = sizeof alternate_signal_stack.buffer - sizeof (void *);
9867f4fee019 c-stack: work around Irix sigaltstack bug
Eric Blake <ebb9@byu.net>
parents: 10358
diff changeset
299 # else
4915
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
300 st.ss_sp = alternate_signal_stack.buffer;
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
301 st.ss_size = sizeof alternate_signal_stack.buffer;
10470
9867f4fee019 c-stack: work around Irix sigaltstack bug
Eric Blake <ebb9@byu.net>
parents: 10358
diff changeset
302 # endif
10230
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
303 r = sigaltstack (&st, NULL);
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
304 if (r != 0)
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
305 return r;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
306
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
307 segv_action = action ? action : null_action;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
308 program_error_message = _("program error");
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
309 stack_overflow_message = _("stack overflow");
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
310
10230
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
311 sigemptyset (&act.sa_mask);
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
312
10230
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
313 # if SIGACTION_WORKS
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
314 /* POSIX 1003.1-2001 says SA_RESETHAND implies SA_NODEFER, but
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
315 this is not true on Solaris 8 at least. It doesn't hurt to use
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
316 SA_NODEFER here, so leave it in. */
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
317 act.sa_flags = SA_NODEFER | SA_ONSTACK | SA_RESETHAND | SA_SIGINFO;
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
318 act.sa_sigaction = segv_handler;
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
319 # else
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
320 act.sa_flags = SA_NODEFER | SA_RESETHAND;
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
321 act.sa_handler = die;
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
322 # endif
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
323
10230
54813304edd2 Use sigaction module rather than signal().
Eric Blake <ebb9@byu.net>
parents: 10214
diff changeset
324 return sigaction (SIGSEGV, &act, NULL);
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
325 }
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
326
10358
37fd490ee38d c-stack: test that stack overflow can be caught
Eric Blake <ebb9@byu.net>
parents: 10279
diff changeset
327 #else /* ! ((HAVE_SIGALTSTACK && HAVE_DECL_SIGALTSTACK
37fd490ee38d c-stack: test that stack overflow can be caught
Eric Blake <ebb9@byu.net>
parents: 10279
diff changeset
328 && HAVE_STACK_OVERFLOW_HANDLING) || HAVE_LIBSIGSEGV) */
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
329
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
330 int
4915
7994c15009db Merge from diffutils.
Paul Eggert <eggert@cs.ucla.edu>
parents: 3921
diff changeset
331 c_stack_action (void (*action) (int) __attribute__ ((unused)))
3902
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
332 {
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
333 errno = ENOTSUP;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
334 return -1;
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
335 }
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
336
f26afed46772 New file, from diffutils-2.8.2.
Jim Meyering <jim@meyering.net>
parents:
diff changeset
337 #endif