X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fruntime.h;h=de83bc86e124a3b75c63237f944d310d944805c0;hb=6d36f2d6954cb79e3c88fef33fe0c3ad63deaea8;hp=01f40318c4653635bed8ec2bead947e6c74aa5a7;hpb=0d4c7a1323106c6e60511bef929048edcb040205;p=sbcl.git diff --git a/src/runtime/runtime.h b/src/runtime/runtime.h index 01f4031..de83bc8 100644 --- a/src/runtime/runtime.h +++ b/src/runtime/runtime.h @@ -29,12 +29,27 @@ #define thread_mutex_unlock(l) 0 #endif -/* #define QSHOW */ /* Enable low-level debugging output? */ -/* #define QSHOW_SAFE */ /* Enable blocking interrupts for each SHOW. */ +/* Block blockable interrupts for each SHOW, if not 0. */ +#define QSHOW_SIGNAL_SAFE 1 +/* Enable extra-verbose low-level debugging output for signals? (You + * probably don't want this unless you're trying to debug very early + * cold boot on a new machine, or one where you've just messed up + * signal handling.) + * + * Note: It may be that doing this is fundamentally unsound, since it + * causes output from signal handlers, and the i/o libraries aren't + * necessarily reentrant. But it can still be very convenient for + * figuring out what's going on when you have a signal handling + * problem. */ +#define QSHOW_SIGNALS 0 +/* Enable low-level debugging output, if not zero. Defaults to enabled + * if QSHOW_SIGNALS, disabled otherwise. Change it to 1 if you want + * low-level debugging output but not the whole signal mess. */ +#define QSHOW QSHOW_SIGNALS -#ifdef QSHOW +#if QSHOW -#ifdef QSHOW_SAFE +#if QSHOW_SIGNAL_SAFE == 1 && !defined(LISP_FEATURE_WIN32) #include extern sigset_t blockable_sigset; @@ -70,18 +85,6 @@ extern sigset_t blockable_sigset; #endif -/* Enable extra-verbose low-level debugging output for signals? (You - * probably don't want this unless you're trying to debug very early - * cold boot on a new machine, or one where you've just messed up - * signal handling.) - * - * Note: It may be that doing this is fundamentally unsound, since it - * causes output from signal handlers, and the i/o libraries aren't - * necessarily reentrant. But it can still be very convenient for - * figuring out what's going on when you have a signal handling - * problem.. */ -#define QSHOW_SIGNALS 0 - #if QSHOW_SIGNALS #define FSHOW_SIGNAL FSHOW #else @@ -226,6 +229,24 @@ fixnum_value(lispobj n) #endif typedef int boolean; +static inline boolean +other_immediate_lowtag_p(lispobj header) +{ + switch (lowtag_of(header)) { + case OTHER_IMMEDIATE_0_LOWTAG: + case OTHER_IMMEDIATE_1_LOWTAG: +#ifdef OTHER_IMMEDIATE_2_LOWTAG + case OTHER_IMMEDIATE_2_LOWTAG: +#endif +#ifdef OTHER_IMMEDIATE_3_LOWTAG + case OTHER_IMMEDIATE_3_LOWTAG: +#endif + return 1; + default: + return 0; + } +} + /* KLUDGE: As far as I can tell there's no ANSI C way of saying * "this function never returns". This is the way that you do it * in GCC later than version 2.5 or so. */ @@ -251,4 +272,7 @@ struct runtime_options { size_t thread_control_stack_size; }; +/* saved runtime path computed from argv[0] */ +extern char *saved_runtime_path; + #endif /* _SBCL_RUNTIME_H_ */