blob: de0d30bf6371f57679be5dd1bf624e6ecfc501ce [file] [log] [blame]
Krzysztof Parzyszek046090d2018-03-12 14:01:28 +00001; RUN: llc -march=hexagon -enable-pipeliner < %s
2; REQUIRES: asserts
3
4; Test that the pipeliner doesn't ICE in the ScheduleDAG code because
5; the latency values are not updated properly. The pipeliner should
6; not change the latency of chain edges.
7
8; Function Attrs: nounwind
9define void @f0() #0 {
10b0:
11 %v0 = alloca [10 x i16], align 8
12 br label %b1
13
14b1: ; preds = %b1, %b0
15 %v1 = phi i32 [ %v7, %b1 ], [ undef, %b0 ]
16 %v2 = add i32 %v1, -1
17 %v3 = getelementptr inbounds [10 x i16], [10 x i16]* %v0, i32 0, i32 %v2
18 %v4 = add i32 %v1, -2
19 %v5 = getelementptr inbounds [10 x i16], [10 x i16]* %v0, i32 0, i32 %v4
20 %v6 = load i16, i16* %v5, align 2, !tbaa !0
21 store i16 %v6, i16* %v3, align 2, !tbaa !0
22 %v7 = add i32 %v1, -4
23 %v8 = icmp sgt i32 %v7, 3
24 br i1 %v8, label %b1, label %b2
25
26b2: ; preds = %b2, %b1
27 br label %b2
28}
29
30attributes #0 = { nounwind "target-cpu"="hexagonv55" }
31
32!0 = !{!1, !1, i64 0}
33!1 = !{!"short", !2, i64 0}
34!2 = !{!"omnipotent char", !3, i64 0}
35!3 = !{!"Simple C/C++ TBAA"}