diff options
author | Evan Cheng <evan.cheng@apple.com> | 2007-06-05 22:03:53 +0000 |
---|---|---|
committer | Evan Cheng <evan.cheng@apple.com> | 2007-06-05 22:03:53 +0000 |
commit | c1a0b8ce1d4de86218cfb90399bb9400b390eaa1 (patch) | |
tree | 2c3e414551a677f161b278db4104ac0f59219550 /llvm/lib/CodeGen/IfConversion.cpp | |
parent | 3e5bf0827c9657763dbe83858039520bb9ffbdd6 (diff) | |
download | bcm5719-llvm-c1a0b8ce1d4de86218cfb90399bb9400b390eaa1.tar.gz bcm5719-llvm-c1a0b8ce1d4de86218cfb90399bb9400b390eaa1.zip |
ReplaceUsesOfBlockWith() can modify the predecessors list.
llvm-svn: 37441
Diffstat (limited to 'llvm/lib/CodeGen/IfConversion.cpp')
-rw-r--r-- | llvm/lib/CodeGen/IfConversion.cpp | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/llvm/lib/CodeGen/IfConversion.cpp b/llvm/lib/CodeGen/IfConversion.cpp index 9a35d1d11e9..e06fb268358 100644 --- a/llvm/lib/CodeGen/IfConversion.cpp +++ b/llvm/lib/CodeGen/IfConversion.cpp @@ -756,9 +756,10 @@ void IfConverter::MergeBlocks(BBInfo &ToBBI, BBInfo &FromBBI) { ToBBI.BB->removeSuccessor(FromBBI.BB); // Redirect all branches to FromBB to ToBB. - for (MachineBasicBlock::pred_iterator I = FromBBI.BB->pred_begin(), - E = FromBBI.BB->pred_end(); I != E; ++I) - (*I)->ReplaceUsesOfBlockWith(FromBBI.BB, ToBBI.BB); + std::vector<MachineBasicBlock *> Preds(FromBBI.BB->pred_begin(), + FromBBI.BB->pred_end()); + for (unsigned i = 0, e = Preds.size(); i != e; ++i) + Preds[i]->ReplaceUsesOfBlockWith(FromBBI.BB, ToBBI.BB); // Transfer preds / succs and update size. TransferPreds(ToBBI.BB, FromBBI.BB); |