summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2008-04-09 17:17:35 +0000
committerChris Lattner <sabre@nondot.org>2008-04-09 17:17:35 +0000
commitcca74e5ab9e0543be0031795bdfb93e1c83b6810 (patch)
treee8b8e00e689a259958a73ba4329bfa85f46d121b /llvm
parent0704e3acffc59cc583befffa71da029787296010 (diff)
downloadbcm5719-llvm-cca74e5ab9e0543be0031795bdfb93e1c83b6810.tar.gz
bcm5719-llvm-cca74e5ab9e0543be0031795bdfb93e1c83b6810.zip
use the new ConstantFP::get method to make this work with
long double and simplify the code. llvm-svn: 49435
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp15
1 files changed, 4 insertions, 11 deletions
diff --git a/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp b/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp
index 24c56abde97..ce536a8a530 100644
--- a/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp
+++ b/llvm/lib/Transforms/IPO/SimplifyLibCalls.cpp
@@ -1149,10 +1149,6 @@ public:
/// @brief Perform the pow optimization.
virtual bool OptimizeCall(CallInst *CI, SimplifyLibCalls &SLC) {
- const Type *Ty = CI->getType();
- if (Ty != Type::FloatTy && Ty != Type::DoubleTy)
- return false; // FIXME long double not yet supported
-
Value *Op1 = CI->getOperand(1);
Value *Op2 = CI->getOperand(2);
if (ConstantFP *Op1C = dyn_cast<ConstantFP>(Op1)) {
@@ -1165,8 +1161,7 @@ public:
if (Op2C->getValueAPF().isZero()) {
// pow(x, 0.0) -> 1.0
- return ReplaceCallWith(CI, ConstantFP::get(Ty,
- Ty==Type::FloatTy ? APFloat(1.0f) : APFloat(1.0)));
+ return ReplaceCallWith(CI, ConstantFP::get(CI->getType(), 1.0));
} else if (Op2C->isExactlyValue(0.5)) {
// pow(x, 0.5) -> sqrt(x)
Value *Sqrt = CallInst::Create(SLC.get_sqrt(), Op1, "sqrt", CI);
@@ -1180,11 +1175,9 @@ public:
return ReplaceCallWith(CI, Sq);
} else if (Op2C->isExactlyValue(-1.0)) {
// pow(x, -1.0) -> 1.0/x
- Value *div_inst =
- BinaryOperator::createFDiv(ConstantFP::get(Ty,
- Ty==Type::FloatTy ? APFloat(1.0f) : APFloat(1.0)),
- Op1, CI->getName()+".pow", CI);
- return ReplaceCallWith(CI, div_inst);
+ Value *R = BinaryOperator::createFDiv(ConstantFP::get(CI->getType(), 1.0),
+ Op1, CI->getName()+".pow", CI);
+ return ReplaceCallWith(CI, R);
}
return false; // opt failed
}
OpenPOWER on IntegriCloud