2020-10-14 15:29:06 +08:00
|
|
|
; REQUIRES: x86
|
|
|
|
|
2020-10-07 10:16:34 +08:00
|
|
|
; This test is to make sure that the necessary alignment for thread locals
|
|
|
|
; gets reflected in the TLS Directory of the generated executable on x86-64.
|
|
|
|
;
|
|
|
|
; aligned_thread_local specifies 'align 64' and so the generated
|
|
|
|
; exe should reflect that with a value of IMAGE_SCN_ALIGN_64BYTES
|
|
|
|
; in the Characteristics field of the IMAGE_TLS_DIRECTORY
|
|
|
|
|
|
|
|
; RUN: llc -filetype=obj %S/Inputs/tlssup-64.ll -o %t.tlssup.obj
|
|
|
|
; RUN: llc -filetype=obj %s -o %t.obj
|
|
|
|
; RUN: lld-link %t.tlssup.obj %t.obj -entry:main -nodefaultlib -out:%t.exe
|
|
|
|
; RUN: llvm-readobj --coff-tls-directory %t.exe | FileCheck %s
|
|
|
|
|
|
|
|
; CHECK: TLSDirectory {
|
2020-10-15 15:06:46 +08:00
|
|
|
; CHECK: Characteristics [ (0x700000)
|
|
|
|
; CHECK-NEXT: IMAGE_SCN_ALIGN_64BYTES (0x700000)
|
2020-10-07 10:16:34 +08:00
|
|
|
|
|
|
|
target triple = "x86_64-pc-windows-msvc"
|
|
|
|
|
|
|
|
@aligned_thread_local = thread_local global i32 42, align 64
|
|
|
|
|
|
|
|
define i32 @main() {
|
|
|
|
%t = load i32, i32* @aligned_thread_local
|
|
|
|
ret i32 %t
|
|
|
|
}
|