disable ldb at runtime in sbcl

If sbcl suffers a low-level problem and crashes, it normally enters a low-level debugger called "ldb" and waits for you to start troubleshooting. That's not so nice if you want the application to simply crash and restart automatically and unattended.

You can disable ldb by tweaking *FEATURES* at build time, but that's a little inconvenient. So here's a way to do it at runtime, inspired by a hint from David Lichteblau:

(funcall (sb-alien:define-alien-routine 
          ("disable_lossage_handler" cl-user::disable-sbcl-ldb) 
          sb-alien:void))

Thanks to Stas Boukarev for helping me test it.

update Pierre Mai suggested a better sb-alien technique:

 (sb-alien:alien-funcall
    (sb-alien:extern-alien "disable_lossage_handler" (function sb-alien:void)))

He has more helpful info in his comment. And the original author of ldb in CMUCL also chipped in.

Tags:

Comments

hey that's my code you are disabling! :-)

ldb was a hack that i wrote when wlott and i were bringing up cmucl under the new runtime with python.

it was never intended for anyone but language developers. it is kind of stupid for it to be invoked by default in any normal situation.
Here's the bit from the SBCL customization file:

 ;; Build SBCL with the old CMU CL low level debugger, "ldb". In the
 ;; ideal world you would not need this unless you are messing with
 ;; SBCL at a very low level (e.g., trying to diagnose GC problems, or
 ;; trying to debug assembly code for a port to a new CPU). However,
 ;; experience shows that sooner or later everyone lose()'s, in which
 ;; case SB-LDB can at least provide an informative backtrace.
they got the original reasons for ldb right. (i wrote the gc and helped write a couple of the compiler backends.) i'm pleased to read that it is still of some use. it was half intended to be a throwaway.

but i still maintain that a decent dump that would be useful for debugging bigtime lossage could be produced (perhaps even by ldb) without ever dropping the average luser into the ldb command loop.



SBCL, at least the version shipped with FC9 drops into LDB when . is unavailable (due to, for example, NFS problems). Perhaps I should file a bug report with the Responsible Persons, but running across this entry, I figured someone else might get some amusement out of it.

September 2014

S M T W T F S
 123456
78910111213
14151617181920
21222324252627
282930    
Powered by LiveJournal.com