2005-03-13 17:55:57 -05:00
|
|
|
! Copyright (C) 2005 Slava Pestov.
|
|
|
|
! See http://factor.sf.net/license.txt for BSD license.
|
2005-05-24 01:26:45 -04:00
|
|
|
IN: compiler-backend
|
2005-12-03 16:13:09 -05:00
|
|
|
USING: assembler compiler errors kernel kernel-internals math
|
|
|
|
memory words ;
|
2005-05-24 01:26:45 -04:00
|
|
|
|
2005-09-23 18:41:26 -04:00
|
|
|
GENERIC: loc>operand
|
|
|
|
|
|
|
|
M: ds-loc loc>operand ds-loc-n cell * neg 14 swap ;
|
|
|
|
M: cs-loc loc>operand cs-loc-n cell * neg 15 swap ;
|
2005-05-24 01:26:45 -04:00
|
|
|
|
|
|
|
M: %immediate generate-node ( vop -- )
|
2005-09-08 22:23:54 -04:00
|
|
|
dup 0 vop-in address swap 0 vop-out v>operand LOAD ;
|
2005-05-24 01:26:45 -04:00
|
|
|
|
2005-06-01 14:06:25 -04:00
|
|
|
: load-indirect ( dest literal -- )
|
2005-11-04 20:19:15 -05:00
|
|
|
add-literal over LOAD32 0 1 rel-address dup 0 LWZ ;
|
2005-06-01 14:06:25 -04:00
|
|
|
|
2005-05-24 01:26:45 -04:00
|
|
|
M: %indirect generate-node ( vop -- )
|
2005-09-08 22:23:54 -04:00
|
|
|
dup 0 vop-out v>operand swap 0 vop-in load-indirect ;
|
2005-05-24 01:26:45 -04:00
|
|
|
|
2005-09-23 18:41:26 -04:00
|
|
|
M: %peek generate-node ( vop -- )
|
|
|
|
dup 0 vop-out v>operand swap 0 vop-in loc>operand LWZ ;
|
2005-05-24 01:26:45 -04:00
|
|
|
|
2005-09-23 18:41:26 -04:00
|
|
|
M: %replace generate-node ( vop -- )
|
|
|
|
dup 0 vop-in v>operand swap 0 vop-out loc>operand STW ;
|
2005-05-24 01:26:45 -04:00
|
|
|
|
|
|
|
M: %inc-d generate-node ( vop -- )
|
2005-09-08 22:23:54 -04:00
|
|
|
14 14 rot 0 vop-in cell * ADDI ;
|
2005-05-24 01:26:45 -04:00
|
|
|
|
|
|
|
M: %inc-r generate-node ( vop -- )
|
2005-09-08 22:23:54 -04:00
|
|
|
15 15 rot 0 vop-in cell * ADDI ;
|