blob: 04813ca0021e7f9b9ed5224a2040471bbf7a8c94 [file] [log] [blame]
; REQUIRES: x86
; 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 {
; CHECK: Characteristics [ (0x700000)
; CHECK-NEXT: IMAGE_SCN_ALIGN_64BYTES (0x700000)
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
}