llvm-project/lld/test/ELF/mips-call16.s

40 lines
944 B
ArmAsm

# REQUIRES: mips
# Check R_MIPS_CALL16 relocation calculation.
# RUN: llvm-mc -filetype=obj -triple=mips-unknown-linux %s -o %t.o
# RUN: ld.lld %t.o -shared -o %t.exe
# RUN: llvm-objdump -d %t.exe | FileCheck %s
# RUN: llvm-readobj -mips-plt-got -symbols %t.exe \
# RUN: | FileCheck -check-prefix=GOT %s
.text
.globl __start
__start:
lw $t0,%call16(g1)($gp)
.globl g1
.type g1,@function
g1:
nop
# CHECK: Disassembly of section .text:
# CHECK-NEXT: __start:
# CHECK-NEXT: 10000: 8f 88 80 18 lw $8, -32744
# GOT: Name: g1
# GOT-NEXT: Value: 0x[[ADDR:[0-9A-F]+]]
# GOT: Local entries [
# GOT-NEXT: ]
# GOT-NEXT: Global entries [
# GOT-NEXT: Entry {
# GOT-NEXT: Address:
# GOT-NEXT: Access: -32744
# GOT-NEXT: Initial: 0x[[ADDR]]
# GOT-NEXT: Value: 0x[[ADDR]]
# GOT-NEXT: Type: Function
# GOT-NEXT: Section: .text
# GOT-NEXT: Name: g1
# GOT-NEXT: }
# GOT-NEXT: ]