X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fcompiler%2Fgeneric%2Fobjdef.lisp;h=262f4729aba6eb80028172513d839fd1dc40e225;hb=70f323d9b06b95ed37a447742c1925906985c088;hp=938990cae89bd7858b5562c01da5c7ac0e5f7f6a;hpb=597826f00530e8d0c6f4a8ccda2e366f56b65579;p=sbcl.git diff --git a/src/compiler/generic/objdef.lisp b/src/compiler/generic/objdef.lisp index 938990c..262f472 100644 --- a/src/compiler/generic/objdef.lisp +++ b/src/compiler/generic/objdef.lisp @@ -51,7 +51,7 @@ (define-primitive-object (bignum :lowtag other-pointer-lowtag :widetag bignum-widetag :alloc-trans sb!bignum::%allocate-bignum) - (digits :rest-p t :c-type #!-alpha "long" #!+alpha "u32")) + (digits :rest-p t :c-type #!-alpha "sword_t" #!+alpha "u32")) (define-primitive-object (ratio :type ratio :lowtag other-pointer-lowtag @@ -143,7 +143,7 @@ ;; VECTOR -- see SHRINK-VECTOR. (length :ref-trans sb!c::vector-length :type index) - (data :rest-p t :c-type #!-alpha "unsigned long" #!+alpha "u32")) + (data :rest-p t :c-type #!-alpha "uword_t" #!+alpha "u32")) (define-primitive-object (code :type code-component :lowtag other-pointer-lowtag @@ -297,8 +297,8 @@ (current-cont :c-type #!-alpha "lispobj *" #!+alpha "u32") #!-(or x86 x86-64) current-code entry-pc - #!+win32 next-seh-frame - #!+win32 seh-frame-handler + #!+(and win32 x86) next-seh-frame + #!+(and win32 x86) seh-frame-handler tag (previous-catch :c-type #!-alpha "struct catch_block *" #!+alpha "u32")) @@ -398,6 +398,7 @@ (control-stack-guard-page-protected) (alien-stack-start :c-type "lispobj *" :length #!+alpha 2 #!-alpha 1) (alien-stack-pointer :c-type "lispobj *" :length #!+alpha 2 #!-alpha 1) + #!+win32 (private-events :c-type "struct private_events" :length 2) (this :c-type "struct thread *" :length #!+alpha 2 #!-alpha 1) (prev :c-type "struct thread *" :length #!+alpha 2 #!-alpha 1) (next :c-type "struct thread *" :length #!+alpha 2 #!-alpha 1) @@ -423,6 +424,18 @@ (control-stack-pointer :c-type "lispobj *") #!+mach-exception-handler (mach-port-name :c-type "mach_port_name_t") + (nonpointer-data :c-type "struct nonpointer_thread_data *" :length #!+alpha 2 #!-alpha 1) + #!+(and sb-safepoint x86) (selfptr :c-type "struct thread *") + ;; Context base pointer for running on top of system libraries built using + ;; -fomit-frame-pointer. Currently truly required and implemented only + ;; for (and win32 x86-64), but could be generalized to other platforms if + ;; needed: + #!+win32 (carried-base-pointer :c-type "os_context_register_t") + #!+sb-safepoint (csp-around-foreign-call :c-type "lispobj *") + #!+sb-safepoint (pc-around-foreign-call :c-type "lispobj *") + #!+win32 (synchronous-io-handle-and-flag :c-type "HANDLE" :length 1) + #!+(and sb-safepoint-strictly (not win32)) + (sprof-alloc-region :c-type "struct alloc_region" :length 5) ;; KLUDGE: On alpha, until STEPPING we have been lucky and the 32 ;; bit slots came in pairs. However the C compiler will align ;; interrupt_contexts on a double word boundary. This logic should