Rewrite a loop to avoid using iterators pointing to

elements that have been erased.  Based on a patch
by Nicolas Capens.



git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51485 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Dale Johannesen 2008-05-23 17:19:02 +00:00
parent b737a64a85
commit 679860e31b

View File

@ -529,18 +529,20 @@ unsigned BranchFolder::ComputeSameTails(unsigned CurHash,
void BranchFolder::RemoveBlocksWithHash(unsigned CurHash, void BranchFolder::RemoveBlocksWithHash(unsigned CurHash,
MachineBasicBlock* SuccBB, MachineBasicBlock* SuccBB,
MachineBasicBlock* PredBB) { MachineBasicBlock* PredBB) {
for (MPIterator CurMPIter = prior(MergePotentials.end()), MPIterator CurMPIter, B;
B = MergePotentials.begin(); for (CurMPIter = prior(MergePotentials.end()), B = MergePotentials.begin();
CurMPIter->first==CurHash; CurMPIter->first==CurHash;
--CurMPIter) { --CurMPIter) {
// Put the unconditional branch back, if we need one. // Put the unconditional branch back, if we need one.
MachineBasicBlock *CurMBB = CurMPIter->second; MachineBasicBlock *CurMBB = CurMPIter->second;
if (SuccBB && CurMBB != PredBB) if (SuccBB && CurMBB != PredBB)
FixTail(CurMBB, SuccBB, TII); FixTail(CurMBB, SuccBB, TII);
MergePotentials.erase(CurMPIter);
if (CurMPIter==B) if (CurMPIter==B)
break; break;
} }
if (CurMPIter->first!=CurHash)
CurMPIter++;
MergePotentials.erase(CurMPIter, MergePotentials.end());
} }
/// CreateCommonTailOnlyBlock - None of the blocks to be tail-merged consist /// CreateCommonTailOnlyBlock - None of the blocks to be tail-merged consist