factor/basis/compiler/cfg/save-contexts/save-contexts.factor

29 lines
867 B
Factor

! Copyright (C) 2009, 2010 Slava Pestov.
! See http://factorcode.org/license.txt for BSD license.
USING: compiler.cfg.instructions compiler.cfg.registers compiler.cfg.rpo
cpu.architecture kernel sequences ;
IN: compiler.cfg.save-contexts
UNION: context-modifier ##phi ##inc-d ##inc-r ##callback-inputs ;
UNION: context-save-needed gc-map-insn ;
: save-context-offset ( insns -- n )
[ context-modifier? not ] find drop ;
: insns-needs-save-context? ( insns -- ? )
[ context-save-needed? ] any? ;
: insert-save-context ( insns -- insns' )
dup insns-needs-save-context? [
[
int-rep next-vreg-rep
int-rep next-vreg-rep
##save-context new-insn
] dip
[ save-context-offset ] keep
insert-nth
] when ;
: insert-save-contexts ( cfg -- )
[ insert-save-context ] simple-optimization ;