2016-04-11 05:48:55 +08:00
|
|
|
# REQUIRES: mips
|
|
|
|
|
|
|
|
# If there are two relocations such that the first one requires
|
|
|
|
# dynamic COPY relocation, the second one requires GOT entry
|
|
|
|
# creation, linker should create both - dynamic relocation
|
|
|
|
# and GOT entry.
|
|
|
|
|
|
|
|
# RUN: llvm-mc -filetype=obj -triple=mips-unknown-linux \
|
|
|
|
# RUN: %S/Inputs/mips-dynamic.s -o %t.so.o
|
|
|
|
# RUN: llvm-mc -filetype=obj -triple=mips-unknown-linux %s -o %t.o
|
|
|
|
# RUN: ld.lld %t.so.o -shared -o %t.so
|
|
|
|
# RUN: ld.lld %t.o %t.so -o %t.exe
|
2019-05-01 13:49:01 +08:00
|
|
|
# RUN: llvm-readobj -r --mips-plt-got %t.exe | FileCheck %s
|
2016-04-11 05:48:55 +08:00
|
|
|
|
|
|
|
# CHECK: Relocations [
|
|
|
|
# CHECK-NEXT: Section (7) .rel.dyn {
|
2017-01-17 05:17:09 +08:00
|
|
|
# CHECK-NEXT: 0x[[DATA0:[0-9A-F]+]] R_MIPS_COPY data0
|
|
|
|
# CHECK-NEXT: 0x[[DATA1:[0-9A-F]+]] R_MIPS_COPY data1
|
2016-04-11 05:48:55 +08:00
|
|
|
# CHECK-NEXT: }
|
|
|
|
# CHECK-NEXT: ]
|
|
|
|
# CHECK-NEXT: Primary GOT {
|
2017-01-17 05:17:09 +08:00
|
|
|
# CHECK-NEXT: Canonical gp value:
|
2016-04-11 05:48:55 +08:00
|
|
|
# CHECK-NEXT: Reserved entries [
|
|
|
|
# CHECK: ]
|
|
|
|
# CHECK-NEXT: Local entries [
|
2018-01-09 08:13:54 +08:00
|
|
|
# CHECK-NEXT: ]
|
|
|
|
# CHECK-NEXT: Global entries [
|
2016-04-11 05:48:55 +08:00
|
|
|
# CHECK-NEXT: Entry {
|
2017-01-17 05:17:09 +08:00
|
|
|
# CHECK-NEXT: Address:
|
2016-05-06 03:41:49 +08:00
|
|
|
# CHECK-NEXT: Access: -32744
|
2017-01-17 05:17:09 +08:00
|
|
|
# CHECK-NEXT: Initial: 0x[[DATA0]]
|
2018-01-09 08:13:54 +08:00
|
|
|
# CHECK-NEXT: Value: 0x[[DATA0]]
|
|
|
|
# CHECK-NEXT: Type: Object
|
|
|
|
# CHECK-NEXT: Section: .bss
|
2019-01-08 18:50:59 +08:00
|
|
|
# CHECK-NEXT: Name: data0
|
2016-04-11 05:48:55 +08:00
|
|
|
# CHECK-NEXT: }
|
|
|
|
# CHECK-NEXT: Entry {
|
2017-01-17 05:17:09 +08:00
|
|
|
# CHECK-NEXT: Address:
|
2016-05-06 03:41:49 +08:00
|
|
|
# CHECK-NEXT: Access: -32740
|
2017-01-17 05:17:09 +08:00
|
|
|
# CHECK-NEXT: Initial: 0x[[DATA1]]
|
|
|
|
# CHECK-NEXT: Value: 0x[[DATA1]]
|
|
|
|
# CHECK-NEXT: Type: Object
|
|
|
|
# CHECK-NEXT: Section: .bss
|
2019-01-08 18:50:59 +08:00
|
|
|
# CHECK-NEXT: Name: data1
|
2016-04-11 05:48:55 +08:00
|
|
|
# CHECK-NEXT: }
|
|
|
|
# CHECK-NEXT: ]
|
|
|
|
# CHECK-NEXT: Number of TLS and multi-GOT entries: 0
|
|
|
|
# CHECK-NEXT: }
|
|
|
|
|
|
|
|
.text
|
|
|
|
.global __start
|
|
|
|
__start:
|
|
|
|
# Case A: 'got' relocation goes before 'copy' relocation
|
|
|
|
lui $t0,%hi(data0) # R_MIPS_HI16 - requires R_MISP_COPY relocation
|
|
|
|
addi $t0,$t0,%lo(data0)
|
|
|
|
lw $t0,%got(data0)($gp) # R_MIPS_GOT16 - requires GOT entry
|
|
|
|
|
|
|
|
# Case B: 'copy' relocation goes before 'got' relocation
|
|
|
|
lw $t0,%got(data1)($gp) # R_MIPS_GOT16 - requires GOT entry
|
|
|
|
lui $t0,%hi(data1) # R_MIPS_HI16 - requires R_MISP_COPY relocation
|
|
|
|
addi $t0,$t0,%lo(data1)
|