X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fcompiler%2Fgeneric%2Fobjdef.lisp;h=c242a4da4c538fbf008c55397cac685fc9b1db39;hb=7f579b076a1fc54587538ead07e506e7f06f3fe8;hp=892630f8326c434db484fcbce04f90dacd289f74;hpb=b727b3bff6f2a989e8e20e199945c2bf768214a9;p=sbcl.git diff --git a/src/compiler/generic/objdef.lisp b/src/compiler/generic/objdef.lisp index 892630f..c242a4d 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 @@ -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")) @@ -358,6 +358,16 @@ (real :c-type "double" :length #!-x86-64 2 #!+x86-64 1) (imag :c-type "double" :length #!-x86-64 2 #!+x86-64 1)) +#!+sb-simd-pack +(define-primitive-object (simd-pack + :lowtag other-pointer-lowtag + :widetag simd-pack-widetag) + (tag :ref-trans %simd-pack-tag + :attributes (movable flushable) + :type fixnum) + (lo-value :c-type "long" :type (unsigned-byte 64)) + (hi-value :c-type "long" :type (unsigned-byte 64))) + ;;; this isn't actually a lisp object at all, it's a c structure that lives ;;; in c-land. However, we need sight of so many parts of it from Lisp that ;;; it makes sense to define it here anyway, so that the GENESIS machinery @@ -426,9 +436,16 @@ (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