X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Finterr.c;h=889d64466d7e5227da777ebe8046d6cc7ec98481;hb=7f1e94ae961a198e00daf281eb1dc858e5b2dcc7;hp=2187fd838ea477e503756b962572fa668102f30d;hpb=9e5604a23d758b7b2d08ed457d737c69b7aea2a5;p=sbcl.git diff --git a/src/runtime/interr.c b/src/runtime/interr.c index 2187fd8..889d644 100644 --- a/src/runtime/interr.c +++ b/src/runtime/interr.c @@ -39,9 +39,44 @@ default_lossage_handler(void) } static void (*lossage_handler)(void) = default_lossage_handler; +#if QSHOW +static void +configurable_lossage_handler() +{ + void lisp_backtrace(int frames); + + if (dyndebug_config.dyndebug_backtrace_when_lost) { + fprintf(stderr, "lose: backtrace follows as requested\n"); + lisp_backtrace(100); + } + + if (dyndebug_config.dyndebug_sleep_when_lost) { + fprintf(stderr, +"The system is too badly corrupted or confused to continue at the Lisp.\n" +"level. The monitor was enabled, but you requested `sleep_when_lost'\n" +"behaviour though dyndebug. To help with your debugging effort, this\n" +"thread will not enter the monitor, and instead proceed immediately to an\n" +"infinite sleep call, maximizing your chances that the thread's current\n" +"state can be preserved until you attach an external debugger. Good luck!\n"); + for (;;) +# ifdef LISP_FEATURE_WIN32 + Sleep(10000); +# else + sleep(10); +# endif + } + + monitor_or_something(); +} +#endif + void enable_lossage_handler(void) { +#if QSHOW + lossage_handler = configurable_lossage_handler; +#else lossage_handler = monitor_or_something; +#endif } void disable_lossage_handler(void) { @@ -53,7 +88,7 @@ void print_message(char *fmt, va_list ap) { fprintf(stderr, " in SBCL pid %d",getpid()); #if defined(LISP_FEATURE_SB_THREAD) - fprintf(stderr, "(tid %lu)", (unsigned long) thread_self()); + fprintf(stderr, "(tid %lu)", (uword_t) thread_self()); #endif if (fmt) { fprintf(stderr, ":\n");