xref: /aosp_15_r20/external/llvm/test/CodeGen/ARM/2016-05-01-RegScavengerAssert.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s
2*9880d681SAndroid Build Coastguard Worker; This test has around 4000 bytes of local variables and it also stresses register allocation
3*9880d681SAndroid Build Coastguard Worker; to force a register scavenging. It tests if the stack is treated as "BigStack" and thus
4*9880d681SAndroid Build Coastguard Worker; spill slots are reserved. If not, reg scavenger will assert.
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n8:16:32-S64"
7*9880d681SAndroid Build Coastguard Workertarget triple = "thumbv7--linux-android"
8*9880d681SAndroid Build Coastguard Worker
9*9880d681SAndroid Build Coastguard Worker%struct.r = type { i32 (...)**, [10 x [9 x float]], [10 x [9 x float]], [101 x [9 x float]], [101 x [9 x float]], i32, i32, i32, i32, i32, [8 x [2 x i32]], [432 x float], [432 x i32], [10 x i8*], [10 x i8*], [10 x i32], [10 x i32], [10 x i32], [10 x i32], [10 x i32], [10 x i32], i32, i32, i32, i32, float, float, i32, i32, [9 x float], float*, float }
10*9880d681SAndroid Build Coastguard Worker
11*9880d681SAndroid Build Coastguard Workerdefine void @foo(%struct.r* %this, float* %srcR, float* %srcC, float* %tempPntsX, float* %tY, float* %ms, float* %sX, float* %sY, i32* dereferenceable(4) %num, float* %tm, i32 %SR, i32 %lev, i8* %tdata, i32 %siW, i32 %pyw, i32 %pyh, i8* %sdata) #0 align 2 {
12*9880d681SAndroid Build Coastguard Workerentry:
13*9880d681SAndroid Build Coastguard Worker %sFV = alloca [49 x float], align 4
14*9880d681SAndroid Build Coastguard Worker %tFV = alloca [49 x float], align 4
15*9880d681SAndroid Build Coastguard Worker %TIM = alloca [9 x float], align 4
16*9880d681SAndroid Build Coastguard Worker %sort_tmp = alloca [432 x float], align 4
17*9880d681SAndroid Build Coastguard Worker %msDiffs = alloca [432 x float], align 4
18*9880d681SAndroid Build Coastguard Worker %TM.sroa.0.0.copyload = load float, float* %tm, align 4
19*9880d681SAndroid Build Coastguard Worker %TM.sroa.8.0.copyload = load float, float* null, align 4
20*9880d681SAndroid Build Coastguard Worker %TM.sroa.9.0..sroa_idx813 = getelementptr inbounds float, float* %tm, i32 6
21*9880d681SAndroid Build Coastguard Worker %TM.sroa.9.0.copyload = load float, float* %TM.sroa.9.0..sroa_idx813, align 4
22*9880d681SAndroid Build Coastguard Worker %TM.sroa.11.0.copyload = load float, float* undef, align 4
23*9880d681SAndroid Build Coastguard Worker br i1 undef, label %for.body.lr.ph, label %if.then343
24*9880d681SAndroid Build Coastguard Worker
25*9880d681SAndroid Build Coastguard Workerfor.body.lr.ph:                  ; preds = %entry
26*9880d681SAndroid Build Coastguard Worker %arrayidx8 = getelementptr inbounds %struct.r, %struct.r* %this, i32 0, i32 1, i32 %lev, i32 0
27*9880d681SAndroid Build Coastguard Worker %arrayidx12 = getelementptr inbounds %struct.r, %struct.r* %this, i32 0, i32 1, i32 %lev, i32 6
28*9880d681SAndroid Build Coastguard Worker %arrayidx15 = getelementptr inbounds %struct.r, %struct.r* %this, i32 0, i32 1, i32 %lev, i32 4
29*9880d681SAndroid Build Coastguard Worker %arrayidx20 = getelementptr inbounds %struct.r, %struct.r* %this, i32 0, i32 1, i32 %lev, i32 7
30*9880d681SAndroid Build Coastguard Worker %arrayidx24 = getelementptr inbounds %struct.r, %struct.r* %this, i32 0, i32 2, i32 %lev, i32 0
31*9880d681SAndroid Build Coastguard Worker %arrayidx28 = getelementptr inbounds %struct.r, %struct.r* %this, i32 0, i32 2, i32 %lev, i32 6
32*9880d681SAndroid Build Coastguard Worker %arrayidx32 = getelementptr inbounds %struct.r, %struct.r* %this, i32 0, i32 2, i32 %lev, i32 4
33*9880d681SAndroid Build Coastguard Worker %arrayidx36 = getelementptr inbounds %struct.r, %struct.r* %this, i32 0, i32 2, i32 %lev, i32 7
34*9880d681SAndroid Build Coastguard Worker %arrayidx84 = getelementptr inbounds [9 x float], [9 x float]* %TIM, i32 0, i32 6
35*9880d681SAndroid Build Coastguard Worker %arrayidx92 = getelementptr inbounds [9 x float], [9 x float]* %TIM, i32 0, i32 7
36*9880d681SAndroid Build Coastguard Worker %add116 = add nsw i32 %pyh, 15
37*9880d681SAndroid Build Coastguard Worker br label %for.body
38*9880d681SAndroid Build Coastguard Worker
39*9880d681SAndroid Build Coastguard Workerfor.body:                     ; preds = %for.cond.cleanup40, %for.body.lr.ph
40*9880d681SAndroid Build Coastguard Worker %arrayidx.phi = phi float* [ %sX, %for.body.lr.ph ], [ %arrayidx.inc, %for.cond.cleanup40 ]
41*9880d681SAndroid Build Coastguard Worker %arrayidx4.phi = phi float* [ %sY, %for.body.lr.ph ], [ %arrayidx4.inc, %for.cond.cleanup40 ]
42*9880d681SAndroid Build Coastguard Worker %0 = load float, float* %arrayidx.phi, align 4
43*9880d681SAndroid Build Coastguard Worker %1 = load float, float* %arrayidx4.phi, align 4
44*9880d681SAndroid Build Coastguard Worker %2 = load float, float* %arrayidx12, align 4
45*9880d681SAndroid Build Coastguard Worker %add = fadd fast float 0.000000e+00, %2
46*9880d681SAndroid Build Coastguard Worker %3 = load float, float* %arrayidx20, align 4
47*9880d681SAndroid Build Coastguard Worker %add21 = fadd fast float 0.000000e+00, %3
48*9880d681SAndroid Build Coastguard Worker %mul3.i = fmul fast float %add21, %TM.sroa.8.0.copyload
49*9880d681SAndroid Build Coastguard Worker %add.i = fadd fast float 0.000000e+00, %TM.sroa.11.0.copyload
50*9880d681SAndroid Build Coastguard Worker %add5.i = fadd fast float %add.i, %mul3.i
51*9880d681SAndroid Build Coastguard Worker %conv6.i = fdiv fast float 1.000000e+00, %add5.i
52*9880d681SAndroid Build Coastguard Worker %mul8.i = fmul fast float %add, %TM.sroa.0.0.copyload
53*9880d681SAndroid Build Coastguard Worker %add11.i = fadd fast float %mul8.i, %TM.sroa.9.0.copyload
54*9880d681SAndroid Build Coastguard Worker %add13.i = fadd fast float %add11.i, 0.000000e+00
55*9880d681SAndroid Build Coastguard Worker %4 = load float, float* %arrayidx24, align 4
56*9880d681SAndroid Build Coastguard Worker %mul14.i = fmul fast float %add13.i, %4
57*9880d681SAndroid Build Coastguard Worker %mul25 = fmul fast float %mul14.i, %conv6.i
58*9880d681SAndroid Build Coastguard Worker %add29 = fadd fast float %mul25, 0.000000e+00
59*9880d681SAndroid Build Coastguard Worker %arrayidx.inc = getelementptr float, float* %arrayidx.phi, i32 1
60*9880d681SAndroid Build Coastguard Worker %arrayidx4.inc = getelementptr float, float* %arrayidx4.phi, i32 1
61*9880d681SAndroid Build Coastguard Worker %conv64.1 = sitofp i32 undef to float
62*9880d681SAndroid Build Coastguard Worker %conv64.6 = sitofp i32 undef to float
63*9880d681SAndroid Build Coastguard Worker br label %for.body41
64*9880d681SAndroid Build Coastguard Worker
65*9880d681SAndroid Build Coastguard Workerfor.cond.cleanup40:                ; preds = %for.body41
66*9880d681SAndroid Build Coastguard Worker %call = call fast float undef(%struct.r* nonnull %this, float* undef, i32 49)
67*9880d681SAndroid Build Coastguard Worker br label %for.body
68*9880d681SAndroid Build Coastguard Worker
69*9880d681SAndroid Build Coastguard Workerfor.body41:                    ; preds = %for.cond.cleanup56.for.body41_crit_edge, %for.body
70*9880d681SAndroid Build Coastguard Worker %5 = phi float [ 0.000000e+00, %for.body ], [ %.pre, %for.cond.cleanup56.for.body41_crit_edge ]
71*9880d681SAndroid Build Coastguard Worker %sFVData.0840 = phi float* [ undef, %for.body ], [ undef, %for.cond.cleanup56.for.body41_crit_edge ]
72*9880d681SAndroid Build Coastguard Worker %dx.0838 = phi i32 [ -3, %for.body ], [ undef, %for.cond.cleanup56.for.body41_crit_edge ]
73*9880d681SAndroid Build Coastguard Worker %conv42 = sitofp i32 %dx.0838 to float
74*9880d681SAndroid Build Coastguard Worker %add43 = fadd fast float %conv42, %add29
75*9880d681SAndroid Build Coastguard Worker %conv44 = fptosi float %add43 to i32
76*9880d681SAndroid Build Coastguard Worker %conv48 = sitofp i32 %conv44 to float
77*9880d681SAndroid Build Coastguard Worker %mul49 = fmul fast float %5, %conv48
78*9880d681SAndroid Build Coastguard Worker %add53 = fadd fast float %mul49, 0.000000e+00
79*9880d681SAndroid Build Coastguard Worker %conv111 = fptosi float undef to i32
80*9880d681SAndroid Build Coastguard Worker %cond = select i1 undef, i32 %conv111, i32 -16
81*9880d681SAndroid Build Coastguard Worker %cond.add116 = select i1 undef, i32 %cond, i32 %add116
82*9880d681SAndroid Build Coastguard Worker %cmp132 = icmp sgt i32 undef, -16
83*9880d681SAndroid Build Coastguard Worker %cond137 = select i1 %cmp132, i32 undef, i32 -16
84*9880d681SAndroid Build Coastguard Worker %cond153 = select i1 undef, i32 %cond137, i32 undef
85*9880d681SAndroid Build Coastguard Worker %add.ptr = getelementptr inbounds i8, i8* %sdata, i32 %cond153
86*9880d681SAndroid Build Coastguard Worker %mul154 = mul nsw i32 %cond.add116, %siW
87*9880d681SAndroid Build Coastguard Worker %add.ptr155 = getelementptr inbounds i8, i8* %add.ptr, i32 %mul154
88*9880d681SAndroid Build Coastguard Worker %6 = load i8, i8* %add.ptr155, align 1
89*9880d681SAndroid Build Coastguard Worker %conv157 = uitofp i8 %6 to float
90*9880d681SAndroid Build Coastguard Worker %incdec.ptr = getelementptr inbounds float, float* %sFVData.0840, i32 1
91*9880d681SAndroid Build Coastguard Worker store float %conv157, float* %sFVData.0840, align 4
92*9880d681SAndroid Build Coastguard Worker %7 = load float, float* %arrayidx15, align 4
93*9880d681SAndroid Build Coastguard Worker %mul65.1 = fmul fast float %7, %conv64.1
94*9880d681SAndroid Build Coastguard Worker %8 = load float, float* %arrayidx20, align 4
95*9880d681SAndroid Build Coastguard Worker %add69.1 = fadd fast float %mul65.1, %8
96*9880d681SAndroid Build Coastguard Worker %conv78.1 = fdiv fast float 1.000000e+00, 0.000000e+00
97*9880d681SAndroid Build Coastguard Worker %9 = load float, float* undef, align 4
98*9880d681SAndroid Build Coastguard Worker %mul80.1 = fmul fast float %9, %add53
99*9880d681SAndroid Build Coastguard Worker %10 = load float, float* undef, align 4
100*9880d681SAndroid Build Coastguard Worker %mul82.1 = fmul fast float %10, %add69.1
101*9880d681SAndroid Build Coastguard Worker %add83.1 = fadd fast float %mul82.1, %mul80.1
102*9880d681SAndroid Build Coastguard Worker %11 = load float, float* %arrayidx84, align 4
103*9880d681SAndroid Build Coastguard Worker %add85.1 = fadd fast float %add83.1, %11
104*9880d681SAndroid Build Coastguard Worker %mul86.1 = fmul fast float %add85.1, %conv78.1
105*9880d681SAndroid Build Coastguard Worker %12 = load float, float* %arrayidx92, align 4
106*9880d681SAndroid Build Coastguard Worker %add93.1 = fadd fast float 0.000000e+00, %12
107*9880d681SAndroid Build Coastguard Worker %mul94.1 = fmul fast float %add93.1, %conv78.1
108*9880d681SAndroid Build Coastguard Worker %13 = load float, float* %arrayidx24, align 4
109*9880d681SAndroid Build Coastguard Worker %mul98.1 = fmul fast float %mul86.1, %13
110*9880d681SAndroid Build Coastguard Worker %14 = load float, float* %arrayidx28, align 4
111*9880d681SAndroid Build Coastguard Worker %add102.1 = fadd fast float %mul98.1, %14
112*9880d681SAndroid Build Coastguard Worker %15 = load float, float* %arrayidx32, align 4
113*9880d681SAndroid Build Coastguard Worker %mul106.1 = fmul fast float %mul94.1, %15
114*9880d681SAndroid Build Coastguard Worker %16 = load float, float* %arrayidx36, align 4
115*9880d681SAndroid Build Coastguard Worker %add110.1 = fadd fast float %mul106.1, %16
116*9880d681SAndroid Build Coastguard Worker %conv111.1 = fptosi float %add102.1 to i32
117*9880d681SAndroid Build Coastguard Worker %conv112.1 = fptosi float %add110.1 to i32
118*9880d681SAndroid Build Coastguard Worker %cond.1 = select i1 undef, i32 %conv111.1, i32 -16
119*9880d681SAndroid Build Coastguard Worker %cond.add116.1 = select i1 undef, i32 %cond.1, i32 %add116
120*9880d681SAndroid Build Coastguard Worker %cond137.1 = select i1 undef, i32 %conv112.1, i32 -16
121*9880d681SAndroid Build Coastguard Worker %cond153.1 = select i1 undef, i32 %cond137.1, i32 undef
122*9880d681SAndroid Build Coastguard Worker %add.ptr.1 = getelementptr inbounds i8, i8* %sdata, i32 %cond153.1
123*9880d681SAndroid Build Coastguard Worker %mul154.1 = mul nsw i32 %cond.add116.1, %siW
124*9880d681SAndroid Build Coastguard Worker %add.ptr155.1 = getelementptr inbounds i8, i8* %add.ptr.1, i32 %mul154.1
125*9880d681SAndroid Build Coastguard Worker %17 = load i8, i8* %add.ptr155.1, align 1
126*9880d681SAndroid Build Coastguard Worker %conv157.1 = uitofp i8 %17 to float
127*9880d681SAndroid Build Coastguard Worker %incdec.ptr.1 = getelementptr inbounds float, float* %sFVData.0840, i32 2
128*9880d681SAndroid Build Coastguard Worker store float %conv157.1, float* %incdec.ptr, align 4
129*9880d681SAndroid Build Coastguard Worker %conv112.2 = fptosi float undef to i32
130*9880d681SAndroid Build Coastguard Worker %cond137.2 = select i1 undef, i32 %conv112.2, i32 -16
131*9880d681SAndroid Build Coastguard Worker %cond153.2 = select i1 undef, i32 %cond137.2, i32 undef
132*9880d681SAndroid Build Coastguard Worker %add.ptr.2 = getelementptr inbounds i8, i8* %sdata, i32 %cond153.2
133*9880d681SAndroid Build Coastguard Worker %add.ptr155.2 = getelementptr inbounds i8, i8* %add.ptr.2, i32 0
134*9880d681SAndroid Build Coastguard Worker %18 = load i8, i8* %add.ptr155.2, align 1
135*9880d681SAndroid Build Coastguard Worker %conv157.2 = uitofp i8 %18 to float
136*9880d681SAndroid Build Coastguard Worker %incdec.ptr.2 = getelementptr inbounds float, float* %sFVData.0840, i32 3
137*9880d681SAndroid Build Coastguard Worker store float %conv157.2, float* %incdec.ptr.1, align 4
138*9880d681SAndroid Build Coastguard Worker %cmp132.3 = icmp sgt i32 undef, -16
139*9880d681SAndroid Build Coastguard Worker %cond137.3 = select i1 %cmp132.3, i32 undef, i32 -16
140*9880d681SAndroid Build Coastguard Worker %cond153.3 = select i1 undef, i32 %cond137.3, i32 undef
141*9880d681SAndroid Build Coastguard Worker %add.ptr.3 = getelementptr inbounds i8, i8* %sdata, i32 %cond153.3
142*9880d681SAndroid Build Coastguard Worker %add.ptr155.3 = getelementptr inbounds i8, i8* %add.ptr.3, i32 0
143*9880d681SAndroid Build Coastguard Worker %19 = load i8, i8* %add.ptr155.3, align 1
144*9880d681SAndroid Build Coastguard Worker %conv157.3 = uitofp i8 %19 to float
145*9880d681SAndroid Build Coastguard Worker store float %conv157.3, float* %incdec.ptr.2, align 4
146*9880d681SAndroid Build Coastguard Worker %incdec.ptr.5 = getelementptr inbounds float, float* %sFVData.0840, i32 6
147*9880d681SAndroid Build Coastguard Worker %20 = load float, float* %arrayidx15, align 4
148*9880d681SAndroid Build Coastguard Worker %mul65.6 = fmul fast float %20, %conv64.6
149*9880d681SAndroid Build Coastguard Worker %21 = load float, float* %arrayidx20, align 4
150*9880d681SAndroid Build Coastguard Worker %add69.6 = fadd fast float %mul65.6, %21
151*9880d681SAndroid Build Coastguard Worker %conv78.6 = fdiv fast float 1.000000e+00, 0.000000e+00
152*9880d681SAndroid Build Coastguard Worker %22 = load float, float* undef, align 4
153*9880d681SAndroid Build Coastguard Worker %mul82.6 = fmul fast float %22, %add69.6
154*9880d681SAndroid Build Coastguard Worker %add83.6 = fadd fast float %mul82.6, 0.000000e+00
155*9880d681SAndroid Build Coastguard Worker %23 = load float, float* %arrayidx84, align 4
156*9880d681SAndroid Build Coastguard Worker %add85.6 = fadd fast float %add83.6, %23
157*9880d681SAndroid Build Coastguard Worker %mul86.6 = fmul fast float %add85.6, %conv78.6
158*9880d681SAndroid Build Coastguard Worker %24 = load float, float* %arrayidx24, align 4
159*9880d681SAndroid Build Coastguard Worker %mul98.6 = fmul fast float %mul86.6, %24
160*9880d681SAndroid Build Coastguard Worker %25 = load float, float* %arrayidx28, align 4
161*9880d681SAndroid Build Coastguard Worker %add102.6 = fadd fast float %mul98.6, %25
162*9880d681SAndroid Build Coastguard Worker %conv111.6 = fptosi float %add102.6 to i32
163*9880d681SAndroid Build Coastguard Worker %conv112.6 = fptosi float undef to i32
164*9880d681SAndroid Build Coastguard Worker %cond.6 = select i1 undef, i32 %conv111.6, i32 -16
165*9880d681SAndroid Build Coastguard Worker %cond.add116.6 = select i1 undef, i32 %cond.6, i32 %add116
166*9880d681SAndroid Build Coastguard Worker %cmp132.6 = icmp sgt i32 %conv112.6, -16
167*9880d681SAndroid Build Coastguard Worker %cond137.6 = select i1 %cmp132.6, i32 %conv112.6, i32 -16
168*9880d681SAndroid Build Coastguard Worker %cond153.6 = select i1 undef, i32 %cond137.6, i32 undef
169*9880d681SAndroid Build Coastguard Worker %add.ptr.6 = getelementptr inbounds i8, i8* %sdata, i32 %cond153.6
170*9880d681SAndroid Build Coastguard Worker %mul154.6 = mul nsw i32 %cond.add116.6, %siW
171*9880d681SAndroid Build Coastguard Worker %add.ptr155.6 = getelementptr inbounds i8, i8* %add.ptr.6, i32 %mul154.6
172*9880d681SAndroid Build Coastguard Worker %26 = load i8, i8* %add.ptr155.6, align 1
173*9880d681SAndroid Build Coastguard Worker %conv157.6 = uitofp i8 %26 to float
174*9880d681SAndroid Build Coastguard Worker store float %conv157.6, float* %incdec.ptr.5, align 4
175*9880d681SAndroid Build Coastguard Worker %exitcond874 = icmp eq i32 %dx.0838, 3
176*9880d681SAndroid Build Coastguard Worker br i1 %exitcond874, label %for.cond.cleanup40, label %for.cond.cleanup56.for.body41_crit_edge
177*9880d681SAndroid Build Coastguard Worker
178*9880d681SAndroid Build Coastguard Workerfor.cond.cleanup56.for.body41_crit_edge:     ; preds = %for.body41
179*9880d681SAndroid Build Coastguard Worker %.pre = load float, float* %arrayidx8, align 4
180*9880d681SAndroid Build Coastguard Worker br label %for.body41
181*9880d681SAndroid Build Coastguard Worker
182*9880d681SAndroid Build Coastguard Workerif.then343:                    ; preds = %entry
183*9880d681SAndroid Build Coastguard Worker ret void
184*9880d681SAndroid Build Coastguard Worker}
185*9880d681SAndroid Build Coastguard Worker
186*9880d681SAndroid Build Coastguard Workerattributes #0 = { sspstrong uwtable "no-frame-pointer-elim"="false" "target-cpu"="cortex-a7" }
187*9880d681SAndroid Build Coastguard Worker
188*9880d681SAndroid Build Coastguard Worker!1 = !{!2, !2, i64 0}
189*9880d681SAndroid Build Coastguard Worker!2 = !{!"float", !3, i64 0}
190*9880d681SAndroid Build Coastguard Worker!3 = !{!"omnipotent char", !4, i64 0}
191*9880d681SAndroid Build Coastguard Worker!4 = !{!"Simple C/C++ TBAA"}
192*9880d681SAndroid Build Coastguard Worker!5 = !{!3, !3, i64 0}
193