(defreg a3 27)
(defreg l0 28)
(defreg l1 29)
- (defreg l2 30)
+ (defreg #!-sb-thread l2 #!+sb-thread thread 30)
(defreg lip 31)
(defregset non-descriptor-regs
nl0 nl1 nl2 nl3 nl4 nl5 nl6 #+nil nl7 cfunc nargs nfp)
(defregset descriptor-regs
- fdefn a0 a1 a2 a3 ocfp lra cname lexenv l0 l1 l2 )
+ fdefn a0 a1 a2 a3 ocfp lra cname lexenv l0 l1 #!-sb-thread l2 )
(defregset *register-arg-offsets* a0 a1 a2 a3)
(defregtn null descriptor-reg)
(defregtn code descriptor-reg)
(defregtn alloc any-reg)
+ (defregtn lra descriptor-reg)
+ (defregtn lexenv descriptor-reg)
(defregtn nargs any-reg)
(defregtn bsp any-reg)
(if (static-symbol-p value)
(sc-number-or-lose 'immediate)
nil))))
+
+;;; A predicate to see if a character can be used as an inline
+;;; constant (the immediate field in the instruction used is sixteen
+;;; bits wide, which is not the same as any defined subtype of
+;;; CHARACTER).
+(defun inlinable-character-constant-p (char)
+ (and (characterp char)
+ (< (char-code char) #x10000)))
\f
;;;; function call parameters
:offset n))
*register-arg-offsets*))
+#!+sb-thread
+(defparameter thread-base-tn
+ (make-random-tn :kind :normal :sc (sc-or-lose 'unsigned-reg)
+ :offset thread-offset))
+
(export 'single-value-return-byte-offset)
;;; This is used by the debugger.
(%%ldb integer size posn))))
(t (values :default nil))))
(t (values :default nil)))))
+
+(defun primitive-type-indirect-cell-type (ptype)
+ (declare (ignore ptype))
+ nil)