mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-30 16:17:05 +00:00 
			
		
		
		
	Every target we support has support for assembly that looks like a = b - c .long a What is special about MachO is that the above combination suppresses the production of a relocation. With this change we avoid producing the intermediary labels when they don't add any value. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@220256 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			64 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; RUN: llc -mtriple=x86_64-unknown-linux -mcpu=corei7                             < %s | FileCheck %s
 | |
| 
 | |
| ; Test invoking of patchpoints
 | |
| ;
 | |
| define i64 @patchpoint_invoke(i64 %p1, i64 %p2) {
 | |
| entry:
 | |
| ; CHECK-LABEL: patchpoint_invoke:
 | |
| ; CHECK-NEXT: .cfi_startproc
 | |
| ; CHECK:      [[FUNC_BEGIN:.L.*]]:
 | |
| ; CHECK:      .cfi_lsda 3, [[EXCEPTION_LABEL:.L[^ ]*]]
 | |
| ; CHECK:      pushq %rbp
 | |
| 
 | |
| ; Unfortunately, hardcode the name of the label that begins the patchpoint:
 | |
| ; CHECK:      .Ltmp0:
 | |
| ; CHECK:      movabsq $-559038736, %r11
 | |
| ; CHECK-NEXT: callq *%r11
 | |
| ; CHECK-NEXT: xchgw %ax, %ax
 | |
| ; CHECK-NEXT: [[PP_END:.L.*]]:
 | |
| ; CHECK:      ret
 | |
|   %resolveCall = inttoptr i64 -559038736 to i8*
 | |
|   %result = invoke i64 (i64, i32, i8*, i32, ...)* @llvm.experimental.patchpoint.i64(i64 2, i32 15, i8* %resolveCall, i32 1, i64 %p1, i64 %p2)
 | |
|             to label %success unwind label %threw
 | |
| 
 | |
| success:
 | |
|   ret i64 %result
 | |
| 
 | |
| threw:
 | |
|   %0 = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
 | |
|           catch i8* null
 | |
|   ret i64 0
 | |
| }
 | |
| 
 | |
| ; Verify that the exception table was emitted:
 | |
| ; CHECK:      [[EXCEPTION_LABEL]]:
 | |
| ; CHECK-NEXT: .byte 255
 | |
| ; CHECK-NEXT: .byte 3
 | |
| ; CHECK-NEXT: .byte 21
 | |
| ; CHECK-NEXT: .byte 3
 | |
| ; CHECK-NEXT: .byte 13
 | |
| ; Verify that the unwind data covers the entire patchpoint region:
 | |
| ; CHECK-NEXT: .long .Ltmp0-[[FUNC_BEGIN]]
 | |
| ; CHECK-NEXT: .long [[PP_END]]-.Ltmp0
 | |
| 
 | |
| 
 | |
| ; Verify that the stackmap section got emitted:
 | |
| ; CHECK-LABEL: __LLVM_StackMaps:
 | |
| ; Header
 | |
| ; CHECK-NEXT:   .byte 1
 | |
| ; CHECK-NEXT:   .byte 0
 | |
| ; CHECK-NEXT:   .short 0
 | |
| ; Num Functions
 | |
| ; CHECK-NEXT:   .long 1
 | |
| ; Num LargeConstants
 | |
| ; CHECK-NEXT:   .long 0
 | |
| ; Num Callsites
 | |
| ; CHECK-NEXT:   .long 1
 | |
| ; CHECK-NEXT:   .quad patchpoint_invoke
 | |
| 
 | |
| 
 | |
| declare void @llvm.experimental.stackmap(i64, i32, ...)
 | |
| declare void @llvm.experimental.patchpoint.void(i64, i32, i8*, i32, ...)
 | |
| declare i64 @llvm.experimental.patchpoint.i64(i64, i32, i8*, i32, ...)
 | |
| declare i32 @__gxx_personality_v0(...)
 |