llvm/lld/test/ELF/ppc64-plt-stub.s

# REQUIRES: ppc

# RUN: llvm-mc -filetype=obj -triple=powerpc64le-unknown-linux %s -o %t.o
# RUN: llvm-mc -filetype=obj -triple=powerpc64le-unknown-linux %p/Inputs/shared-ppc64.s -o %t2.o
# RUN: ld.lld -shared %t2.o -soname=t2.so -o %t2.so
# RUN: ld.lld %t.o %t2.so -o %t
# RUN: llvm-readelf -S -d %t | FileCheck --check-prefix=SEC %s
# RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck %s

# RUN: llvm-mc -filetype=obj -triple=powerpc64-unknown-linux %s -o %t.o
# RUN: llvm-mc -filetype=obj -triple=powerpc64-unknown-linux %p/Inputs/shared-ppc64.s -o %t2.o
# RUN: ld.lld -shared %t2.o -soname=t2.so -o %t2.so
# RUN: ld.lld %t.o %t2.so -o %t
# RUN: llvm-readelf -S -d %t | FileCheck --check-prefix=SEC %s
# RUN: llvm-objdump -d --no-show-raw-insn %t | FileCheck %s

## DT_PLTGOT points to .plt
# SEC: .plt NOBITS 0000000010030400 000400 000018
# SEC: 0x0000000000000003 (PLTGOT) 0x10030400
# SEC: 0x0000000070000000 (PPC64_GLINK) 0x100102e0
# SEC: 0x0000000070000003 (PPC64_OPT) 0x0

## .plt[0] holds the address of _dl_runtime_resolve.
## .plt[1] holds the link map.
## The JMP_SLOT relocation is stored at .plt[2]
# RELOC: 0x10030010 R_PPC64_JMP_SLOT foo 0x0

# CHECK:      <_start>:
# CHECK:      10010298: bl 0x100102b0

# CHECK-LABEL: 00000000100102b0 <__plt_foo>:
# CHECK-NEXT:      std 2, 24(1)
# CHECK-NEXT:      addis 12, 2, 1
# CHECK-NEXT:      ld 12, -32744(12)
# CHECK-NEXT:      mtctr 12
# CHECK-NEXT:      bctr

# CHECK-LABEL: <.glink>:
# CHECK-NEXT:  100102c4: mflr 0
# CHECK-NEXT:            bcl 20, 31, 0x100102cc <.glink+0x8>
# CHECK-NEXT:            mflr 11
# CHECK-NEXT:            mtlr 0
# CHECK-NEXT:            sub     12, 12, 11
# CHECK-NEXT:            addi 0, 12, -52
# CHECK-NEXT:            rldicl 0, 0, 62, 2
# CHECK-NEXT:            ld 12, 44(11)
# CHECK-NEXT:            add 11, 12, 11
# CHECK-NEXT:            ld 12, 0(11)
# CHECK-NEXT:            ld 11, 8(11)
# CHECK-NEXT:            mtctr 12
# CHECK-NEXT:            bctr
# CHECK-NEXT:            <unknown>
# CHECK-NEXT:            <unknown>
## DT_PPC64_GLINK+0x20 = 0x10010300
# CHECK-NEXT:  10010300: b 0x100102c4 <.glink>
# CHECK-NOT:   {{.}}

        .text
        .abiversion 2
        .globl  _start
        .p2align        4
        .type   _start,@function
_start:
.Lfunc_begin0:
.Lfunc_gep0:
  addis 2, 12, .TOC.-.Lfunc_gep0@ha
  addi 2, 2, .TOC.-.Lfunc_gep0@l
.Lfunc_lep0:
  .localentry     _start, .Lfunc_lep0-.Lfunc_gep0
  bl foo
  nop
  li 0, 1
  sc
  .size _start, .-.Lfunc_begin0