1.0.0.32: support for FreeBSD/x86-64
[sbcl.git] / src / compiler / x86 / 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 eax-offset
21                :target result
22                :from :eval
23                :to (:result 0))
24               eax)
25   #!+darwin (:temporary (:sc unsigned-reg
26                             :offset esi-offset)
27                        prev-stack-pointer)
28   (:results (result :scs (descriptor-reg)))
29   (:save-p t)
30   (:generator 100
31     ;; the stack should be 16-byte aligned on Darwin
32     #!-darwin (inst push object)
33     #!+darwin (progn (inst mov prev-stack-pointer esp-tn)
34                      (inst sub esp-tn n-word-bytes)
35                      (inst and esp-tn -16)
36                      (storew object esp-tn))
37     (inst lea eax (make-fixup "debug_print" :foreign))
38     (inst call (make-fixup "call_into_c" :foreign))
39     #!-darwin (inst add esp-tn n-word-bytes)
40     #!+darwin (inst mov esp-tn prev-stack-pointer)
41     (move result eax)))