From b68d591475f6deb2abdf65c57b633cb89be253cb Mon Sep 17 00:00:00 2001 From: Heejin Ahn Date: Thu, 4 Oct 2018 21:03:35 +0000 Subject: [PATCH] [WebAssembly] Don't modify preds/succs iterators while erasing from them Summary: This caused out-of-bound bugs. Found by `-DLLVM_ENABLE_EXPENSIVE_CHECKS=ON`. Reviewers: dschuff Subscribers: sbc100, jgravelle-google, sunfish, llvm-commits Differential Revision: https://reviews.llvm.org/D52902 llvm-svn: 343814 --- llvm/lib/Target/WebAssembly/WebAssemblyLateEHPrepare.cpp | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/llvm/lib/Target/WebAssembly/WebAssemblyLateEHPrepare.cpp b/llvm/lib/Target/WebAssembly/WebAssemblyLateEHPrepare.cpp index 8f40b4c..936b801 100644 --- a/llvm/lib/Target/WebAssembly/WebAssemblyLateEHPrepare.cpp +++ b/llvm/lib/Target/WebAssembly/WebAssemblyLateEHPrepare.cpp @@ -91,12 +91,15 @@ static void EraseBBsAndChildren(const Container &MBBs) { SmallVector WL(MBBs.begin(), MBBs.end()); while (!WL.empty()) { MachineBasicBlock *MBB = WL.pop_back_val(); - for (auto *Pred : MBB->predecessors()) + SmallVector Preds(MBB->pred_begin(), + MBB->pred_end()); + for (auto *Pred : Preds) Pred->removeSuccessor(MBB); - for (auto *Succ : MBB->successors()) { - WL.push_back(Succ); + SmallVector Succs(MBB->succ_begin(), + MBB->succ_end()); + WL.append(MBB->succ_begin(), MBB->succ_end()); + for (auto *Succ : Succs) MBB->removeSuccessor(Succ); - } MBB->eraseFromParent(); } } -- 2.7.4