Skip to content

Commit

Permalink
Keep symbols passed by -init and -fini
Browse files Browse the repository at this point in the history
Previously, symbols passed by -init and -fini look as if they are
not referenced by anyone, and the LTO might eliminate them.
This patch fixes the issue.

Fixes a bug reported in https://bugs.llvm.org/show_bug.cgi?id=43927

Differential Revision: https://reviews.llvm.org/D69985
  • Loading branch information
rui314 committed Nov 8, 2019
1 parent 41449c5 commit f95273f
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 0 deletions.
6 changes: 6 additions & 0 deletions lld/ELF/Driver.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1782,6 +1782,12 @@ template <class ELFT> void LinkerDriver::link(opt::InputArgList &args) {
for (StringRef pat : args::getStrings(args, OPT_undefined_glob))
handleUndefinedGlob(pat);

// Mark -init and -fini symbols so that the LTO doesn't eliminate them.
if (Symbol *sym = symtab->find(config->init))
sym->isUsedInRegularObj = true;
if (Symbol *sym = symtab->find(config->fini))
sym->isUsedInRegularObj = true;

// If any of our inputs are bitcode files, the LTO code generator may create
// references to certain library functions that might not be explicit in the
// bitcode file's symbol table. If any of those library functions are defined
Expand Down
38 changes: 38 additions & 0 deletions lld/test/ELF/lto/init-fini.ll
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
; REQUIRES: x86
; RUN: llvm-as %s -o %t.o

;;
;; Verify that symbols given by -init and -fini are preserved and
;; DT_INIT/DT_FINI are created.
;;

; RUN: ld.lld -o %t.exe -pie %t.o
; RUN: llvm-nm %t.exe | FileCheck -check-prefix=TEST1 --allow-empty %s
; RUN: llvm-readelf -d %t.exe | FileCheck -check-prefix=TEST2 %s

; TEST1-NOT: foo
; TEST1-NOT: bar

; TEST2-NOT: INIT
; TEST2-NOT: FINI

; RUN: ld.lld -o %t.exe -pie -init=foo -fini=bar %t.o
; RUN: llvm-nm %t.exe | FileCheck -check-prefix=TEST3 %s
; RUN: llvm-readelf -d %t.exe | FileCheck -check-prefix=TEST4 %s

; TEST3: bar
; TEST3: foo

; TEST4: INIT
; TEST4: FINI

target triple = "x86_64-unknown-linux-gnu"
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128"

define void @foo() {
ret void
}

define void @bar() {
ret void
}

0 comments on commit f95273f

Please sign in to comment.