diff options
| author | Chris Lattner <sabre@nondot.org> | 2008-04-09 17:17:35 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2008-04-09 17:17:35 +0000 |
| commit | cca74e5ab9e0543be0031795bdfb93e1c83b6810 (patch) | |
| tree | e8b8e00e689a259958a73ba4329bfa85f46d121b /llvm | |
| parent | 0704e3acffc59cc583befffa71da029787296010 (diff) | |
| download | bcm5719-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.cpp | 15 |
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 } |

