factor/library/compiler/ppc/alien.factor

90 lines
2.4 KiB
Factor
Raw Normal View History

2006-02-13 22:20:39 -05:00
! Copyright (C) 2005, 2006 Slava Pestov.
! See http://factorcode.org/license.txt for BSD license.
IN: compiler-backend
USING: alien assembler kernel kernel-internals 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 ;
2006-02-13 22:20:39 -05:00
M: int-regs stack>freg drop 1 rot stack@ LWZ ;
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 ;
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
2006-02-20 17:49:44 -05:00
drop 2dup = [
2drop
] [
>r 0 1 rot stack@ LWZ 0 1 r> stack@ STW
] if ;
M: stack-params freg>stack
>r stack-increment + swap r> stack>freg ;
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
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-03-10 22:16:46 -05:00
: struct-ptr/size ( func -- )
! Load destination address
3 1 0 input stack@ ADDI
! Load struct size
2 input 4 LI
2006-03-10 22:16:46 -05:00
f compile-c-call ;
M: %unbox-struct generate-node ( vop -- )
drop "unbox_value_struct" struct-ptr/size ;
M: %box-struct generate-node ( vop -- )
drop "box_value_struct" struct-ptr/size ;
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.
2006-02-13 22:47:42 -05:00
0 input [
1 input [ fastcall-regs first ] keep stack>freg
] when*
2006-02-13 22:20:39 -05:00
2 input f compile-c-call ;
2005-04-23 19:34:06 -04:00
M: %alien-callback generate-node ( vop -- )
2006-02-13 17:16:34 -05:00
drop
3 0 input load-indirect
"run_callback" f compile-c-call ;
: save-return 0 swap [ return-reg ] keep freg>stack ;
: load-return 0 swap [ return-reg ] keep stack>freg ;
M: %callback-value generate-node ( vop -- )
drop
! Call the unboxer
1 input f compile-c-call
! Save return register
0 input save-return
! Restore data/callstacks
"unnest_stacks" f compile-c-call
! Restore return register
0 input load-return ;