annotate llvm/test/Feature/OperandBundles/early-cse.ll @ 150:1d019706d866

LLVM10
author anatofuz
date Thu, 13 Feb 2020 15:10:13 +0900
parents
children 2e18cbf3894f
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 ; RUN: opt -S -early-cse < %s | FileCheck %s
anatofuz
parents:
diff changeset
2
anatofuz
parents:
diff changeset
3 ; While it is normally okay to do memory optimizations over calls to
anatofuz
parents:
diff changeset
4 ; @readonly_function and @readnone_function, we cannot do that if
anatofuz
parents:
diff changeset
5 ; they're carrying unknown operand bundles since the presence of
anatofuz
parents:
diff changeset
6 ; unknown operand bundles implies arbitrary memory effects.
anatofuz
parents:
diff changeset
7
anatofuz
parents:
diff changeset
8 declare void @readonly_function() readonly nounwind
anatofuz
parents:
diff changeset
9 declare void @readnone_function() readnone nounwind
anatofuz
parents:
diff changeset
10
anatofuz
parents:
diff changeset
11 define i32 @test0(i32* %x) {
anatofuz
parents:
diff changeset
12 ; CHECK-LABEL: @test0(
anatofuz
parents:
diff changeset
13 entry:
anatofuz
parents:
diff changeset
14 store i32 100, i32* %x
anatofuz
parents:
diff changeset
15 ; CHECK: store i32 100, i32* %x
anatofuz
parents:
diff changeset
16 call void @readonly_function() [ "tag"() ]
anatofuz
parents:
diff changeset
17 ; CHECK: call void @readonly_function()
anatofuz
parents:
diff changeset
18
anatofuz
parents:
diff changeset
19 %v = load i32, i32* %x
anatofuz
parents:
diff changeset
20 ; CHECK: %v = load i32, i32* %x
anatofuz
parents:
diff changeset
21 ; CHECK: ret i32 %v
anatofuz
parents:
diff changeset
22 ret i32 %v
anatofuz
parents:
diff changeset
23 }
anatofuz
parents:
diff changeset
24
anatofuz
parents:
diff changeset
25 define i32 @test1(i32* %x) {
anatofuz
parents:
diff changeset
26 ; CHECK: @test1(
anatofuz
parents:
diff changeset
27 entry:
anatofuz
parents:
diff changeset
28 store i32 100, i32* %x
anatofuz
parents:
diff changeset
29 ; CHECK: store i32 100, i32* %x
anatofuz
parents:
diff changeset
30 call void @readonly_function() readonly [ "tag"() ]
anatofuz
parents:
diff changeset
31 ; CHECK-NOT: call void @readonly_function
anatofuz
parents:
diff changeset
32 %v = load i32, i32* %x
anatofuz
parents:
diff changeset
33 ret i32 %v
anatofuz
parents:
diff changeset
34 ; CHECK: ret i32 100
anatofuz
parents:
diff changeset
35 }
anatofuz
parents:
diff changeset
36
anatofuz
parents:
diff changeset
37 define i32 @test3(i32* %x) {
anatofuz
parents:
diff changeset
38 ; CHECK-LABEL: @test3(
anatofuz
parents:
diff changeset
39 entry:
anatofuz
parents:
diff changeset
40 store i32 100, i32* %x
anatofuz
parents:
diff changeset
41 ; CHECK: store i32 100, i32* %x
anatofuz
parents:
diff changeset
42 call void @readonly_function()
anatofuz
parents:
diff changeset
43 ; CHECK-NOT: call void @readonly_function
anatofuz
parents:
diff changeset
44 %v = load i32, i32* %x
anatofuz
parents:
diff changeset
45 ret i32 %v
anatofuz
parents:
diff changeset
46 ; CHECK: ret i32 100
anatofuz
parents:
diff changeset
47 }
anatofuz
parents:
diff changeset
48
anatofuz
parents:
diff changeset
49 define void @test4(i32* %x) {
anatofuz
parents:
diff changeset
50 ; CHECK-LABEL: @test4(
anatofuz
parents:
diff changeset
51 entry:
anatofuz
parents:
diff changeset
52 store i32 100, i32* %x
anatofuz
parents:
diff changeset
53 ; CHECK: store i32 100, i32* %x
anatofuz
parents:
diff changeset
54 call void @readnone_function() [ "tag"() ]
anatofuz
parents:
diff changeset
55 ; CHECK: call void @readnone_function
anatofuz
parents:
diff changeset
56 store i32 200, i32* %x
anatofuz
parents:
diff changeset
57 ; CHECK: store i32 200, i32* %x
anatofuz
parents:
diff changeset
58 ret void
anatofuz
parents:
diff changeset
59 }
anatofuz
parents:
diff changeset
60
anatofuz
parents:
diff changeset
61 define void @test5(i32* %x) {
anatofuz
parents:
diff changeset
62 ; CHECK-LABEL: @test5(
anatofuz
parents:
diff changeset
63 entry:
anatofuz
parents:
diff changeset
64 store i32 100, i32* %x
anatofuz
parents:
diff changeset
65 ; CHECK-NOT: store i32 100, i32* %x
anatofuz
parents:
diff changeset
66 ; CHECK-NOT: call void @readnone_function
anatofuz
parents:
diff changeset
67 call void @readnone_function() readnone [ "tag"() ]
anatofuz
parents:
diff changeset
68 store i32 200, i32* %x
anatofuz
parents:
diff changeset
69 ; CHECK: store i32 200, i32* %x
anatofuz
parents:
diff changeset
70 ret void
anatofuz
parents:
diff changeset
71 }
anatofuz
parents:
diff changeset
72
anatofuz
parents:
diff changeset
73 define void @test6(i32* %x) {
anatofuz
parents:
diff changeset
74 ; The "deopt" operand bundle does not make the call to
anatofuz
parents:
diff changeset
75 ; @readonly_function read-write; and so the nounwind readonly call can
anatofuz
parents:
diff changeset
76 ; be deleted.
anatofuz
parents:
diff changeset
77
anatofuz
parents:
diff changeset
78 ; CHECK-LABEL: @test6(
anatofuz
parents:
diff changeset
79 entry:
anatofuz
parents:
diff changeset
80
anatofuz
parents:
diff changeset
81 ; CHECK-NEXT: entry:
anatofuz
parents:
diff changeset
82 ; CHECK-NEXT: store i32 200, i32* %x
anatofuz
parents:
diff changeset
83 ; CHECK-NEXT: ret void
anatofuz
parents:
diff changeset
84
anatofuz
parents:
diff changeset
85 store i32 100, i32* %x
anatofuz
parents:
diff changeset
86 call void @readonly_function() [ "deopt"() ]
anatofuz
parents:
diff changeset
87 store i32 200, i32* %x
anatofuz
parents:
diff changeset
88 ret void
anatofuz
parents:
diff changeset
89 }