2018-06-27 00:58:19 +08:00
|
|
|
# REQUIRES: mips
|
2017-11-09 07:34:34 +08:00
|
|
|
# Check less-significant bit setup for microMIPS PLT.
|
|
|
|
|
|
|
|
# RUN: llvm-mc -filetype=obj -triple=mips-unknown-linux \
|
|
|
|
# RUN: -mattr=micromips %S/Inputs/mips-dynamic.s -o %t-dso.o
|
2019-07-25 15:12:23 +08:00
|
|
|
# RUN: ld.lld %t-dso.o -shared -soname=t.so -o %t.so
|
2017-11-09 07:34:34 +08:00
|
|
|
# RUN: llvm-mc -filetype=obj -triple=mips-unknown-linux \
|
|
|
|
# RUN: -mattr=micromips %s -o %t-exe.o
|
2019-09-10 06:04:20 +08:00
|
|
|
# RUN: echo "SECTIONS { \
|
|
|
|
# RUN: . = 0x20000; .text ALIGN(0x100) : { *(.text) } \
|
|
|
|
# RUN: . = 0x20300; .plt : { *(.plt) } \
|
|
|
|
# RUN: }" > %t.script
|
|
|
|
# RUN: ld.lld %t-exe.o %t.so --script %t.script -o %t.exe
|
2019-10-03 20:08:04 +08:00
|
|
|
# RUN: llvm-readelf --symbols --dyn-syms -A %t.exe | FileCheck %s
|
2020-03-16 08:47:44 +08:00
|
|
|
# RUN: llvm-objdump -d --mattr=micromips --no-show-raw-insn %t.exe \
|
2019-09-10 06:04:20 +08:00
|
|
|
# RUN: | FileCheck --check-prefix=ASM %s
|
2017-11-09 07:34:34 +08:00
|
|
|
|
2019-09-10 06:04:20 +08:00
|
|
|
# CHECK: Symbol table '.dynsym'
|
|
|
|
# CHECK: Num: Value Size Type Bind Vis Ndx Name
|
|
|
|
# CHECK: 1: 00020321 0 FUNC GLOBAL DEFAULT [<other: 0x88>] UND foo0
|
2017-11-14 06:40:36 +08:00
|
|
|
|
2019-09-10 06:04:20 +08:00
|
|
|
# CHECK: Symbol table '.symtab'
|
|
|
|
# CHECK: Num: Value Size Type Bind Vis Ndx Name
|
|
|
|
# CHECK: 1: 00020210 0 NOTYPE LOCAL HIDDEN [<other: 0x82>] 8 foo
|
|
|
|
# CHECK: 4: 00020200 0 NOTYPE GLOBAL DEFAULT [<other: 0x80>] 8 __start
|
|
|
|
# CHECK: 5: 00020320 0 FUNC GLOBAL DEFAULT [<other: 0x88>] UND foo0
|
2017-11-09 07:34:34 +08:00
|
|
|
|
2019-09-10 06:04:20 +08:00
|
|
|
# CHECK: Primary GOT:
|
|
|
|
# CHECK: Local entries:
|
|
|
|
# CHECK: Address Access Initial
|
|
|
|
# CHECK: -32744(gp) 00020211
|
|
|
|
|
|
|
|
# CHECK: PLT GOT:
|
|
|
|
# CHECK: Entries:
|
|
|
|
# CHECK: Address Initial Sym.Val. Type Ndx Name
|
|
|
|
# CHECK: 00020301 00020321 FUNC UND foo0
|
2017-11-09 07:34:34 +08:00
|
|
|
|
2020-03-06 06:18:38 +08:00
|
|
|
# ASM: <__start>:
|
2019-09-10 06:04:20 +08:00
|
|
|
# ASM-NEXT: 20200: lw $8, -32744($gp)
|
|
|
|
# ASM-NEXT: addi $8, $8, 529
|
|
|
|
# ASM-NEXT: lui $8, 2
|
|
|
|
# ASM-NEXT: addi $8, $8, 801
|
2018-05-04 01:33:10 +08:00
|
|
|
#
|
2020-03-06 06:18:38 +08:00
|
|
|
# ASM: <foo>:
|
2019-09-10 06:04:20 +08:00
|
|
|
# ASM-NEXT: 20210: jal 131872
|
2018-05-04 01:33:10 +08:00
|
|
|
|
2017-11-09 07:34:34 +08:00
|
|
|
.text
|
|
|
|
.set micromips
|
|
|
|
.global foo
|
|
|
|
.hidden foo
|
|
|
|
.global __start
|
|
|
|
__start:
|
|
|
|
lw $t0,%got(foo)($gp)
|
|
|
|
addi $t0,$t0,%lo(foo)
|
2018-05-04 01:33:10 +08:00
|
|
|
lui $t0,%hi(foo0)
|
|
|
|
addi $t0,$t0,%lo(foo0)
|
2017-11-09 07:34:34 +08:00
|
|
|
foo:
|
|
|
|
jal foo0
|