diff options
| author | David Greene <greened@obbligato.org> | 2008-04-01 22:14:23 +0000 |
|---|---|---|
| committer | David Greene <greened@obbligato.org> | 2008-04-01 22:14:23 +0000 |
| commit | 7f7edc3824405cd0b974a0afae9e9cc534c874f0 (patch) | |
| tree | f8b41a051d1d4b289950522ee32559a756f9397d /llvm/lib/Transforms | |
| parent | fc9f25dab0f4a37c30e06032e57ceb66e5e00f18 (diff) | |
| download | bcm5719-llvm-7f7edc3824405cd0b974a0afae9e9cc534c874f0.tar.gz bcm5719-llvm-7f7edc3824405cd0b974a0afae9e9cc534c874f0.zip | |
Iterators folloring a SmallVector erased element are invalidated so
don't access cached iterators from after the erased element.
llvm-svn: 49056
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/LoopIndexSplit.cpp | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/llvm/lib/Transforms/Scalar/LoopIndexSplit.cpp b/llvm/lib/Transforms/Scalar/LoopIndexSplit.cpp index 8053554c17c..48b45351a0f 100644 --- a/llvm/lib/Transforms/Scalar/LoopIndexSplit.cpp +++ b/llvm/lib/Transforms/Scalar/LoopIndexSplit.cpp @@ -232,8 +232,8 @@ bool LoopIndexSplit::runOnLoop(Loop *IncomingLoop, LPPassManager &LPM_Ref) { return false; // First see if it is possible to eliminate loop itself or not. - for (SmallVector<SplitInfo, 4>::iterator SI = SplitData.begin(), - E = SplitData.end(); SI != E;) { + for (SmallVector<SplitInfo, 4>::iterator SI = SplitData.begin(); + SI != SplitData.end();) { SplitInfo &SD = *SI; ICmpInst *CI = dyn_cast<ICmpInst>(SD.SplitCondition); if (SD.SplitCondition->getOpcode() == Instruction::And) { @@ -244,8 +244,7 @@ bool LoopIndexSplit::runOnLoop(Loop *IncomingLoop, LPPassManager &LPM_Ref) { return Changed; } else { SmallVector<SplitInfo, 4>::iterator Delete_SI = SI; - ++SI; - SplitData.erase(Delete_SI); + SI = SplitData.erase(Delete_SI); } } else if (CI && CI->getPredicate() == ICmpInst::ICMP_EQ) { @@ -256,8 +255,7 @@ bool LoopIndexSplit::runOnLoop(Loop *IncomingLoop, LPPassManager &LPM_Ref) { return Changed; } else { SmallVector<SplitInfo, 4>::iterator Delete_SI = SI; - ++SI; - SplitData.erase(Delete_SI); + SI = SplitData.erase(Delete_SI); } } else ++SI; |

