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