aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Analysis/LoopInfo.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-04-18 05:38:05 +0000
committerChris Lattner <sabre@nondot.org>2004-04-18 05:38:05 +0000
commit24199db80ebd43398318b21d3e8d13e9bf72981d (patch)
treeb73ebc3f53d3287b8f186f38f9dd073a1f0b79f7 /lib/Analysis/LoopInfo.cpp
parent4e55b7d2c62de7efa0147e0579980de8b1df9123 (diff)
downloadexternal_llvm-24199db80ebd43398318b21d3e8d13e9bf72981d.zip
external_llvm-24199db80ebd43398318b21d3e8d13e9bf72981d.tar.gz
external_llvm-24199db80ebd43398318b21d3e8d13e9bf72981d.tar.bz2
Add a new method, add a check missing that caused a segfault if a loop didn't
have a canonical indvar git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@13032 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/LoopInfo.cpp')
-rw-r--r--lib/Analysis/LoopInfo.cpp14
1 files changed, 14 insertions, 0 deletions
diff --git a/lib/Analysis/LoopInfo.cpp b/lib/Analysis/LoopInfo.cpp
index 87c0723..38b9c66 100644
--- a/lib/Analysis/LoopInfo.cpp
+++ b/lib/Analysis/LoopInfo.cpp
@@ -315,6 +315,19 @@ void LoopInfo::changeTopLevelLoop(Loop *OldLoop, Loop *NewLoop) {
"Loops already embedded into a subloop!");
}
+/// removeLoop - This removes the specified top-level loop from this loop info
+/// object. The loop is not deleted, as it will presumably be inserted into
+/// another loop.
+Loop *LoopInfo::removeLoop(iterator I) {
+ assert(I != end() && "Cannot remove end iterator!");
+ Loop *L = *I;
+ assert(L->getParentLoop() == 0 && "Not a top-level loop!");
+ TopLevelLoops.erase(TopLevelLoops.begin() + (I-begin()));
+ return L;
+}
+
+
+
//===----------------------------------------------------------------------===//
// APIs for simple analysis of the loop.
//
@@ -409,6 +422,7 @@ Value *Loop::getTripCount() const {
// Canonical loops will end with a 'setne I, V', where I is the incremented
// canonical induction variable and V is the trip count of the loop.
Instruction *Inc = getCanonicalInductionVariableIncrement();
+ if (Inc == 0) return 0;
PHINode *IV = cast<PHINode>(Inc->getOperand(0));
BasicBlock *BackedgeBlock =