[PATCH] D80856: [lld-macho] Support X86_64_RELOC_GOT
Jez Ng via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Jun 17 21:03:17 PDT 2020
This revision was automatically updated to reflect the committed changes.
Closed by commit rGc3d98ea89fa4: [lld-macho] Support X86_64_RELOC_GOT (authored by int3).
Changed prior to commit:
https://reviews.llvm.org/D80856?vs=270605&id=271568#toc
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D80856/new/
https://reviews.llvm.org/D80856
Files:
lld/MachO/Arch/X86_64.cpp
lld/test/MachO/dylink.s
Index: lld/test/MachO/dylink.s
===================================================================
--- lld/test/MachO/dylink.s
+++ lld/test/MachO/dylink.s
@@ -19,7 +19,7 @@
# RUN: llvm-mc -filetype=obj -triple=x86_64-apple-darwin %s -o %t/dylink.o
# RUN: lld -flavor darwinnew -o %t/dylink -Z -L%t -lhello -lgoodbye %t/dylink.o
-# RUN: llvm-objdump --bind -d %t/dylink | FileCheck %s
+# RUN: llvm-objdump --bind -d --no-show-raw-insn %t/dylink | FileCheck %s
# CHECK: movq [[#%u, HELLO_OFF:]](%rip), %rsi
# CHECK-NEXT: [[#%x, HELLO_RIP:]]:
@@ -27,8 +27,8 @@
# CHECK: movq [[#%u, HELLO_ITS_ME_OFF:]](%rip), %rsi
# CHECK-NEXT: [[#%x, HELLO_ITS_ME_RIP:]]:
-# CHECK: movq [[#%u, GOODBYE_OFF:]](%rip), %rsi
-# CHECK-NEXT: [[#%x, GOODBYE_RIP:]]:
+# CHECK: pushq [[#%u, GOODBYE_OFF:]](%rip)
+# CHECK-NEXT: [[#%x, GOODBYE_RIP:]]: popq %rsi
# CHECK-LABEL: Bind table:
# CHECK-DAG: __DATA_CONST __got 0x{{0*}}[[#%x, HELLO_RIP + HELLO_OFF]] pointer 0 libhello _hello_world
@@ -53,7 +53,8 @@
movl $0x2000004, %eax # write() syscall
mov $1, %rdi # stdout
- movq _goodbye_world at GOTPCREL(%rip), %rsi
+ pushq _goodbye_world at GOTPCREL(%rip)
+ popq %rsi
mov $15, %rdx # length of str
syscall
mov $0, %rax
Index: lld/MachO/Arch/X86_64.cpp
===================================================================
--- lld/MachO/Arch/X86_64.cpp
+++ lld/MachO/Arch/X86_64.cpp
@@ -82,6 +82,7 @@
case X86_64_RELOC_SIGNED_2:
case X86_64_RELOC_SIGNED_4:
case X86_64_RELOC_GOT_LOAD:
+ case X86_64_RELOC_GOT:
if (!rel.r_pcrel)
fatal(getErrorLocation(mb, sec, rel) + ": relocations of type " +
std::to_string(rel.r_type) + " must be pcrel");
@@ -120,6 +121,7 @@
case X86_64_RELOC_SIGNED_2:
case X86_64_RELOC_SIGNED_4:
case X86_64_RELOC_GOT_LOAD:
+ case X86_64_RELOC_GOT:
// These types are only used for pc-relative relocations, so offset by 4
// since the RIP has advanced by 4 at this point. This is only valid when
// r_length = 2, which is enforced by validateLength().
@@ -209,13 +211,13 @@
void X86_64::prepareDylibSymbolRelocation(DylibSymbol &sym, uint8_t type) {
switch (type) {
case X86_64_RELOC_GOT_LOAD:
+ // TODO: implement mov -> lea relaxation for non-dynamic symbols
+ case X86_64_RELOC_GOT:
in.got->addEntry(sym);
break;
case X86_64_RELOC_BRANCH:
in.stubs->addEntry(sym);
break;
- case X86_64_RELOC_GOT:
- fatal("TODO: Unhandled dylib symbol relocation X86_64_RELOC_GOT");
default:
llvm_unreachable("Unexpected dylib relocation type");
}
@@ -224,11 +226,10 @@
uint64_t X86_64::getDylibSymbolVA(const DylibSymbol &sym, uint8_t type) const {
switch (type) {
case X86_64_RELOC_GOT_LOAD:
+ case X86_64_RELOC_GOT:
return in.got->addr + sym.gotIndex * WordSize;
case X86_64_RELOC_BRANCH:
return in.stubs->addr + sym.stubsIndex * sizeof(stub);
- case X86_64_RELOC_GOT:
- fatal("TODO: Unhandled dylib symbol relocation X86_64_RELOC_GOT");
default:
llvm_unreachable("Unexpected dylib relocation type");
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D80856.271568.patch
Type: text/x-patch
Size: 3074 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20200618/b9429ae2/attachment.bin>
More information about the llvm-commits
mailing list