Fix an iterator invalidation problem. :(
authorChris Lattner <sabre@nondot.org>
Thu, 19 Feb 2004 18:32:29 +0000 (18:32 +0000)
committerChris Lattner <sabre@nondot.org>
Thu, 19 Feb 2004 18:32:29 +0000 (18:32 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@11627 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/LiveVariables.cpp

index c4c8d639292d0014d503b3e0de0509a5e5e25b99..361b5038a2bec04f665dd6ab8adbfecce2af2067 100644 (file)
@@ -337,13 +337,22 @@ void LiveVariables::instructionChanged(MachineInstr *OldMI,
   // Move the killed information over...
   killed_iterator I, E;
   tie(I, E) = killed_range(OldMI);
+  std::vector<unsigned> Regs;
   for (killed_iterator A = I; A != E; ++A)
-    RegistersKilled.insert(std::make_pair(NewMI, A->second));
+    Regs.push_back(A->second);
   RegistersKilled.erase(I, E);
 
+  for (unsigned i = 0, e = Regs.size(); i != e; ++i)
+    RegistersKilled.insert(std::make_pair(NewMI, Regs[i]));
+  Regs.clear();
+
+
   // Move the dead information over...
   tie(I, E) = dead_range(OldMI);
   for (killed_iterator A = I; A != E; ++A)
-    RegistersDead.insert(std::make_pair(NewMI, A->second));
+    Regs.push_back(A->second);
   RegistersDead.erase(I, E);
+
+  for (unsigned i = 0, e = Regs.size(); i != e; ++i)
+    RegistersDead.insert(std::make_pair(NewMI, Regs[i]));
 }