Use more efficient map operations. Fix a bug that would affect hypothetical
authorChris Lattner <sabre@nondot.org>
Thu, 30 Sep 2004 16:35:08 +0000 (16:35 +0000)
committerChris Lattner <sabre@nondot.org>
Thu, 30 Sep 2004 16:35:08 +0000 (16:35 +0000)
targets that supported multiple memory operands.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@16614 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/VirtRegMap.cpp

index 4d7c826a89738310b3a56f21c3c924c097ed5741..b687c57ae7aad3f465b774c6e385de9a6890c9e7 100644 (file)
@@ -79,17 +79,19 @@ void VirtRegMap::virtFolded(unsigned virtReg,
                             MachineInstr* oldMI,
                             MachineInstr* newMI) {
   // move previous memory references folded to new instruction
-  MI2VirtMapTy::iterator i, e;
   std::vector<MI2VirtMapTy::mapped_type> regs;
-  for (tie(i, e) = MI2VirtMap.equal_range(oldMI); i != e; ) {
-    regs.push_back(i->second);
-    MI2VirtMap.erase(i++);
+  for (MI2VirtMapTy::iterator I = MI2VirtMap.lower_bound(oldMI), 
+         E = MI2VirtMap.end(); I != E && I->first == oldMI; ) {
+    regs.push_back(I->second);
+    MI2VirtMap.erase(I++);
   }
+
+  MI2VirtMapTy::iterator IP = MI2VirtMap.lower_bound(newMI);
   for (unsigned i = 0, e = regs.size(); i != e; ++i)
-    MI2VirtMap.insert(std::make_pair(newMI, i));
+    MI2VirtMap.insert(IP, std::make_pair(newMI, regs[i]));
 
   // add new memory reference
-  MI2VirtMap.insert(std::make_pair(newMI, virtReg));
+  MI2VirtMap.insert(IP, std::make_pair(newMI, virtReg));
 }
 
 void VirtRegMap::print(std::ostream &OS) const {