Index: ELF/Driver.cpp =================================================================== --- ELF/Driver.cpp +++ ELF/Driver.cpp @@ -675,7 +675,7 @@ // if it is resolvable. Config->Entry = (Config->EMachine == EM_MIPS) ? "__start" : "_start"; } - if (!HasEntryAddr) { + if (!Config->Shared && !HasEntryAddr) { if (Symtab.find(Config->Entry)) Config->EntrySym = Symtab.addUndefined(Config->Entry); else Index: test/ELF/entry.s =================================================================== --- test/ELF/entry.s +++ test/ELF/entry.s @@ -3,7 +3,7 @@ # RUN: llvm-readobj -file-headers %t2 | FileCheck -check-prefix=NOENTRY %s # 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: ld.lld %t1 --fatal-warnings -shared -o %t2 -e entry # RUN: llvm-readobj -file-headers %t2 | FileCheck -check-prefix=DSO %s # RUN: ld.lld %t1 -o %t2 --entry=4096 # RUN: llvm-readobj -file-headers %t2 | FileCheck -check-prefix=DEC %s @@ -16,7 +16,7 @@ # NOENTRY: Entry: 0x0 # SYM: Entry: 0x11000 -# DSO: Entry: 0x1000 +# DSO: Entry: 0x0 # DEC: Entry: 0x1000 # HEX: Entry: 0xCAFE # OCT: Entry: 0x1FF