94 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
			
		
		
	
	
			94 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
| @ Integrated test for ARM unwind directive parser and assembler.
 | |
| 
 | |
| @ This is a simplified real world test case generated from this C++ code
 | |
| @ (with and without -fomit-frame-pointer)
 | |
| @
 | |
| @   extern void print(int, int, int, int, int);
 | |
| @   extern void print(double, double, double, double, double);
 | |
| @
 | |
| @   void test(int a, int b, int c, int d, int e,
 | |
| @             double m, double n, double p, double q, double r) {
 | |
| @     try {
 | |
| @       print(a, b, c, d, e);
 | |
| @     } catch (...) {
 | |
| @       print(m, n, p, q, r);
 | |
| @     }
 | |
| @   }
 | |
| @
 | |
| @ This test case should check the unwind opcode to adjust the opcode and
 | |
| @ restore the general-purpose and VFP registers.
 | |
| 
 | |
| 
 | |
| @ RUN: llvm-mc %s -triple=armv7-unknown-linux-gnueabi -filetype=obj -o - \
 | |
| @ RUN:   | llvm-readobj -s -sd | FileCheck %s
 | |
| 
 | |
| 
 | |
| @-------------------------------------------------------------------------------
 | |
| @ Assembly without frame pointer elimination
 | |
| @-------------------------------------------------------------------------------
 | |
| 	.syntax unified
 | |
| 	.section	.TEST1
 | |
| 	.globl	func1
 | |
| 	.align	2
 | |
| 	.type	func1,%function
 | |
| func1:
 | |
| 	.fnstart
 | |
| 	.save	{r4, r11, lr}
 | |
| 	push	{r4, r11, lr}
 | |
| 	.setfp	r11, sp, #4
 | |
| 	add	r11, sp, #4
 | |
| 	.vsave	{d8, d9, d10, d11, d12}
 | |
| 	vpush	{d8, d9, d10, d11, d12}
 | |
| 	.pad	#28
 | |
| 	sub	sp, sp, #28
 | |
| 	sub	sp, r11, #44
 | |
| 	vpop	{d8, d9, d10, d11, d12}
 | |
| 	pop	{r4, r11, pc}
 | |
| .Ltmp1:
 | |
| 	.size	func1, .Ltmp1-func1
 | |
| 	.globl	__gxx_personality_v0
 | |
| 	.personality __gxx_personality_v0
 | |
| 	.handlerdata
 | |
| 	.fnend
 | |
| 
 | |
| @ CHECK: Section {
 | |
| @ CHECK:   Name: .ARM.extab.TEST1
 | |
| @ CHECK:   SectionData (
 | |
| @ CHECK:     0000: 00000000 C94A9B01 B0818484           |.....J......|
 | |
| @ CHECK:   )
 | |
| @ CHECK: }
 | |
| 
 | |
| 
 | |
| 
 | |
| @-------------------------------------------------------------------------------
 | |
| @ Assembly with frame pointer elimination
 | |
| @-------------------------------------------------------------------------------
 | |
| 	.section	.TEST2
 | |
| 	.globl	func2
 | |
| 	.align	2
 | |
| 	.type	func2,%function
 | |
| func2:
 | |
| 	.fnstart
 | |
| 	.save	{r4, lr}
 | |
| 	push	{r4, lr}
 | |
| 	.vsave	{d8, d9, d10, d11, d12}
 | |
| 	vpush	{d8, d9, d10, d11, d12}
 | |
| 	.pad	#24
 | |
| 	sub	sp, sp, #24
 | |
| 	add	sp, sp, #24
 | |
| 	vpop	{d8, d9, d10, d11, d12}
 | |
| 	pop	{r4, pc}
 | |
| .Ltmp2:
 | |
| 	.size	func2, .Ltmp2-func2
 | |
| 	.globl	__gxx_personality_v0
 | |
| 	.personality __gxx_personality_v0
 | |
| 	.handlerdata
 | |
| 	.fnend
 | |
| 
 | |
| @ CHECK: Section {
 | |
| @ CHECK:   Name: .ARM.extab.TEST2
 | |
| @ CHECK:   SectionData (
 | |
| @ CHECK:     0000: 00000000 84C90501 B0B0B0A8           |............|
 | |
| @ CHECK:   )
 | |
| @ CHECK: }
 |