blob: aa69da4b50538812ab2178dee5eb93f9b0e35000 [file] [log] [blame]
Andrew Trick020dd892014-01-02 19:29:38 +00001; RUN: opt < %s -indvars -S | FileCheck %s
Sanjoy Das4d4339d2016-06-05 18:01:19 +00002; RUN: opt -lcssa -loop-simplify -S < %s | opt -S -passes='require<targetir>,require<scalar-evolution>,require<domtree>,loop(indvars)'
Andrew Trick020dd892014-01-02 19:29:38 +00003
Mehdi Amini46a43552015-03-04 18:43:29 +00004; Provide legal integer types.
5target datalayout = "n8:16:32:64"
6
7
Andrew Trick020dd892014-01-02 19:29:38 +00008target triple = "x86_64-apple-darwin"
9
Sanjoy Das37e87c22015-10-16 01:00:47 +000010; CHECK-LABEL: @loop_0
Andrew Trick020dd892014-01-02 19:29:38 +000011; CHECK-LABEL: B18:
12; Only one phi now.
13; CHECK: phi
14; CHECK-NOT: phi
Andrew Tricke4a18602014-01-07 06:59:12 +000015; One trunc for the gep.
Andrew Trick020dd892014-01-02 19:29:38 +000016; CHECK: trunc i64 %indvars.iv to i32
Andrew Tricke4a18602014-01-07 06:59:12 +000017; One trunc for the dummy() call.
18; CHECK-LABEL: exit24:
19; CHECK: trunc i64 {{.*}}lcssa.wide to i32
Sanjoy Das37e87c22015-10-16 01:00:47 +000020define void @loop_0(i32* %a) {
Andrew Trick020dd892014-01-02 19:29:38 +000021Prologue:
22 br i1 undef, label %B18, label %B6
23
24B18: ; preds = %B24, %Prologue
25 %.02 = phi i32 [ 0, %Prologue ], [ %tmp33, %B24 ]
26 %tmp23 = zext i32 %.02 to i64
27 %tmp33 = add i32 %.02, 1
David Blaikie79e6c742015-02-27 19:29:02 +000028 %o = getelementptr i32, i32* %a, i32 %.02
David Blaikiea79ac142015-02-27 21:17:42 +000029 %v = load i32, i32* %o
Andrew Trick020dd892014-01-02 19:29:38 +000030 %t = icmp eq i32 %v, 0
31 br i1 %t, label %exit24, label %B24
32
33B24: ; preds = %B18
34 %t2 = icmp eq i32 %tmp33, 20
35 br i1 %t2, label %B6, label %B18
36
37B6: ; preds = %Prologue
38 ret void
39
40exit24: ; preds = %B18
41 call void @dummy(i32 %.02)
42 unreachable
43}
44
Sanjoy Das37e87c22015-10-16 01:00:47 +000045define void @loop_1(i32 %lim) {
46; CHECK-LABEL: @loop_1(
47 entry:
48 %entry.cond = icmp ne i32 %lim, 0
49 br i1 %entry.cond, label %loop, label %leave
50
51 loop:
52; CHECK: loop:
53; CHECK: %indvars.iv = phi i64 [ 1, %loop.preheader ], [ %indvars.iv.next, %loop ]
54; CHECK: %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1
55; CHECK: [[IV_INC:%[^ ]+]] = add nsw i64 %indvars.iv, -1
56; CHECK: call void @dummy.i64(i64 [[IV_INC]])
57
58 %iv = phi i32 [ 1, %entry ], [ %iv.inc, %loop ]
59 %iv.inc = add i32 %iv, 1
60 %iv.inc.sub = add i32 %iv, -1
61 %iv.inc.sub.zext = zext i32 %iv.inc.sub to i64
62 call void @dummy.i64(i64 %iv.inc.sub.zext)
63 %be.cond = icmp ult i32 %iv.inc, %lim
64 br i1 %be.cond, label %loop, label %leave
65
66 leave:
67 ret void
68}
69
Andrew Trick020dd892014-01-02 19:29:38 +000070declare void @dummy(i32)
Sanjoy Das37e87c22015-10-16 01:00:47 +000071declare void @dummy.i64(i64)
Wei Mid2948ce2016-11-15 17:34:52 +000072
73
74define void @loop_2(i32 %size, i32 %nsteps, i32 %hsize, i32* %lined, i8 %tmp1) {
75; CHECK-LABEL: @loop_2(
76entry:
77 %cmp215 = icmp sgt i32 %size, 1
78 %tmp0 = bitcast i32* %lined to i8*
79 br label %for.body
80
81for.body:
82 %j = phi i32 [ 0, %entry ], [ %inc6, %for.inc ]
83 %mul = mul nsw i32 %j, %size
84 %add = add nsw i32 %mul, %hsize
85 br i1 %cmp215, label %for.body2, label %for.inc
86
87; check that the induction variable of the inner loop has been widened after indvars.
88; CHECK: [[INNERLOOPINV:%[^ ]+]] = add nsw i64
89; CHECK: for.body2:
90; CHECK-NEXT: %indvars.iv = phi i64 [ 1, %for.body2.preheader ], [ %indvars.iv.next, %for.body2 ]
91; CHECK-NEXT: [[WIDENED:%[^ ]+]] = add nsw i64 [[INNERLOOPINV]], %indvars.iv
92; CHECK-NEXT: %add.ptr = getelementptr inbounds i8, i8* %tmp0, i64 [[WIDENED]]
93for.body2:
94 %k = phi i32 [ %inc, %for.body2 ], [ 1, %for.body ]
95 %add4 = add nsw i32 %add, %k
96 %idx.ext = sext i32 %add4 to i64
97 %add.ptr = getelementptr inbounds i8, i8* %tmp0, i64 %idx.ext
98 store i8 %tmp1, i8* %add.ptr, align 1
99 %inc = add nsw i32 %k, 1
100 %cmp2 = icmp slt i32 %inc, %size
101 br i1 %cmp2, label %for.body2, label %for.body3
102
103; check that the induction variable of the inner loop has been widened after indvars.
104; CHECK: for.body3.preheader:
105; CHECK: [[INNERLOOPINV:%[^ ]+]] = zext i32
106; CHECK: for.body3:
107; CHECK-NEXT: %indvars.iv2 = phi i64 [ 1, %for.body3.preheader ], [ %indvars.iv.next3, %for.body3 ]
108; CHECK-NEXT: [[WIDENED:%[^ ]+]] = add nuw nsw i64 [[INNERLOOPINV]], %indvars.iv2
109; CHECK-NEXT: %add.ptr2 = getelementptr inbounds i8, i8* %tmp0, i64 [[WIDENED]]
110for.body3:
111 %l = phi i32 [ %inc2, %for.body3 ], [ 1, %for.body2 ]
112 %add5 = add nuw i32 %add, %l
113 %idx.ext2 = zext i32 %add5 to i64
114 %add.ptr2 = getelementptr inbounds i8, i8* %tmp0, i64 %idx.ext2
115 store i8 %tmp1, i8* %add.ptr2, align 1
116 %inc2 = add nsw i32 %l, 1
117 %cmp3 = icmp slt i32 %inc2, %size
118 br i1 %cmp3, label %for.body3, label %for.inc
119
120for.inc:
121 %inc6 = add nsw i32 %j, 1
122 %cmp = icmp slt i32 %inc6, %nsteps
123 br i1 %cmp, label %for.body, label %for.end.loopexit
124
125for.end.loopexit:
126 ret void
127}