31 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			31 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			LLVM
		
	
	
	
| ;; Test that we don't pad the x86-64 General Dynamic/Local Dynamic TLS code
 | |
| ;; sequence. It uses prefixes to allow linker relaxation. We need to disable
 | |
| ;; prefix or nop padding for it. For simplicity and consistency, disable for
 | |
| ;; Local Dynamic and 32-bit as well.
 | |
| ; RUN: llc -mtriple=i386 -relocation-model=pic -x86-branches-within-32B-boundaries < %s | FileCheck --check-prefixes=CHECK,32 %s
 | |
| ; RUN: llc -mtriple=x86_64 -relocation-model=pic -x86-branches-within-32B-boundaries < %s | FileCheck --check-prefixes=CHECK,64 %s
 | |
| 
 | |
| @gd = external thread_local global i32
 | |
| @ld = internal thread_local global i32 0
 | |
| 
 | |
| define i32 @tls_get_addr() {
 | |
| ; CHECK-LABEL: tls_get_addr:
 | |
| ; CHECK: #noautopadding
 | |
| ; 32: leal gd@TLSGD(,%ebx), %eax
 | |
| ; 32: calll ___tls_get_addr@PLT
 | |
| ; 64: data16
 | |
| ; 64: leaq gd@TLSGD(%rip), %rdi
 | |
| ; 64: callq __tls_get_addr@PLT
 | |
| ; CHECK: #autopadding
 | |
| ; CHECK: #noautopadding
 | |
| ; 32: leal ld@TLSLDM(%ebx), %eax
 | |
| ; 32: calll ___tls_get_addr@PLT
 | |
| ; 64: leaq ld@TLSLD(%rip), %rdi
 | |
| ; 64: callq __tls_get_addr@PLT
 | |
| ; CHECK: #autopadding
 | |
|   %1 = load i32, i32* @gd
 | |
|   %2 = load i32, i32* @ld
 | |
|   %3 = add i32 %1, %2
 | |
|   ret i32 %3
 | |
| }
 |