From f59b2daddb7fb9364c24161a422ded9ecd4fc6ec Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 30 Jul 2005 00:04:12 +0000 Subject: Allow targets to have custom expanders for FP_TO_*INT conversions where both the src and dest values are legal llvm-svn: 22555 --- llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) (limited to 'llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp') diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp index 8508030b820..53e9b5cb63c 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp @@ -1570,21 +1570,27 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) { case ISD::FP_TO_UINT: switch (getTypeAction(Node->getOperand(0).getValueType())) { case Legal: + Tmp1 = LegalizeOp(Node->getOperand(0)); + switch (TLI.getOperationAction(Node->getOpcode(), Node->getValueType(0))){ default: assert(0 && "Unknown operation action!"); case TargetLowering::Expand: assert(0 && "Cannot expand FP_TO*INT yet"); case TargetLowering::Promote: - Result = PromoteLegalFP_TO_INT(LegalizeOp(Node->getOperand(0)), - Node->getValueType(0), + Result = PromoteLegalFP_TO_INT(Tmp1, Node->getValueType(0), Node->getOpcode() == ISD::FP_TO_SINT); AddLegalizedOperand(Op, Result); return Result; case TargetLowering::Legal: break; + case TargetLowering::Custom: + Result = DAG.getNode(Node->getOpcode(), Node->getValueType(0), Tmp1); + Result = TLI.LowerOperation(Result, DAG); + AddLegalizedOperand(Op, Result); + NeedsAnotherIteration = true; + return Result; } - Tmp1 = LegalizeOp(Node->getOperand(0)); if (Tmp1 != Node->getOperand(0)) Result = DAG.getNode(Node->getOpcode(), Node->getValueType(0), Tmp1); break; -- cgit v1.2.3