factor/basis/compiler/cfg/stacks/stacks.factor

77 lines
1.8 KiB
Factor
Raw Normal View History

2010-01-14 10:10:13 -05:00
! Copyright (C) 2008, 2010 Slava Pestov.
2008-09-10 23:11:03 -04:00
! See http://factorcode.org/license.txt for BSD license.
2014-12-13 19:10:21 -05:00
USING: accessors biassocs compiler.cfg compiler.cfg.registers
compiler.cfg.stacks.finalize compiler.cfg.stacks.global
compiler.cfg.stacks.height compiler.cfg.stacks.local compiler.cfg.utilities
kernel math namespaces sequences ;
IN: compiler.cfg.stacks
2008-09-10 23:11:03 -04:00
: begin-stack-analysis ( -- )
<bihash> locs>vregs set
H{ } clone ds-heights set
H{ } clone rs-heights set
H{ } clone peek-sets set
H{ } clone replace-sets set
H{ } clone kill-sets set
initial-height-state height-state set ;
2008-09-17 19:52:11 -04:00
: end-stack-analysis ( -- )
cfg get
{
compute-anticip-sets
compute-live-sets
compute-pending-sets
compute-dead-sets
compute-avail-sets
finalize-stack-shuffling
} apply-passes ;
2008-09-10 23:11:03 -04:00
: ds-drop ( -- ) -1 inc-d ;
: ds-peek ( -- vreg ) D 0 peek-loc ;
: ds-pop ( -- vreg ) ds-peek ds-drop ;
: ds-push ( vreg -- )
1 inc-d D 0 replace-loc ;
2008-09-10 23:11:03 -04:00
: ds-load ( n -- vregs )
dup 0 =
[ drop f ]
2010-01-14 10:10:13 -05:00
[ [ iota <reversed> [ <ds-loc> peek-loc ] map ] [ neg inc-d ] bi ] if ;
2008-09-10 23:11:03 -04:00
: ds-store ( vregs -- )
[
<reversed>
[ length inc-d ]
[ [ <ds-loc> replace-loc ] each-index ] bi
] unless-empty ;
2008-09-10 23:11:03 -04:00
: rs-store ( vregs -- )
[
<reversed>
[ length inc-r ]
[ [ <rs-loc> replace-loc ] each-index ] bi
] unless-empty ;
2008-09-10 23:11:03 -04:00
: (2inputs) ( -- vreg1 vreg2 )
D 1 peek-loc D 0 peek-loc ;
: 2inputs ( -- vreg1 vreg2 )
(2inputs) -2 inc-d ;
: (3inputs) ( -- vreg1 vreg2 vreg3 )
D 2 peek-loc D 1 peek-loc D 0 peek-loc ;
2008-09-10 23:11:03 -04:00
: 3inputs ( -- vreg1 vreg2 vreg3 )
(3inputs) -3 inc-d ;
2010-04-22 04:21:23 -04:00
: binary-op ( quot -- )
[ 2inputs ] dip call ds-push ; inline
: unary-op ( quot -- )
[ ds-pop ] dip call ds-push ; inline
: adjust-d ( n -- )
<ds-loc> height-state get swap adjust ;