2009-09-09 08:09:15 +08:00
|
|
|
; RUN: llc < %s
|
2016-11-08 00:47:20 +08:00
|
|
|
; RUN: llc -O0 < %s
|
2005-04-30 12:07:15 +08:00
|
|
|
|
2005-04-30 12:41:27 +08:00
|
|
|
;; SQRT
|
2008-02-19 09:41:04 +08:00
|
|
|
declare float @llvm.sqrt.f32(float)
|
|
|
|
|
|
|
|
declare double @llvm.sqrt.f64(double)
|
|
|
|
|
|
|
|
define double @test_sqrt(float %F) {
|
|
|
|
%G = call float @llvm.sqrt.f32( float %F ) ; <float> [#uses=1]
|
|
|
|
%H = fpext float %G to double ; <double> [#uses=1]
|
|
|
|
%I = call double @llvm.sqrt.f64( double %H ) ; <double> [#uses=1]
|
|
|
|
ret double %I
|
2005-04-30 12:07:15 +08:00
|
|
|
}
|
2005-04-30 12:41:27 +08:00
|
|
|
|
2008-02-19 09:41:04 +08:00
|
|
|
|
2005-04-30 12:41:27 +08:00
|
|
|
; SIN
|
2009-11-03 10:19:31 +08:00
|
|
|
declare float @sinf(float) readonly
|
2008-02-19 09:41:04 +08:00
|
|
|
|
2009-11-03 10:19:31 +08:00
|
|
|
declare double @sin(double) readonly
|
2008-02-19 09:41:04 +08:00
|
|
|
|
|
|
|
define double @test_sin(float %F) {
|
|
|
|
%G = call float @sinf( float %F ) ; <float> [#uses=1]
|
|
|
|
%H = fpext float %G to double ; <double> [#uses=1]
|
|
|
|
%I = call double @sin( double %H ) ; <double> [#uses=1]
|
|
|
|
ret double %I
|
2005-04-30 12:41:27 +08:00
|
|
|
}
|
|
|
|
|
2008-02-19 09:41:04 +08:00
|
|
|
|
2005-04-30 12:41:27 +08:00
|
|
|
; COS
|
2009-11-03 10:19:31 +08:00
|
|
|
declare float @cosf(float) readonly
|
2008-02-19 09:41:04 +08:00
|
|
|
|
2009-11-03 10:19:31 +08:00
|
|
|
declare double @cos(double) readonly
|
2008-02-19 09:41:04 +08:00
|
|
|
|
|
|
|
define double @test_cos(float %F) {
|
|
|
|
%G = call float @cosf( float %F ) ; <float> [#uses=1]
|
|
|
|
%H = fpext float %G to double ; <double> [#uses=1]
|
|
|
|
%I = call double @cos( double %H ) ; <double> [#uses=1]
|
|
|
|
ret double %I
|
2005-04-30 12:41:27 +08:00
|
|
|
}
|
2008-02-19 09:41:04 +08:00
|
|
|
|
2018-05-03 19:03:01 +08:00
|
|
|
declare i8* @llvm.launder.invariant.group(i8*)
|
2016-11-08 00:47:20 +08:00
|
|
|
|
Implement strip.invariant.group
Summary:
This patch introduce new intrinsic -
strip.invariant.group that was described in the
RFC: Devirtualization v2
Reviewers: rsmith, hfinkel, nlopes, sanjoy, amharc, kuhar
Subscribers: arsenm, nhaehnle, JDevlieghere, hiraditya, xbolva00, llvm-commits
Differential Revision: https://reviews.llvm.org/D47103
Co-authored-by: Krzysztof Pszeniczny <krzysztof.pszeniczny@gmail.com>
llvm-svn: 336073
2018-07-02 12:49:30 +08:00
|
|
|
define i8* @launder(i8* %p) {
|
2018-05-03 19:03:01 +08:00
|
|
|
%q = call i8* @llvm.launder.invariant.group(i8* %p)
|
2016-11-08 00:47:20 +08:00
|
|
|
ret i8* %q
|
|
|
|
}
|
Add an @llvm.sideeffect intrinsic
This patch implements Chandler's idea [0] for supporting languages that
require support for infinite loops with side effects, such as Rust, providing
part of a solution to bug 965 [1].
Specifically, it adds an `llvm.sideeffect()` intrinsic, which has no actual
effect, but which appears to optimization passes to have obscure side effects,
such that they don't optimize away loops containing it. It also teaches
several optimization passes to ignore this intrinsic, so that it doesn't
significantly impact optimization in most cases.
As discussed on llvm-dev [2], this patch is the first of two major parts.
The second part, to change LLVM's semantics to have defined behavior
on infinite loops by default, with a function attribute for opting into
potential-undefined-behavior, will be implemented and posted for review in
a separate patch.
[0] http://lists.llvm.org/pipermail/llvm-dev/2015-July/088103.html
[1] https://bugs.llvm.org/show_bug.cgi?id=965
[2] http://lists.llvm.org/pipermail/llvm-dev/2017-October/118632.html
Differential Revision: https://reviews.llvm.org/D38336
llvm-svn: 317729
2017-11-09 05:59:51 +08:00
|
|
|
|
Implement strip.invariant.group
Summary:
This patch introduce new intrinsic -
strip.invariant.group that was described in the
RFC: Devirtualization v2
Reviewers: rsmith, hfinkel, nlopes, sanjoy, amharc, kuhar
Subscribers: arsenm, nhaehnle, JDevlieghere, hiraditya, xbolva00, llvm-commits
Differential Revision: https://reviews.llvm.org/D47103
Co-authored-by: Krzysztof Pszeniczny <krzysztof.pszeniczny@gmail.com>
llvm-svn: 336073
2018-07-02 12:49:30 +08:00
|
|
|
declare i8* @llvm.strip.invariant.group(i8*)
|
|
|
|
|
|
|
|
define i8* @strip(i8* %p) {
|
|
|
|
%q = call i8* @llvm.strip.invariant.group(i8* %p)
|
|
|
|
ret i8* %q
|
|
|
|
}
|
|
|
|
|
|
|
|
|
Add an @llvm.sideeffect intrinsic
This patch implements Chandler's idea [0] for supporting languages that
require support for infinite loops with side effects, such as Rust, providing
part of a solution to bug 965 [1].
Specifically, it adds an `llvm.sideeffect()` intrinsic, which has no actual
effect, but which appears to optimization passes to have obscure side effects,
such that they don't optimize away loops containing it. It also teaches
several optimization passes to ignore this intrinsic, so that it doesn't
significantly impact optimization in most cases.
As discussed on llvm-dev [2], this patch is the first of two major parts.
The second part, to change LLVM's semantics to have defined behavior
on infinite loops by default, with a function attribute for opting into
potential-undefined-behavior, will be implemented and posted for review in
a separate patch.
[0] http://lists.llvm.org/pipermail/llvm-dev/2015-July/088103.html
[1] https://bugs.llvm.org/show_bug.cgi?id=965
[2] http://lists.llvm.org/pipermail/llvm-dev/2017-October/118632.html
Differential Revision: https://reviews.llvm.org/D38336
llvm-svn: 317729
2017-11-09 05:59:51 +08:00
|
|
|
; sideeffect
|
|
|
|
|
|
|
|
declare void @llvm.sideeffect()
|
|
|
|
|
|
|
|
define void @test_sideeffect() {
|
|
|
|
call void @llvm.sideeffect()
|
|
|
|
ret void
|
|
|
|
}
|