[llvm-commits] CVS: llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp

Chris Lattner lattner at cs.uiuc.edu
Sun Dec 18 07:28:02 PST 2005



Changes in directory llvm/lib/CodeGen/SelectionDAG:

LegalizeDAG.cpp updated: 1.231 -> 1.232
---
Log message:

legalize copytoreg and copyfromreg nodes that have flag operands correctly.


---
Diffs of the changes:  (+34 -11)

 LegalizeDAG.cpp |   45 ++++++++++++++++++++++++++++++++++-----------
 1 files changed, 34 insertions(+), 11 deletions(-)


Index: llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
diff -u llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp:1.231 llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp:1.232
--- llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp:1.231	Sat Dec 17 17:46:46 2005
+++ llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp	Sun Dec 18 09:27:43 2005
@@ -567,13 +567,21 @@
     return LegalizeOp(Node->getOperand(Op.ResNo));
   case ISD::CopyFromReg:
     Tmp1 = LegalizeOp(Node->getOperand(0));
-    if (Tmp1 != Node->getOperand(0))
-      Result = DAG.getCopyFromReg(Tmp1, 
+    Result = Op.getValue(0);
+    if (Node->getNumOperands() == 2) {
+      if (Tmp1 != Node->getOperand(0))
+        Result = DAG.getCopyFromReg(Tmp1, 
                             cast<RegisterSDNode>(Node->getOperand(1))->getReg(),
-                                  Node->getValueType(0));
-    else
-      Result = Op.getValue(0);
-
+                                    Node->getValueType(0));
+    } else {
+      assert(Node->getNumOperands() == 3 && "Invalid copyfromreg!");
+      Tmp2 = LegalizeOp(Node->getOperand(2));
+      if (Tmp1 != Node->getOperand(0) || Tmp2 != Node->getOperand(2))
+        Result = DAG.getCopyFromReg(Tmp1, 
+                            cast<RegisterSDNode>(Node->getOperand(1))->getReg(),
+                                    Node->getValueType(0), Tmp2);
+      AddLegalizedOperand(Op.getValue(2), Result.getValue(2));
+    }
     // Since CopyFromReg produces two values, make sure to remember that we
     // legalized both of them.
     AddLegalizedOperand(Op.getValue(0), Result);
@@ -1130,11 +1138,27 @@
 
     assert(isTypeLegal(Node->getOperand(2).getValueType()) &&
            "Register type must be legal!");
-    // Legalize the incoming value (must be legal).
+    // Legalize the incoming value (must be a legal type).
     Tmp2 = LegalizeOp(Node->getOperand(2));
-    if (Tmp1 != Node->getOperand(0) || Tmp2 != Node->getOperand(2))
-      Result = DAG.getNode(ISD::CopyToReg, MVT::Other, Tmp1,
-                           Node->getOperand(1), Tmp2);
+    if (Node->getNumOperands() == 3) {
+      if (Tmp1 != Node->getOperand(0) || Tmp2 != Node->getOperand(2))
+        Result = DAG.getNode(ISD::CopyToReg, MVT::Other, Tmp1,
+                             Node->getOperand(1), Tmp2);
+    } else {
+      assert(Node->getNumOperands() == 4 && "Unknown CopyToReg");
+      Tmp3 = LegalizeOp(Node->getOperand(3));
+      if (Tmp1 != Node->getOperand(0) || Tmp2 != Node->getOperand(2) ||
+          Tmp3 != Node->getOperand(3)) {
+        unsigned Reg = cast<RegisterSDNode>(Node->getOperand(1))->getReg();
+        Result = DAG.getCopyToReg(Tmp1, Reg, Tmp2, Tmp3);
+      }
+      
+      // Since this produces two values, make sure to remember that we legalized
+      // both of them.
+      AddLegalizedOperand(SDOperand(Node, 0), Result);
+      AddLegalizedOperand(SDOperand(Node, 1), Result.getValue(1));
+      return Result.getValue(Op.ResNo);
+    }
     break;
 
   case ISD::RET:
@@ -1278,7 +1302,6 @@
     AddLegalizedOperand(SDOperand(Node, 0), Result);
     AddLegalizedOperand(SDOperand(Node, 1), Result.getValue(1));
     return Result.getValue(Op.ResNo);
-    break;
 
   case ISD::TRUNCSTORE:
     Tmp1 = LegalizeOp(Node->getOperand(0));  // Legalize the chain.






More information about the llvm-commits mailing list