37 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Factor
		
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Factor
		
	
	
! Copyright (C) 2008 Slava Pestov.
 | 
						|
! See http://factorcode.org/license.txt for BSD license.
 | 
						|
USING: accessors kernel sequences sets arrays math strings fry
 | 
						|
prettyprint compiler.cfg.linear-scan.live-intervals
 | 
						|
compiler.cfg.linear-scan.allocation ;
 | 
						|
IN: compiler.cfg.linear-scan.debugger
 | 
						|
 | 
						|
: check-assigned ( live-intervals -- )
 | 
						|
    [
 | 
						|
        reg>>
 | 
						|
        [ "Not all intervals have registers" throw ] unless
 | 
						|
    ] each ;
 | 
						|
 | 
						|
: split-children ( live-interval -- seq )
 | 
						|
    dup split-before>> [
 | 
						|
        [ split-before>> ] [ split-after>> ] bi
 | 
						|
        [ split-children ] bi@
 | 
						|
        append
 | 
						|
    ] [ 1array ] if ;
 | 
						|
 | 
						|
: check-linear-scan ( live-intervals machine-registers -- )
 | 
						|
    [ [ clone ] map ] dip allocate-registers
 | 
						|
    [ split-children ] map concat check-assigned ;
 | 
						|
 | 
						|
: picture ( uses -- str )
 | 
						|
    dup last 1 + CHAR: space <string>
 | 
						|
    [ '[ CHAR: * swap _ set-nth ] each ] keep ;
 | 
						|
 | 
						|
: interval-picture ( interval -- str )
 | 
						|
    [ uses>> picture ]
 | 
						|
    [ copy-from>> unparse ]
 | 
						|
    [ vreg>> unparse ]
 | 
						|
    tri 3array ;
 | 
						|
 | 
						|
: live-intervals. ( seq -- )
 | 
						|
    [ interval-picture ] map simple-table. ;
 |