summaryrefslogtreecommitdiff
path: root/test/CodeGen/X86/tls-windows-itanium.ll
blob: 20ac09901969cba09270eaac543031720fc2dca0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
; RUN: llc -mtriple i686-windows-itanium -filetype asm -o - %s | FileCheck %s -check-prefix CHECK-ASM
; RUN: llc -mtriple i686-windows-itanium -filetype obj -o - %s | llvm-readobj -relocations - | FileCheck %s -check-prefix CHECK-OBJ

@get_count_incremented.count = internal thread_local unnamed_addr global i32 0, align 4

define i32 @get_count_incremented() {
entry:
  %0 = load i32, i32* @get_count_incremented.count, align 4
  %inc = add i32 %0, 1
  store i32 %inc, i32* @get_count_incremented.count, align 4
  ret i32 %inc
}

; CHECK-ASM-LABEL: _get_count_incremented:
; CHECK-ASM: movl __tls_index, %eax
; CHECK-ASM: movl %fs:__tls_array, %ecx
; CHECK-ASM: movl (%ecx,%eax,4), %ecx
; CHECK-ASM: _get_count_incremented.count@SECREL32(%ecx), %eax
; CHECK-ASM: incl %eax
; CHECK-ASM: movl %eax, _get_count_incremented.count@SECREL32(%ecx)
; CHECK-ASM: retl

; CHECK-OBJ: Relocations [
; CHECK-OBJ:   Section ({{[0-9]+}}) .text {
; CHECK-OBJ:     0x1 IMAGE_REL_I386_DIR32 __tls_index
; CHECK-OBJ:     0x8 IMAGE_REL_I386_DIR32 __tls_array
; CHECK-OBJ:     0x11 IMAGE_REL_I386_SECREL _get_count_incremented.count
; CHECK-OBJ:     0x18 IMAGE_REL_I386_SECREL _get_count_incremented.count
; CHECK-OBJ:   }
; CHECK-OBJ: ]