From 5d2c6c784bdc3d572a553ed7aa48dcf27a45b1a3 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 8 Jan 2005 06:25:56 +0000 Subject: [PATCH] Implement the 'store FPIMM, Ptr' -> 'store INTIMM, Ptr' optimization for all targets. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@19366 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | 25 ++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp index 996f116f8dd..4d6d0ebacae 100644 --- a/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp +++ b/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp @@ -424,6 +424,31 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) { Tmp1 = LegalizeOp(Node->getOperand(0)); // Legalize the chain. Tmp2 = LegalizeOp(Node->getOperand(2)); // Legalize the pointer. + // Turn 'store float 1.0, Ptr' -> 'store int 0x12345678, Ptr' + if (ConstantFPSDNode *CFP = + dyn_cast(Node->getOperand(1))) { + if (CFP->getValueType(0) == MVT::f32) { + union { + unsigned I; + float F; + } V; + V.F = CFP->getValue(); + Result = DAG.getNode(ISD::STORE, MVT::Other, Tmp1, + DAG.getConstant(V.I, MVT::i32), Tmp2); + } else { + assert(CFP->getValueType(0) == MVT::f64 && "Unknown FP type!"); + union { + uint64_t I; + double F; + } V; + V.F = CFP->getValue(); + Result = DAG.getNode(ISD::STORE, MVT::Other, Tmp1, + DAG.getConstant(V.I, MVT::i64), Tmp2); + } + Op = Result; + Node = Op.Val; + } + switch (getTypeAction(Node->getOperand(1).getValueType())) { case Legal: { SDOperand Val = LegalizeOp(Node->getOperand(1));