[llvm-commits] [llvm] r108010 - /llvm/trunk/lib/CodeGen/SimpleRegisterCoalescing.cpp

Jakob Stoklund Olesen stoklund at 2pi.dk
Fri Jul 9 13:43:05 PDT 2010


Author: stoklund
Date: Fri Jul  9 15:43:05 2010
New Revision: 108010

URL: http://llvm.org/viewvc/llvm-project?rev=108010&view=rev
Log:
Remat uncoalescable COPY instrs

Modified:
    llvm/trunk/lib/CodeGen/SimpleRegisterCoalescing.cpp

Modified: llvm/trunk/lib/CodeGen/SimpleRegisterCoalescing.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/SimpleRegisterCoalescing.cpp?rev=108010&r1=108009&r2=108010&view=diff
==============================================================================
--- llvm/trunk/lib/CodeGen/SimpleRegisterCoalescing.cpp (original)
+++ llvm/trunk/lib/CodeGen/SimpleRegisterCoalescing.cpp Fri Jul  9 15:43:05 2010
@@ -781,6 +781,17 @@
           ReMaterializeTrivialDef(li_->getInterval(SrcReg), CopyDstReg, 0,
                                   UseMI))
         continue;
+
+      if (UseMI->isCopy() &&
+          !UseMI->getOperand(1).getSubReg() &&
+          !UseMI->getOperand(0).getSubReg() &&
+          UseMI->getOperand(1).getReg() == SrcReg &&
+          UseMI->getOperand(0).getReg() != SrcReg &&
+          UseMI->getOperand(0).getReg() != DstReg &&
+          !JoinedCopies.count(UseMI) &&
+          ReMaterializeTrivialDef(li_->getInterval(SrcReg),
+                                  UseMI->getOperand(0).getReg(), 0, UseMI))
+        continue;
     }
 
     SmallVector<unsigned,8> Ops;





More information about the llvm-commits mailing list