summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-04-02 05:26:37 +0000
committerChris Lattner <sabre@nondot.org>2005-04-02 05:26:37 +0000
commita0c72cf289de29e7f4c9994e148f9e1c56b804b8 (patch)
treef3e4878a598120ce9ff1e2773b40d92d4a5fc64c
parent0720dc14ed4b6d1af94acfae39dae4aac1b8e877 (diff)
downloadbcm5719-llvm-a0c72cf289de29e7f4c9994e148f9e1c56b804b8.tar.gz
bcm5719-llvm-a0c72cf289de29e7f4c9994e148f9e1c56b804b8.zip
Expand fabs into fneg
llvm-svn: 21013
-rw-r--r--llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp10
1 files changed, 9 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
index 2615a505862..731ea553222 100644
--- a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
@@ -887,8 +887,16 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
Tmp2 = DAG.getConstantFP(-0.0, Node->getValueType(0));
Result = LegalizeOp(DAG.getNode(ISD::SUB, Node->getValueType(0),
Tmp2, Tmp1));
+ } else if (Node->getOpcode() == ISD::FABS) {
+ // Expand Y = FABS(X) -> Y = (X >u 0.0) ? X : fneg(X).
+ MVT::ValueType VT = Node->getValueType(0);
+ Tmp2 = DAG.getConstantFP(0.0, VT);
+ Tmp2 = DAG.getSetCC(ISD::SETUGT, TLI.getSetCCResultTy(), Tmp1, Tmp2);
+ Tmp3 = DAG.getNode(ISD::FNEG, VT, Tmp1);
+ Result = DAG.getNode(ISD::SELECT, VT, Tmp2, Tmp1, Tmp3);
+ Result = LegalizeOp(Result);
} else {
- assert(0 && "Expand fneg not impl yet!");
+ assert(0 && "Unreachable!");
}
break;
}
OpenPOWER on IntegriCloud