Matt Arsenault
6a288c1e32
Replace hardcoded intrinsic list with speculatable attribute.
...
No change in which intrinsics should be speculated.
llvm-svn: 301995
2017-05-03 02:26:10 +00:00
Davide Italiano
472684eaf5
[SimplifyLibCalls] pow(x, -0.5) -> 1.0 / sqrt(x).
...
Differential Revision: https://reviews.llvm.org/D28479
llvm-svn: 291486
2017-01-09 21:55:23 +00:00
Davide Italiano
873219c406
[SimplifyLibCalls] Restore the old behaviour, emit a libcall.
...
Hal pointed out that the semantic of our intrinsic and the libc
call are slightly different. Add a comment while I'm here to
explain why we can't emit an intrinsic. Thanks Hal!
llvm-svn: 278200
2016-08-10 06:33:32 +00:00
Davide Italiano
e3b916d164
[SimplifyLibCalls] Emit sqrt intrinsic instead of a libcall.
...
llvm-svn: 277972
2016-08-08 03:23:01 +00:00
Sanjay Patel
53ba88dbb0
[LibCallSimplifier] use instruction-level fast-math-flags to transform pow(x, 0.5) calls
...
Also, propagate the FMF to the newly created sqrt() call.
llvm-svn: 257503
2016-01-12 19:06:35 +00:00
Davide Italiano
c5cedd195a
[SimplifyLibCalls] New trick: pow(x, 0.5) -> sqrt(x) under -ffast-math.
...
Differential Revision: http://reviews.llvm.org/D14466
llvm-svn: 253521
2015-11-18 23:21:32 +00:00