Don't use iterator after being erased.
authorJakub Staszak <kubastaszak@gmail.com>
Mon, 26 Nov 2012 22:14:19 +0000 (22:14 +0000)
committerJakub Staszak <kubastaszak@gmail.com>
Mon, 26 Nov 2012 22:14:19 +0000 (22:14 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@168622 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/MachineCSE.cpp

index 497e000b687219abd1f9fa68724518499e5972bd..dbc41defeb5a4b0ab2ac1e6a909e338e723e207f 100644 (file)
@@ -429,8 +429,8 @@ void MachineCSE::ExitScope(MachineBasicBlock *MBB) {
   DEBUG(dbgs() << "Exiting: " << MBB->getName() << '\n');
   DenseMap<MachineBasicBlock*, ScopeType*>::iterator SI = ScopeMap.find(MBB);
   assert(SI != ScopeMap.end());
-  ScopeMap.erase(SI);
   delete SI->second;
+  ScopeMap.erase(SI);
 }
 
 bool MachineCSE::ProcessBlock(MachineBasicBlock *MBB) {