llvm-project/llvm/test/Transforms/LoopReroll
Eli Friedman 203eaaf5ba [LoopReroll] Rewrite induction variable rewriting.
This gets rid of a bunch of weird special cases; instead, just use SCEV
rewriting for everything.  In addition to being simpler, this fixes a
bug where we would use the wrong stride in certain edge cases.

The one bit I'm not quite sure about is the trip count handling,
specifically the FIXME about overflow.  In general, I think we need to
widen the exit condition, but that's probably not profitable if the new
type isn't legal, so we probably need a check somewhere.  That said, I
don't think I'm making the existing problem any worse.

As a followup to this, a bunch of IV-related code in root-finding could
be cleaned up; with SCEV-based rewriting, there isn't any reason to
assume a loop will have exactly one or two PHI nodes.

Differential Revision: https://reviews.llvm.org/D45191

llvm-svn: 335400
2018-06-22 22:58:55 +00:00
..
basic.ll [LoopReroll] Rewrite induction variable rewriting. 2018-06-22 22:58:55 +00:00
basic32iters.ll
complex_reroll.ll [LoopReroll] Rewrite induction variable rewriting. 2018-06-22 22:58:55 +00:00
indvar_with_ext.ll [LoopReroll] Rewrite induction variable rewriting. 2018-06-22 22:58:55 +00:00
negative.ll
nonconst_lb.ll [LoopReroll] Rewrite induction variable rewriting. 2018-06-22 22:58:55 +00:00
ptrindvar.ll [LoopReroll] Rewrite induction variable rewriting. 2018-06-22 22:58:55 +00:00
reduction.ll [LoopReroll] Rewrite induction variable rewriting. 2018-06-22 22:58:55 +00:00
reroll_with_dbg.ll