[llvm-commits] [llvm] r142287 - /llvm/trunk/lib/CodeGen/OptimizePHIs.cpp

Cameron Zwarich zwarich at apple.com
Mon Oct 17 14:54:46 PDT 2011


Author: zwarich
Date: Mon Oct 17 16:54:46 2011
New Revision: 142287

URL: http://llvm.org/viewvc/llvm-project?rev=142287&view=rev
Log:
When deleting a phi cycle after looking through copies, constrain the register
to match its final use.

With this change, all of test-suite compiles for Thumb2 with -verify-coalescing
enabled.

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

Modified: llvm/trunk/lib/CodeGen/OptimizePHIs.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/OptimizePHIs.cpp?rev=142287&r1=142286&r2=142287&view=diff
==============================================================================
--- llvm/trunk/lib/CodeGen/OptimizePHIs.cpp (original)
+++ llvm/trunk/lib/CodeGen/OptimizePHIs.cpp Mon Oct 17 16:54:46 2011
@@ -165,7 +165,11 @@
     InstrSet PHIsInCycle;
     if (IsSingleValuePHICycle(MI, SingleValReg, PHIsInCycle) &&
         SingleValReg != 0) {
-      MRI->replaceRegWith(MI->getOperand(0).getReg(), SingleValReg);
+      unsigned OldReg = MI->getOperand(0).getReg();
+      if (!MRI->constrainRegClass(SingleValReg, MRI->getRegClass(OldReg)))
+        continue;
+
+      MRI->replaceRegWith(OldReg, SingleValReg);
       MI->eraseFromParent();
       ++NumPHICycles;
       Changed = true;





More information about the llvm-commits mailing list