xref: /aosp_15_r20/external/llvm/test/CodeGen/PowerPC/ppc64-anyregcc.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Workertarget datalayout = "E-m:e-i64:64-n32:64"
3*9880d681SAndroid Build Coastguard Workertarget triple = "powerpc64-unknown-linux-gnu"
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: test:
6*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[test_BEGIN:.*]]:{{$}}
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: property_access1:
9*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[property_access1_BEGIN:.*]]:{{$}}
10*9880d681SAndroid Build Coastguard Worker
11*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: property_access2:
12*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[property_access2_BEGIN:.*]]:{{$}}
13*9880d681SAndroid Build Coastguard Worker
14*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: property_access3:
15*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[property_access3_BEGIN:.*]]:{{$}}
16*9880d681SAndroid Build Coastguard Worker
17*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: anyreg_test1:
18*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[anyreg_test1_BEGIN:.*]]:{{$}}
19*9880d681SAndroid Build Coastguard Worker
20*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: anyreg_test2:
21*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[anyreg_test2_BEGIN:.*]]:{{$}}
22*9880d681SAndroid Build Coastguard Worker
23*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: patchpoint_spilldef:
24*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[patchpoint_spilldef_BEGIN:.*]]:{{$}}
25*9880d681SAndroid Build Coastguard Worker
26*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: patchpoint_spillargs:
27*9880d681SAndroid Build Coastguard Worker; CHECK: {{^}}.L[[patchpoint_spillargs_BEGIN:.*]]:{{$}}
28*9880d681SAndroid Build Coastguard Worker
29*9880d681SAndroid Build Coastguard Worker
30*9880d681SAndroid Build Coastguard Worker; Stackmap Header: no constants - 6 callsites
31*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: .section	.llvm_stackmaps
32*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:  __LLVM_StackMaps:
33*9880d681SAndroid Build Coastguard Worker; Header
34*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
35*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 0
36*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short 0
37*9880d681SAndroid Build Coastguard Worker; Num Functions
38*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 8
39*9880d681SAndroid Build Coastguard Worker; Num LargeConstants
40*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
41*9880d681SAndroid Build Coastguard Worker; Num Callsites
42*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 8
43*9880d681SAndroid Build Coastguard Worker
44*9880d681SAndroid Build Coastguard Worker; Functions and stack size
45*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad test
46*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad 128
47*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad property_access1
48*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad 128
49*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad property_access2
50*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad 128
51*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad property_access3
52*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad 128
53*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad anyreg_test1
54*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad 144
55*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad anyreg_test2
56*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad 144
57*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad patchpoint_spilldef
58*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad 256
59*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad patchpoint_spillargs
60*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .quad 288
61*9880d681SAndroid Build Coastguard Worker
62*9880d681SAndroid Build Coastguard Worker
63*9880d681SAndroid Build Coastguard Worker; test
64*9880d681SAndroid Build Coastguard Worker; CHECK:  .long   .L{{.*}}-.L[[test_BEGIN]]
65*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  0
66*9880d681SAndroid Build Coastguard Worker; 3 locations
67*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  3
68*9880d681SAndroid Build Coastguard Worker; Loc 0: Register
69*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
70*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 4
71*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
72*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
73*9880d681SAndroid Build Coastguard Worker; Loc 1: Register
74*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
75*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 4
76*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
77*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
78*9880d681SAndroid Build Coastguard Worker; Loc 2: Constant 3
79*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 4
80*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
81*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  0
82*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 3
83*9880d681SAndroid Build Coastguard Workerdefine i64 @test() nounwind ssp uwtable {
84*9880d681SAndroid Build Coastguard Workerentry:
85*9880d681SAndroid Build Coastguard Worker  call anyregcc void (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.void(i64 0, i32 40, i8* null, i32 2, i32 1, i32 2, i64 3)
86*9880d681SAndroid Build Coastguard Worker  ret i64 0
87*9880d681SAndroid Build Coastguard Worker}
88*9880d681SAndroid Build Coastguard Worker
89*9880d681SAndroid Build Coastguard Worker; property access 1 - %obj is an anyreg call argument and should therefore be in a register
90*9880d681SAndroid Build Coastguard Worker; CHECK:  .long   .L{{.*}}-.L[[property_access1_BEGIN]]
91*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  0
92*9880d681SAndroid Build Coastguard Worker; 2 locations
93*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  2
94*9880d681SAndroid Build Coastguard Worker; Loc 0: Register <-- this is the return register
95*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
96*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
97*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
98*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
99*9880d681SAndroid Build Coastguard Worker; Loc 1: Register
100*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
101*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
102*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
103*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
104*9880d681SAndroid Build Coastguard Workerdefine i64 @property_access1(i8* %obj) nounwind ssp uwtable {
105*9880d681SAndroid Build Coastguard Workerentry:
106*9880d681SAndroid Build Coastguard Worker  %f = inttoptr i64 281474417671919 to i8*
107*9880d681SAndroid Build Coastguard Worker  %ret = call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 1, i32 40, i8* %f, i32 1, i8* %obj)
108*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
109*9880d681SAndroid Build Coastguard Worker}
110*9880d681SAndroid Build Coastguard Worker
111*9880d681SAndroid Build Coastguard Worker; property access 2 - %obj is an anyreg call argument and should therefore be in a register
112*9880d681SAndroid Build Coastguard Worker; CHECK:  .long   .L{{.*}}-.L[[property_access2_BEGIN]]
113*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  0
114*9880d681SAndroid Build Coastguard Worker; 2 locations
115*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  2
116*9880d681SAndroid Build Coastguard Worker; Loc 0: Register <-- this is the return register
117*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
118*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
119*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
120*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
121*9880d681SAndroid Build Coastguard Worker; Loc 1: Register
122*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
123*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
124*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
125*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
126*9880d681SAndroid Build Coastguard Workerdefine i64 @property_access2() nounwind ssp uwtable {
127*9880d681SAndroid Build Coastguard Workerentry:
128*9880d681SAndroid Build Coastguard Worker  %obj = alloca i64, align 8
129*9880d681SAndroid Build Coastguard Worker  %f = inttoptr i64 281474417671919 to i8*
130*9880d681SAndroid Build Coastguard Worker  %ret = call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 2, i32 40, i8* %f, i32 1, i64* %obj)
131*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
132*9880d681SAndroid Build Coastguard Worker}
133*9880d681SAndroid Build Coastguard Worker
134*9880d681SAndroid Build Coastguard Worker; property access 3 - %obj is a frame index
135*9880d681SAndroid Build Coastguard Worker; CHECK:  .long   .L{{.*}}-.L[[property_access3_BEGIN]]
136*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  0
137*9880d681SAndroid Build Coastguard Worker; 2 locations
138*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  2
139*9880d681SAndroid Build Coastguard Worker; Loc 0: Register <-- this is the return register
140*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
141*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
142*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
143*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
144*9880d681SAndroid Build Coastguard Worker; Loc 1: Direct FP - 8
145*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 2
146*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
147*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short 31
148*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 112
149*9880d681SAndroid Build Coastguard Workerdefine i64 @property_access3() nounwind ssp uwtable {
150*9880d681SAndroid Build Coastguard Workerentry:
151*9880d681SAndroid Build Coastguard Worker  %obj = alloca i64, align 8
152*9880d681SAndroid Build Coastguard Worker  %f = inttoptr i64 281474417671919 to i8*
153*9880d681SAndroid Build Coastguard Worker  %ret = call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 3, i32 40, i8* %f, i32 0, i64* %obj)
154*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
155*9880d681SAndroid Build Coastguard Worker}
156*9880d681SAndroid Build Coastguard Worker
157*9880d681SAndroid Build Coastguard Worker; anyreg_test1
158*9880d681SAndroid Build Coastguard Worker; CHECK:  .long   .L{{.*}}-.L[[anyreg_test1_BEGIN]]
159*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  0
160*9880d681SAndroid Build Coastguard Worker; 14 locations
161*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  14
162*9880d681SAndroid Build Coastguard Worker; Loc 0: Register <-- this is the return register
163*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
164*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
165*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
166*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
167*9880d681SAndroid Build Coastguard Worker; Loc 1: Register
168*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
169*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
170*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
171*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
172*9880d681SAndroid Build Coastguard Worker; Loc 2: Register
173*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
174*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
175*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
176*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
177*9880d681SAndroid Build Coastguard Worker; Loc 3: Register
178*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
179*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
180*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
181*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
182*9880d681SAndroid Build Coastguard Worker; Loc 4: Register
183*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
184*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
185*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
186*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
187*9880d681SAndroid Build Coastguard Worker; Loc 5: Register
188*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
189*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
190*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
191*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
192*9880d681SAndroid Build Coastguard Worker; Loc 6: Register
193*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
194*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
195*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
196*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
197*9880d681SAndroid Build Coastguard Worker; Loc 7: Register
198*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
199*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
200*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
201*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
202*9880d681SAndroid Build Coastguard Worker; Loc 8: Register
203*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
204*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
205*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
206*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
207*9880d681SAndroid Build Coastguard Worker; Loc 9: Register
208*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
209*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
210*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
211*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
212*9880d681SAndroid Build Coastguard Worker; Loc 10: Register
213*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
214*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
215*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
216*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
217*9880d681SAndroid Build Coastguard Worker; Loc 11: Register
218*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
219*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
220*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
221*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
222*9880d681SAndroid Build Coastguard Worker; Loc 12: Register
223*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
224*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
225*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
226*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
227*9880d681SAndroid Build Coastguard Worker; Loc 13: Register
228*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
229*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
230*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
231*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
232*9880d681SAndroid Build Coastguard Workerdefine i64 @anyreg_test1(i8* %a1, i8* %a2, i8* %a3, i8* %a4, i8* %a5, i8* %a6, i8* %a7, i8* %a8, i8* %a9, i8* %a10, i8* %a11, i8* %a12, i8* %a13) nounwind ssp uwtable {
233*9880d681SAndroid Build Coastguard Workerentry:
234*9880d681SAndroid Build Coastguard Worker  %f = inttoptr i64 281474417671919 to i8*
235*9880d681SAndroid Build Coastguard Worker  %ret = call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 4, i32 40, i8* %f, i32 13, i8* %a1, i8* %a2, i8* %a3, i8* %a4, i8* %a5, i8* %a6, i8* %a7, i8* %a8, i8* %a9, i8* %a10, i8* %a11, i8* %a12, i8* %a13)
236*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
237*9880d681SAndroid Build Coastguard Worker}
238*9880d681SAndroid Build Coastguard Worker
239*9880d681SAndroid Build Coastguard Worker; anyreg_test2
240*9880d681SAndroid Build Coastguard Worker; CHECK:  .long   .L{{.*}}-.L[[anyreg_test2_BEGIN]]
241*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  0
242*9880d681SAndroid Build Coastguard Worker; 14 locations
243*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short  14
244*9880d681SAndroid Build Coastguard Worker; Loc 0: Register <-- this is the return register
245*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
246*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
247*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
248*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
249*9880d681SAndroid Build Coastguard Worker; Loc 1: Register
250*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
251*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
252*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
253*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
254*9880d681SAndroid Build Coastguard Worker; Loc 2: Register
255*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
256*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
257*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
258*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
259*9880d681SAndroid Build Coastguard Worker; Loc 3: Register
260*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
261*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
262*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
263*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
264*9880d681SAndroid Build Coastguard Worker; Loc 4: Register
265*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
266*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
267*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
268*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
269*9880d681SAndroid Build Coastguard Worker; Loc 5: Register
270*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
271*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
272*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
273*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
274*9880d681SAndroid Build Coastguard Worker; Loc 6: Register
275*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
276*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
277*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
278*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
279*9880d681SAndroid Build Coastguard Worker; Loc 7: Register
280*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
281*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
282*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
283*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
284*9880d681SAndroid Build Coastguard Worker; Loc 8: Register
285*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
286*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
287*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
288*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
289*9880d681SAndroid Build Coastguard Worker; Loc 9: Register
290*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
291*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
292*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
293*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
294*9880d681SAndroid Build Coastguard Worker; Loc 10: Register
295*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
296*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
297*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
298*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
299*9880d681SAndroid Build Coastguard Worker; Loc 11: Register
300*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
301*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
302*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
303*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
304*9880d681SAndroid Build Coastguard Worker; Loc 12: Register
305*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
306*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
307*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
308*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
309*9880d681SAndroid Build Coastguard Worker; Loc 13: Register
310*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 1
311*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .byte 8
312*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .short {{[0-9]+}}
313*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT:   .long 0
314*9880d681SAndroid Build Coastguard Workerdefine i64 @anyreg_test2(i8* %a1, i8* %a2, i8* %a3, i8* %a4, i8* %a5, i8* %a6, i8* %a7, i8* %a8, i8* %a9, i8* %a10, i8* %a11, i8* %a12, i8* %a13) nounwind ssp uwtable {
315*9880d681SAndroid Build Coastguard Workerentry:
316*9880d681SAndroid Build Coastguard Worker  %f = inttoptr i64 281474417671919 to i8*
317*9880d681SAndroid Build Coastguard Worker  %ret = call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 5, i32 40, i8* %f, i32 8, i8* %a1, i8* %a2, i8* %a3, i8* %a4, i8* %a5, i8* %a6, i8* %a7, i8* %a8, i8* %a9, i8* %a10, i8* %a11, i8* %a12, i8* %a13)
318*9880d681SAndroid Build Coastguard Worker  ret i64 %ret
319*9880d681SAndroid Build Coastguard Worker}
320*9880d681SAndroid Build Coastguard Worker
321*9880d681SAndroid Build Coastguard Worker; Test spilling the return value of an anyregcc call.
322*9880d681SAndroid Build Coastguard Worker;
323*9880d681SAndroid Build Coastguard Worker; <rdar://problem/15432754> [JS] Assertion: "Folded a def to a non-store!"
324*9880d681SAndroid Build Coastguard Worker;
325*9880d681SAndroid Build Coastguard Worker; CHECK: .long .L{{.*}}-.L[[patchpoint_spilldef_BEGIN]]
326*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 0
327*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 3
328*9880d681SAndroid Build Coastguard Worker; Loc 0: Register (some register that will be spilled to the stack)
329*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  1
330*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  8
331*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}}
332*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long  0
333*9880d681SAndroid Build Coastguard Worker; Loc 1: Register
334*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  1
335*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  8
336*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}}
337*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long  0
338*9880d681SAndroid Build Coastguard Worker; Loc 1: Register
339*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  1
340*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  8
341*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}}
342*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long  0
343*9880d681SAndroid Build Coastguard Workerdefine i64 @patchpoint_spilldef(i64 %p1, i64 %p2, i64 %p3, i64 %p4) {
344*9880d681SAndroid Build Coastguard Workerentry:
345*9880d681SAndroid Build Coastguard Worker  %result = tail call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 12, i32 40, i8* inttoptr (i64 0 to i8*), i32 2, i64 %p1, i64 %p2)
346*9880d681SAndroid Build Coastguard Worker  tail call void asm sideeffect "nop", "~{r0},~{r3},~{r4},~{r5},~{r6},~{r7},~{r8},~{r9},~{r10},~{r11},~{r12},~{r14},~{r15},~{r16},~{r17
347*9880d681SAndroid Build Coastguard Worker},~{r18},~{r19},~{r20},~{r21},~{r22},~{r23},~{r24},~{r25},~{r26},~{r27},~{r28},~{r29},~{r30},~{r31}"() nounwind
348*9880d681SAndroid Build Coastguard Worker  ret i64 %result
349*9880d681SAndroid Build Coastguard Worker}
350*9880d681SAndroid Build Coastguard Worker
351*9880d681SAndroid Build Coastguard Worker; Test spilling the arguments of an anyregcc call.
352*9880d681SAndroid Build Coastguard Worker;
353*9880d681SAndroid Build Coastguard Worker; <rdar://problem/15487687> [JS] AnyRegCC argument ends up being spilled
354*9880d681SAndroid Build Coastguard Worker;
355*9880d681SAndroid Build Coastguard Worker; CHECK: .long .L{{.*}}-.L[[patchpoint_spillargs_BEGIN]]
356*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 0
357*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 5
358*9880d681SAndroid Build Coastguard Worker; Loc 0: Return a register
359*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  1
360*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  8
361*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}}
362*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long  0
363*9880d681SAndroid Build Coastguard Worker; Loc 1: Arg0 in a Register
364*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  1
365*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  8
366*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}}
367*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long  0
368*9880d681SAndroid Build Coastguard Worker; Loc 2: Arg1 in a Register
369*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  1
370*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  8
371*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short {{[0-9]+}}
372*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long  0
373*9880d681SAndroid Build Coastguard Worker; Loc 3: Arg2 spilled to FP -96
374*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  3
375*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  8
376*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 31
377*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 128
378*9880d681SAndroid Build Coastguard Worker; Loc 4: Arg3 spilled to FP - 88
379*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  3
380*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .byte  8
381*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .short 31
382*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: .long 136
383*9880d681SAndroid Build Coastguard Workerdefine i64 @patchpoint_spillargs(i64 %p1, i64 %p2, i64 %p3, i64 %p4) {
384*9880d681SAndroid Build Coastguard Workerentry:
385*9880d681SAndroid Build Coastguard Worker  tail call void asm sideeffect "nop", "~{r0},~{r3},~{r4},~{r5},~{r6},~{r7},~{r8},~{r9},~{r10},~{r11},~{r12},~{r14},~{r15},~{r16},~{r17
386*9880d681SAndroid Build Coastguard Worker},~{r18},~{r19},~{r20},~{r21},~{r22},~{r23},~{r24},~{r25},~{r26},~{r27},~{r28},~{r29},~{r30},~{r31}"() nounwind
387*9880d681SAndroid Build Coastguard Worker  %result = tail call anyregcc i64 (i64, i32, i8*, i32, ...) @llvm.experimental.patchpoint.i64(i64 13, i32 40, i8* inttoptr (i64 0 to i8*), i32 2, i64 %p1, i64 %p2, i64 %p3, i64 %p4)
388*9880d681SAndroid Build Coastguard Worker  ret i64 %result
389*9880d681SAndroid Build Coastguard Worker}
390*9880d681SAndroid Build Coastguard Worker
391*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.experimental.patchpoint.void(i64, i32, i8*, i32, ...)
392*9880d681SAndroid Build Coastguard Workerdeclare i64 @llvm.experimental.patchpoint.i64(i64, i32, i8*, i32, ...)
393