| ; 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 |
| } |