Avoid potential iterator invalidation problems.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@40607 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Owen Anderson 2007-07-30 21:26:39 +00:00
parent df5cf2074c
commit 891eecb040

View File

@ -895,11 +895,14 @@ bool GVN::runOnFunction(Function &F) {
currAvail = availableOut[DI->getIDom()->getBlock()]; currAvail = availableOut[DI->getIDom()->getBlock()];
for (BasicBlock::iterator BI = BB->begin(), BE = BB->end(); for (BasicBlock::iterator BI = BB->begin(), BE = BB->end();
BI != BE; ++BI) { BI != BE; ) {
changed_function |= processInstruction(BI, currAvail, lastSeenLoad, toErase); changed_function |= processInstruction(BI, currAvail, lastSeenLoad, toErase);
NumGVNInstr += toErase.size(); NumGVNInstr += toErase.size();
// Avoid iterator invalidation
++BI;
for (SmallVector<Instruction*, 4>::iterator I = toErase.begin(), for (SmallVector<Instruction*, 4>::iterator I = toErase.begin(),
E = toErase.end(); I != E; ++I) E = toErase.end(); I != E; ++I)
(*I)->eraseFromParent(); (*I)->eraseFromParent();