From d5f94c9574c73e8b9c450f95f9db5b85d8461a29 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Mon, 27 Mar 2006 20:28:29 +0000 Subject: [PATCH] Fix legalization of intrinsics with chain and result values llvm-svn: 27181 --- llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp index 81139dcde178..b0a48eef6d76 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp @@ -564,8 +564,19 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) { TargetLowering::Custom) { Tmp3 = TLI.LowerOperation(Result, DAG); if (Tmp3.Val) Result = Tmp3; - } - break; + } + + if (Result.Val->getNumValues() == 1) break; + + // Must have return value and chain result. + assert(Result.Val->getNumValues() == 2 && + "Cannot return more than two values!"); + + // Since loads produce two values, make sure to remember that we + // legalized both of them. + AddLegalizedOperand(SDOperand(Node, 0), Result.getValue(0)); + AddLegalizedOperand(SDOperand(Node, 1), Result.getValue(1)); + return Result.getValue(Op.ResNo); } case ISD::LOCATION: