2018-06-27 06:20:04 +08:00
|
|
|
// REQUIRES: x86
|
2019-09-10 20:28:07 +08:00
|
|
|
|
|
|
|
/// For non-preemptable ifunc, place ifunc PLT entries after regular PLT entries.
|
|
|
|
|
2016-12-08 20:58:55 +08:00
|
|
|
// RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %S/Inputs/shared2-x86-64.s -o %t1.o
|
2019-09-10 20:28:07 +08:00
|
|
|
// RUN: ld.lld %t1.o --shared -soname=so -o %t.so
|
2016-12-08 20:58:55 +08:00
|
|
|
// RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t.o
|
2017-10-06 17:37:44 +08:00
|
|
|
// RUN: ld.lld --hash-style=sysv %t.so %t.o -o %tout
|
2019-09-10 20:28:07 +08:00
|
|
|
// RUN: llvm-objdump -d --no-show-raw-insn %tout | FileCheck %s --check-prefix=DISASM
|
2016-12-08 20:58:55 +08:00
|
|
|
// RUN: llvm-objdump -s %tout | FileCheck %s --check-prefix=GOTPLT
|
2019-05-01 13:49:01 +08:00
|
|
|
// RUN: llvm-readobj -r --dynamic-table %tout | FileCheck %s
|
2016-12-08 20:58:55 +08:00
|
|
|
|
|
|
|
// Check that the IRELATIVE relocations are after the JUMP_SLOT in the plt
|
|
|
|
// CHECK: Relocations [
|
2019-08-03 10:26:52 +08:00
|
|
|
// CHECK-NEXT: Section (4) .rela.dyn {
|
2019-09-16 15:05:34 +08:00
|
|
|
// CHECK-NEXT: 0x203458 R_X86_64_IRELATIVE - 0x2012D8
|
|
|
|
// CHECK-NEXT: 0x203460 R_X86_64_IRELATIVE - 0x2012D9
|
2019-08-03 10:26:52 +08:00
|
|
|
// CHECK-NEXT: }
|
|
|
|
// CHECK-NEXT: Section (5) .rela.plt {
|
2019-09-16 15:05:34 +08:00
|
|
|
// CHECK-NEXT: 0x203448 R_X86_64_JUMP_SLOT bar2 0x0
|
|
|
|
// CHECK-NEXT: 0x203450 R_X86_64_JUMP_SLOT zed2 0x0
|
2019-08-03 10:26:52 +08:00
|
|
|
// CHECK-NEXT: }
|
2016-12-08 20:58:55 +08:00
|
|
|
|
|
|
|
// Check that .got.plt entries point back to PLT header
|
|
|
|
// GOTPLT: Contents of section .got.plt:
|
2019-09-16 15:05:34 +08:00
|
|
|
// GOTPLT-NEXT: 203430 40232000 00000000 00000000 00000000
|
|
|
|
// GOTPLT-NEXT: 203440 00000000 00000000 06132000 00000000
|
|
|
|
// GOTPLT-NEXT: 203450 16132000 00000000 26132000 00000000
|
|
|
|
// GOTPLT-NEXT: 203460 36132000 00000000
|
2016-12-08 20:58:55 +08:00
|
|
|
|
2019-08-03 10:26:52 +08:00
|
|
|
// Check that the PLTRELSZ tag does not include the IRELATIVE relocations
|
2016-12-08 20:58:55 +08:00
|
|
|
// CHECK: DynamicSection [
|
2019-08-03 10:26:52 +08:00
|
|
|
// CHECK: 0x0000000000000008 RELASZ 48 (bytes)
|
|
|
|
// CHECK: 0x0000000000000002 PLTRELSZ 48 (bytes)
|
2016-12-08 20:58:55 +08:00
|
|
|
|
|
|
|
// Check that a PLT header is written and the ifunc entries appear last
|
|
|
|
// DISASM: Disassembly of section .text:
|
2019-05-01 18:40:48 +08:00
|
|
|
// DISASM-EMPTY:
|
2016-12-08 20:58:55 +08:00
|
|
|
// DISASM-NEXT: foo:
|
2019-09-16 15:05:34 +08:00
|
|
|
// DISASM-NEXT: 2012d8: retq
|
2016-12-08 20:58:55 +08:00
|
|
|
// DISASM: bar:
|
2019-09-16 15:05:34 +08:00
|
|
|
// DISASM-NEXT: 2012d9: retq
|
2016-12-08 20:58:55 +08:00
|
|
|
// DISASM: _start:
|
2019-09-16 15:05:34 +08:00
|
|
|
// DISASM-NEXT: 2012da: callq 65
|
|
|
|
// DISASM-NEXT: 2012df: callq 76
|
2019-09-10 20:28:07 +08:00
|
|
|
// DISASM-NEXT: callq {{.*}} <bar2@plt>
|
|
|
|
// DISASM-NEXT: callq {{.*}} <zed2@plt>
|
2019-05-01 18:40:48 +08:00
|
|
|
// DISASM-EMPTY:
|
2016-12-08 20:58:55 +08:00
|
|
|
// DISASM-NEXT: Disassembly of section .plt:
|
2019-05-01 18:40:48 +08:00
|
|
|
// DISASM-EMPTY:
|
2016-12-08 20:58:55 +08:00
|
|
|
// DISASM-NEXT: .plt:
|
2019-09-16 15:05:34 +08:00
|
|
|
// DISASM-NEXT: 2012f0: pushq 8514(%rip)
|
|
|
|
// DISASM-NEXT: 2012f6: jmpq *8516(%rip)
|
|
|
|
// DISASM-NEXT: 2012fc: nopl (%rax)
|
2018-08-25 00:22:42 +08:00
|
|
|
// DISASM-EMPTY:
|
|
|
|
// DISASM-NEXT: bar2@plt:
|
2019-09-16 15:05:34 +08:00
|
|
|
// DISASM-NEXT: 201300: jmpq *8514(%rip)
|
|
|
|
// DISASM-NEXT: 201306: pushq $0
|
|
|
|
// DISASM-NEXT: 20130b: jmp -32 <.plt>
|
2018-08-25 00:22:42 +08:00
|
|
|
// DISASM-EMPTY:
|
|
|
|
// DISASM-NEXT: zed2@plt:
|
2019-09-16 15:05:34 +08:00
|
|
|
// DISASM-NEXT: 201310: jmpq *8506(%rip)
|
|
|
|
// DISASM-NEXT: 201316: pushq $1
|
|
|
|
// DISASM-NEXT: 20131b: jmp -48 <.plt>
|
2019-12-15 08:19:03 +08:00
|
|
|
// DISASM-EMPTY:
|
|
|
|
// DISASM-NEXT: Disassembly of section .iplt:
|
|
|
|
// DISASM-EMPTY:
|
|
|
|
// DISASM-NEXT: .iplt:
|
2019-09-16 15:05:34 +08:00
|
|
|
// DISASM-NEXT: 201320: jmpq *8498(%rip)
|
|
|
|
// DISASM-NEXT: 201326: pushq $0
|
2019-12-15 06:17:35 +08:00
|
|
|
// DISASM-NEXT: 20132b: jmp -64 <.plt>
|
2019-09-16 15:05:34 +08:00
|
|
|
// DISASM-NEXT: 201330: jmpq *8490(%rip)
|
|
|
|
// DISASM-NEXT: 201336: pushq $1
|
2019-12-15 06:17:35 +08:00
|
|
|
// DISASM-NEXT: 20133b: jmp -80 <.plt>
|
2016-12-08 20:58:55 +08:00
|
|
|
|
|
|
|
.text
|
|
|
|
.type foo STT_GNU_IFUNC
|
|
|
|
.globl foo
|
|
|
|
foo:
|
|
|
|
ret
|
|
|
|
|
|
|
|
.type bar STT_GNU_IFUNC
|
|
|
|
.globl bar
|
|
|
|
bar:
|
|
|
|
ret
|
|
|
|
|
|
|
|
.globl _start
|
|
|
|
_start:
|
|
|
|
call foo
|
|
|
|
call bar
|
|
|
|
call bar2
|
|
|
|
call zed2
|