From cde0f5cfe7b7e0a73708c0db29dcfc0d00294e98 Mon Sep 17 00:00:00 2001 From: Andrew Lenharth Date: Fri, 2 Dec 2005 06:08:08 +0000 Subject: [PATCH] bah, must generate all results git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@24574 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp index feaf890e950..c02fc9ac69e 100644 --- a/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp +++ b/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp @@ -1191,8 +1191,14 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) { break; case ISD::READCYCLECOUNTER: Tmp1 = LegalizeOp(Node->getOperand(0)); // Legalize the chain - if (Tmp1 != Node->getOperand(0)) - Result = DAG.getNode(ISD::READCYCLECOUNTER, MVT::i64, Tmp1); + if (Tmp1 != Node->getOperand(0)) { + std::vector rtypes; + std::vector rvals; + rtypes.push_back(MVT::i64); + rtypes.push_back(MVT::Other); + rvals.push_back(Tmp1); + Result = DAG.getNode(ISD::READCYCLECOUNTER, rtypes, rvals); + } // Since rdcc produce two values, make sure to remember that we legalized // both of them.