Skip to content

Commit e18dca2

Browse files
committed
[IndVars] Add test for #68260 (NFC)
1 parent d066300 commit e18dca2

File tree

1 file changed

+53
-0
lines changed

1 file changed

+53
-0
lines changed
Lines changed: 53 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
1+
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 3
2+
; RUN: opt -S -passes='print<scalar-evolution>,loop(loop-unroll-full,indvars)' < %s 2>/dev/null | FileCheck %s
3+
@g = constant [5 x i32] [i32 0, i32 1, i32 2, i32 3, i32 4]
4+
5+
declare void @use(i32)
6+
7+
; FIXME: This is a miscompile.
8+
define void @test() {
9+
; CHECK-LABEL: define void @test() {
10+
; CHECK-NEXT: entry:
11+
; CHECK-NEXT: br label [[LOOP:%.*]]
12+
; CHECK: loop:
13+
; CHECK-NEXT: br label [[LOOP2:%.*]]
14+
; CHECK: loop2:
15+
; CHECK-NEXT: br i1 false, label [[LOOP2]], label [[LOOP_LATCH:%.*]], !llvm.loop [[LOOP0:![0-9]+]]
16+
; CHECK: loop.latch:
17+
; CHECK-NEXT: call void @use(i32 4)
18+
; CHECK-NEXT: br label [[LOOP2_1:%.*]]
19+
; CHECK: loop2.1:
20+
; CHECK-NEXT: br i1 false, label [[LOOP2_1]], label [[LOOP_LATCH_1:%.*]], !llvm.loop [[LOOP0]]
21+
; CHECK: loop.latch.1:
22+
; CHECK-NEXT: call void @use(i32 4)
23+
; CHECK-NEXT: ret void
24+
;
25+
entry:
26+
br label %loop
27+
28+
loop:
29+
%iv = phi i64 [ 0, %entry ], [ %iv.next, %loop.latch ]
30+
%iv.next = add i64 %iv, 1
31+
br label %loop2
32+
33+
loop2:
34+
%iv2 = phi i64 [ 0, %loop ], [ %iv2.next, %loop2 ]
35+
%iv2.next = add i64 %iv2, 1
36+
%idx = add i64 %iv, %iv2
37+
%gep = getelementptr i32, ptr @g, i64 %idx
38+
%load = load i32, ptr %gep
39+
%cmp2 = icmp ne i64 %iv2, 3
40+
br i1 %cmp2, label %loop2, label %loop.latch, !llvm.loop !0
41+
42+
loop.latch:
43+
%load.lcssa = phi i32 [ %load, %loop2 ]
44+
call void @use(i32 %load)
45+
%cmp = icmp ne i64 %iv, 1
46+
br i1 %cmp, label %loop, label %exit
47+
48+
exit:
49+
ret void
50+
}
51+
52+
!0 = distinct !{!0, !1}
53+
!1 = !{!"llvm.loop.unroll.disable", i1 true}

0 commit comments

Comments
 (0)