| # REQUIRES: ppc |
| # RUN: llvm-mc -filetype=obj -triple=powerpc %s -o %t.o |
| # RUN: ld.lld -pie %t.o -o %t |
| # RUN: llvm-readobj -r %t | FileCheck --check-prefix=RELOC %s |
| # RUN: llvm-readelf -s %t | FileCheck --check-prefix=SYM %s |
| # RUN: llvm-readelf -x .got2 %t | FileCheck --check-prefix=HEX %s |
| # RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck %s |
| |
| # RELOC: .rela.dyn { |
| # RELOC-NEXT: 0x30248 R_PPC_RELATIVE - 0x101A8 |
| # RELOC-NEXT: 0x3024C R_PPC_IRELATIVE - 0x10188 |
| # RELOC-NEXT: } |
| |
| # SYM: 000101a8 0 FUNC GLOBAL DEFAULT {{.*}} func |
| # HEX: 0x00030248 00000000 |
| |
| .section .got2,"aw" |
| .long func |
| |
| # CHECK: Disassembly of section .text: |
| # CHECK: <.text>: |
| # CHECK-NEXT: 10188: blr |
| # CHECK: <_start>: |
| # CHECK-NEXT: bl 0x10198 |
| # CHECK-NEXT: lis 9, 1 |
| # CHECK-NEXT: addi 9, 9, 424 |
| # CHECK-EMPTY: |
| # CHECK-NEXT: <00008000.got2.plt_pic32.func>: |
| ## 0x10020114 = 65536*4098+276 |
| # CHECK-NEXT: lwz 11, -32764(30) |
| # CHECK-NEXT: mtctr 11 |
| # CHECK-NEXT: bctr |
| # CHECK-NEXT: nop |
| |
| .text |
| .globl func |
| .type func, @gnu_indirect_function |
| func: |
| blr |
| |
| .globl _start |
| _start: |
| bl func+0x8000@plt |
| |
| lis 9, func@ha |
| la 9, func@l(9) |