- (:cost 10)
- (:return-style :full-call)
- (:policy :safe)
- (:translate ,translate)
- (:save-p t))
- ((:arg x (descriptor-reg any-reg) a0-offset)
- (:arg y (descriptor-reg any-reg) a1-offset)
-
- (:res res descriptor-reg a0-offset)
-
- (:temp temp non-descriptor-reg nl0-offset)
- (:temp lip interior-reg lip-offset)
- (:temp nargs any-reg nargs-offset)
- (:temp ocfp any-reg ocfp-offset))
- (inst or temp x y)
- (inst and temp fixnum-tag-mask)
- (inst beq temp DO-COMPARE)
- ,cmp
-
- ;; DO-STATIC-FUN
- (inst lw lip null-tn (static-fun-offset ',static-fn))
- (inst li nargs (fixnumize 2))
- (inst move ocfp cfp-tn)
- (inst j lip)
- (inst move cfp-tn csp-tn)
-
- DO-COMPARE
- (inst beq temp DONE)
- (inst move res null-tn)
- (load-symbol res t)
-
- DONE)))
+ (:cost 10)
+ (:return-style :full-call)
+ (:policy :safe)
+ (:translate ,translate)
+ (:save-p t))
+ ((:arg x (descriptor-reg any-reg) a0-offset)
+ (:arg y (descriptor-reg any-reg) a1-offset)
+
+ (:res res descriptor-reg a0-offset)
+
+ (:temp temp non-descriptor-reg nl0-offset)
+ (:temp lip interior-reg lip-offset)
+ (:temp nargs any-reg nargs-offset)
+ (:temp ocfp any-reg ocfp-offset))
+ (inst or temp x y)
+ (inst and temp fixnum-tag-mask)
+ (inst beq temp DO-COMPARE)
+ ,cmp
+
+ ;; DO-STATIC-FUN
+ (inst lw lip null-tn (static-fun-offset ',static-fn))
+ (inst li nargs (fixnumize 2))
+ (move ocfp cfp-tn)
+ (inst j lip)
+ (move cfp-tn csp-tn t)
+
+ DO-COMPARE
+ (inst beq temp DONE)
+ (move res null-tn t)
+ (load-symbol res t)
+
+ DONE)))