mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +00:00 
			
		
		
		
	This patch fixes the ldr-pseudo implementation to work when used in inline assembly. The fix is to move arm assembler constant pools from the ARMAsmParser class to the ARMTargetStreamer class. Previously we kept the assembler generated constant pools in the ARMAsmParser object. This does not work for inline assembly because a new parser object is created for each blob of inline assembly. This patch moves the constant pools to the ARMTargetStreamer class so that the constant pool will remain alive for the entire code generation process. An ARMTargetStreamer class is now required for the arm backend. There was no existing implementation for MachO, only Asm and ELF. Instead of creating an empty MachO subclass, we decided to make the ARMTargetStreamer a non-abstract class and provide default (llvm_unreachable) implementations for the non constant-pool related methods. Differential Revision: http://llvm-reviews.chandlerc.com/D2638 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@200777 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			18 lines
		
	
	
		
			879 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			18 lines
		
	
	
		
			879 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; PR18354
 | |
| ; We actually need to use -filetype=obj in this test because if we output
 | |
| ; assembly, the current code path will bypass the parser and just write the
 | |
| ; raw text out to the Streamer. We need to actually parse the inlineasm to
 | |
| ; demonstrate the bug. Going the asm->obj route does not show the issue.
 | |
| ; RUN: llc -mtriple=arm-none-linux   < %s -filetype=obj | llvm-objdump -d - | FileCheck %s
 | |
| ; RUN: llc -mtriple=arm-apple-darwin < %s -filetype=obj | llvm-objdump -d - | FileCheck %s
 | |
| ; CHECK-LABEL: foo:
 | |
| ; CHECK: 0:       00 00 9f e5                                     ldr     r0, [pc]
 | |
| ; CHECK: 4:       0e f0 a0 e1                                     mov     pc, lr
 | |
| ; Make sure the constant pool entry comes after the return
 | |
| ; CHECK: 8:       01 00 00 00
 | |
| define i32 @foo() nounwind {
 | |
| entry:
 | |
|   %0 = tail call i32 asm sideeffect "ldr $0,=1", "=r"() nounwind
 | |
|   ret i32 %0
 | |
| }
 |