From f1a47c3371ecd5bb449f39736a36ebbebd4e9e14 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sun, 18 Dec 2005 15:36:21 +0000 Subject: [PATCH] More corrections for flagged copyto/from reg git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@24828 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp index 7b13db8258b..0521270b071 100644 --- a/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp +++ b/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp @@ -568,15 +568,17 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) { case ISD::CopyFromReg: Tmp1 = LegalizeOp(Node->getOperand(0)); Result = Op.getValue(0); - if (Node->getNumOperands() == 2) { + if (Node->getNumValues() == 2) { if (Tmp1 != Node->getOperand(0)) Result = DAG.getCopyFromReg(Tmp1, cast(Node->getOperand(1))->getReg(), Node->getValueType(0)); } else { - assert(Node->getNumOperands() == 3 && "Invalid copyfromreg!"); - Tmp2 = LegalizeOp(Node->getOperand(2)); - if (Tmp1 != Node->getOperand(0) || Tmp2 != Node->getOperand(2)) + assert(Node->getNumValues() == 3 && "Invalid copyfromreg!"); + if (Node->getNumOperands() == 3) + Tmp2 = LegalizeOp(Node->getOperand(2)); + if (Tmp1 != Node->getOperand(0) || + (Node->getNumOperands() == 3 && Tmp2 != Node->getOperand(2))) Result = DAG.getCopyFromReg(Tmp1, cast(Node->getOperand(1))->getReg(), Node->getValueType(0), Tmp2); @@ -1140,15 +1142,16 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) { "Register type must be legal!"); // Legalize the incoming value (must be a legal type). Tmp2 = LegalizeOp(Node->getOperand(2)); - if (Node->getNumOperands() == 3) { + if (Node->getNumValues() == 1) { 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)); + assert(Node->getNumValues() == 2 && "Unknown CopyToReg"); + if (Node->getNumOperands() == 4) + Tmp3 = LegalizeOp(Node->getOperand(3)); if (Tmp1 != Node->getOperand(0) || Tmp2 != Node->getOperand(2) || - Tmp3 != Node->getOperand(3)) { + (Node->getNumOperands() == 4 && Tmp3 != Node->getOperand(3))) { unsigned Reg = cast(Node->getOperand(1))->getReg(); Result = DAG.getCopyToReg(Tmp1, Reg, Tmp2, Tmp3); }