1; ARM EHABI integrated test
2
3; This test case checks whether the ARM unwind directives are properly
4; generated or not.
5
6; The purpose of the test:
7; (1) .fnstart and .fnend directives should wrap the function.
8; (2) .setfp directive should be available if frame pointer is not eliminated.
9; (3) .save directive should come with push instruction.
10; (4) .vsave directive should come with vpush instruction.
11; (5) .pad directive should come with stack pointer adjustment.
12; (6) .cantunwind directive should be available if the function is marked with
13;     nounwind function attribute.
14
15; We have to check several cases:
16; (1) arm with -frame-pointer=all
17; (2) arm without -frame-pointer=all
18; (3) armv7 with -frame-pointer=all
19; (4) armv7 without -frame-pointer=all
20
21; RUN: llc -mtriple arm-unknown-linux-gnueabi \
22; RUN:     -frame-pointer=all -filetype=asm -o - %s \
23; RUN:   | FileCheck %s --check-prefix=CHECK-FP
24
25; RUN: llc -mtriple arm-unknown-linux-gnueabi \
26; RUN:     -filetype=asm -o - %s \
27; RUN:   | FileCheck %s --check-prefix=CHECK-FP-ELIM
28
29; RUN: llc -mtriple armv7-unknown-linux-gnueabi \
30; RUN:     -frame-pointer=all -filetype=asm -o - %s \
31; RUN:   | FileCheck %s --check-prefix=CHECK-V7-FP
32
33; RUN: llc -mtriple armv7-unknown-linux-gnueabi \
34; RUN:     -filetype=asm -o - %s \
35; RUN:   | FileCheck %s --check-prefix=CHECK-V7-FP-ELIM
36
37; RUN: llc -mtriple arm-unknown-linux-musleabi \
38; RUN:     -frame-pointer=all -filetype=asm -o - %s \
39; RUN:   | FileCheck %s --check-prefix=CHECK-FP
40
41; RUN: llc -mtriple arm-unknown-linux-musleabi \
42; RUN:     -filetype=asm -o - %s \
43; RUN:   | FileCheck %s --check-prefix=CHECK-FP-ELIM
44
45; RUN: llc -mtriple armv7-unknown-linux-musleabi \
46; RUN:     -frame-pointer=all -filetype=asm -o - %s \
47; RUN:   | FileCheck %s --check-prefix=CHECK-V7-FP
48
49; RUN: llc -mtriple armv7-unknown-linux-musleabi \
50; RUN:     -filetype=asm -o - %s \
51; RUN:   | FileCheck %s --check-prefix=CHECK-V7-FP-ELIM
52
53; RUN: llc -mtriple arm-unknown-linux-androideabi \
54; RUN:     -frame-pointer=all -filetype=asm -o - %s \
55; RUN:   | FileCheck %s --check-prefix=CHECK-FP
56
57; RUN: llc -mtriple arm-unknown-linux-androideabi \
58; RUN:     -filetype=asm -o - %s \
59; RUN:   | FileCheck %s --check-prefix=CHECK-FP-ELIM
60
61; RUN: llc -mtriple armv7-unknown-linux-androideabi \
62; RUN:     -frame-pointer=all -filetype=asm -o - %s \
63; RUN:   | FileCheck %s --check-prefix=CHECK-V7-FP
64
65; RUN: llc -mtriple armv7-unknown-linux-androideabi \
66; RUN:     -filetype=asm -o - %s \
67; RUN:   | FileCheck %s --check-prefix=CHECK-V7-FP-ELIM
68
69; RUN: llc -mtriple arm-unknown-netbsd-eabi \
70; RUN:     -frame-pointer=all -filetype=asm -o - %s \
71; RUN:   | FileCheck %s --check-prefix=DWARF-FP
72
73; RUN: llc -mtriple arm-unknown-netbsd-eabi \
74; RUN:     -filetype=asm -o - %s \
75; RUN:   | FileCheck %s --check-prefix=DWARF-FP-ELIM
76
77; RUN: llc -mtriple armv7-unknown-netbsd-eabi \
78; RUN:     -frame-pointer=all -filetype=asm -o - %s \
79; RUN:   | FileCheck %s --check-prefix=DWARF-V7-FP
80
81; RUN: llc -mtriple armv7-unknown-netbsd-eabi \
82; RUN:     -filetype=asm -o - %s \
83; RUN:   | FileCheck %s --check-prefix=DWARF-V7-FP-ELIM
84
85; RUN: llc -mtriple thumbv7-windows-gnu \
86; RUN:     -filetype=asm -o - %s \
87; RUN:   | FileCheck %s --check-prefix=DWARF-WIN-FP-ELIM
88
89;-------------------------------------------------------------------------------
90; Test 1
91;-------------------------------------------------------------------------------
92; This is the LLVM assembly generated from following C++ code:
93;
94;   extern void print(int, int, int, int, int);
95;   extern void print(double, double, double, double, double);
96;
97;   void test(int a, int b, int c, int d, int e,
98;             double m, double n, double p, double q, double r) {
99;     try {
100;       print(a, b, c, d, e);
101;     } catch (...) {
102;       print(m, n, p, q, r);
103;     }
104;   }
105
106declare void @_Z5printiiiii(i32, i32, i32, i32, i32)
107
108declare void @_Z5printddddd(double, double, double, double, double)
109
110define void @_Z4testiiiiiddddd(i32 %a, i32 %b, i32 %c, i32 %d, i32 %e,
111                               double %m, double %n, double %p,
112                               double %q, double %r) personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*) {
113entry:
114  invoke void @_Z5printiiiii(i32 %a, i32 %b, i32 %c, i32 %d, i32 %e)
115          to label %try.cont unwind label %lpad
116
117lpad:
118  %0 = landingpad { i8*, i32 }
119          catch i8* null
120  %1 = extractvalue { i8*, i32 } %0, 0
121  %2 = tail call i8* @__cxa_begin_catch(i8* %1)
122  invoke void @_Z5printddddd(double %m, double %n, double %p,
123                             double %q, double %r)
124          to label %invoke.cont2 unwind label %lpad1
125
126invoke.cont2:
127  tail call void @__cxa_end_catch()
128  br label %try.cont
129
130try.cont:
131  ret void
132
133lpad1:
134  %3 = landingpad { i8*, i32 }
135          cleanup
136  invoke void @__cxa_end_catch()
137          to label %eh.resume unwind label %terminate.lpad
138
139eh.resume:
140  resume { i8*, i32 } %3
141
142terminate.lpad:
143  %4 = landingpad { i8*, i32 }
144          catch i8* null
145  %5 = extractvalue { i8*, i32 } %4, 0
146  tail call void @__clang_call_terminate(i8* %5)
147  unreachable
148}
149
150declare void @__clang_call_terminate(i8*)
151
152declare i32 @__gxx_personality_v0(...)
153
154declare i8* @__cxa_begin_catch(i8*)
155
156declare void @__cxa_end_catch()
157
158declare void @_ZSt9terminatev()
159
160; CHECK-FP-LABEL: _Z4testiiiiiddddd:
161; CHECK-FP:   .fnstart
162; CHECK-FP:   .save  {r4, r5, r6, r7, r8, r9, r10, r11, lr}
163; CHECK-FP:   push   {r4, r5, r6, r7, r8, r9, r10, r11, lr}
164; CHECK-FP:   .setfp r11, sp, #28
165; CHECK-FP:   add    r11, sp, #28
166; CHECK-FP:   .pad   #44
167; CHECK-FP:   sub    sp, sp, #44
168; CHECK-FP:   .personality __gxx_personality_v0
169; CHECK-FP:   .handlerdata
170; CHECK-FP:   .fnend
171
172; CHECK-FP-ELIM-LABEL: _Z4testiiiiiddddd:
173; CHECK-FP-ELIM:   .fnstart
174; CHECK-FP-ELIM:   .save {r4, r5, r6, r7, r8, r9, r10, r11, lr}
175; CHECK-FP-ELIM:   push  {r4, r5, r6, r7, r8, r9, r10, r11, lr}
176; CHECK-FP-ELIM:   .pad  #36
177; CHECK-FP-ELIM:   sub   sp, sp, #36
178; CHECK-FP-ELIM:   .personality __gxx_personality_v0
179; CHECK-FP-ELIM:   .handlerdata
180; CHECK-FP-ELIM:   .fnend
181
182; CHECK-V7-FP-LABEL: _Z4testiiiiiddddd:
183; CHECK-V7-FP:   .fnstart
184; CHECK-V7-FP:   .save  {r4, r10, r11, lr}
185; CHECK-V7-FP:   push   {r4, r10, r11, lr}
186; CHECK-V7-FP:   .setfp r11, sp, #8
187; CHECK-V7-FP:   add    r11, sp, #8
188; CHECK-V7-FP:   .vsave {d8, d9, d10, d11, d12}
189; CHECK-V7-FP:   vpush  {d8, d9, d10, d11, d12}
190; CHECK-V7-FP:   .pad   #24
191; CHECK-V7-FP:   sub    sp, sp, #24
192; CHECK-V7-FP:   .personality __gxx_personality_v0
193; CHECK-V7-FP:   .handlerdata
194; CHECK-V7-FP:   .fnend
195
196; CHECK-V7-FP-ELIM-LABEL: _Z4testiiiiiddddd:
197; CHECK-V7-FP-ELIM:   .fnstart
198; CHECK-V7-FP-ELIM:   .save  {r4, lr}
199; CHECK-V7-FP-ELIM:   push   {r4, lr}
200; CHECK-V7-FP-ELIM:   .vsave {d8, d9, d10, d11, d12}
201; CHECK-V7-FP-ELIM:   vpush  {d8, d9, d10, d11, d12}
202; CHECK-V7-FP-ELIM:   .pad   #24
203; CHECK-V7-FP-ELIM:   sub    sp, sp, #24
204; CHECK-V7-FP-ELIM:   .personality __gxx_personality_v0
205; CHECK-V7-FP-ELIM:   .handlerdata
206; CHECK-V7-FP-ELIM:   .fnend
207
208; DWARF-FP-LABEL: _Z4testiiiiiddddd:
209; DWARF-FP:    .cfi_startproc
210; DWARF-FP:    .cfi_personality 0, __gxx_personality_v0
211; DWARF-FP:    .cfi_lsda 0, .Lexception0
212; DWARF-FP:    push {r4, r5, r6, r7, r8, r9, r10, r11, lr}
213; DWARF-FP:    .cfi_def_cfa_offset 36
214; DWARF-FP:    .cfi_offset lr, -4
215; DWARF-FP:    .cfi_offset r11, -8
216; DWARF-FP:    .cfi_offset r10, -12
217; DWARF-FP:    .cfi_offset r9, -16
218; DWARF-FP:    .cfi_offset r8, -20
219; DWARF-FP:    .cfi_offset r7, -24
220; DWARF-FP:    .cfi_offset r6, -28
221; DWARF-FP:    .cfi_offset r5, -32
222; DWARF-FP:    .cfi_offset r4, -36
223; DWARF-FP:    add r11, sp, #28
224; DWARF-FP:    .cfi_def_cfa r11, 8
225; DWARF-FP:    sub sp, sp, #44
226; DWARF-FP:    sub sp, r11, #28
227; DWARF-FP:    pop {r4, r5, r6, r7, r8, r9, r10, r11, lr}
228; DWARF-FP:    mov pc, lr
229; DWARF-FP:    .cfi_endproc
230
231; DWARF-FP-ELIM-LABEL: _Z4testiiiiiddddd:
232; DWARF-FP-ELIM:    .cfi_startproc
233; DWARF-FP-ELIM:    .cfi_personality 0, __gxx_personality_v0
234; DWARF-FP-ELIM:    .cfi_lsda 0, .Lexception0
235; DWARF-FP-ELIM:    push {r4, r5, r6, r7, r8, r9, r10, r11, lr}
236; DWARF-FP-ELIM:    .cfi_def_cfa_offset 36
237; DWARF-FP-ELIM:    .cfi_offset lr, -4
238; DWARF-FP-ELIM:    .cfi_offset r11, -8
239; DWARF-FP-ELIM:    .cfi_offset r10, -12
240; DWARF-FP-ELIM:    .cfi_offset r9, -16
241; DWARF-FP-ELIM:    .cfi_offset r8, -20
242; DWARF-FP-ELIM:    .cfi_offset r7, -24
243; DWARF-FP-ELIM:    .cfi_offset r6, -28
244; DWARF-FP-ELIM:    .cfi_offset r5, -32
245; DWARF-FP-ELIM:    .cfi_offset r4, -36
246; DWARF-FP-ELIM:    sub sp, sp, #36
247; DWARF-FP-ELIM:    .cfi_def_cfa_offset 72
248; DWARF-FP-ELIM:    add sp, sp, #36
249; DWARF-FP-ELIM:    pop {r4, r5, r6, r7, r8, r9, r10, r11, lr}
250; DWARF-FP-ELIM:    mov pc, lr
251; DWARF-FP-ELIM:    .cfi_endproc
252
253; DWARF-V7-FP-LABEL: _Z4testiiiiiddddd:
254; DWARF-V7-FP:    .cfi_startproc
255; DWARF-V7-FP:    .cfi_personality 0, __gxx_personality_v0
256; DWARF-V7-FP:    .cfi_lsda 0, .Lexception0
257; DWARF-V7-FP:    push {r4, r10, r11, lr}
258; DWARF-V7-FP:    .cfi_def_cfa_offset 16
259; DWARF-V7-FP:    .cfi_offset lr, -4
260; DWARF-V7-FP:    .cfi_offset r11, -8
261; DWARF-V7-FP:    .cfi_offset r10, -12
262; DWARF-V7-FP:    .cfi_offset r4, -16
263; DWARF-V7-FP:    add r11, sp, #8
264; DWARF-V7-FP:    .cfi_def_cfa r11, 8
265; DWARF-V7-FP:    vpush {d8, d9, d10, d11, d12}
266; DWARF-V7-FP:    .cfi_offset d12, -24
267; DWARF-V7-FP:    .cfi_offset d11, -32
268; DWARF-V7-FP:    .cfi_offset d10, -40
269; DWARF-V7-FP:    .cfi_offset d9, -48
270; DWARF-V7-FP:    sub sp, sp, #24
271; DWARF-V7-FP:    sub sp, r11, #48
272; DWARF-V7-FP:    vpop {d8, d9, d10, d11, d12}
273; DWARF-V7-FP:    pop {r4, r10, r11, pc}
274; DWARF-V7-FP:    .cfi_endproc
275
276; DWARF-V7-FP-ELIM-LABEL: _Z4testiiiiiddddd:
277; DWARF-V7-FP-ELIM:    .cfi_startproc
278; DWARF-V7-FP-ELIM:    .cfi_personality 0, __gxx_personality_v0
279; DWARF-V7-FP-ELIM:    .cfi_lsda 0, .Lexception0
280; DWARF-V7-FP-ELIM:    push {r4, lr}
281; DWARF-V7-FP-ELIM:    .cfi_def_cfa_offset 8
282; DWARF-V7-FP-ELIM:    .cfi_offset lr, -4
283; DWARF-V7-FP-ELIM:    .cfi_offset r4, -8
284; DWARF-V7-FP-ELIM:    vpush {d8, d9, d10, d11, d12}
285; DWARF-V7-FP-ELIM:    .cfi_offset d12, -16
286; DWARF-V7-FP-ELIM:    .cfi_offset d11, -24
287; DWARF-V7-FP-ELIM:    .cfi_offset d10, -32
288; DWARF-V7-FP-ELIM:    .cfi_offset d9, -40
289; DWARF-V7-FP-ELIM:    sub sp, sp, #24
290; DWARF-V7-FP-ELIM:    .cfi_def_cfa_offset 72
291; DWARF-V7-FP-ELIM:    add sp, sp, #24
292; DWARF-V7-FP-ELIM:    vpop {d8, d9, d10, d11, d12}
293; DWARF-V7-FP-ELIM:    pop {r4, pc}
294; DWARF-V7-FP-ELIM:    .cfi_endproc
295
296; DWARF-WIN-FP-ELIM-LABEL: _Z4testiiiiiddddd:
297; DWARF-WIN-FP-ELIM:    .cfi_startproc
298; DWARF-WIN-FP-ELIM:    .cfi_personality 0, __gxx_personality_v0
299; DWARF-WIN-FP-ELIM:    .cfi_lsda 0, .Lexception0
300; DWARF-WIN-FP-ELIM:    push {r4, lr}
301; DWARF-WIN-FP-ELIM:    .cfi_def_cfa_offset 8
302; DWARF-WIN-FP-ELIM:    .cfi_offset lr, -4
303; DWARF-WIN-FP-ELIM:    .cfi_offset r4, -8
304; DWARF-WIN-FP-ELIM:    vpush {d8, d9, d10, d11, d12}
305; DWARF-WIN-FP-ELIM:    .cfi_offset d12, -16
306; DWARF-WIN-FP-ELIM:    .cfi_offset d11, -24
307; DWARF-WIN-FP-ELIM:    .cfi_offset d10, -32
308; DWARF-WIN-FP-ELIM:    .cfi_offset d9, -40
309; DWARF-WIN-FP-ELIM:    sub sp, #8
310; DWARF-WIN-FP-ELIM:    .cfi_def_cfa_offset 56
311; DWARF-WIN-FP-ELIM:    add sp, #8
312; DWARF-WIN-FP-ELIM:    vpop {d8, d9, d10, d11, d12}
313; DWARF-WIN-FP-ELIM:    pop {r4, pc}
314; DWARF-WIN-FP-ELIM:    .cfi_endproc
315
316;-------------------------------------------------------------------------------
317; Test 2
318;-------------------------------------------------------------------------------
319
320declare void @throw_exception_2()
321
322define void @test2() {
323entry:
324  call void @throw_exception_2()
325  ret void
326}
327
328; CHECK-FP-LABEL: test2:
329; CHECK-FP:   .fnstart
330; CHECK-FP:   .save  {r11, lr}
331; CHECK-FP:   push   {r11, lr}
332; CHECK-FP:   .setfp r11, sp
333; CHECK-FP:   mov    r11, sp
334; CHECK-FP:   pop    {r11, lr}
335; CHECK-FP:   mov    pc, lr
336; CHECK-FP:   .fnend
337
338; CHECK-FP-ELIM-LABEL: test2:
339; CHECK-FP-ELIM:   .fnstart
340; CHECK-FP-ELIM:   .save {r11, lr}
341; CHECK-FP-ELIM:   push  {r11, lr}
342; CHECK-FP-ELIM:   pop   {r11, lr}
343; CHECK-FP-ELIM:   mov   pc, lr
344; CHECK-FP-ELIM:   .fnend
345
346; CHECK-V7-FP-LABEL: test2:
347; CHECK-V7-FP:   .fnstart
348; CHECK-V7-FP:   .save  {r11, lr}
349; CHECK-V7-FP:   push   {r11, lr}
350; CHECK-V7-FP:   .setfp r11, sp
351; CHECK-V7-FP:   mov    r11, sp
352; CHECK-V7-FP:   pop    {r11, pc}
353; CHECK-V7-FP:   .fnend
354
355; CHECK-V7-FP-ELIM-LABEL: test2:
356; CHECK-V7-FP-ELIM:   .fnstart
357; CHECK-V7-FP-ELIM:   .save {r11, lr}
358; CHECK-V7-FP-ELIM:   push  {r11, lr}
359; CHECK-V7-FP-ELIM:   pop   {r11, pc}
360; CHECK-V7-FP-ELIM:   .fnend
361
362; DWARF-FP-LABEL: test2:
363; DWARF-FP:    .cfi_startproc
364; DWARF-FP:    push {r11, lr}
365; DWARF-FP:    .cfi_def_cfa_offset 8
366; DWARF-FP:    .cfi_offset lr, -4
367; DWARF-FP:    .cfi_offset r11, -8
368; DWARF-FP:    mov  r11, sp
369; DWARF-FP:    .cfi_def_cfa_register r11
370; DWARF-FP:    pop  {r11, lr}
371; DWARF-FP:    mov  pc, lr
372; DWARF-FP:    .cfi_endproc
373
374; DWARF-FP-ELIM-LABEL: test2:
375; DWARF-FP-ELIM:    .cfi_startproc
376; DWARF-FP-ELIM:    push {r11, lr}
377; DWARF-FP-ELIM:    .cfi_def_cfa_offset 8
378; DWARF-FP-ELIM:    .cfi_offset lr, -4
379; DWARF-FP-ELIM:    .cfi_offset r11, -8
380; DWARF-FP-ELIM:    pop  {r11, lr}
381; DWARF-FP-ELIM:    mov  pc, lr
382; DWARF-FP-ELIM:    .cfi_endproc
383
384; DWARF-V7-FP-LABEL: test2:
385; DWARF-V7-FP:    .cfi_startproc
386; DWARF-V7-FP:    push {r11, lr}
387; DWARF-V7-FP:    .cfi_def_cfa_offset 8
388; DWARF-V7-FP:    .cfi_offset lr, -4
389; DWARF-V7-FP:    .cfi_offset r11, -8
390; DWARF-V7-FP:    mov  r11, sp
391; DWARF-V7-FP:    .cfi_def_cfa_register r11
392; DWARF-V7-FP:    pop  {r11, pc}
393; DWARF-V7-FP:    .cfi_endproc
394
395; DWARF-V7-FP-ELIM-LABEL: test2:
396; DWARF-V7-FP-ELIM:    .cfi_startproc
397; DWARF-V7-FP-ELIM:    push {r11, lr}
398; DWARF-V7-FP-ELIM:    .cfi_def_cfa_offset 8
399; DWARF-V7-FP-ELIM:    .cfi_offset lr, -4
400; DWARF-V7-FP-ELIM:    .cfi_offset r11, -8
401; DWARF-V7-FP-ELIM:    pop  {r11, pc}
402; DWARF-V7-FP-ELIM:    .cfi_endproc
403
404; DWARF-WIN-FP-ELIM-LABEL: test2:
405; DWARF-WIN-FP-ELIM:    .cfi_startproc
406; DWARF-WIN-FP-ELIM:    push.w {r11, lr}
407; DWARF-WIN-FP-ELIM:    .cfi_def_cfa_offset 8
408; DWARF-WIN-FP-ELIM:    .cfi_offset lr, -4
409; DWARF-WIN-FP-ELIM:    .cfi_offset r11, -8
410; DWARF-WIN-FP-ELIM:    pop.w  {r11, pc}
411; DWARF-WIN-FP-ELIM:    .cfi_endproc
412
413
414;-------------------------------------------------------------------------------
415; Test 3
416;-------------------------------------------------------------------------------
417
418declare void @throw_exception_3(i32)
419
420define i32 @test3(i32 %a, i32 %b, i32 %c, i32 %d,
421                  i32 %e, i32 %f, i32 %g, i32 %h) {
422entry:
423  %add = add nsw i32 %b, %a
424  %add1 = add nsw i32 %add, %c
425  %add2 = add nsw i32 %add1, %d
426  tail call void @throw_exception_3(i32 %add2)
427  %add3 = add nsw i32 %f, %e
428  %add4 = add nsw i32 %add3, %g
429  %add5 = add nsw i32 %add4, %h
430  tail call void @throw_exception_3(i32 %add5)
431  %add6 = add nsw i32 %add5, %add2
432  ret i32 %add6
433}
434
435; CHECK-FP-LABEL: test3:
436; CHECK-FP:   .fnstart
437; CHECK-FP:   .save  {r4, r5, r11, lr}
438; CHECK-FP:   push   {r4, r5, r11, lr}
439; CHECK-FP:   .setfp r11, sp, #8
440; CHECK-FP:   add    r11, sp, #8
441; CHECK-FP:   pop    {r4, r5, r11, lr}
442; CHECK-FP:   mov    pc, lr
443; CHECK-FP:   .fnend
444
445; CHECK-FP-ELIM-LABEL: test3:
446; CHECK-FP-ELIM:   .fnstart
447; CHECK-FP-ELIM:   .save {r4, r5, r11, lr}
448; CHECK-FP-ELIM:   push  {r4, r5, r11, lr}
449; CHECK-FP-ELIM:   pop   {r4, r5, r11, lr}
450; CHECK-FP-ELIM:   mov   pc, lr
451; CHECK-FP-ELIM:   .fnend
452
453; CHECK-V7-FP-LABEL: test3:
454; CHECK-V7-FP:   .fnstart
455; CHECK-V7-FP:   .save  {r4, r5, r11, lr}
456; CHECK-V7-FP:   push   {r4, r5, r11, lr}
457; CHECK-V7-FP:   .setfp r11, sp, #8
458; CHECK-V7-FP:   add    r11, sp, #8
459; CHECK-V7-FP:   pop    {r4, r5, r11, pc}
460; CHECK-V7-FP:   .fnend
461
462; CHECK-V7-FP-ELIM-LABEL: test3:
463; CHECK-V7-FP-ELIM:   .fnstart
464; CHECK-V7-FP-ELIM:   .save {r4, r5, r11, lr}
465; CHECK-V7-FP-ELIM:   push  {r4, r5, r11, lr}
466; CHECK-V7-FP-ELIM:   pop   {r4, r5, r11, pc}
467; CHECK-V7-FP-ELIM:   .fnend
468
469; DWARF-FP-LABEL: test3:
470; DWARF-FP:    .cfi_startproc
471; DWARF-FP:    push {r4, r5, r11, lr}
472; DWARF-FP:    .cfi_def_cfa_offset 16
473; DWARF-FP:    .cfi_offset lr, -4
474; DWARF-FP:    .cfi_offset r11, -8
475; DWARF-FP:    .cfi_offset r5, -12
476; DWARF-FP:    .cfi_offset r4, -16
477; DWARF-FP:    add  r11, sp, #8
478; DWARF-FP:    .cfi_def_cfa r11, 8
479; DWARF-FP:    pop  {r4, r5, r11, lr}
480; DWARF-FP:    mov  pc, lr
481; DWARF-FP:    .cfi_endproc
482
483; DWARF-FP-ELIM-LABEL: test3:
484; DWARF-FP-ELIM:    .cfi_startproc
485; DWARF-FP-ELIM:    push {r4, r5, r11, lr}
486; DWARF-FP-ELIM:    .cfi_def_cfa_offset 16
487; DWARF-FP-ELIM:    .cfi_offset lr, -4
488; DWARF-FP-ELIM:    .cfi_offset r11, -8
489; DWARF-FP-ELIM:    .cfi_offset r5, -12
490; DWARF-FP-ELIM:    .cfi_offset r4, -16
491; DWARF-FP-ELIM:    pop  {r4, r5, r11, lr}
492; DWARF-FP-ELIM:    mov  pc, lr
493; DWARF-FP-ELIM:    .cfi_endproc
494
495; DWARF-V7-FP-LABEL: test3:
496; DWARF-V7-FP:    .cfi_startproc
497; DWARF-V7-FP:    push {r4, r5, r11, lr}
498; DWARF-V7-FP:    .cfi_def_cfa_offset 16
499; DWARF-V7-FP:    .cfi_offset lr, -4
500; DWARF-V7-FP:    .cfi_offset r11, -8
501; DWARF-V7-FP:    .cfi_offset r5, -12
502; DWARF-V7-FP:    .cfi_offset r4, -16
503; DWARF-V7-FP:    add  r11, sp, #8
504; DWARF-V7-FP:    .cfi_def_cfa r11, 8
505; DWARF-V7-FP:    pop  {r4, r5, r11, pc}
506; DWARF-V7-FP:    .cfi_endproc
507
508; DWARF-V7-FP-ELIM-LABEL: test3:
509; DWARF-V7-FP-ELIM:    .cfi_startproc
510; DWARF-V7-FP-ELIM:    push {r4, r5, r11, lr}
511; DWARF-V7-FP-ELIM:    .cfi_def_cfa_offset 16
512; DWARF-V7-FP-ELIM:    .cfi_offset lr, -4
513; DWARF-V7-FP-ELIM:    .cfi_offset r11, -8
514; DWARF-V7-FP-ELIM:    .cfi_offset r5, -12
515; DWARF-V7-FP-ELIM:    .cfi_offset r4, -16
516; DWARF-V7-FP-ELIM:    pop  {r4, r5, r11, pc}
517; DWARF-V7-FP-ELIM:    .cfi_endproc
518
519; DWARF-WIN-FP-ELIM-LABEL: test3:
520; DWARF-WIN-FP-ELIM:    .cfi_startproc
521; DWARF-WIN-FP-ELIM:    push.w {r4, r5, r11, lr}
522; DWARF-WIN-FP-ELIM:    .cfi_def_cfa_offset 16
523; DWARF-WIN-FP-ELIM:    .cfi_offset lr, -4
524; DWARF-WIN-FP-ELIM:    .cfi_offset r11, -8
525; DWARF-WIN-FP-ELIM:    .cfi_offset r5, -12
526; DWARF-WIN-FP-ELIM:    .cfi_offset r4, -16
527; DWARF-WIN-FP-ELIM:    pop.w  {r4, r5, r11, pc}
528; DWARF-WIN-FP-ELIM:    .cfi_endproc
529
530
531;-------------------------------------------------------------------------------
532; Test 4
533;-------------------------------------------------------------------------------
534
535define void @test4() nounwind {
536entry:
537  ret void
538}
539
540; CHECK-FP-LABEL: test4:
541; CHECK-FP:   .fnstart
542; CHECK-FP:   mov pc, lr
543; CHECK-FP:   .cantunwind
544; CHECK-FP:   .fnend
545
546; CHECK-FP-ELIM-LABEL: test4:
547; CHECK-FP-ELIM:   .fnstart
548; CHECK-FP-ELIM:   mov pc, lr
549; CHECK-FP-ELIM:   .cantunwind
550; CHECK-FP-ELIM:   .fnend
551
552; CHECK-V7-FP-LABEL: test4:
553; CHECK-V7-FP:   .fnstart
554; CHECK-V7-FP:   bx lr
555; CHECK-V7-FP:   .cantunwind
556; CHECK-V7-FP:   .fnend
557
558; CHECK-V7-FP-ELIM-LABEL: test4:
559; CHECK-V7-FP-ELIM:   .fnstart
560; CHECK-V7-FP-ELIM:   bx lr
561; CHECK-V7-FP-ELIM:   .cantunwind
562; CHECK-V7-FP-ELIM:   .fnend
563
564; DWARF-FP-LABEL: test4:
565; DWARF-FP-NOT: .cfi_startproc
566; DWARF-FP:    mov pc, lr
567; DWARF-FP-NOT: .cfi_endproc
568; DWARF-FP:    .size test4,
569
570; DWARF-FP-ELIM-LABEL: test4:
571; DWARF-FP-ELIM-NOT: .cfi_startproc
572; DWARF-FP-ELIM:     mov pc, lr
573; DWARF-FP-ELIM-NOT: .cfi_endproc
574; DWARF-FP-ELIM:     .size test4,
575
576; DWARF-V7-FP-LABEL: test4:
577; DWARF-V7-FP-NOT: .cfi_startproc
578; DWARF-V7-FP:    bx lr
579; DWARF-V7-FP-NOT: .cfi_endproc
580; DWARF-V7-FP:    .size test4,
581
582; DWARF-V7-FP-ELIM-LABEL: test4:
583; DWARF-V7-FP-ELIM-NOT: .cfi_startproc
584; DWARF-V7-FP-ELIM:     bx lr
585; DWARF-V7-FP-ELIM-NOT: .cfi_endproc
586; DWARF-V7-FP-ELIM:     .size test4,
587
588; DWARF-WIN-FP-ELIM-LABEL: test4:
589; DWARF-WIN-FP-ELIM-NOT: .cfi_startproc
590; DWARF-WIN-FP-ELIM:     bx lr
591; DWARF-WIN-FP-ELIM-NOT: .cfi_endproc
592