summaryrefslogtreecommitdiff
path: root/test/CodeGen/Hexagon/tls_static.ll
blob: f4e882b4ff28575d8c2651dab2e3245c6c161d36 (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
; RUN: llc -O0 -mtriple=hexagon-- -relocation-model=static < %s | FileCheck %s

@dst_le = thread_local global i32 0, align 4
@src_le = thread_local global i32 0, align 4

; CHECK-LABEL: test_local_exec
; CHECK-DAG:   ##src_le@TPREL
; CHECK-DAG:   ##dst_le@TPREL
define i32 @test_local_exec() nounwind {
entry:
  %0 = load i32, i32* @src_le, align 4
  store i32 %0, i32* @dst_le, align 4
  ret i32 0
}

@dst_ie = external thread_local global i32
@src_ie = external thread_local global i32

; CHECK-LABEL: test_initial_exec:
; CHECK-DAG:   = memw(##src_ie@IE)
; CHECK-DAG:   = memw(##dst_ie@IE)
define i32 @test_initial_exec() nounwind {
entry:
  %0 = load i32, i32* @src_ie, align 4
  store i32 %0, i32* @dst_ie, align 4
  ret i32 0
}