xref: /llvm-project/llvm/test/CodeGen/M68k/TLS/tlsld.ll (revision 65b710efc19d46932308097258ae1f8167edcbf2)
1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2; RUN: llc -mtriple=m68k --relocation-model=pic -o - %s | FileCheck %s
3
4@myvar = internal thread_local global i32 2, align 4
5
6define dso_local ptr @get_addr() nounwind {
7; CHECK-LABEL: get_addr:
8; CHECK:       ; %bb.0: ; %entry
9; CHECK-NEXT:    suba.l #4, %sp
10; CHECK-NEXT:    lea (_GLOBAL_OFFSET_TABLE_@GOTPCREL,%pc), %a0
11; CHECK-NEXT:    lea (myvar@TLSLDM,%a0), %a0
12; CHECK-NEXT:    move.l %a0, (%sp)
13; CHECK-NEXT:    jsr (__tls_get_addr@PLT,%pc)
14; CHECK-NEXT:    lea (myvar@TLSLD,%a0), %a0
15; CHECK-NEXT:    adda.l #4, %sp
16; CHECK-NEXT:    rts
17entry:
18  %0 = call align 4 ptr @llvm.threadlocal.address.p0(ptr align 4 @myvar)
19  ret ptr %0
20}
21
22declare nonnull ptr @llvm.threadlocal.address.p0(ptr nonnull)
23