[Unroll] Improve the brute force loop unroll estimate by propagating
authorChandler Carruth <chandlerc@gmail.com>
Mon, 3 Aug 2015 20:32:27 +0000 (20:32 +0000)
committerChandler Carruth <chandlerc@gmail.com>
Mon, 3 Aug 2015 20:32:27 +0000 (20:32 +0000)
commit6e3744f374463c523762668824fee930842c05ee
treed3d8e97d5ae66f76ae05201a96ebf77dd8ce5519
parent5b8c55e5b65ce4b5315f8609afb9b08a9e1d6850
[Unroll] Improve the brute force loop unroll estimate by propagating
through PHI nodes across iterations.

This patch teaches the new advanced loop unrolling heuristics to propagate
constants into the loop from the preheader and around the backedge after
simulating each iteration. This lets us brute force solve simple recurrances
that aren't modeled effectively by SCEV. It also makes it more clear why we
need to process the loop in-order rather than bottom-up which might otherwise
make much more sense (for example, for DCE).

This came out of an attempt I'm making to develop a principled way to account
for dead code in the unroll estimation. When I implemented
a forward-propagating version of that it produced incorrect results due to
failing to propagate *cost* between loop iterations through the PHI nodes, and
it occured to me we really should at least propagate simplifications across
those edges, and it is quite easy thanks to the loop being in canonical and
LCSSA form.

Differential Revision: http://reviews.llvm.org/D11706

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@243900 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Transforms/Scalar/LoopUnrollPass.cpp
test/Transforms/LoopUnroll/full-unroll-heuristics-phi-prop.ll [new file with mode: 0644]