| # RUN: llvm-mc -triple=powerpc %s | FileCheck %s --check-prefix=ASM |
| # RUN: llvm-mc -filetype=obj -triple=powerpc %s -o %t |
| # RUN: llvm-readobj -r %t | FileCheck %s |
| |
| # RUN: not llvm-mc -triple=powerpc --defsym ERR=1 %s 2>&1 | FileCheck %s --check-prefix=ERR --implicit-check-not=error: |
| |
| # ASM: bl __tls_get_addr(a@tlsgd) |
| # ASM: bl __tls_get_addr(b@tlsld) |
| # ASM: bl __tls_get_addr(c@tlsgd)@PLT |
| # ASM: bl __tls_get_addr(d@tlsld)@PLT+32768 |
| # ASM: bl __tls_get_addr(e@tlsld)@PLT+32768 |
| bl __tls_get_addr(a@tlsgd) |
| bl __tls_get_addr(b@tlsld) |
| bl __tls_get_addr(c@tlsgd)@plt |
| bl __tls_get_addr(d@tlsld)@PLT+32768 |
| bl __tls_get_addr+32768(e@tlsld)@plt # gcc -fPIC |
| |
| ## These are not present in the wild, but just to test we can parse them. |
| # ASM: bl __tls_get_addr(f@tlsld)@PLT+1+(-2) |
| bl __tls_get_addr+1(f@tlsld)@PLT+-2 |
| # ASM: bl __tls_get_addr(g@tlsld)@PLT+1+(y-x) |
| x: |
| bl __tls_get_addr+1(g@tlsld)@PLT+(y-x) |
| y: |
| |
| # CHECK: .rela.text { |
| # CHECK-NEXT: 0x0 R_PPC_TLSGD a 0x0 |
| # CHECK-NEXT: 0x0 R_PPC_REL24 __tls_get_addr 0x0 |
| # CHECK-NEXT: 0x4 R_PPC_TLSLD b 0x0 |
| # CHECK-NEXT: 0x4 R_PPC_REL24 __tls_get_addr 0x0 |
| # CHECK-NEXT: 0x8 R_PPC_TLSGD c 0x0 |
| # CHECK-NEXT: 0x8 R_PPC_PLTREL24 __tls_get_addr 0x0 |
| # CHECK-NEXT: 0xC R_PPC_TLSLD d 0x0 |
| # CHECK-NEXT: 0xC R_PPC_PLTREL24 __tls_get_addr 0x8000 |
| # CHECK-NEXT: 0x10 R_PPC_TLSLD e 0x0 |
| # CHECK-NEXT: 0x10 R_PPC_PLTREL24 __tls_get_addr 0x8000 |
| # CHECK-NEXT: 0x14 R_PPC_TLSLD f 0x0 |
| # CHECK-NEXT: 0x14 R_PPC_PLTREL24 __tls_get_addr 0xFFFFFFFF |
| # CHECK-NEXT: 0x18 R_PPC_TLSLD g 0x0 |
| # CHECK-NEXT: 0x18 R_PPC_PLTREL24 __tls_get_addr 0x5 |
| # CHECK-NEXT: } |
| |
| .ifdef ERR |
| # ERR: :[[#@LINE+1]]:27: error: unexpected token |
| bl __tls_get_addr(d@tlsld)plt |
| # ERR: :[[#@LINE+1]]:28: error: expected 'plt' |
| bl __tls_get_addr(d@tlsld)@invalid |
| # ERR: :[[#@LINE+1]]:31: error: unexpected token |
| bl __tls_get_addr(d@tlsld)@plt-32768 |
| |
| # ERR: :[[#@LINE+1]]:21: error: invalid memory operand |
| bl __tls_get_addr-1(f@tlsld)@plt |
| .endif |