summaryrefslogtreecommitdiff
path: root/test/CodeGen/ARM/emutls1.ll
blob: 18d32646e15d945bb37222b16aab142170f85614 (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
31
; RUN: llc < %s -emulated-tls -mtriple=arm-linux-androideabi \
; RUN:     | FileCheck %s
; RUN: llc < %s -emulated-tls -mtriple=arm-linux-androideabi \
; RUN:     -relocation-model=pic | FileCheck %s --check-prefix=PIC

; Compared with tls1.ll, emulated mode should not use __aeabi_read_tp or __tls_get_addr.

; CHECK-NOT: _aeabi_read_tp
; CHECK-NOT: _tls_get_addr
; CHECK:     __emutls_get_addr
; CHECK-NOT: __aeabi_read_tp
; CHECK-NOT: _tls_get_addr

; PIC-NOT: _aeabi_read_tp
; PIC-NOT: _tls_get_addr
; PIC:     __emutls_get_addr
; PIC-NOT: _aeabi_read_tp
; PIC-NOT: _tls_get_addr

@i = thread_local global i32 15 ; <i32*> [#uses=2]

define i32 @f() {
entry:
 %tmp1 = load i32, i32* @i ; <i32> [#uses=1]
 ret i32 %tmp1
}

define i32* @g() {
entry:
 ret i32* @i
}