X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fruntime%2Fruntime.h;h=abf27dae1695bf9e163e42e915aa644047c15654;hb=ab5427d31da2bd95805cccc8e47b8f43d3dd606d;hp=de83bc86e124a3b75c63237f944d310d944805c0;hpb=3257c25015012253a096c990d5809daee974d057;p=sbcl.git diff --git a/src/runtime/runtime.h b/src/runtime/runtime.h index de83bc8..abf27da 100644 --- a/src/runtime/runtime.h +++ b/src/runtime/runtime.h @@ -168,7 +168,11 @@ FDEFN(lispobj obj) static inline int is_lisp_pointer(lispobj obj) { +#if N_WORD_BITS == 64 + return (obj & 3) == 3; +#else return obj & 1; +#endif } #include "fixnump.h" @@ -232,19 +236,8 @@ 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; - } + /* These lowtags are spaced 4 apart throughout the lowtag space. */ + return (lowtag_of(header) & 3) == OTHER_IMMEDIATE_0_LOWTAG; } /* KLUDGE: As far as I can tell there's no ANSI C way of saying