diff options
author | Chris Lattner <sabre@nondot.org> | 2005-12-18 15:36:21 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2005-12-18 15:36:21 +0000 |
commit | ebcfa0c210205b8a413818b8de282caf6cf21aa2 (patch) | |
tree | b663f334bcc97c461e956b852004aac31c58def1 /llvm/lib/CodeGen | |
parent | fc3d4f8fd8b2c782102594da59e2d2f10e9aa9b5 (diff) | |
download | bcm5719-llvm-ebcfa0c210205b8a413818b8de282caf6cf21aa2.tar.gz bcm5719-llvm-ebcfa0c210205b8a413818b8de282caf6cf21aa2.zip |
More corrections for flagged copyto/from reg
llvm-svn: 24828
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | 19 |
1 files changed, 11 insertions, 8 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp index 7b13db8258b..0521270b071 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp +++ b/llvm/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<RegisterSDNode>(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<RegisterSDNode>(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<RegisterSDNode>(Node->getOperand(1))->getReg(); Result = DAG.getCopyToReg(Tmp1, Reg, Tmp2, Tmp3); } |