mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 11:13:28 +01:00
be1a902cbd
The x86-64 General Dynamic TLS code sequence uses prefixes to allow linker relaxation. Adding segment override prefix or NOPs can break linker relaxation (ld -pie/-no-pie). i386 General Dynamic and x86-64 Local Dynamic do not use prefixes, but for simplicity, just disable auto padding consistently. Reviewed By: skan, LuoYuanke Differential Revision: https://reviews.llvm.org/D72878
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
|
|
}
|