Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / lld / test / COFF / tls-alignment-64.ll
blobb3baf8b2898fbaeff102d9f2b38bc11642f95638
1 ; REQUIRES: x86
3 ; This test is to make sure that the necessary alignment for thread locals
4 ; gets reflected in the TLS Directory of the generated executable on x86-64.
6 ; aligned_thread_local specifies 'align 64' and so the generated
7 ; exe should reflect that with a value of IMAGE_SCN_ALIGN_64BYTES
8 ; in the Characteristics field of the IMAGE_TLS_DIRECTORY
10 ; RUN: llc -filetype=obj %S/Inputs/tlssup-64.ll -o %t.tlssup.obj
11 ; RUN: llc -filetype=obj %s -o %t.obj
12 ; RUN: lld-link %t.tlssup.obj %t.obj -entry:main -nodefaultlib -out:%t.exe
13 ; RUN: llvm-readobj --coff-tls-directory %t.exe | FileCheck %s
15 ; CHECK: TLSDirectory {
16 ; CHECK: Characteristics [ (0x700000)
17 ; CHECK-NEXT: IMAGE_SCN_ALIGN_64BYTES (0x700000)
19 target triple = "x86_64-pc-windows-msvc"
21 @aligned_thread_local = thread_local global i32 42, align 64
23 define i32 @main() {
24   %t = load i32, ptr @aligned_thread_local
25   ret i32 %t