[PATCH] D15454: lld: allow -e with -shared
Ed Maste via llvm-commits
llvm-commits at lists.llvm.org
Fri Dec 11 09:03:49 PST 2015
emaste created this revision.
emaste added reviewers: ruiu, grimar.
emaste added a subscriber: llvm-commits.
Herald added a subscriber: emaste.
It is reasonable to specify an entry point for shared objects - e.g. FreeBSD rtld ld-elf.so.1.
Unlike GNU ld we leave it as 0 if -shared is specified without an explicit -e address or symbol.
http://reviews.llvm.org/D15454
Files:
ELF/Driver.cpp
test/ELF/entry.s
Index: test/ELF/entry.s
===================================================================
--- test/ELF/entry.s
+++ test/ELF/entry.s
@@ -2,14 +2,17 @@
# RUN: not ld.lld %t1 -o %t2
# RUN: ld.lld %t1 -o %t2 -e entry
# RUN: llvm-readobj -file-headers %t2 | FileCheck -check-prefix=SYM %s
+# RUN: ld.lld %t1 -shared -o %t2 -e entry
+# RUN: llvm-readobj -file-headers %t2 | FileCheck -check-prefix=DSO %s
# RUN: ld.lld %t1 -o %t2 -e 4096
# RUN: llvm-readobj -file-headers %t2 | FileCheck -check-prefix=DEC %s
# RUN: ld.lld %t1 -o %t2 -e 0xcafe
# RUN: llvm-readobj -file-headers %t2 | FileCheck -check-prefix=HEX %s
# RUN: ld.lld %t1 -o %t2 -e 0777
# RUN: llvm-readobj -file-headers %t2 | FileCheck -check-prefix=OCT %s
# SYM: Entry: 0x11000
+# DSO: Entry: 0x1000
# DEC: Entry: 0x1000
# HEX: Entry: 0xCAFE
# OCT: Entry: 0x1FF
Index: ELF/Driver.cpp
===================================================================
--- ELF/Driver.cpp
+++ ELF/Driver.cpp
@@ -248,11 +248,6 @@
if (Config->Entry.empty())
Config->Entry = (Config->EMachine == EM_MIPS) ? "__start" : "_start";
- // Set either EntryAddr (if S is a number) or EntrySym (otherwise).
- StringRef S = Config->Entry;
- if (S.getAsInteger(0, Config->EntryAddr))
- Config->EntrySym = Symtab.addUndefined(S);
-
// In the assembly for 32 bit x86 the _GLOBAL_OFFSET_TABLE_ symbol
// is magical and is used to produce a R_386_GOTPC relocation.
// The R_386_GOTPC relocation value doesn't actually depend on the
@@ -268,6 +263,13 @@
Symtab.addIgnoredSym("_GLOBAL_OFFSET_TABLE_");
}
+ if (!Config->Entry.empty()) {
+ // Set either EntryAddr (if S is a number) or EntrySym (otherwise).
+ StringRef S = Config->Entry;
+ if (S.getAsInteger(0, Config->EntryAddr))
+ Config->EntrySym = Symtab.addUndefined(S);
+ }
+
// Define _gp for MIPS. st_value of _gp symbol will be updated by Writer
// so that it points to an absolute address which is relative to GOT.
// See "Global Data Symbols" in Chapter 6 in the following document:
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D15454.42528.patch
Type: text/x-patch
Size: 2059 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20151211/080809da/attachment.bin>
More information about the llvm-commits
mailing list