annotate llvm/test/Transforms/LoopDistribute/laa-invalidation.ll @ 252:1f2b6ac9f198 llvm-original

LLVM16-1
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 18 Aug 2023 09:04:13 +0900
parents c4bab56944e8
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
236
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 236
diff changeset
2 ; RUN: opt -passes='loop-load-elim,indvars,loop-distribute' -enable-loop-distribute -S %s | FileCheck %s
236
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
3
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
4 define void @test_pr50940(ptr %A, ptr %B) {
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
5 ; CHECK-LABEL: @test_pr50940(
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
6 ; CHECK-NEXT: entry:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
7 ; CHECK-NEXT: br label [[OUTER_HEADER:%.*]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
8 ; CHECK: outer.header:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
9 ; CHECK-NEXT: br i1 false, label [[OUTER_LATCH:%.*]], label [[INNER_PH:%.*]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
10 ; CHECK: inner.ph:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
11 ; CHECK-NEXT: [[UGLYGEP:%.*]] = getelementptr i8, ptr [[A:%.*]], i64 4
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
12 ; CHECK-NEXT: [[GEP_A_3:%.*]] = getelementptr inbounds i16, ptr [[A]], i64 3
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
13 ; CHECK-NEXT: br label [[INNER_LVER_CHECK:%.*]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
14 ; CHECK: inner.lver.check:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
15 ; CHECK-NEXT: [[UGLYGEP1:%.*]] = getelementptr i8, ptr [[A]], i64 8
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
16 ; CHECK-NEXT: [[UGLYGEP2:%.*]] = getelementptr i8, ptr [[B:%.*]], i64 2
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
17 ; CHECK-NEXT: [[BOUND0:%.*]] = icmp ult ptr [[UGLYGEP]], [[UGLYGEP2]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
18 ; CHECK-NEXT: [[BOUND1:%.*]] = icmp ult ptr [[B]], [[UGLYGEP1]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
19 ; CHECK-NEXT: [[FOUND_CONFLICT:%.*]] = and i1 [[BOUND0]], [[BOUND1]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
20 ; CHECK-NEXT: br i1 [[FOUND_CONFLICT]], label [[INNER_PH3_LVER_ORIG:%.*]], label [[INNER_PH3_LDIST1:%.*]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
21 ; CHECK: inner.ph3.lver.orig:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
22 ; CHECK-NEXT: br label [[INNER_LVER_ORIG:%.*]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
23 ; CHECK: inner.lver.orig:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
24 ; CHECK-NEXT: [[IV_LVER_ORIG:%.*]] = phi i16 [ 0, [[INNER_PH3_LVER_ORIG]] ], [ [[IV_NEXT_LVER_ORIG:%.*]], [[INNER_LVER_ORIG]] ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
25 ; CHECK-NEXT: [[L_LVER_ORIG:%.*]] = load <2 x i16>, ptr [[UGLYGEP]], align 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
26 ; CHECK-NEXT: store i16 0, ptr [[GEP_A_3]], align 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
27 ; CHECK-NEXT: store i16 1, ptr [[B]], align 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
28 ; CHECK-NEXT: [[IV_NEXT_LVER_ORIG]] = add nuw nsw i16 [[IV_LVER_ORIG]], 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
29 ; CHECK-NEXT: [[C_1_LVER_ORIG:%.*]] = icmp ult i16 [[IV_LVER_ORIG]], 38
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
30 ; CHECK-NEXT: br i1 [[C_1_LVER_ORIG]], label [[INNER_LVER_ORIG]], label [[EXIT_LOOPEXIT:%.*]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
31 ; CHECK: inner.ph3.ldist1:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
32 ; CHECK-NEXT: br label [[INNER_LDIST1:%.*]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
33 ; CHECK: inner.ldist1:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
34 ; CHECK-NEXT: [[IV_LDIST1:%.*]] = phi i16 [ 0, [[INNER_PH3_LDIST1]] ], [ [[IV_NEXT_LDIST1:%.*]], [[INNER_LDIST1]] ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
35 ; CHECK-NEXT: [[L_LDIST1:%.*]] = load <2 x i16>, ptr [[UGLYGEP]], align 1, !alias.scope !0, !noalias !3
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
36 ; CHECK-NEXT: store i16 0, ptr [[GEP_A_3]], align 1, !alias.scope !0, !noalias !3
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
37 ; CHECK-NEXT: [[IV_NEXT_LDIST1]] = add nuw nsw i16 [[IV_LDIST1]], 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
38 ; CHECK-NEXT: [[C_1_LDIST1:%.*]] = icmp ult i16 [[IV_LDIST1]], 38
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
39 ; CHECK-NEXT: br i1 [[C_1_LDIST1]], label [[INNER_LDIST1]], label [[INNER_PH3:%.*]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
40 ; CHECK: inner.ph3:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
41 ; CHECK-NEXT: br label [[INNER:%.*]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
42 ; CHECK: inner:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
43 ; CHECK-NEXT: [[IV:%.*]] = phi i16 [ 0, [[INNER_PH3]] ], [ [[IV_NEXT:%.*]], [[INNER]] ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
44 ; CHECK-NEXT: store i16 1, ptr [[B]], align 1, !alias.scope !3
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
45 ; CHECK-NEXT: [[IV_NEXT]] = add nuw nsw i16 [[IV]], 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
46 ; CHECK-NEXT: [[C_1:%.*]] = icmp ult i16 [[IV]], 38
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
47 ; CHECK-NEXT: br i1 [[C_1]], label [[INNER]], label [[EXIT_LOOPEXIT4:%.*]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
48 ; CHECK: outer.latch:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
49 ; CHECK-NEXT: br label [[OUTER_HEADER]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
50 ; CHECK: exit.loopexit:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
51 ; CHECK-NEXT: br label [[EXIT:%.*]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
52 ; CHECK: exit.loopexit4:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
53 ; CHECK-NEXT: br label [[EXIT]]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
54 ; CHECK: exit:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
55 ; CHECK-NEXT: ret void
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
56 ;
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
57 entry:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
58 %gep.A.1 = getelementptr inbounds i16, ptr %A, i64 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
59 br label %outer.header
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
60
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
61 outer.header:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
62 %gep.A.2 = getelementptr inbounds i16, ptr %gep.A.1, i64 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
63 br i1 false, label %outer.latch, label %inner.ph
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
64
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
65 inner.ph: ; preds = %for.body5
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
66 %lcssa.gep = phi ptr [ %gep.A.2, %outer.header ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
67 %gep.A.3 = getelementptr inbounds i16, ptr %A, i64 3
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
68 br label %inner
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
69
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
70 inner:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
71 %iv = phi i16 [ 0, %inner.ph ], [ %iv.next, %inner ]
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
72 %l = load <2 x i16>, ptr %lcssa.gep, align 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
73 store i16 0, ptr %gep.A.3, align 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
74 store i16 1, ptr %B, align 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
75 %iv.next = add nuw nsw i16 %iv, 1
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
76 %c.1 = icmp ult i16 %iv, 38
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
77 br i1 %c.1, label %inner, label %exit
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
78
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
79 outer.latch:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
80 br label %outer.header
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
81
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
82 exit:
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
83 ret void
c4bab56944e8 LLVM 16
kono
parents:
diff changeset
84 }