2016-10-20 17:59:26 +08:00
|
|
|
// RUN: llvm-mc -filetype=obj -triple=armv7a-none-linux-gnueabi %s -o %t
|
|
|
|
// RUN: ld.lld %t --shared -o %t2 2>&1
|
|
|
|
// RUN: llvm-readobj --relocations %t2 | FileCheck %s
|
|
|
|
// RUN: llvm-objdump -s -triple=armv7a-none-linux-gnueabi %t2 | FileCheck -check-prefix=CHECK-EXTAB %s
|
2016-10-20 18:16:13 +08:00
|
|
|
// REQUIRES: arm
|
2016-10-20 17:59:26 +08:00
|
|
|
|
|
|
|
// Check that the relative R_ARM_PREL31 relocation can access a PLT entry
|
|
|
|
// for when the personality routine is referenced from a shared library.
|
|
|
|
// Also check that the R_ARM_NONE no-op relocation can be used in a shared
|
|
|
|
// library.
|
|
|
|
.syntax unified
|
|
|
|
// Will produce an ARM.exidx entry with an R_ARM_NONE relocation to
|
|
|
|
// __aeabi_unwind_cpp_pr0
|
|
|
|
.section .text.func1, "ax",%progbits
|
|
|
|
.global func1
|
|
|
|
func1:
|
|
|
|
.fnstart
|
|
|
|
bx lr
|
|
|
|
.fnend
|
|
|
|
|
|
|
|
// Will produce a R_ARM_PREL31 relocation with respect to the PLT entry of
|
|
|
|
// __gxx_personality_v0
|
|
|
|
.section .text.func2, "ax",%progbits
|
|
|
|
.global func2
|
|
|
|
func2:
|
|
|
|
.fnstart
|
|
|
|
bx lr
|
|
|
|
.personality __gxx_personality_v0
|
|
|
|
.handlerdata
|
|
|
|
.long 0
|
|
|
|
.section .text.func2
|
|
|
|
.fnend
|
|
|
|
|
|
|
|
.section .text.__aeabi_unwind_cpp_pr0, "ax", %progbits
|
|
|
|
.global __aeabi_unwind_cpp_pr0
|
|
|
|
__aeabi_unwind_cpp_pr0:
|
|
|
|
bx lr
|
|
|
|
|
|
|
|
// CHECK: Relocations [
|
|
|
|
// CHECK-NEXT: Section (6) .rel.plt {
|
2017-01-10 09:21:30 +08:00
|
|
|
// CHECK-NEXT: 0x200C R_ARM_JUMP_SLOT __gxx_personality_v0
|
2016-10-20 17:59:26 +08:00
|
|
|
|
|
|
|
// CHECK-EXTAB: Contents of section .ARM.extab.text.func2:
|
2016-11-24 19:43:55 +08:00
|
|
|
// 014c + 0ed8 = 0x1024 = __gxx_personality_v0(PLT)
|
|
|
|
// CHECK-EXTAB-NEXT: 014c d80e0000 b0b0b000 00000000
|