X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fcompiler%2Fltn.lisp;h=619ebbc0d9e537b6eea2543b1ae9d167dc2214bd;hb=4898ef32c639b1c7f4ee13a5ba566ce6debd03e6;hp=7d12edbfdd0e7b3a23a7e53eb9d07b8f4a0465ac;hpb=7c7e6276719b8d40fddec2070cad81064a25c8ed;p=sbcl.git diff --git a/src/compiler/ltn.lisp b/src/compiler/ltn.lisp index 7d12edb..619ebbc 100644 --- a/src/compiler/ltn.lisp +++ b/src/compiler/ltn.lisp @@ -67,13 +67,24 @@ ;;; Return true if a constant LEAF is of a type which we can legally ;;; directly reference in code. Named constants with arbitrary pointer ;;; values cannot, since we must preserve EQLness. +;;; +;;; FIXME: why not? The values in a function's constant vector are +;;; subject to being moved by the garbage collector. Having arbitrary +;;; values in said vector doesn't seem like a problem. (defun legal-immediate-constant-p (leaf) (declare (type constant leaf)) (or (not (leaf-has-source-name-p leaf)) - (typecase (constant-value leaf) - ((or number character) t) - (symbol (symbol-package (constant-value leaf))) - (t nil)))) + ;; Specialized arrays are legal, too. KLUDGE: this would be + ;; *much* cleaner if SIMPLE-UNBOXED-ARRAY was defined on the host. + #.(loop for saetp across sb!vm:*specialized-array-element-type-properties* + unless (eq t (sb!vm:saetp-specifier saetp)) + collect `((simple-array ,(sb!vm:saetp-specifier saetp) (*)) t) into cases + finally (return + `(typecase (constant-value leaf) + ((or number character) t) + (symbol (symbol-package (constant-value leaf))) + ,@cases + (t nil)))))) ;;; If LVAR is used only by a REF to a leaf that can be delayed, then ;;; return the leaf, otherwise return NIL.