+ {
+ struct sigaction act;
+
++ if (!__crashreporter_info__)
++ __crashreporter_info__ = "abort() called";
+ /*
+ * POSIX requires we flush stdio buffers on abort.
+ * XXX ISO C requires that abort() be async-signal-safe.
+@@ -67,11 +74,22 @@ abort()
+ 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;
++
++ if (!__crashreporter_info__)
++ __crashreporter_info__ = "__abort() called";
+ act.sa_handler = SIG_DFL;
+ act.sa_flags = 0;
+ sigfillset(&act.sa_mask);
+@@ -79,5 +97,19 @@ abort()
+ 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 */
++}
++
++__private_extern__ void
++abort_report_np(const char *fmt, ...)
++{
++ char *str;
++ va_list ap;
++
++ va_start(ap, fmt);
++ vasprintf(&str, fmt, ap);
++ va_end(ap);
++ __crashreporter_info__ = str ? str : fmt;
++ abort();
+ }