xref: /aosp_15_r20/external/llvm/test/CodeGen/AArch64/emutls_generic.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -emulated-tls -mtriple=aarch64-linux-android -relocation-model=pic \
2*9880d681SAndroid Build Coastguard Worker; RUN:     | FileCheck -check-prefix=ARM_64 %s
3*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -emulated-tls -mtriple=aarch64-linux-android -relocation-model=pic -O3 \
4*9880d681SAndroid Build Coastguard Worker; RUN:     | FileCheck -check-prefix=ARM_64 %s
5*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -emulated-tls -mtriple=aarch64-linux-android -O3 \
6*9880d681SAndroid Build Coastguard Worker; RUN:     | FileCheck -check-prefix=ARM_64 %s
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Worker; Make sure that TLS symbols are emitted in expected order.
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Worker@external_x = external thread_local global i32, align 8
11*9880d681SAndroid Build Coastguard Worker@external_y = thread_local global i8 7, align 2
12*9880d681SAndroid Build Coastguard Worker@internal_y = internal thread_local global i64 9, align 16
13*9880d681SAndroid Build Coastguard Worker
14*9880d681SAndroid Build Coastguard Workerdefine i32* @get_external_x() {
15*9880d681SAndroid Build Coastguard Workerentry:
16*9880d681SAndroid Build Coastguard Worker  ret i32* @external_x
17*9880d681SAndroid Build Coastguard Worker}
18*9880d681SAndroid Build Coastguard Worker
19*9880d681SAndroid Build Coastguard Workerdefine i8* @get_external_y() {
20*9880d681SAndroid Build Coastguard Workerentry:
21*9880d681SAndroid Build Coastguard Worker  ret i8* @external_y
22*9880d681SAndroid Build Coastguard Worker}
23*9880d681SAndroid Build Coastguard Worker
24*9880d681SAndroid Build Coastguard Workerdefine i64* @get_internal_y() {
25*9880d681SAndroid Build Coastguard Workerentry:
26*9880d681SAndroid Build Coastguard Worker  ret i64* @internal_y
27*9880d681SAndroid Build Coastguard Worker}
28*9880d681SAndroid Build Coastguard Worker
29*9880d681SAndroid Build Coastguard Worker; ARM_64-LABEL:  get_external_x:
30*9880d681SAndroid Build Coastguard Worker; ARM_64:      __emutls_v.external_x
31*9880d681SAndroid Build Coastguard Worker; ARM_64:      __emutls_get_address
32*9880d681SAndroid Build Coastguard Worker; ARM_64-LABEL:  get_external_y:
33*9880d681SAndroid Build Coastguard Worker; ARM_64:      __emutls_v.external_y
34*9880d681SAndroid Build Coastguard Worker; ARM_64:      __emutls_get_address
35*9880d681SAndroid Build Coastguard Worker; ARM_64-LABEL:  get_internal_y:
36*9880d681SAndroid Build Coastguard Worker; ARM_64:      __emutls_v.internal_y
37*9880d681SAndroid Build Coastguard Worker; ARM_64:      __emutls_get_address
38*9880d681SAndroid Build Coastguard Worker; ARM_64-NOT:   __emutls_t.external_x
39*9880d681SAndroid Build Coastguard Worker; ARM_64-NOT:   __emutls_v.external_x:
40*9880d681SAndroid Build Coastguard Worker; ARM_64:        .data{{$}}
41*9880d681SAndroid Build Coastguard Worker; ARM_64:        .globl __emutls_v.external_y
42*9880d681SAndroid Build Coastguard Worker; ARM_64:        .p2align 3
43*9880d681SAndroid Build Coastguard Worker; ARM_64-LABEL:  __emutls_v.external_y:
44*9880d681SAndroid Build Coastguard Worker; ARM_64-NEXT:   .xword 1
45*9880d681SAndroid Build Coastguard Worker; ARM_64-NEXT:   .xword 2
46*9880d681SAndroid Build Coastguard Worker; ARM_64-NEXT:   .xword 0
47*9880d681SAndroid Build Coastguard Worker; ARM_64-NEXT:   .xword __emutls_t.external_y
48*9880d681SAndroid Build Coastguard Worker; ARM_64-NOT:    __emutls_v.external_x:
49*9880d681SAndroid Build Coastguard Worker; ARM_64:        .section .rodata,
50*9880d681SAndroid Build Coastguard Worker; ARM_64-LABEL:  __emutls_t.external_y:
51*9880d681SAndroid Build Coastguard Worker; ARM_64-NEXT:   .byte 7
52*9880d681SAndroid Build Coastguard Worker; ARM_64:        .data{{$}}
53*9880d681SAndroid Build Coastguard Worker; ARM_64-NOT:    .globl __emutls_v
54*9880d681SAndroid Build Coastguard Worker; ARM_64:        .p2align 3
55*9880d681SAndroid Build Coastguard Worker; ARM_64-LABEL:  __emutls_v.internal_y:
56*9880d681SAndroid Build Coastguard Worker; ARM_64-NEXT:   .xword 8
57*9880d681SAndroid Build Coastguard Worker; ARM_64-NEXT:   .xword 16
58*9880d681SAndroid Build Coastguard Worker; ARM_64-NEXT:   .xword 0
59*9880d681SAndroid Build Coastguard Worker; ARM_64-NEXT:   .xword __emutls_t.internal_y
60*9880d681SAndroid Build Coastguard Worker; ARM_64:        .section .rodata,
61*9880d681SAndroid Build Coastguard Worker; ARM_64-LABEL:  __emutls_t.internal_y:
62*9880d681SAndroid Build Coastguard Worker; ARM_64-NEXT:   .xword 9
63