2006-02-13 22:20:39 -05:00
|
|
|
! Copyright (C) 2005, 2006 Slava Pestov.
|
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
2005-06-14 19:10:48 -04:00
|
|
|
IN: compiler-backend
|
2006-02-13 22:20:39 -05:00
|
|
|
USING: alien assembler kernel math sequences ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2006-02-13 22:20:39 -05:00
|
|
|
GENERIC: freg>stack ( stack reg reg-class -- )
|
2005-12-23 03:05:20 -05:00
|
|
|
|
2006-02-13 22:20:39 -05:00
|
|
|
GENERIC: stack>freg ( stack reg reg-class -- )
|
2005-12-23 03:05:20 -05:00
|
|
|
|
2006-02-13 22:20:39 -05:00
|
|
|
M: int-regs freg>stack drop 1 rot stack@ STW ;
|
2005-06-14 05:01:07 -04:00
|
|
|
|
2006-02-13 22:20:39 -05:00
|
|
|
M: int-regs stack>freg drop 1 rot stack@ LWZ ;
|
2005-06-14 05:01:07 -04:00
|
|
|
|
2006-02-13 22:20:39 -05:00
|
|
|
: STF float-regs-size 4 = [ STFS ] [ STFD ] if ;
|
2005-12-23 03:05:20 -05:00
|
|
|
|
2006-02-13 22:20:39 -05:00
|
|
|
M: float-regs freg>stack >r 1 rot stack@ r> STF ;
|
2005-10-18 20:19:10 -04:00
|
|
|
|
2006-02-13 22:20:39 -05:00
|
|
|
: LF float-regs-size 4 = [ LFS ] [ LFD ] if ;
|
|
|
|
|
|
|
|
M: float-regs stack>freg >r 1 rot stack@ r> LF ;
|
|
|
|
|
|
|
|
M: stack-params stack>freg
|
2005-10-18 20:19:10 -04:00
|
|
|
drop >r 0 1 rot stack@ LWZ 0 1 r> stack@ STW ;
|
2005-06-14 05:01:07 -04:00
|
|
|
|
2005-05-24 01:26:45 -04:00
|
|
|
M: %unbox generate-node ( vop -- )
|
2005-12-07 21:46:54 -05:00
|
|
|
drop
|
2005-12-24 16:08:15 -05:00
|
|
|
! Call the unboxer
|
2006-02-06 01:43:59 -05:00
|
|
|
2 input f compile-c-call
|
2005-12-24 16:08:15 -05:00
|
|
|
! Store the return value on the C stack
|
2006-02-13 22:20:39 -05:00
|
|
|
0 input 1 input [ return-reg ] keep freg>stack ;
|
2006-02-06 01:43:59 -05:00
|
|
|
|
|
|
|
M: %unbox-struct generate-node ( vop -- )
|
|
|
|
drop
|
|
|
|
! Load destination address
|
|
|
|
3 1 0 input stack@ ADDI
|
|
|
|
! Load struct size
|
|
|
|
2 input 4 LI
|
|
|
|
! Copy the struct to the stack
|
|
|
|
"unbox_value_struct" f compile-c-call ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2006-02-13 22:20:39 -05:00
|
|
|
: (%move) 0 input 1 input 2 input [ fastcall-regs nth ] keep ;
|
|
|
|
|
|
|
|
M: %stack>freg generate-node ( vop -- )
|
2005-12-24 16:08:15 -05:00
|
|
|
! Move a value from the C stack into the fastcall register
|
2006-02-13 22:20:39 -05:00
|
|
|
drop (%move) stack>freg ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2006-02-13 22:20:39 -05:00
|
|
|
M: %freg>stack generate-node ( vop -- )
|
|
|
|
! Move a value from a fastcall register to the C stack
|
|
|
|
drop (%move) freg>stack ;
|
|
|
|
|
|
|
|
M: %box generate-node ( vop -- )
|
|
|
|
drop
|
|
|
|
! If the source is a stack location, load it into freg #0.
|
|
|
|
! If the source is f, then we assume the value is already in
|
|
|
|
! freg #0.
|
|
|
|
0 input [ 0 1 input stack>freg ] when*
|
|
|
|
2 input f compile-c-call ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2005-10-18 20:19:10 -04:00
|
|
|
M: %cleanup generate-node ( vop -- ) drop ;
|
2006-02-13 17:16:34 -05:00
|
|
|
|
|
|
|
M: %nullary-callback generate-node ( vop -- )
|
|
|
|
drop
|
|
|
|
3 0 input load-indirect
|
|
|
|
"run_nullary_callback" f compile-c-call ;
|