diff options
author | Dan Gohman <gohman@apple.com> | 2009-09-26 18:10:13 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2009-09-26 18:10:13 +0000 |
commit | 62995c71a218434e216cd7f0b8a2a54ceaf63c67 (patch) | |
tree | 265aed62c984d5bb5e186e3ba1a8922ebe521bf2 /llvm/lib | |
parent | 2f5198b022edbb2a23922887c99c9bdfd5b04245 (diff) | |
download | bcm5719-llvm-62995c71a218434e216cd7f0b8a2a54ceaf63c67.tar.gz bcm5719-llvm-62995c71a218434e216cd7f0b8a2a54ceaf63c67.zip |
Fix SimplifyLibCalls to transfer attributes from callees rather than
calls, since direct calls don't always reflect the attributes of their
callees.
llvm-svn: 82867
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Transforms/Scalar/SimplifyLibCalls.cpp | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/llvm/lib/Transforms/Scalar/SimplifyLibCalls.cpp b/llvm/lib/Transforms/Scalar/SimplifyLibCalls.cpp index bb4d5e250b5..57a7d051e9f 100644 --- a/llvm/lib/Transforms/Scalar/SimplifyLibCalls.cpp +++ b/llvm/lib/Transforms/Scalar/SimplifyLibCalls.cpp @@ -1019,7 +1019,7 @@ struct PowOpt : public LibCallOptimization { if (Op1C->isExactlyValue(1.0)) // pow(1.0, x) -> 1.0 return Op1C; if (Op1C->isExactlyValue(2.0)) // pow(2.0, x) -> exp2(x) - return EmitUnaryFloatFnCall(Op2, "exp2", B, CI->getAttributes()); + return EmitUnaryFloatFnCall(Op2, "exp2", B, Callee->getAttributes()); } ConstantFP *Op2C = dyn_cast<ConstantFP>(Op2); @@ -1036,8 +1036,10 @@ struct PowOpt : public LibCallOptimization { // TODO: In finite-only mode, this could be just fabs(sqrt(x)). Value *Inf = ConstantFP::getInfinity(CI->getType()); Value *NegInf = ConstantFP::getInfinity(CI->getType(), true); - Value *Sqrt = EmitUnaryFloatFnCall(Op1, "sqrt", B, CI->getAttributes()); - Value *FAbs = EmitUnaryFloatFnCall(Sqrt, "fabs", B, CI->getAttributes()); + Value *Sqrt = EmitUnaryFloatFnCall(Op1, "sqrt", B, + Callee->getAttributes()); + Value *FAbs = EmitUnaryFloatFnCall(Sqrt, "fabs", B, + Callee->getAttributes()); Value *FCmp = B.CreateFCmpOEQ(Op1, NegInf, "tmp"); Value *Sel = B.CreateSelect(FCmp, Inf, FAbs, "tmp"); return Sel; @@ -1121,7 +1123,8 @@ struct UnaryDoubleFPOpt : public LibCallOptimization { // floor((double)floatval) -> (double)floorf(floatval) Value *V = Cast->getOperand(0); - V = EmitUnaryFloatFnCall(V, Callee->getName().data(), B, CI->getAttributes()); + V = EmitUnaryFloatFnCall(V, Callee->getName().data(), B, + Callee->getAttributes()); return B.CreateFPExt(V, Type::getDoubleTy(*Context)); } }; |