mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-03-30 04:37:20 +00:00
Iterators folloring a SmallVector erased element are invalidated so
don't access cached iterators from after the erased element. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@49056 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a442006f48
commit
da2903f028
@ -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;
|
||||
|
Loading…
x
Reference in New Issue
Block a user