]> granicus.if.org Git - llvm/commitdiff
[SCEV] NFC : Removing unnecessary check on outgoing branches of a branch instr.
authorJatin Bhateja <jatin.bhateja@gmail.com>
Sun, 26 Nov 2017 02:01:01 +0000 (02:01 +0000)
committerJatin Bhateja <jatin.bhateja@gmail.com>
Sun, 26 Nov 2017 02:01:01 +0000 (02:01 +0000)
Summary:
For a given loop, getLoopLatch returns a non-null value
when a loop has only one latch block. In the modified
context a check on both the outgoing branches of a terminator instruction (of latch) to same header is redundant.

Reviewers: jbhateja

Reviewed By: jbhateja

Subscribers: sanjoy

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

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@318991 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/ScalarEvolution.cpp

index d2a7a545733157edf977c497cb83cef1b98fa298..53e216a5dc5960e8fd69a4244dc3ecb00a6b360b 100644 (file)
@@ -4092,8 +4092,7 @@ public:
     Value *BECond = nullptr;
     if (BasicBlock *Latch = L->getLoopLatch()) {
       BranchInst *BI = dyn_cast<BranchInst>(Latch->getTerminator());
-      if (BI && BI->isConditional() &&
-          BI->getSuccessor(0) != BI->getSuccessor(1)) {
+      if (BI && BI->isConditional()) {
         BECond = BI->getCondition();
         IsPosBECond = BI->getSuccessor(0) == L->getHeader();
       } else {