• Josh Bleecher Snyder's avatar
    [dev.ssa] cmd/compile: speed up cse · 8c954d57
    Josh Bleecher Snyder authored
    By walking only the current set of partitions
    at any given point, the cse pass ended up doing
    lots of extraneous, effectively O(n^2) work.
    
    Using a regular for loop allows each cse pass to
    make as much progress as possible by processing
    each new class as it is introduced.
    
    This can and should be optimized further,
    but it already reduces by 75% cse time on test/slice3.go.
    
    The overall time to compile test/slice3.go is still
    dominated by the O(n^2) work in the liveness pass.
    However, Keith is rewriting regalloc anyway.
    
    Change-Id: I8be020b2f69352234587eeadeba923481bf43fcc
    Reviewed-on: https://go-review.googlesource.com/12244Reviewed-by: default avatarKeith Randall <khr@golang.org>
    8c954d57
cse.go 4.67 KB