X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fcompiler%2Fgeneric%2Fobjdef.lisp;h=5228849ca98d2f16176094642dcb1cf5606d8d60;hb=df679ed627975948b1cee190f4d79c397588c43e;hp=85a0b4be93e09e66e533dca5c040f160ab58fcd5;hpb=1419c1d2d50f039be46a8667351b7738ac4965e4;p=sbcl.git diff --git a/src/compiler/generic/objdef.lisp b/src/compiler/generic/objdef.lisp index 85a0b4b..5228849 100644 --- a/src/compiler/generic/objdef.lisp +++ b/src/compiler/generic/objdef.lisp @@ -326,8 +326,7 @@ ;; subtract 3 from (sb-kernel:get-lisp-obj-address 'NIL) you get the ;; first data slot, and if you subtract 7 you get a symbol header. - (value #!-sb-thread :set-trans #!-sb-thread %set-symbol-value - :init :unbound) ;also the CAR of NIL-as-end-of-list + (value :init :unbound) ;also the CAR of NIL-as-end-of-list (hash) ;the CDR of NIL-as-end-of-list (plist :ref-trans symbol-plist @@ -370,19 +369,19 @@ ;; unbound_marker is borrowed very briefly at thread startup to ;; pass the address of initial-function into new_thread_trampoline (unbound-marker :init :unbound) ; tls[0] = UNBOUND_MARKER_WIDETAG - (binding-stack-start :c-type "lispobj *") - (binding-stack-pointer :c-type "lispobj *") - (control-stack-start :c-type "lispobj *") - (control-stack-end :c-type "lispobj *") - (alien-stack-start :c-type "lispobj *") - (alien-stack-pointer :c-type "lispobj *") - #!+gencgc - (alloc-region :c-type "struct alloc_region" :length 5) (pid :c-type "pid_t") + (binding-stack-start :c-type "lispobj *" :length #!+alpha 2 #!-alpha 1) + (binding-stack-pointer :c-type "lispobj *" :length #!+alpha 2 #!-alpha 1) + (control-stack-start :c-type "lispobj *" :length #!+alpha 2 #!-alpha 1) + (control-stack-end :c-type "lispobj *" :length #!+alpha 2 #!-alpha 1) + (alien-stack-start :c-type "lispobj *" :length #!+alpha 2 #!-alpha 1) + (alien-stack-pointer :c-type "lispobj *" :length #!+alpha 2 #!-alpha 1) + #!+gencgc (alloc-region :c-type "struct alloc_region" :length 5) (tls-cookie) ; on x86, the LDT index - (this :c-type "struct thread *") - (next :c-type "struct thread *") - (pseudo-atomic-atomic) - (pseudo-atomic-interrupted) - (interrupt-data :c-type "struct interrupt_data *") + (this :c-type "struct thread *" :length #!+alpha 2 #!-alpha 1) + (next :c-type "struct thread *" :length #!+alpha 2 #!-alpha 1) + #!+x86 (pseudo-atomic-atomic) + #!+x86 (pseudo-atomic-interrupted) + (interrupt-data :c-type "struct interrupt_data *" + :length #!+alpha 2 #!-alpha 1) (interrupt-contexts :c-type "os_context_t *" :rest-p t))