factor/library/compiler/amd64/alien.factor

39 lines
1.1 KiB
Factor
Raw Normal View History

2005-12-10 01:02:13 -05:00
! Copyright (C) 2005 Slava Pestov.
! See http://factor.sf.net/license.txt for BSD license.
IN: compiler-backend
2005-12-24 16:08:15 -05:00
USING: alien assembler kernel math ;
2005-12-10 01:02:13 -05:00
2005-12-24 16:08:15 -05:00
GENERIC: store-insn ( from to offset reg-class -- )
2005-12-10 01:02:13 -05:00
2005-12-24 16:08:15 -05:00
GENERIC: load-insn ( elt parameter reg-class -- )
2005-12-10 01:02:13 -05:00
2005-12-24 16:08:15 -05:00
M: int-regs store-insn drop 1 swap stack@ STW ;
2005-12-10 01:02:13 -05:00
2005-12-24 16:08:15 -05:00
M: int-regs load-insn drop 3 + 1 rot stack@ LWZ ;
2005-12-10 01:02:13 -05:00
2005-12-24 16:08:15 -05:00
M: float-regs store-insn
>r 1 swap stack@ r>
float-regs-size 4 = [ STFS ] [ STFD ] if ;
M: float-regs load-insn
>r 1+ 1 rot stack@ r>
float-regs-size 4 = [ LFS ] [ LFD ] if ;
M: stack-params load-insn
drop >r 0 1 rot stack@ LWZ 0 1 r> stack@ STW ;
M: %unbox generate-node ( vop -- )
drop
! Call the unboxer
1 input f compile-c-call
! Store the return value on the C stack
2 input return-reg 0 input 2 input store-insn ;
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 ;
M: %box generate-node ( vop -- ) drop 0 input f compile-c-call ;
M: %cleanup generate-node ( vop -- ) drop ;