xref: /llvm-project/llvm/test/MC/PowerPC/ppc32-tls.s (revision 6e07e90890d61b1be19d3f5fbf00ea7430068325)
1# RUN: llvm-mc -triple=powerpc %s | FileCheck %s --check-prefix=ASM
2# RUN: llvm-mc -filetype=obj -triple=powerpc %s -o %t
3# RUN: llvm-readobj -r %t | FileCheck %s
4
5# RUN: not llvm-mc -triple=powerpc --defsym ERR=1 %s 2>&1 | FileCheck %s --check-prefix=ERR --implicit-check-not=error:
6
7# ASM: bl __tls_get_addr(a@tlsgd)
8# ASM: bl __tls_get_addr(b@tlsld)
9# ASM: bl __tls_get_addr(c@tlsgd)@PLT
10# ASM: bl __tls_get_addr(d@tlsld)@PLT+32768
11# ASM: bl __tls_get_addr(e@tlsld)@PLT+32768
12bl __tls_get_addr(a@tlsgd)
13bl __tls_get_addr(b@tlsld)
14bl __tls_get_addr(c@tlsgd)@plt
15bl __tls_get_addr(d@tlsld)@PLT+32768
16bl __tls_get_addr+32768(e@tlsld)@plt  # gcc -fPIC
17
18## These are not present in the wild, but just to test we can parse them.
19# ASM: bl __tls_get_addr(f@tlsld)@PLT+1+(-2)
20bl __tls_get_addr+1(f@tlsld)@PLT+-2
21# ASM: bl __tls_get_addr(g@tlsld)@PLT+1+(y-x)
22x:
23bl __tls_get_addr+1(g@tlsld)@PLT+(y-x)
24y:
25
26# CHECK:      .rela.text {
27# CHECK-NEXT:   0x0 R_PPC_TLSGD a 0x0
28# CHECK-NEXT:   0x0 R_PPC_REL24 __tls_get_addr 0x0
29# CHECK-NEXT:   0x4 R_PPC_TLSLD b 0x0
30# CHECK-NEXT:   0x4 R_PPC_REL24 __tls_get_addr 0x0
31# CHECK-NEXT:   0x8 R_PPC_TLSGD c 0x0
32# CHECK-NEXT:   0x8 R_PPC_PLTREL24 __tls_get_addr 0x0
33# CHECK-NEXT:   0xC R_PPC_TLSLD d 0x0
34# CHECK-NEXT:   0xC R_PPC_PLTREL24 __tls_get_addr 0x8000
35# CHECK-NEXT:   0x10 R_PPC_TLSLD e 0x0
36# CHECK-NEXT:   0x10 R_PPC_PLTREL24 __tls_get_addr 0x8000
37# CHECK-NEXT:   0x14 R_PPC_TLSLD f 0x0
38# CHECK-NEXT:   0x14 R_PPC_PLTREL24 __tls_get_addr 0xFFFFFFFF
39# CHECK-NEXT:   0x18 R_PPC_TLSLD g 0x0
40# CHECK-NEXT:   0x18 R_PPC_PLTREL24 __tls_get_addr 0x5
41# CHECK-NEXT: }
42
43.ifdef ERR
44# ERR: :[[#@LINE+1]]:27: error: unexpected token
45bl __tls_get_addr(d@tlsld)plt
46# ERR: :[[#@LINE+1]]:28: error: expected 'plt'
47bl __tls_get_addr(d@tlsld)@invalid
48# ERR: :[[#@LINE+1]]:31: error: unexpected token
49bl __tls_get_addr(d@tlsld)@plt-32768
50
51# ERR: :[[#@LINE+1]]:21: error: invalid memory operand
52bl __tls_get_addr-1(f@tlsld)@plt
53.endif
54