summaryrefslogtreecommitdiffstats
path: root/lib/Analysis/ConstantFolding.cpp
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2007-07-16 15:26:22 +0000
committerDan Gohman <gohman@apple.com>2007-07-16 15:26:22 +0000
commit384152444d22d356f7b4090a158da4cbc1f79464 (patch)
tree34177034eb827fd34fddfd428e6577d804858937 /lib/Analysis/ConstantFolding.cpp
parentd6257fe581585f5061d1c672d2110c0cd26aa257 (diff)
downloadexternal_llvm-384152444d22d356f7b4090a158da4cbc1f79464.zip
external_llvm-384152444d22d356f7b4090a158da4cbc1f79464.tar.gz
external_llvm-384152444d22d356f7b4090a158da4cbc1f79464.tar.bz2
Use ConstantFoldFP for folding all unary floating-point operations which may
have an error, and refector out the code for binary operators into ConstantFoldBinaryFP and use it for all binary floating-point operations which may have an error. These functions still rely exclusively on errno to detect errors though. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@39923 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/ConstantFolding.cpp')
-rw-r--r--lib/Analysis/ConstantFolding.cpp45
1 files changed, 25 insertions, 20 deletions
diff --git a/lib/Analysis/ConstantFolding.cpp b/lib/Analysis/ConstantFolding.cpp
index 8991c24..e85d150 100644
--- a/lib/Analysis/ConstantFolding.cpp
+++ b/lib/Analysis/ConstantFolding.cpp
@@ -363,6 +363,17 @@ static Constant *ConstantFoldFP(double (*NativeFP)(double), double V,
return 0;
}
+static Constant *ConstantFoldBinaryFP(double (*NativeFP)(double, double),
+ double V, double W,
+ const Type *Ty) {
+ errno = 0;
+ V = NativeFP(V, W);
+ if (errno == 0)
+ return ConstantFP::get(Ty, V);
+ errno = 0;
+ return 0;
+}
+
/// ConstantFoldCall - Attempt to constant fold a call to the specified function
/// with the specified arguments, returning null if unsuccessful.
Constant *
@@ -381,19 +392,19 @@ llvm::ConstantFoldCall(Function *F, Constant** Operands, unsigned NumOperands) {
else if (Name == "asin")
return ConstantFoldFP(asin, V, Ty);
else if (Name == "atan")
- return ConstantFP::get(Ty, atan(V));
+ return ConstantFoldFP(atan, V, Ty);
break;
case 'c':
if (Name == "ceil")
return ConstantFoldFP(ceil, V, Ty);
else if (Name == "cos")
- return ConstantFP::get(Ty, cos(V));
+ return ConstantFoldFP(cos, V, Ty);
else if (Name == "cosh")
- return ConstantFP::get(Ty, cosh(V));
+ return ConstantFoldFP(cosh, V, Ty);
break;
case 'e':
if (Name == "exp")
- return ConstantFP::get(Ty, exp(V));
+ return ConstantFoldFP(exp, V, Ty);
break;
case 'f':
if (Name == "fabs")
@@ -403,7 +414,7 @@ llvm::ConstantFoldCall(Function *F, Constant** Operands, unsigned NumOperands) {
break;
case 'l':
if (Name == "log" && V > 0)
- return ConstantFP::get(Ty, log(V));
+ return ConstantFoldFP(log, V, Ty);
else if (Name == "log10" && V > 0)
return ConstantFoldFP(log10, V, Ty);
else if (Name == "llvm.sqrt.f32" || Name == "llvm.sqrt.f64") {
@@ -415,19 +426,19 @@ llvm::ConstantFoldCall(Function *F, Constant** Operands, unsigned NumOperands) {
break;
case 's':
if (Name == "sin")
- return ConstantFP::get(Ty, sin(V));
+ return ConstantFoldFP(sin, V, Ty);
else if (Name == "sinh")
- return ConstantFP::get(Ty, sinh(V));
+ return ConstantFoldFP(sinh, V, Ty);
else if (Name == "sqrt" && V >= 0)
- return ConstantFP::get(Ty, sqrt(V));
+ return ConstantFoldFP(sqrt, V, Ty);
else if (Name == "sqrtf" && V >= 0)
- return ConstantFP::get(Ty, sqrt((float)V));
+ return ConstantFoldFP(sqrt, V, Ty);
break;
case 't':
if (Name == "tan")
- return ConstantFP::get(Ty, tan(V));
+ return ConstantFoldFP(tan, V, Ty);
else if (Name == "tanh")
- return ConstantFP::get(Ty, tanh(V));
+ return ConstantFoldFP(tanh, V, Ty);
break;
default:
break;
@@ -453,17 +464,11 @@ llvm::ConstantFoldCall(Function *F, Constant** Operands, unsigned NumOperands) {
double Op2V = Op2->getValue();
if (Name == "pow") {
- errno = 0;
- double V = pow(Op1V, Op2V);
- if (errno == 0)
- return ConstantFP::get(Ty, V);
+ return ConstantFoldBinaryFP(pow, Op1V, Op2V, Ty);
} else if (Name == "fmod") {
- errno = 0;
- double V = fmod(Op1V, Op2V);
- if (errno == 0)
- return ConstantFP::get(Ty, V);
+ return ConstantFoldBinaryFP(fmod, Op1V, Op2V, Ty);
} else if (Name == "atan2") {
- return ConstantFP::get(Ty, atan2(Op1V,Op2V));
+ return ConstantFoldBinaryFP(atan2, Op1V, Op2V, Ty);
}
} else if (ConstantInt *Op2C = dyn_cast<ConstantInt>(Operands[1])) {
if (Name == "llvm.powi.f32") {