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