0.8.0.74:
[sbcl.git] / src / compiler / hppa / show.lisp
1 (in-package "SB!VM")
2
3
4 (define-vop (print)
5   (:args (object :scs (descriptor-reg) :target arg))
6   (:results (result :scs (descriptor-reg)))
7   (:save-p t)
8   (:temporary (:sc non-descriptor-reg :offset cfunc-offset) cfunc)
9   (:temporary (:sc non-descriptor-reg :offset nl0-offset :from (:argument 0))
10               arg)
11   (:temporary (:sc non-descriptor-reg :offset nl4-offset :to (:result 0))
12               res)
13   (:temporary (:sc control-stack :offset nfp-save-offset) nfp-save)
14   (:temporary (:scs (non-descriptor-reg)) temp)
15   (:vop-var vop)
16   (:generator 0
17     (let ((cur-nfp (current-nfp-tn vop)))
18       (move object arg)
19       (when cur-nfp
20         (store-stack-tn nfp-save cur-nfp))
21       ;; Allocate 64 bytes, the minimum stack size.
22       (inst addi 64 nsp-tn nsp-tn)
23       (inst li (make-fixup "debug_print" :foreign) cfunc)
24       (let ((fixup (make-fixup "call_into_c" :foreign)))
25         (inst ldil fixup temp)
26         (inst ble fixup c-text-space temp :nullify t)
27         (inst nop))
28       (inst addi -64 nsp-tn nsp-tn)
29       (when cur-nfp
30         (load-stack-tn cur-nfp nfp-save))
31       (move res result))))