mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +00:00 
			
		
		
		
	Previously, all ARM::CONSTPOOL_ENTRY instructions had a hardwired alignment of 4 bytes emitted by ARMAsmPrinter. Now the same alignment is set on the basic block. This is in preparation of supporting ARM constant pool islands with different alignments. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@145890 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			75 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; RUN: llc < %s -mtriple=armv6-apple-darwin -relocation-model=static | FileCheck %s -check-prefix=DarwinStatic
 | |
| ; RUN: llc < %s -mtriple=armv6-apple-darwin -relocation-model=dynamic-no-pic | FileCheck %s -check-prefix=DarwinDynamic
 | |
| ; RUN: llc < %s -mtriple=armv6-apple-darwin -relocation-model=pic | FileCheck %s -check-prefix=DarwinPIC
 | |
| ; RUN: llc < %s -mtriple=armv6-linux-gnueabi -relocation-model=pic | FileCheck %s -check-prefix=LinuxPIC
 | |
| 
 | |
| @G = external global i32
 | |
| 
 | |
| define i32 @test1() {
 | |
| 	%tmp = load i32* @G
 | |
| 	ret i32 %tmp
 | |
| }
 | |
| 
 | |
| ; DarwinStatic: _test1:
 | |
| ; DarwinStatic: 	ldr r0, LCPI0_0
 | |
| ; DarwinStatic:	        ldr r0, [r0]
 | |
| ; DarwinStatic:	        bx lr
 | |
| 
 | |
| ; DarwinStatic: 	.align	2
 | |
| ; DarwinStatic:	LCPI0_0:
 | |
| ; DarwinStatic: 	.long	{{_G$}}
 | |
| 
 | |
| 
 | |
| ; DarwinDynamic: _test1:
 | |
| ; DarwinDynamic: 	ldr r0, LCPI0_0
 | |
| ; DarwinDynamic:        ldr r0, [r0]
 | |
| ; DarwinDynamic:        ldr r0, [r0]
 | |
| ; DarwinDynamic:        bx lr
 | |
| 
 | |
| ; DarwinDynamic: 	.align	2
 | |
| ; DarwinDynamic:	LCPI0_0:
 | |
| ; DarwinDynamic: 	.long	L_G$non_lazy_ptr
 | |
| 
 | |
| ; DarwinDynamic: 	.section __DATA,__nl_symbol_ptr,non_lazy_symbol_pointers
 | |
| ; DarwinDynamic:	.align	2
 | |
| ; DarwinDynamic: L_G$non_lazy_ptr:
 | |
| ; DarwinDynamic:	.indirect_symbol _G
 | |
| ; DarwinDynamic:	.long	0
 | |
| 
 | |
| 
 | |
| 
 | |
| ; DarwinPIC: _test1:
 | |
| ; DarwinPIC: 	ldr r0, LCPI0_0
 | |
| ; DarwinPIC: LPC0_0:
 | |
| ; DarwinPIC:    ldr r0, [pc, r0]
 | |
| ; DarwinPIC:    ldr r0, [r0]
 | |
| ; DarwinPIC:    bx lr
 | |
| 
 | |
| ; DarwinPIC: 	.align	2
 | |
| ; DarwinPIC: LCPI0_0:
 | |
| ; DarwinPIC: 	.long	L_G$non_lazy_ptr-(LPC0_0+8)
 | |
| 
 | |
| ; DarwinPIC: 	.section __DATA,__nl_symbol_ptr,non_lazy_symbol_pointers
 | |
| ; DarwinPIC:	.align	2
 | |
| ; DarwinPIC: L_G$non_lazy_ptr:
 | |
| ; DarwinPIC:	.indirect_symbol _G
 | |
| ; DarwinPIC:	.long	0
 | |
| 
 | |
| 
 | |
| 
 | |
| ; LinuxPIC: test1:
 | |
| ; LinuxPIC: 	ldr r0, .LCPI0_0
 | |
| ; LinuxPIC: 	ldr r1, .LCPI0_1
 | |
| 	
 | |
| ; LinuxPIC: .LPC0_0:
 | |
| ; LinuxPIC: 	add r0, pc, r0
 | |
| ; LinuxPIC: 	ldr r0, [r1, r0]
 | |
| ; LinuxPIC: 	ldr r0, [r0]
 | |
| ; LinuxPIC: 	bx lr
 | |
| 
 | |
| ; LinuxPIC: .align 2
 | |
| ; LinuxPIC: .LCPI0_0:
 | |
| ; LinuxPIC:     .long _GLOBAL_OFFSET_TABLE_-(.LPC0_0+8)
 | |
| ; LinuxPIC: .LCPI0_1:
 | |
| ; LinuxPIC:     .long	G(GOT)
 |