libroot: Fix handling of debugger() call in abort().
The kernel's handling of SIGABRT is just to terminate the application immediately without doing anything else (it only notifies the debugger if there's one installed for this application already.) More serious faults (e.g. SIGSEGV) originate in the kernel and handle this logic before they even invoke the signal handler. So the correct solution is to do the same here in libroot. This incurs a very, very slight performance penalty of the syscall time for sigaction(), though I expect whatever applications are causing SIGABRT to be invoked more than once a second will call raise() directly instead of abort()...
This commit is contained in:
parent
e54f86aa6a
commit
0df493a13a
@ -288,8 +288,14 @@ abort()
|
|||||||
{
|
{
|
||||||
fprintf(stderr, "Abort\n");
|
fprintf(stderr, "Abort\n");
|
||||||
|
|
||||||
raise(SIGABRT);
|
// If there's no handler installed for SIGABRT, call debugger().
|
||||||
|
struct sigaction signalAction;
|
||||||
|
if (sigaction(SIGABRT, NULL, &signalAction) == 0
|
||||||
|
&& signalAction.sa_handler == SIG_DFL) {
|
||||||
debugger("abort() called");
|
debugger("abort() called");
|
||||||
|
}
|
||||||
|
|
||||||
|
raise(SIGABRT);
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user