xref: /aosp_15_r20/external/llvm/test/CodeGen/PowerPC/stack-realign.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=powerpc64-unknown-linux-gnu -mcpu=pwr7 -disable-fp-elim < %s | FileCheck -check-prefix=CHECK-FP %s
3*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=powerpc-unknown-linux-gnu -disable-fp-elim < %s | FileCheck -check-prefix=CHECK-32 %s
4*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=powerpc-unknown-linux-gnu -disable-fp-elim -relocation-model=pic < %s | FileCheck -check-prefix=CHECK-32-PIC %s
5*9880d681SAndroid Build Coastguard Workertarget datalayout = "E-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-f128:128:128-v128:128:128-n32:64"
6*9880d681SAndroid Build Coastguard Workertarget triple = "powerpc64-unknown-linux-gnu"
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker%struct.s = type { i32, i32 }
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Workerdeclare void @bar(i32*)
11*9880d681SAndroid Build Coastguard Worker
12*9880d681SAndroid Build Coastguard Worker@barbaz = external global i32
13*9880d681SAndroid Build Coastguard Worker
14*9880d681SAndroid Build Coastguard Workerdefine void @goo(%struct.s* byval nocapture readonly %a) {
15*9880d681SAndroid Build Coastguard Workerentry:
16*9880d681SAndroid Build Coastguard Worker  %x = alloca [2 x i32], align 32
17*9880d681SAndroid Build Coastguard Worker  %a1 = getelementptr inbounds %struct.s, %struct.s* %a, i64 0, i32 0
18*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* %a1, align 4
19*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds [2 x i32], [2 x i32]* %x, i64 0, i64 0
20*9880d681SAndroid Build Coastguard Worker  store i32 %0, i32* %arrayidx, align 32
21*9880d681SAndroid Build Coastguard Worker  %b = getelementptr inbounds %struct.s, %struct.s* %a, i64 0, i32 1
22*9880d681SAndroid Build Coastguard Worker  %1 = load i32, i32* %b, align 4
23*9880d681SAndroid Build Coastguard Worker  %2 = load i32, i32* @barbaz, align 4
24*9880d681SAndroid Build Coastguard Worker  %arrayidx2 = getelementptr inbounds [2 x i32], [2 x i32]* %x, i64 0, i64 1
25*9880d681SAndroid Build Coastguard Worker  store i32 %2, i32* %arrayidx2, align 4
26*9880d681SAndroid Build Coastguard Worker  call void @bar(i32* %arrayidx)
27*9880d681SAndroid Build Coastguard Worker  ret void
28*9880d681SAndroid Build Coastguard Worker}
29*9880d681SAndroid Build Coastguard Worker
30*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @goo
31*9880d681SAndroid Build Coastguard Worker
32*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mflr {{[0-9]+}}
33*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: clrldi [[REG:[0-9]+]], 1, 59
34*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: std 30, -16(1)
35*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mr 30, 1
36*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: std 0, 16(1)
37*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: subfic 0, [[REG]], -160
38*9880d681SAndroid Build Coastguard Worker; CHECK: stdux 1, 1, 0
39*9880d681SAndroid Build Coastguard Worker
40*9880d681SAndroid Build Coastguard Worker; CHECK: .cfi_def_cfa_register r30
41*9880d681SAndroid Build Coastguard Worker; CHECK: .cfi_offset r30, -16
42*9880d681SAndroid Build Coastguard Worker; CHECK: .cfi_offset lr, 16
43*9880d681SAndroid Build Coastguard Worker
44*9880d681SAndroid Build Coastguard Worker; CHECK: std 3, 48(30)
45*9880d681SAndroid Build Coastguard Worker
46*9880d681SAndroid Build Coastguard Worker; CHECK: ld 1, 0(1)
47*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: ld [[SR:[0-9]+]], 16(1)
48*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: ld 30, -16(1)
49*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mtlr [[SR]]
50*9880d681SAndroid Build Coastguard Worker; CHECK: blr
51*9880d681SAndroid Build Coastguard Worker
52*9880d681SAndroid Build Coastguard Worker; CHECK-FP-LABEL: @goo
53*9880d681SAndroid Build Coastguard Worker
54*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: mflr {{[0-9]+}}
55*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: clrldi [[REG:[0-9]+]], 1, 59
56*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: std 31, -8(1)
57*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: std 30, -16(1)
58*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: mr 30, 1
59*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: std 0, 16(1)
60*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: subfic 0, [[REG]], -160
61*9880d681SAndroid Build Coastguard Worker; CHECK-FP: stdux 1, 1, 0
62*9880d681SAndroid Build Coastguard Worker
63*9880d681SAndroid Build Coastguard Worker; CHECK-FP: .cfi_def_cfa_register r30
64*9880d681SAndroid Build Coastguard Worker; CHECK-FP: .cfi_offset r31, -8
65*9880d681SAndroid Build Coastguard Worker; CHECK-FP: .cfi_offset r30, -16
66*9880d681SAndroid Build Coastguard Worker; CHECK-FP: .cfi_offset lr, 16
67*9880d681SAndroid Build Coastguard Worker
68*9880d681SAndroid Build Coastguard Worker; CHECK-FP: mr 31, 1
69*9880d681SAndroid Build Coastguard Worker
70*9880d681SAndroid Build Coastguard Worker; CHECK-FP: std 3, 48(30)
71*9880d681SAndroid Build Coastguard Worker
72*9880d681SAndroid Build Coastguard Worker; CHECK-FP: ld 1, 0(1)
73*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: ld [[SR:[0-9]+]], 16(1)
74*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: ld 31, -8(1)
75*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: ld 30, -16(1)
76*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: mtlr [[SR]]
77*9880d681SAndroid Build Coastguard Worker; CHECK-FP: blr
78*9880d681SAndroid Build Coastguard Worker
79*9880d681SAndroid Build Coastguard Worker; CHECK-32-LABEL: @goo
80*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: mflr {{[0-9]+}}
81*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: clrlwi [[REG:[0-9]+]], 1, 27
82*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: stw 30, -8(1)
83*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: mr 30, 1
84*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: stw 0, 4(1)
85*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: subfic 0, [[REG]], -64
86*9880d681SAndroid Build Coastguard Worker; CHECK-32: stwux 1, 1, 0
87*9880d681SAndroid Build Coastguard Worker
88*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-LABEL: @goo
89*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: mflr {{[0-9]+}}
90*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: clrlwi [[REG:[0-9]+]], 1, 27
91*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: stw 29, -12(1)
92*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: mr 29, 1
93*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: stw 0, 4(1)
94*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: subfic 0, [[REG]], -64
95*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC: stwux 1, 1, 0
96*9880d681SAndroid Build Coastguard Worker
97*9880d681SAndroid Build Coastguard Worker; The large-frame-size case.
98*9880d681SAndroid Build Coastguard Workerdefine void @hoo(%struct.s* byval nocapture readonly %a) {
99*9880d681SAndroid Build Coastguard Workerentry:
100*9880d681SAndroid Build Coastguard Worker  %x = alloca [200000 x i32], align 32
101*9880d681SAndroid Build Coastguard Worker  %a1 = getelementptr inbounds %struct.s, %struct.s* %a, i64 0, i32 0
102*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* %a1, align 4
103*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds [200000 x i32], [200000 x i32]* %x, i64 0, i64 0
104*9880d681SAndroid Build Coastguard Worker  store i32 %0, i32* %arrayidx, align 32
105*9880d681SAndroid Build Coastguard Worker  %b = getelementptr inbounds %struct.s, %struct.s* %a, i64 0, i32 1
106*9880d681SAndroid Build Coastguard Worker  %1 = load i32, i32* %b, align 4
107*9880d681SAndroid Build Coastguard Worker  %arrayidx2 = getelementptr inbounds [200000 x i32], [200000 x i32]* %x, i64 0, i64 1
108*9880d681SAndroid Build Coastguard Worker  store i32 %1, i32* %arrayidx2, align 4
109*9880d681SAndroid Build Coastguard Worker  call void @bar(i32* %arrayidx)
110*9880d681SAndroid Build Coastguard Worker  ret void
111*9880d681SAndroid Build Coastguard Worker}
112*9880d681SAndroid Build Coastguard Worker
113*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @hoo
114*9880d681SAndroid Build Coastguard Worker
115*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: lis [[REG1:[0-9]+]], -13
116*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: clrldi [[REG3:[0-9]+]], 1, 59
117*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mflr {{[0-9]+}}
118*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: ori [[REG2:[0-9]+]], [[REG1]], 51808
119*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: std 30, -16(1)
120*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mr 30, 1
121*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: std 0, 16(1)
122*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: subfc 0, [[REG3]], [[REG2]]
123*9880d681SAndroid Build Coastguard Worker; CHECK: stdux 1, 1, 0
124*9880d681SAndroid Build Coastguard Worker
125*9880d681SAndroid Build Coastguard Worker; CHECK: .cfi_def_cfa_register r30
126*9880d681SAndroid Build Coastguard Worker
127*9880d681SAndroid Build Coastguard Worker; CHECK: blr
128*9880d681SAndroid Build Coastguard Worker
129*9880d681SAndroid Build Coastguard Worker; CHECK-32-LABEL: @hoo
130*9880d681SAndroid Build Coastguard Worker
131*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: lis [[REG1:[0-9]+]], -13
132*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: clrlwi [[REG3:[0-9]+]], 1, 27
133*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: mflr {{[0-9]+}}
134*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: ori [[REG2:[0-9]+]], [[REG1]], 51904
135*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: stw 30, -8(1)
136*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: mr 30, 1
137*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: stw 0, 4(1)
138*9880d681SAndroid Build Coastguard Worker; CHECK-32-DAG: subfc 0, [[REG3]], [[REG2]]
139*9880d681SAndroid Build Coastguard Worker; CHECK-32: stwux 1, 1, 0
140*9880d681SAndroid Build Coastguard Worker
141*9880d681SAndroid Build Coastguard Worker; CHECK-32: blr
142*9880d681SAndroid Build Coastguard Worker
143*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-LABEL: @hoo
144*9880d681SAndroid Build Coastguard Worker
145*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: lis [[REG1:[0-9]+]], -13
146*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: clrlwi [[REG3:[0-9]+]], 1, 27
147*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: mflr {{[0-9]+}}
148*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: ori [[REG2:[0-9]+]], [[REG1]], 51904
149*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: stw 29, -12(1)
150*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: mr 29, 1
151*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: stw 0, 4(1)
152*9880d681SAndroid Build Coastguard Worker; CHECK-32-PIC-DAG: subfc 0, [[REG3]], [[REG2]]
153*9880d681SAndroid Build Coastguard Worker; CHECK-32: stwux 1, 1, 0
154*9880d681SAndroid Build Coastguard Worker
155*9880d681SAndroid Build Coastguard Worker; CHECK-32: blr
156*9880d681SAndroid Build Coastguard Worker
157*9880d681SAndroid Build Coastguard Worker; Make sure that the FP save area is still allocated correctly relative to
158*9880d681SAndroid Build Coastguard Worker; where r30 is saved.
159*9880d681SAndroid Build Coastguard Workerdefine void @loo(%struct.s* byval nocapture readonly %a) {
160*9880d681SAndroid Build Coastguard Workerentry:
161*9880d681SAndroid Build Coastguard Worker  %x = alloca [2 x i32], align 32
162*9880d681SAndroid Build Coastguard Worker  %a1 = getelementptr inbounds %struct.s, %struct.s* %a, i64 0, i32 0
163*9880d681SAndroid Build Coastguard Worker  %0 = load i32, i32* %a1, align 4
164*9880d681SAndroid Build Coastguard Worker  %arrayidx = getelementptr inbounds [2 x i32], [2 x i32]* %x, i64 0, i64 0
165*9880d681SAndroid Build Coastguard Worker  store i32 %0, i32* %arrayidx, align 32
166*9880d681SAndroid Build Coastguard Worker  %b = getelementptr inbounds %struct.s, %struct.s* %a, i64 0, i32 1
167*9880d681SAndroid Build Coastguard Worker  %1 = load i32, i32* %b, align 4
168*9880d681SAndroid Build Coastguard Worker  %arrayidx2 = getelementptr inbounds [2 x i32], [2 x i32]* %x, i64 0, i64 1
169*9880d681SAndroid Build Coastguard Worker  store i32 %1, i32* %arrayidx2, align 4
170*9880d681SAndroid Build Coastguard Worker  call void @bar(i32* %arrayidx)
171*9880d681SAndroid Build Coastguard Worker  call void asm sideeffect "", "~{f30}"() nounwind
172*9880d681SAndroid Build Coastguard Worker  ret void
173*9880d681SAndroid Build Coastguard Worker}
174*9880d681SAndroid Build Coastguard Worker
175*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @loo
176*9880d681SAndroid Build Coastguard Worker
177*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mflr {{[0-9]+}}
178*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: clrldi [[REG:[0-9]+]], 1, 59
179*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: std 30, -32(1)
180*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: mr 30, 1
181*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: std 0, 16(1)
182*9880d681SAndroid Build Coastguard Worker; CHECK-DAG: subfic 0, [[REG]], -192
183*9880d681SAndroid Build Coastguard Worker; CHECK: stdux 1, 1, 0
184*9880d681SAndroid Build Coastguard Worker
185*9880d681SAndroid Build Coastguard Worker; CHECK: .cfi_def_cfa_register r30
186*9880d681SAndroid Build Coastguard Worker
187*9880d681SAndroid Build Coastguard Worker; CHECK: stfd 30, -16(30)
188*9880d681SAndroid Build Coastguard Worker
189*9880d681SAndroid Build Coastguard Worker; CHECK: blr
190*9880d681SAndroid Build Coastguard Worker
191*9880d681SAndroid Build Coastguard Worker; CHECK-FP-LABEL: @loo
192*9880d681SAndroid Build Coastguard Worker
193*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: mflr {{[0-9]+}}
194*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: clrldi [[REG:[0-9]+]], 1, 59
195*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: std 31, -24(1)
196*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: std 30, -32(1)
197*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: mr 30, 1
198*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: std 0, 16(1)
199*9880d681SAndroid Build Coastguard Worker; CHECK-FP-DAG: subfic 0, [[REG]], -192
200*9880d681SAndroid Build Coastguard Worker; CHECK-FP: stdux 1, 1, 0
201*9880d681SAndroid Build Coastguard Worker
202*9880d681SAndroid Build Coastguard Worker; CHECK-FP: .cfi_def_cfa_register r30
203*9880d681SAndroid Build Coastguard Worker
204*9880d681SAndroid Build Coastguard Worker; CHECK-FP: stfd 30, -16(30)
205*9880d681SAndroid Build Coastguard Worker
206*9880d681SAndroid Build Coastguard Worker; CHECK-FP: blr
207