Loading...
stdlib/FreeBSD/abort.c.patch Libc-498 /dev/null
--- Libc/Libc-498/stdlib/FreeBSD/abort.c.patch
+++ /dev/null
@@ -1,43 +0,0 @@
---- abort.c.orig	2007-04-17 01:31:46.000000000 -0700
-+++ abort.c	2007-04-17 01:36:22.000000000 -0700
-@@ -45,7 +45,10 @@
- #include <pthread.h>
- #include "un-namespace.h"
- 
--void (*__cleanup)();
-+extern void (*__cleanup)();
-+extern void __abort(void) __dead2;
-+
-+#define TIMEOUT	10000	/* 10 milliseconds */
- 
- void
- abort()
-@@ -67,11 +70,20 @@
- 	sigdelset(&act.sa_mask, SIGABRT);
- 	(void)_sigprocmask(SIG_SETMASK, &act.sa_mask, NULL);
- 	(void)raise(SIGABRT);
-+	usleep(TIMEOUT); /* give time for signal to happen */
- 
- 	/*
- 	 * If SIGABRT was ignored, or caught and the handler returns, do
- 	 * it again, only harder.
- 	 */
-+	 __abort();
-+}
-+
-+__private_extern__ void
-+__abort()
-+{
-+	struct sigaction act;
-+
- 	act.sa_handler = SIG_DFL;
- 	act.sa_flags = 0;
- 	sigfillset(&act.sa_mask);
-@@ -79,5 +91,6 @@
- 	sigdelset(&act.sa_mask, SIGABRT);
- 	(void)_sigprocmask(SIG_SETMASK, &act.sa_mask, NULL);
- 	(void)raise(SIGABRT);
--	exit(1);
-+	usleep(TIMEOUT); /* give time for signal to happen */
-+	__builtin_trap(); /* never exit normally */
- }