diff options
author | Dale Johannesen <dalej@apple.com> | 2008-05-23 17:19:02 +0000 |
---|---|---|
committer | Dale Johannesen <dalej@apple.com> | 2008-05-23 17:19:02 +0000 |
commit | 3ecd4258f63b12591d37a3ed291eab3dccdbbbed (patch) | |
tree | cd321e181bad56287ce8ff9cc0e0d977d3669803 /lib/CodeGen | |
parent | 0f0195b81c5d39f2cc0f4929120a492977d0405d (diff) | |
download | external_llvm-3ecd4258f63b12591d37a3ed291eab3dccdbbbed.zip external_llvm-3ecd4258f63b12591d37a3ed291eab3dccdbbbed.tar.gz external_llvm-3ecd4258f63b12591d37a3ed291eab3dccdbbbed.tar.bz2 |
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
Diffstat (limited to 'lib/CodeGen')
-rw-r--r-- | lib/CodeGen/BranchFolding.cpp | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/lib/CodeGen/BranchFolding.cpp b/lib/CodeGen/BranchFolding.cpp index e935898..e67339a 100644 --- a/lib/CodeGen/BranchFolding.cpp +++ b/lib/CodeGen/BranchFolding.cpp @@ -529,18 +529,20 @@ unsigned BranchFolder::ComputeSameTails(unsigned CurHash, void BranchFolder::RemoveBlocksWithHash(unsigned CurHash, MachineBasicBlock* SuccBB, MachineBasicBlock* PredBB) { - for (MPIterator CurMPIter = prior(MergePotentials.end()), - B = MergePotentials.begin(); + MPIterator CurMPIter, B; + for (CurMPIter = prior(MergePotentials.end()), B = MergePotentials.begin(); CurMPIter->first==CurHash; --CurMPIter) { // Put the unconditional branch back, if we need one. MachineBasicBlock *CurMBB = CurMPIter->second; if (SuccBB && CurMBB != PredBB) FixTail(CurMBB, SuccBB, TII); - MergePotentials.erase(CurMPIter); - if (CurMPIter==B) + if (CurMPIter==B) break; } + if (CurMPIter->first!=CurHash) + CurMPIter++; + MergePotentials.erase(CurMPIter, MergePotentials.end()); } /// CreateCommonTailOnlyBlock - None of the blocks to be tail-merged consist |