Don't use LiveVariables::VarInfo::DefInst.
authorOwen Anderson <resistor@mac.com>
Thu, 10 Jan 2008 03:12:54 +0000 (03:12 +0000)
committerOwen Anderson <resistor@mac.com>
Thu, 10 Jan 2008 03:12:54 +0000 (03:12 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@45815 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/LiveIntervalAnalysis.cpp

index 80d3547e4b41798b68e8d3d19bbdad5d7d0a44a0..b4f50e19291825407aeb16adf18eb4ff781f24e2 100644 (file)
@@ -309,7 +309,14 @@ void LiveIntervals::handleVirtualRegisterDef(MachineBasicBlock *mbb,
       // are actually two values in the live interval.  Because of this we
       // need to take the LiveRegion that defines this register and split it
       // into two values.
-      unsigned DefIndex = getDefIndex(getInstructionIndex(vi.DefInst));
+      MachineRegisterInfo& MRI = mbb->getParent()->getRegInfo();
+      unsigned lowIndex = ~0U;
+      for (MachineRegisterInfo::def_iterator DI = MRI.def_begin(interval.reg),
+          DE = MRI.def_end(); DI != DE; ++DI)
+        if (getInstructionIndex(&*DI) < lowIndex)
+          lowIndex = getInstructionIndex(&*DI);
+      
+      unsigned DefIndex = getDefIndex(lowIndex);
       unsigned RedefIndex = getDefIndex(MIIdx);
 
       const LiveRange *OldLR = interval.getLiveRangeContaining(RedefIndex-1);