xref: /aosp_15_r20/external/llvm/test/Transforms/LoopStrengthReduce/2011-10-13-SCEVChain.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: opt -loop-reduce -S < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker;
3*9880d681SAndroid Build Coastguard Worker; Test TransformForPostIncUse and LSR's expansion of expressions in
4*9880d681SAndroid Build Coastguard Worker; post-inc form to ensure the implementation can handle expressions
5*9880d681SAndroid Build Coastguard Worker; DAGs, not just trees.
6*9880d681SAndroid Build Coastguard Worker
7*9880d681SAndroid Build Coastguard Workertarget triple = "x86_64-apple-darwin"
8*9880d681SAndroid Build Coastguard Worker
9*9880d681SAndroid Build Coastguard Worker; Verify that -loop-reduce runs without "hanging" and reuses post-inc
10*9880d681SAndroid Build Coastguard Worker; expansions.
11*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @test(
12*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
13*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
14*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
15*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
16*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
17*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
18*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
19*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
20*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
21*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
22*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
23*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
24*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
25*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
26*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
27*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
28*9880d681SAndroid Build Coastguard Worker; CHECK: icmp
29*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: icmp
30*9880d681SAndroid Build Coastguard Workerdefine void @test(i8* %base, i32 %a0) nounwind {
31*9880d681SAndroid Build Coastguard Workerentry:
32*9880d681SAndroid Build Coastguard Worker  br label %bb1
33*9880d681SAndroid Build Coastguard Workerbb1:
34*9880d681SAndroid Build Coastguard Worker  %n0 = sub i32 0, %a0
35*9880d681SAndroid Build Coastguard Worker  %t0 = icmp ugt i32 %n0, -4
36*9880d681SAndroid Build Coastguard Worker  %m0 = select i1 %t0, i32 %n0, i32 -4
37*9880d681SAndroid Build Coastguard Worker  %a1 = add i32 %m0, %a0
38*9880d681SAndroid Build Coastguard Worker  %n1 = sub i32 0, %a1
39*9880d681SAndroid Build Coastguard Worker  %t1 = icmp ugt i32 %n1, -4
40*9880d681SAndroid Build Coastguard Worker  %m1 = select i1 %t1, i32 %n1, i32 -4
41*9880d681SAndroid Build Coastguard Worker  %a2 = add i32 %m1, %a1
42*9880d681SAndroid Build Coastguard Worker  %n2 = sub i32 0, %a2
43*9880d681SAndroid Build Coastguard Worker  %t2 = icmp ugt i32 %n2, -4
44*9880d681SAndroid Build Coastguard Worker  %m2 = select i1 %t2, i32 %n2, i32 -4
45*9880d681SAndroid Build Coastguard Worker  %a3 = add i32 %m2, %a2
46*9880d681SAndroid Build Coastguard Worker  %n3 = sub i32 0, %a3
47*9880d681SAndroid Build Coastguard Worker  %t3 = icmp ugt i32 %n3, -4
48*9880d681SAndroid Build Coastguard Worker  %m3 = select i1 %t3, i32 %n3, i32 -4
49*9880d681SAndroid Build Coastguard Worker  %a4 = add i32 %m3, %a3
50*9880d681SAndroid Build Coastguard Worker  %n4 = sub i32 0, %a4
51*9880d681SAndroid Build Coastguard Worker  %t4 = icmp ugt i32 %n4, -4
52*9880d681SAndroid Build Coastguard Worker  %m4 = select i1 %t4, i32 %n4, i32 -4
53*9880d681SAndroid Build Coastguard Worker  %a5 = add i32 %m4, %a4
54*9880d681SAndroid Build Coastguard Worker  %n5 = sub i32 0, %a5
55*9880d681SAndroid Build Coastguard Worker  %t5 = icmp ugt i32 %n5, -4
56*9880d681SAndroid Build Coastguard Worker  %m5 = select i1 %t5, i32 %n5, i32 -4
57*9880d681SAndroid Build Coastguard Worker  %a6 = add i32 %m5, %a5
58*9880d681SAndroid Build Coastguard Worker  %n6 = sub i32 0, %a6
59*9880d681SAndroid Build Coastguard Worker  %t6 = icmp ugt i32 %n6, -4
60*9880d681SAndroid Build Coastguard Worker  %m6 = select i1 %t6, i32 %n6, i32 -4
61*9880d681SAndroid Build Coastguard Worker  %a7 = add i32 %m6, %a6
62*9880d681SAndroid Build Coastguard Worker  %n7 = sub i32 0, %a7
63*9880d681SAndroid Build Coastguard Worker  %t7 = icmp ugt i32 %n7, -4
64*9880d681SAndroid Build Coastguard Worker  %m7 = select i1 %t7, i32 %n7, i32 -4
65*9880d681SAndroid Build Coastguard Worker  %a8 = add i32 %m7, %a7
66*9880d681SAndroid Build Coastguard Worker  %n8 = sub i32 0, %a8
67*9880d681SAndroid Build Coastguard Worker  %t8 = icmp ugt i32 %n8, -4
68*9880d681SAndroid Build Coastguard Worker  %m8 = select i1 %t8, i32 %n8, i32 -4
69*9880d681SAndroid Build Coastguard Worker  %a9 = add i32 %m8, %a8
70*9880d681SAndroid Build Coastguard Worker  %n9 = sub i32 0, %a9
71*9880d681SAndroid Build Coastguard Worker  %t9 = icmp ugt i32 %n9, -4
72*9880d681SAndroid Build Coastguard Worker  %m9 = select i1 %t9, i32 %n9, i32 -4
73*9880d681SAndroid Build Coastguard Worker  %a10 = add i32 %m9, %a9
74*9880d681SAndroid Build Coastguard Worker  %n10 = sub i32 0, %a10
75*9880d681SAndroid Build Coastguard Worker  %t10 = icmp ugt i32 %n10, -4
76*9880d681SAndroid Build Coastguard Worker  %m10 = select i1 %t10, i32 %n10, i32 -4
77*9880d681SAndroid Build Coastguard Worker  %a11 = add i32 %m10, %a10
78*9880d681SAndroid Build Coastguard Worker  %n11 = sub i32 0, %a11
79*9880d681SAndroid Build Coastguard Worker  %t11 = icmp ugt i32 %n11, -4
80*9880d681SAndroid Build Coastguard Worker  %m11 = select i1 %t11, i32 %n11, i32 -4
81*9880d681SAndroid Build Coastguard Worker  %a12 = add i32 %m11, %a11
82*9880d681SAndroid Build Coastguard Worker  %n12 = sub i32 0, %a12
83*9880d681SAndroid Build Coastguard Worker  %t12 = icmp ugt i32 %n12, -4
84*9880d681SAndroid Build Coastguard Worker  %m12 = select i1 %t12, i32 %n12, i32 -4
85*9880d681SAndroid Build Coastguard Worker  %a13 = add i32 %m12, %a12
86*9880d681SAndroid Build Coastguard Worker  %n13 = sub i32 0, %a13
87*9880d681SAndroid Build Coastguard Worker  %t13 = icmp ugt i32 %n13, -4
88*9880d681SAndroid Build Coastguard Worker  %m13 = select i1 %t13, i32 %n13, i32 -4
89*9880d681SAndroid Build Coastguard Worker  %a14 = add i32 %m13, %a13
90*9880d681SAndroid Build Coastguard Worker  %n14 = sub i32 0, %a14
91*9880d681SAndroid Build Coastguard Worker  %t14 = icmp ugt i32 %n14, -4
92*9880d681SAndroid Build Coastguard Worker  %m14 = select i1 %t14, i32 %n14, i32 -4
93*9880d681SAndroid Build Coastguard Worker  %a15 = add i32 %m14, %a14
94*9880d681SAndroid Build Coastguard Worker  %n15 = sub i32 0, %a15
95*9880d681SAndroid Build Coastguard Worker  %t15 = icmp ugt i32 %n15, -4
96*9880d681SAndroid Build Coastguard Worker  %m15 = select i1 %t15, i32 %n15, i32 -4
97*9880d681SAndroid Build Coastguard Worker  %a16 = add i32 %m15, %a15
98*9880d681SAndroid Build Coastguard Worker  %gep = getelementptr i8, i8* %base, i32 %a16
99*9880d681SAndroid Build Coastguard Worker  %ofs = add i32 %a16, 4
100*9880d681SAndroid Build Coastguard Worker  %limit = getelementptr i8, i8* %base, i32 %ofs
101*9880d681SAndroid Build Coastguard Worker  br label %loop
102*9880d681SAndroid Build Coastguard Worker
103*9880d681SAndroid Build Coastguard Workerloop:
104*9880d681SAndroid Build Coastguard Worker  %iv = phi i8* [ %gep, %bb1 ], [ %inc, %loop ]
105*9880d681SAndroid Build Coastguard Worker  %inc = getelementptr inbounds i8, i8* %iv, i64 1
106*9880d681SAndroid Build Coastguard Worker  %exitcond = icmp eq i8* %inc, %limit
107*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond, label %loop, label %exit
108*9880d681SAndroid Build Coastguard Worker
109*9880d681SAndroid Build Coastguard Workerexit:
110*9880d681SAndroid Build Coastguard Worker  ret void
111*9880d681SAndroid Build Coastguard Worker}
112