X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fruntime.h;h=e99d86b22ee5cb5cc90d1f913bb36f828e80362e;hb=0285aa5ff8416027932daa001b84429be2ca559b;hp=b143eda5317cea2101fd7b53a39d7d1f1b87342f;hpb=973114b3cc157ea00cc9a9352aba0c888172eb7a;p=sbcl.git diff --git a/src/runtime/runtime.h b/src/runtime/runtime.h index b143eda..e99d86b 100644 --- a/src/runtime/runtime.h +++ b/src/runtime/runtime.h @@ -29,6 +29,12 @@ #define thread_mutex_unlock(l) 0 #endif +#if defined(LISP_FEATURE_SB_SAFEPOINT) +void map_gc_page(); +void unmap_gc_page(); +int check_pending_interrupts(); +#endif + /* Block blockable interrupts for each SHOW, if not 0. */ #define QSHOW_SIGNAL_SAFE 1 /* Enable extra-verbose low-level debugging output for signals? (You @@ -64,7 +70,7 @@ extern sigset_t blockable_sigset; #endif #ifdef LISP_FEATURE_SB_THREAD -#define QSHOW_PREFIX fprintf(stderr, "%lu ", pthread_self()); +#define QSHOW_PREFIX fprintf(stderr, "%p ", pthread_self()); #else #define QSHOW_PREFIX #endif @@ -120,8 +126,10 @@ typedef pid_t os_thread_t; alpha64 has arrived, all this nastiness can go away */ #if 64 == N_WORD_BITS #define LOW_WORD(c) ((pointer_sized_uint_t)c) +#define OBJ_FMTX "lx" typedef unsigned long lispobj; #else +#define OBJ_FMTX "x" #define LOW_WORD(c) ((long)(c) & 0xFFFFFFFFL) /* fake it on alpha32 */ typedef unsigned int lispobj; @@ -206,10 +214,11 @@ make_lispobj(void *o, int low_tag) return LOW_WORD(o) | low_tag; } +#define MAKE_FIXNUM(n) (n << N_FIXNUM_TAG_BITS) static inline lispobj make_fixnum(long n) { - return n << N_FIXNUM_TAG_BITS; + return MAKE_FIXNUM(n); } static inline long @@ -256,4 +265,8 @@ other_immediate_lowtag_p(lispobj header) extern void *successful_malloc (size_t size); extern char *copied_string (char *string); +#if defined(LISP_FEATURE_SB_THREAD) && !defined(LISP_FEATURE_SB_SAFEPOINT) +# define THREADS_USING_GCSIGNAL 1 +#endif + #endif /* _SBCL_RUNTIME_H_ */