diff options
| author | Chris Lattner <sabre@nondot.org> | 2005-07-30 00:04:12 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2005-07-30 00:04:12 +0000 |
| commit | f59b2daddb7fb9364c24161a422ded9ecd4fc6ec (patch) | |
| tree | 037a56b4595acab006276a293a4c3cd1c0b45a07 /llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | |
| parent | 0940218ccaba85b05825bacd4a1b187c3595be3e (diff) | |
| download | bcm5719-llvm-f59b2daddb7fb9364c24161a422ded9ecd4fc6ec.tar.gz bcm5719-llvm-f59b2daddb7fb9364c24161a422ded9ecd4fc6ec.zip | |
Allow targets to have custom expanders for FP_TO_*INT conversions where
both the src and dest values are legal
llvm-svn: 22555
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | 12 |
1 files changed, 9 insertions, 3 deletions
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; |

