A partial re-def instruction may be a copy.
authorEvan Cheng <evan.cheng@apple.com>
Sat, 15 May 2010 01:35:44 +0000 (01:35 +0000)
committerEvan Cheng <evan.cheng@apple.com>
Sat, 15 May 2010 01:35:44 +0000 (01:35 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@103850 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/LiveIntervalAnalysis.cpp

index 78d46398a19a9e4051c533e3735db0ffc0237a86..aa0597f687625d829153778ff75d77acd9c97dee 100644 (file)
@@ -454,7 +454,14 @@ void LiveIntervals::handleVirtualRegisterDef(MachineBasicBlock *mbb,
 
       // Value#0 is now defined by the 2-addr instruction.
       OldValNo->def  = RedefIndex;
-      OldValNo->setCopy(0);
+      if (!PartReDef)
+        OldValNo->setCopy(0);
+      else {
+        // A re-def may be a copy. e.g. %reg1030:6<def> = VMOVD %reg1026, ...
+        unsigned SrcReg, DstReg, SrcSubReg, DstSubReg;
+        if (tii_->isMoveInstr(*mi, SrcReg, DstReg, SrcSubReg, DstSubReg))
+          OldValNo->setCopy(&*mi);
+      }
       
       // Add the new live interval which replaces the range for the input copy.
       LiveRange LR(DefIndex, RedefIndex, ValNo);