function-lambda-expression: Return the name of a generic function.
[sbcl.git] / src / assembly / x86-64 / support.lisp
index 5e10c88..62bc41f 100644 (file)
@@ -9,38 +9,31 @@
 
 (in-package "SB!VM")
 
-(!def-vm-support-routine generate-call-sequence (name style vop)
+(defun generate-call-sequence (name style vop)
   (ecase style
     (:raw
      (values
-      `((inst lea temp-reg-tn
-              (make-ea :qword :disp (make-fixup ',name :assembly-routine)))
+      `((inst mov temp-reg-tn (make-fixup ',name :assembly-routine))
         (inst call temp-reg-tn))
       nil))
     (:full-call
      (values
       `((note-this-location ,vop :call-site)
-        (inst lea temp-reg-tn
-              (make-ea :qword :disp (make-fixup ',name :assembly-routine)))
+        (inst mov temp-reg-tn (make-fixup ',name :assembly-routine))
         (inst call temp-reg-tn)
-        (note-this-location ,vop :single-value-return)
-        (move rsp-tn rbx-tn))
+        (note-this-location ,vop :single-value-return))
       '((:save-p :compute-only))))
     (:none
      (values
-      `((inst lea temp-reg-tn
-              (make-ea :qword :disp (make-fixup ',name :assembly-routine)))
+      `((inst mov temp-reg-tn (make-fixup ',name :assembly-routine))
         (inst jmp temp-reg-tn))
       nil))))
 
-(!def-vm-support-routine generate-return-sequence (style)
+(defun generate-return-sequence (style)
   (ecase style
     (:raw
      `(inst ret))
     (:full-call
-     `(
-       (inst pop rax-tn)
-
-       (inst add rax-tn 3)
-       (inst jmp rax-tn)))
+     `((inst clc)
+       (inst ret)))
     (:none)))