Alpha doesn't have a native f32 extload instruction.
authorChris Lattner <sabre@nondot.org>
Fri, 28 Jan 2005 22:58:25 +0000 (22:58 +0000)
committerChris Lattner <sabre@nondot.org>
Fri, 28 Jan 2005 22:58:25 +0000 (22:58 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@19880 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/LegalizeDAG.cpp

index e435bd609de8dd41321ac46f613132781e8720fa..56ed08e680f4377c9fa55c4af326ce0f065b1073 100644 (file)
@@ -256,7 +256,11 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
       bool isDouble = VT == MVT::f64;
       ConstantFP *LLVMC = ConstantFP::get(isDouble ? Type::DoubleTy :
                                              Type::FloatTy, CFP->getValue());
-      if (isDouble && CFP->isExactlyValue((float)CFP->getValue())) {
+      if (isDouble && CFP->isExactlyValue((float)CFP->getValue()) &&
+          // Only do this if the target has a native EXTLOAD instruction from
+          // f32.
+          TLI.getOperationAction(ISD::EXTLOAD,
+                                 MVT::f32) == TargetLowering::Legal) {
         LLVMC = cast<ConstantFP>(ConstantExpr::getCast(LLVMC, Type::FloatTy));
         VT = MVT::f32;
         Extend = true;