X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fcompiler%2Fgeneric%2Fearly-vm.lisp;h=670e0adb8e152819408a6666a9f0600133ad5e0c;hb=66cff1e1319861c080d563359afea284614b3a7f;hp=1e7ec1c1d9835f378bc6abb9146da055f3683cf3;hpb=4af254de85367806d14ccafc4dfbe79a235b926d;p=sbcl.git diff --git a/src/compiler/generic/early-vm.lisp b/src/compiler/generic/early-vm.lisp index 1e7ec1c..670e0ad 100644 --- a/src/compiler/generic/early-vm.lisp +++ b/src/compiler/generic/early-vm.lisp @@ -25,13 +25,19 @@ ;;; the bit width of positive fixnums (def!constant n-positive-fixnum-bits (- n-word-bits n-fixnum-tag-bits 1)) +;;; the number of bits to shift between word addresses and byte addresses +(def!constant word-shift (1- (integer-length (/ n-word-bits n-byte-bits)))) + +;;; the number of bytes in a word +(def!constant n-word-bytes (/ n-word-bits n-byte-bits)) + ;;; the number of bits used in the header word of a data block to store ;;; the type (def!constant n-widetag-bits 8) ;;; a mask to extract the type from a data block header word (def!constant widetag-mask (1- (ash 1 n-widetag-bits))) -(def!constant sb!xc:most-positive-fixnum +(def!constant sb!xc:most-positive-fixnum (1- (ash 1 (- n-word-bits n-lowtag-bits))) #!+sb-doc "the fixnum closest in value to positive infinity")