2018-06-27 00:58:19 +08:00
|
|
|
# REQUIRES: mips
|
2016-10-21 15:22:30 +08:00
|
|
|
# Check that GOT entries accessed via 16-bit indexing are allocated
|
|
|
|
# in the beginning of the GOT.
|
|
|
|
|
|
|
|
# RUN: llvm-mc -filetype=obj -triple=mips-unknown-linux %s -o %t.o
|
|
|
|
# RUN: ld.lld %t.o -o %t.exe
|
2019-09-10 06:04:20 +08:00
|
|
|
# RUN: llvm-objdump -d --no-show-raw-insn %t.exe | FileCheck %s
|
2019-10-03 20:08:04 +08:00
|
|
|
# RUN: llvm-readelf -s -A %t.exe | FileCheck -check-prefix=GOT %s
|
2016-10-21 15:22:30 +08:00
|
|
|
|
|
|
|
# CHECK: Disassembly of section .text:
|
2019-05-01 18:40:48 +08:00
|
|
|
# CHECK-EMPTY:
|
2020-03-06 06:18:38 +08:00
|
|
|
# CHECK-NEXT: <__start>:
|
2019-09-10 06:04:20 +08:00
|
|
|
# CHECK-NEXT: lui $2, 0
|
|
|
|
# CHECK-NEXT: lw $2, -32732($2)
|
|
|
|
# CHECK-NEXT: lui $2, 0
|
|
|
|
# CHECK-NEXT: lw $2, -32728($2)
|
2016-10-21 15:22:30 +08:00
|
|
|
#
|
2020-03-06 06:18:38 +08:00
|
|
|
# CHECK: <bar>:
|
2019-09-10 06:04:20 +08:00
|
|
|
# CHECK-NEXT: lw $2, -32736($2)
|
|
|
|
# CHECK-NEXT: lw $2, -32744($2)
|
|
|
|
# CHECK-NEXT: addi $2, $2, {{.*}}
|
2016-10-21 15:22:30 +08:00
|
|
|
|
2019-09-10 06:04:20 +08:00
|
|
|
# GOT: Symbol table '.symtab'
|
|
|
|
# GOT: Num: Value Size Type Bind Vis Ndx Name
|
|
|
|
# GOT: [[LOC:[0-9a-f]+]] 0 NOTYPE LOCAL DEFAULT 4 loc
|
|
|
|
# GOT: [[START:[0-9a-f]+]] 0 NOTYPE GLOBAL DEFAULT 3 __start
|
|
|
|
# GOT: [[BAR:[0-9a-f]+]] 0 NOTYPE GLOBAL DEFAULT 3 bar
|
2016-10-21 15:22:30 +08:00
|
|
|
|
2019-09-10 06:04:20 +08:00
|
|
|
# GOT: Static GOT:
|
|
|
|
# GOT: Local entries:
|
|
|
|
# GOT: Address Access Initial
|
|
|
|
# GOT-NEXT: -32744(gp) 00030000
|
|
|
|
# GOT-NEXT: -32740(gp) 00040000
|
|
|
|
# GOT-NEXT: -32736(gp) [[BAR]]
|
|
|
|
# GOT-NEXT: -32732(gp) [[START]]
|
|
|
|
# GOT-NEXT: -32728(gp) [[LOC]]
|
2016-10-21 15:22:30 +08:00
|
|
|
|
|
|
|
.text
|
|
|
|
.global __start, bar
|
|
|
|
__start:
|
|
|
|
lui $2, %got_hi(__start)
|
|
|
|
lw $2, %got_lo(__start)($2)
|
|
|
|
lui $2, %got_hi(loc)
|
|
|
|
lw $2, %got_lo(loc)($2)
|
|
|
|
bar:
|
|
|
|
lw $2, %got(bar)($2)
|
|
|
|
lw $2, %got(loc)($2)
|
|
|
|
addi $2, $2, %lo(loc)
|
|
|
|
|
|
|
|
.data
|
|
|
|
loc:
|
|
|
|
.word 0
|