factor/library/compiler/ppc/alien.factor

47 lines
1.2 KiB
Factor
Raw Normal View History

2005-04-23 19:34:06 -04:00
! Copyright (C) 2005 Slava Pestov.
! See http://factor.sf.net/license.txt for BSD license.
IN: compiler-backend
USING: alien assembler kernel math ;
2005-04-23 19:34:06 -04:00
M: %alien-invoke generate-node ( vop -- )
2005-09-08 22:23:54 -04:00
dup 0 vop-in swap 1 vop-in load-library compile-c-call ;
2005-04-23 19:34:06 -04:00
: stack-reserve 8 + 16 align ;
2005-06-14 20:54:11 -04:00
: stack@ 12 + ;
M: %parameters generate-node ( vop -- )
2005-09-08 22:23:54 -04:00
0 vop-in dup 0 =
2005-09-24 15:21:17 -04:00
[ drop ] [ stack-reserve 1 1 rot SUBI ] if ;
2005-04-23 19:34:06 -04:00
GENERIC: store-insn
GENERIC: load-insn
GENERIC: return-reg
M: int-regs store-insn drop STW ;
M: int-regs return-reg drop 3 ;
M: int-regs load-insn drop 3 + 1 rot LWZ ;
2005-06-14 20:54:11 -04:00
M: float-regs store-insn
2005-09-24 15:21:17 -04:00
float-regs-size 4 = [ STFS ] [ STFD ] if ;
M: float-regs return-reg drop 1 ;
2005-06-14 20:54:11 -04:00
M: float-regs load-insn
2005-09-24 15:21:17 -04:00
>r 1+ 1 rot r> float-regs-size 4 = [ LFS ] [ LFD ] if ;
M: %unbox generate-node ( vop -- )
2005-09-08 22:23:54 -04:00
[ 1 vop-in f compile-c-call ] keep
[ 2 vop-in return-reg 1 ] keep
[ 0 vop-in stack@ ] keep
2 vop-in store-insn ;
2005-04-23 19:34:06 -04:00
M: %parameter generate-node ( vop -- )
2005-09-08 22:23:54 -04:00
dup 0 vop-in stack@
over 1 vop-in
rot 2 vop-in load-insn ;
2005-04-23 19:34:06 -04:00
M: %box generate-node ( vop -- )
2005-09-08 22:23:54 -04:00
0 vop-in f compile-c-call ;
2005-04-23 19:34:06 -04:00
M: %cleanup generate-node ( vop -- )
2005-09-08 22:23:54 -04:00
0 vop-in dup 0 =
2005-09-24 15:21:17 -04:00
[ drop ] [ stack-reserve 1 1 rot ADDI ] if ;