factor/library/compiler/amd64/alien.factor

93 lines
2.4 KiB
Factor
Raw Normal View History

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 ;
2006-02-20 00:55:38 -05:00
GENERIC: freg>stack ( stack reg reg-class -- )
2006-01-24 19:56:08 -05:00
2006-02-20 00:55:38 -05:00
GENERIC: stack>freg ( stack reg reg-class -- )
2006-01-24 19:56:08 -05:00
: stack@ RSP swap [+] ;
2006-01-24 19:56:08 -05:00
2006-02-20 00:55:38 -05:00
M: int-regs freg>stack drop >r stack@ r> MOV ;
2006-01-24 19:56:08 -05:00
2006-02-20 00:55:38 -05:00
M: int-regs stack>freg drop swap stack@ MOV ;
2006-01-24 20:20:20 -05:00
: MOVSS/LPD float-regs-size 4 = [ MOVSS ] [ MOVLPD ] if ;
2006-02-20 00:55:38 -05:00
M: float-regs freg>stack >r >r stack@ r> r> MOVSS/LPD ;
2006-01-24 20:20:20 -05:00
2006-02-20 00:55:38 -05:00
M: float-regs stack>freg >r swap stack@ r> MOVSS/LPD ;
2006-01-24 19:56:08 -05:00
2006-02-20 00:55:38 -05:00
M: stack-params stack>freg
drop >r R11 swap stack@ MOV r> stack@ R11 MOV ;
2006-01-25 01:18:12 -05:00
2006-02-21 18:12:00 -05:00
M: stack-params freg>stack
>r stack-increment + cell + swap r> stack>freg ;
2006-02-20 00:55:38 -05:00
M: %unbox-struct generate-node ( vop -- )
drop
! Load destination address
RDI RSP MOV
RDI 0 input ADD
! Load struct size
RSI 2 input MOV
! Copy the struct to the stack
"unbox_value_struct" f compile-c-call ;
2006-01-24 19:56:08 -05:00
M: %unbox generate-node ( vop -- )
drop
! Call the unboxer
2 input f compile-c-call
2006-01-24 19:56:08 -05:00
! Store the return value on the C stack
2006-02-20 00:55:38 -05:00
0 input 1 input [ return-reg ] keep freg>stack ;
: (%move) 0 input 1 input 2 input [ fastcall-regs nth ] keep ;
2006-01-24 19:56:08 -05:00
2006-02-15 00:25:15 -05:00
M: %stack>freg generate-node ( vop -- )
2006-01-24 19:56:08 -05:00
! Move a value from the C stack into the fastcall register
2006-02-20 00:55:38 -05:00
drop (%move) stack>freg ;
M: %freg>stack generate-node ( vop -- )
! Move a value from a fastcall register to the C stack
drop (%move) freg>stack ;
2006-01-24 19:56:08 -05:00
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-20 00:55:38 -05:00
drop
0 input [
1 input [ fastcall-regs first ] keep stack>freg
] [
1 input load-return-value
] if*
2 input f compile-c-call ;
M: %alien-callback generate-node ( vop -- )
drop
RDI 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 ;