ce470870bb4ac68c5c702fce0708506e16f1d99b
[sbcl.git] / src / compiler / x86-64 / show.lisp
1 ;;;; VOPs which are useful for following the progress of the system
2 ;;;; early in boot
3
4 ;;;; This software is part of the SBCL system. See the README file for
5 ;;;; more information.
6 ;;;;
7 ;;;; This software is derived from the CMU CL system, which was
8 ;;;; written at Carnegie Mellon University and released into the
9 ;;;; public domain. The software is in the public domain and is
10 ;;;; provided with absolutely no warranty. See the COPYING and CREDITS
11 ;;;; files for more information.
12
13 (in-package "SB!VM")
14
15 ;;; FIXME: should probably become conditional on #!+SB-SHOW
16 ;;; FIXME: should be called DEBUG-PRINT or COLD-PRINT
17 (define-vop (print)
18   (:args (object :scs (descriptor-reg any-reg)))
19   (:temporary (:sc unsigned-reg
20                :offset rax-offset
21                :target result
22                :from :eval
23                :to (:result 0))
24               rax)
25   (:temporary (:sc unsigned-reg) call-target)
26   (:results (result :scs (descriptor-reg)))
27   (:save-p t)
28   (:generator 100
29     (inst push object)
30     (inst lea rax (make-fixup "debug_print" :foreign))
31     (inst lea call-target
32           (make-ea :qword
33                    :disp (make-fixup "call_into_c" :foreign)))
34     (inst call call-target)
35     (inst add rsp-tn n-word-bytes)
36     (move result rax)))