2005-04-23 19:34:06 -04:00
|
|
|
! Copyright (C) 2005 Slava Pestov.
|
|
|
|
! See http://factor.sf.net/license.txt for BSD license.
|
2005-05-09 02:34:15 -04:00
|
|
|
IN: compiler-backend
|
2005-05-13 20:37:28 -04:00
|
|
|
USING: alien assembler compiler inference kernel
|
|
|
|
kernel-internals lists math memory namespaces words ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2005-05-08 20:30:38 -04:00
|
|
|
M: %alien-invoke generate-node
|
|
|
|
#! call a C function.
|
2005-09-08 22:23:54 -04:00
|
|
|
dup 0 vop-in swap 1 vop-in load-library compile-c-call ;
|
2005-05-13 20:37:28 -04:00
|
|
|
|
2005-05-08 20:30:38 -04:00
|
|
|
M: %parameters generate-node
|
|
|
|
#! x86 does not pass parameters in registers
|
|
|
|
drop ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2005-05-08 20:30:38 -04:00
|
|
|
M: %parameter generate-node
|
|
|
|
#! x86 does not pass parameters in registers
|
|
|
|
drop ;
|
2005-05-04 22:34:55 -04:00
|
|
|
|
2005-06-14 05:01:07 -04:00
|
|
|
GENERIC: reg-size ( reg-class -- n )
|
|
|
|
GENERIC: push-reg ( reg-class -- )
|
2005-05-04 22:34:55 -04:00
|
|
|
|
2005-06-14 05:01:07 -04:00
|
|
|
M: int-regs reg-size drop cell ;
|
|
|
|
M: int-regs push-reg drop EAX PUSH ;
|
2005-05-04 22:34:55 -04:00
|
|
|
|
2005-06-15 16:34:16 -04:00
|
|
|
M: float-regs reg-size float-regs-size ;
|
2005-06-14 05:01:07 -04:00
|
|
|
M: float-regs push-reg
|
2005-06-14 20:54:11 -04:00
|
|
|
ESP swap reg-size [ SUB [ ESP ] ] keep
|
|
|
|
4 = [ FSTPS ] [ FSTPL ] ifte ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2005-06-14 05:01:07 -04:00
|
|
|
M: %unbox generate-node
|
2005-09-08 22:23:54 -04:00
|
|
|
dup 1 vop-in f compile-c-call 2 vop-in push-reg ;
|
2005-05-04 22:34:55 -04:00
|
|
|
|
2005-05-08 20:30:38 -04:00
|
|
|
M: %box generate-node
|
2005-09-08 22:23:54 -04:00
|
|
|
dup 1 vop-in push-reg
|
|
|
|
dup 0 vop-in f compile-c-call
|
|
|
|
1 vop-in ESP swap reg-size ADD ;
|
2005-04-23 19:34:06 -04:00
|
|
|
|
2005-05-08 20:30:38 -04:00
|
|
|
M: %cleanup generate-node
|
2005-09-08 22:23:54 -04:00
|
|
|
0 vop-in dup 0 = [ drop ] [ ESP swap ADD ] ifte ;
|