2006-01-24 19:56:08 -05:00
|
|
|
! Copyright (C) 2005, 2006 Slava Pestov.
|
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
2005-12-10 01:02:13 -05:00
|
|
|
IN: compiler-backend
|
2006-01-24 19:56:08 -05:00
|
|
|
USING: alien arrays assembler kernel kernel-internals math
|
|
|
|
sequences ;
|
|
|
|
|
|
|
|
GENERIC: store-insn ( offset reg-class -- )
|
|
|
|
|
|
|
|
GENERIC: load-insn ( elt parameter reg-class -- )
|
|
|
|
|
2006-01-29 22:51:26 -05:00
|
|
|
: stack@ R10 RSP MOV R10 swap 2array ;
|
2006-01-24 19:56:08 -05:00
|
|
|
|
|
|
|
M: int-regs store-insn
|
|
|
|
drop stack@ RAX MOV ;
|
|
|
|
|
|
|
|
M: int-regs load-insn
|
2006-01-24 20:20:20 -05:00
|
|
|
fastcall-regs nth swap stack@ MOV ;
|
|
|
|
|
|
|
|
: MOVSS/LPD float-regs-size 4 = [ MOVSS ] [ MOVLPD ] if ;
|
|
|
|
|
|
|
|
M: float-regs store-insn
|
|
|
|
>r stack@ XMM0 r> MOVSS/LPD ;
|
|
|
|
|
|
|
|
M: float-regs load-insn
|
|
|
|
[ fastcall-regs nth swap stack@ ] keep MOVSS/LPD ;
|
2006-01-24 19:56:08 -05:00
|
|
|
|
2006-01-30 02:03:34 -05:00
|
|
|
M: stack-params load-insn
|
|
|
|
drop >r R11 swap stack@ MOV r> stack@ R11 MOV ;
|
2006-01-25 01:18:12 -05:00
|
|
|
|
2006-01-24 19:56:08 -05:00
|
|
|
M: %unbox generate-node ( vop -- )
|
|
|
|
drop
|
|
|
|
! Call the unboxer
|
2006-02-06 01:43:59 -05:00
|
|
|
2 input f compile-c-call
|
2006-01-24 19:56:08 -05:00
|
|
|
! Store the return value on the C stack
|
2006-02-06 01:43:59 -05:00
|
|
|
0 input 1 input store-insn ;
|
2006-01-24 19:56:08 -05:00
|
|
|
|
|
|
|
M: %parameter generate-node ( vop -- )
|
|
|
|
! Move a value from the C stack into the fastcall register
|
|
|
|
drop 0 input 1 input 2 input load-insn ;
|
|
|
|
|
2006-01-29 22:51:26 -05:00
|
|
|
: reset-sse RAX RAX XOR ;
|
|
|
|
|
|
|
|
M: %alien-invoke generate-node
|
|
|
|
reset-sse
|
|
|
|
drop 0 input 1 input load-library compile-c-call ;
|
|
|
|
|
2006-01-24 20:20:20 -05:00
|
|
|
: load-return-value ( reg-class -- )
|
|
|
|
dup fastcall-regs first swap return-reg
|
|
|
|
2dup eq? [ 2drop ] [ MOV ] if ;
|
|
|
|
|
2006-01-24 19:56:08 -05:00
|
|
|
M: %box generate-node ( vop -- )
|
2006-02-06 01:43:59 -05:00
|
|
|
drop 0 input load-return-value 1 input f compile-c-call ;
|