diff options
Diffstat (limited to 'src/lib/libc/stdlib/abort.c')
-rw-r--r-- | src/lib/libc/stdlib/abort.c | 25 |
1 files changed, 23 insertions, 2 deletions
diff --git a/src/lib/libc/stdlib/abort.c b/src/lib/libc/stdlib/abort.c index c298e016b4..41a9f0f48b 100644 --- a/src/lib/libc/stdlib/abort.c +++ b/src/lib/libc/stdlib/abort.c | |||
@@ -32,26 +32,43 @@ | |||
32 | */ | 32 | */ |
33 | 33 | ||
34 | #if defined(LIBC_SCCS) && !defined(lint) | 34 | #if defined(LIBC_SCCS) && !defined(lint) |
35 | /*static char *sccsid = "from: @(#)abort.c 5.11 (Berkeley) 2/23/91";*/ | 35 | static char *rcsid = "$OpenBSD: abort.c,v 1.7 2001/08/12 12:03:01 heko Exp $"; |
36 | static char *rcsid = "$Id: abort.c,v 1.1.1.1 1995/10/18 08:42:16 deraadt Exp $"; | ||
37 | #endif /* LIBC_SCCS and not lint */ | 36 | #endif /* LIBC_SCCS and not lint */ |
38 | 37 | ||
39 | #include <signal.h> | 38 | #include <signal.h> |
40 | #include <stdlib.h> | 39 | #include <stdlib.h> |
41 | #include <unistd.h> | 40 | #include <unistd.h> |
41 | #include "thread_private.h" | ||
42 | |||
43 | void (*__cleanup)(); | ||
42 | 44 | ||
43 | void | 45 | void |
44 | abort() | 46 | abort() |
45 | { | 47 | { |
48 | static int cleanup_called = 0; | ||
46 | sigset_t mask; | 49 | sigset_t mask; |
47 | 50 | ||
51 | |||
48 | sigfillset(&mask); | 52 | sigfillset(&mask); |
49 | /* | 53 | /* |
50 | * don't block SIGABRT to give any handler a chance; we ignore | 54 | * don't block SIGABRT to give any handler a chance; we ignore |
51 | * any errors -- X311J doesn't allow abort to return anyway. | 55 | * any errors -- X311J doesn't allow abort to return anyway. |
52 | */ | 56 | */ |
53 | sigdelset(&mask, SIGABRT); | 57 | sigdelset(&mask, SIGABRT); |
58 | #ifdef _THREAD_SAFE | ||
59 | (void)_thread_sys_sigprocmask(SIG_SETMASK, &mask, (sigset_t *)NULL); | ||
60 | #else /* _THREAD_SAFE */ | ||
54 | (void)sigprocmask(SIG_SETMASK, &mask, (sigset_t *)NULL); | 61 | (void)sigprocmask(SIG_SETMASK, &mask, (sigset_t *)NULL); |
62 | #endif /* _THREAD_SAFE */ | ||
63 | |||
64 | /* | ||
65 | * POSIX requires we flush stdio buffers on abort | ||
66 | */ | ||
67 | if (cleanup_called == 0 && __cleanup != NULL) { | ||
68 | cleanup_called = 1; | ||
69 | (*__cleanup)(); | ||
70 | } | ||
71 | |||
55 | (void)kill(getpid(), SIGABRT); | 72 | (void)kill(getpid(), SIGABRT); |
56 | 73 | ||
57 | /* | 74 | /* |
@@ -59,7 +76,11 @@ abort() | |||
59 | * it again, only harder. | 76 | * it again, only harder. |
60 | */ | 77 | */ |
61 | (void)signal(SIGABRT, SIG_DFL); | 78 | (void)signal(SIGABRT, SIG_DFL); |
79 | #ifdef _THREAD_SAFE | ||
80 | (void)_thread_sys_sigprocmask(SIG_SETMASK, &mask, (sigset_t *)NULL); | ||
81 | #else /* _THREAD_SAFE */ | ||
62 | (void)sigprocmask(SIG_SETMASK, &mask, (sigset_t *)NULL); | 82 | (void)sigprocmask(SIG_SETMASK, &mask, (sigset_t *)NULL); |
83 | #endif /* _THREAD_SAFE */ | ||
63 | (void)kill(getpid(), SIGABRT); | 84 | (void)kill(getpid(), SIGABRT); |
64 | exit(1); | 85 | exit(1); |
65 | } | 86 | } |