[PATCH] D13974: [IndVarSimplify] Rewrite loop exit values with their initial values from loop preheader
Sanjoy Das via llvm-commits
llvm-commits at lists.llvm.org
Thu Oct 22 02:07:18 PDT 2015
sanjoy added inline comments.
================
Comment at: lib/Transforms/Scalar/IndVarSimplify.cpp:758
@@ +757,3 @@
+ // incoming block as loop preheader, and others as back edges.
+ auto *InductionPHI =
+ dyn_cast<PHINode>(PN->getIncomingValue(0));
----------------
chenli wrote:
> sanjoy wrote:
> > How do you know that the 0th incoming value to `PN` is an induction PHI node?
> This is basically because of the previous assumption that we only have single entry PHI here. So if there is an induction PHI node, it should be 0th. The later
> ```
> InductionPHI->getBasicBlockIndex(LoopPreheader) != -1
> ```
> is used to filter non-induction PHI node.
> The name InductionPHI is confusing because it's not necessary an indication PHI if it fails the check.
> I will refactor the code to make it cleaner.
In any case, we don't really care about the PHI being an induction variable (i.e. a integer that increases / decreases by some amount every iteration) -- whatever the value incoming from the preheader -> header edge is will be the exit value of the PHI. So perhaps it makes sense to not call the value `InductionPHI`?
http://reviews.llvm.org/D13974
More information about the llvm-commits
mailing list