annotate llvm/test/Transforms/SpeculateAroundPHIs/convergent.ll @ 201:a96fbbdf2d0f

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 04 Jun 2021 21:07:06 +0900
parents 1d019706d866
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
anatofuz
parents:
diff changeset
2 ; RUN: opt -S -passes=spec-phis < %s | FileCheck %s
anatofuz
parents:
diff changeset
3 ; Make sure convergent and noduplicate calls aren't duplicated.
anatofuz
parents:
diff changeset
4
anatofuz
parents:
diff changeset
5 declare i32 @llvm.convergent(i32) #0
anatofuz
parents:
diff changeset
6 declare i32 @llvm.noduplicate(i32) #1
anatofuz
parents:
diff changeset
7 declare i32 @llvm.regular(i32) #2
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 define i32 @test_convergent(i1 %flag, i32 %arg) #0 {
anatofuz
parents:
diff changeset
10 ; CHECK-LABEL: @test_convergent(
anatofuz
parents:
diff changeset
11 ; CHECK-NEXT: entry:
anatofuz
parents:
diff changeset
12 ; CHECK-NEXT: br i1 [[FLAG:%.*]], label [[A:%.*]], label [[B:%.*]]
anatofuz
parents:
diff changeset
13 ; CHECK: a:
anatofuz
parents:
diff changeset
14 ; CHECK-NEXT: br label [[EXIT:%.*]]
anatofuz
parents:
diff changeset
15 ; CHECK: b:
anatofuz
parents:
diff changeset
16 ; CHECK-NEXT: br label [[EXIT]]
anatofuz
parents:
diff changeset
17 ; CHECK: exit:
anatofuz
parents:
diff changeset
18 ; CHECK-NEXT: [[P:%.*]] = phi i32 [ 7, [[A]] ], [ 11, [[B]] ]
anatofuz
parents:
diff changeset
19 ; CHECK-NEXT: [[SUM:%.*]] = call i32 @llvm.convergent(i32 [[P]])
anatofuz
parents:
diff changeset
20 ; CHECK-NEXT: ret i32 [[SUM]]
anatofuz
parents:
diff changeset
21 ;
anatofuz
parents:
diff changeset
22 entry:
anatofuz
parents:
diff changeset
23 br i1 %flag, label %a, label %b
anatofuz
parents:
diff changeset
24
anatofuz
parents:
diff changeset
25 a:
anatofuz
parents:
diff changeset
26 br label %exit
anatofuz
parents:
diff changeset
27
anatofuz
parents:
diff changeset
28 b:
anatofuz
parents:
diff changeset
29 br label %exit
anatofuz
parents:
diff changeset
30
anatofuz
parents:
diff changeset
31 exit:
anatofuz
parents:
diff changeset
32 %p = phi i32 [ 7, %a ], [ 11, %b ]
anatofuz
parents:
diff changeset
33 %sum = call i32 @llvm.convergent(i32 %p)
anatofuz
parents:
diff changeset
34 ret i32 %sum
anatofuz
parents:
diff changeset
35 }
anatofuz
parents:
diff changeset
36
anatofuz
parents:
diff changeset
37 define i32 @test_noduplicate(i1 %flag, i32 %arg) #1 {
anatofuz
parents:
diff changeset
38 ; CHECK-LABEL: @test_noduplicate(
anatofuz
parents:
diff changeset
39 ; CHECK-NEXT: entry:
anatofuz
parents:
diff changeset
40 ; CHECK-NEXT: br i1 [[FLAG:%.*]], label [[A:%.*]], label [[B:%.*]]
anatofuz
parents:
diff changeset
41 ; CHECK: a:
anatofuz
parents:
diff changeset
42 ; CHECK-NEXT: br label [[EXIT:%.*]]
anatofuz
parents:
diff changeset
43 ; CHECK: b:
anatofuz
parents:
diff changeset
44 ; CHECK-NEXT: br label [[EXIT]]
anatofuz
parents:
diff changeset
45 ; CHECK: exit:
anatofuz
parents:
diff changeset
46 ; CHECK-NEXT: [[P:%.*]] = phi i32 [ 7, [[A]] ], [ 11, [[B]] ]
anatofuz
parents:
diff changeset
47 ; CHECK-NEXT: [[SUM:%.*]] = call i32 @llvm.noduplicate(i32 [[P]])
anatofuz
parents:
diff changeset
48 ; CHECK-NEXT: ret i32 [[SUM]]
anatofuz
parents:
diff changeset
49 ;
anatofuz
parents:
diff changeset
50 entry:
anatofuz
parents:
diff changeset
51 br i1 %flag, label %a, label %b
anatofuz
parents:
diff changeset
52
anatofuz
parents:
diff changeset
53 a:
anatofuz
parents:
diff changeset
54 br label %exit
anatofuz
parents:
diff changeset
55
anatofuz
parents:
diff changeset
56 b:
anatofuz
parents:
diff changeset
57 br label %exit
anatofuz
parents:
diff changeset
58
anatofuz
parents:
diff changeset
59 exit:
anatofuz
parents:
diff changeset
60 %p = phi i32 [ 7, %a ], [ 11, %b ]
anatofuz
parents:
diff changeset
61 %sum = call i32 @llvm.noduplicate(i32 %p)
anatofuz
parents:
diff changeset
62 ret i32 %sum
anatofuz
parents:
diff changeset
63 }
anatofuz
parents:
diff changeset
64
anatofuz
parents:
diff changeset
65 ; Otherwise identical function which should be transformed.
anatofuz
parents:
diff changeset
66 define i32 @test_reference(i1 %flag, i32 %arg) #2 {
anatofuz
parents:
diff changeset
67 ; CHECK-LABEL: @test_reference(
anatofuz
parents:
diff changeset
68 ; CHECK-NEXT: entry:
anatofuz
parents:
diff changeset
69 ; CHECK-NEXT: br i1 [[FLAG:%.*]], label [[A:%.*]], label [[B:%.*]]
anatofuz
parents:
diff changeset
70 ; CHECK: a:
anatofuz
parents:
diff changeset
71 ; CHECK-NEXT: [[SUM_0:%.*]] = call i32 @llvm.regular(i32 7)
anatofuz
parents:
diff changeset
72 ; CHECK-NEXT: br label [[EXIT:%.*]]
anatofuz
parents:
diff changeset
73 ; CHECK: b:
anatofuz
parents:
diff changeset
74 ; CHECK-NEXT: [[SUM_1:%.*]] = call i32 @llvm.regular(i32 11)
anatofuz
parents:
diff changeset
75 ; CHECK-NEXT: br label [[EXIT]]
anatofuz
parents:
diff changeset
76 ; CHECK: exit:
anatofuz
parents:
diff changeset
77 ; CHECK-NEXT: [[SUM_PHI:%.*]] = phi i32 [ [[SUM_0]], [[A]] ], [ [[SUM_1]], [[B]] ]
anatofuz
parents:
diff changeset
78 ; CHECK-NEXT: ret i32 [[SUM_PHI]]
anatofuz
parents:
diff changeset
79 ;
anatofuz
parents:
diff changeset
80 entry:
anatofuz
parents:
diff changeset
81 br i1 %flag, label %a, label %b
anatofuz
parents:
diff changeset
82
anatofuz
parents:
diff changeset
83 a:
anatofuz
parents:
diff changeset
84 br label %exit
anatofuz
parents:
diff changeset
85
anatofuz
parents:
diff changeset
86 b:
anatofuz
parents:
diff changeset
87 br label %exit
anatofuz
parents:
diff changeset
88
anatofuz
parents:
diff changeset
89 exit:
anatofuz
parents:
diff changeset
90 %p = phi i32 [ 7, %a ], [ 11, %b ]
anatofuz
parents:
diff changeset
91 %sum = call i32 @llvm.regular(i32 %p)
anatofuz
parents:
diff changeset
92 ret i32 %sum
anatofuz
parents:
diff changeset
93 }
anatofuz
parents:
diff changeset
94
anatofuz
parents:
diff changeset
95
anatofuz
parents:
diff changeset
96 attributes #0 = { nounwind readnone convergent speculatable }
anatofuz
parents:
diff changeset
97 attributes #1 = { nounwind readnone noduplicate speculatable }
anatofuz
parents:
diff changeset
98 attributes #2 = { nounwind readnone speculatable }