diff options
| author | Dale Johannesen <dalej@apple.com> | 2007-09-28 18:06:58 +0000 |
|---|---|---|
| committer | Dale Johannesen <dalej@apple.com> | 2007-09-28 18:06:58 +0000 |
| commit | 6bf69ed3cc94cca3ad0da1beb5c334ac278613fd (patch) | |
| tree | 5d87552b86f5cbf0c68836517aa7f4a7223ecf3d /llvm/lib | |
| parent | 483e305210d0a57d329831206475709f4f12b699 (diff) | |
| download | bcm5719-llvm-6bf69ed3cc94cca3ad0da1beb5c334ac278613fd.tar.gz bcm5719-llvm-6bf69ed3cc94cca3ad0da1beb5c334ac278613fd.zip | |
minor long double related changes
llvm-svn: 42439
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter.cpp | 1 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/IntrinsicLowering.cpp | 18 | ||||
| -rw-r--r-- | llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp | 6 |
3 files changed, 21 insertions, 4 deletions
diff --git a/llvm/lib/CodeGen/AsmPrinter.cpp b/llvm/lib/CodeGen/AsmPrinter.cpp index 88d21af0541..488185d9bb6 100644 --- a/llvm/lib/CodeGen/AsmPrinter.cpp +++ b/llvm/lib/CodeGen/AsmPrinter.cpp @@ -1271,6 +1271,7 @@ void AsmPrinter::printDataDirective(const Type *type) { } break; case Type::FloatTyID: case Type::DoubleTyID: + case Type::X86_FP80TyID: case Type::FP128TyID: case Type::PPC_FP128TyID: assert (0 && "Should have already output floating point constant."); default: assert (0 && "Can't handle printing this type of thing"); diff --git a/llvm/lib/CodeGen/IntrinsicLowering.cpp b/llvm/lib/CodeGen/IntrinsicLowering.cpp index 42b09c2d3ae..0a2f0d6a517 100644 --- a/llvm/lib/CodeGen/IntrinsicLowering.cpp +++ b/llvm/lib/CodeGen/IntrinsicLowering.cpp @@ -794,6 +794,24 @@ void IntrinsicLowering::LowerIntrinsicCall(CallInst *CI) { Type::DoubleTy, sqrtFCache); break; } + case Intrinsic::sqrt_f80: { + static Constant *sqrtF80Cache = 0; + ReplaceCallWith("sqrtl", CI, CI->op_begin()+1, CI->op_end(), + Type::X86_FP80Ty, sqrtF80Cache); + break; + } + case Intrinsic::sqrt_f128: { + static Constant *sqrtF128Cache = 0; + ReplaceCallWith("sqrtl", CI, CI->op_begin()+1, CI->op_end(), + Type::FP128Ty, sqrtF128Cache); + break; + } + case Intrinsic::sqrt_ppcf128: { + static Constant *sqrtppcF128Cache = 0; + ReplaceCallWith("sqrtl", CI, CI->op_begin()+1, CI->op_end(), + Type::PPC_FP128Ty, sqrtppcF128Cache); + break; + } } assert(CI->use_empty() && diff --git a/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp b/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp index 01d3c9ff2ec..717a5a847f8 100644 --- a/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp +++ b/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp @@ -1115,17 +1115,15 @@ public: /// @brief Perform the pow optimization. virtual bool OptimizeCall(CallInst *ci, SimplifyLibCalls &SLC) { const Type *Ty = cast<Function>(ci->getOperand(0))->getReturnType(); + if (Ty!=Type::FloatTy && Ty!=Type::DoubleTy) + return false; // FIXME long double not yet supported Value* base = ci->getOperand(1); Value* expn = ci->getOperand(2); if (ConstantFP *Op1 = dyn_cast<ConstantFP>(base)) { - if (Ty!=Type::FloatTy && Ty!=Type::DoubleTy) - return false; // FIXME long double not yet supported if (Op1->isExactlyValue(1.0)) // pow(1.0,x) -> 1.0 return ReplaceCallWith(ci, ConstantFP::get(Ty, Ty==Type::FloatTy ? APFloat(1.0f) : APFloat(1.0))); } else if (ConstantFP* Op2 = dyn_cast<ConstantFP>(expn)) { - if (Ty!=Type::FloatTy && Ty!=Type::DoubleTy) - return false; // FIXME long double not yet supported if (Op2->getValueAPF().isZero()) { // pow(x,0.0) -> 1.0 return ReplaceCallWith(ci, ConstantFP::get(Ty, |

