blob: 5e6cb639787ec1de5e323db7ec3174493b51f17d [file] [log] [blame]
Rui Ueyamac4aaed92015-10-22 18:49:53 +00001//===- MarkLive.cpp -------------------------------------------------------===//
2//
3// The LLVM Linker
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This file implements --gc-sections, which is a feature to remove unused
11// sections from output. Unused sections are sections that are not reachable
12// from known GC-root symbols or sections. Naturally the feature is
13// implemented as a mark-sweep garbage collector.
14//
15// Here's how it works. Each InputSectionBase has a "Live" bit. The bit is off
16// by default. Starting with GC-root symbols or sections, markLive function
17// defined in this file visits all reachable sections to set their Live
18// bits. Writer will then ignore sections whose Live bits are off, so that
19// such sections are removed from output.
20//
21//===----------------------------------------------------------------------===//
22
23#include "InputSection.h"
24#include "OutputSections.h"
25#include "SymbolTable.h"
26#include "Symbols.h"
27#include "Writer.h"
28#include "llvm/ADT/STLExtras.h"
29#include "llvm/Object/ELF.h"
30#include <functional>
31#include <vector>
32
33using namespace llvm;
34using namespace llvm::ELF;
35using namespace llvm::object;
36
37using namespace lld;
38using namespace lld::elf2;
39
Rui Ueyamac4aaed92015-10-22 18:49:53 +000040// Calls Fn for each section that Sec refers to.
41template <class ELFT>
42static void forEachSuccessor(InputSection<ELFT> *Sec,
43 std::function<void(InputSectionBase<ELFT> *)> Fn) {
Rui Ueyama12504642015-10-27 21:51:13 +000044 typedef typename ELFFile<ELFT>::Elf_Rel Elf_Rel;
45 typedef typename ELFFile<ELFT>::Elf_Rela Elf_Rela;
Rui Ueyamac4aaed92015-10-22 18:49:53 +000046 typedef typename ELFFile<ELFT>::Elf_Shdr Elf_Shdr;
Rui Ueyama12504642015-10-27 21:51:13 +000047
48 ELFFile<ELFT> &Obj = Sec->getFile()->getObj();
Rui Ueyamac4aaed92015-10-22 18:49:53 +000049 for (const Elf_Shdr *RelSec : Sec->RelocSections) {
Rui Ueyama12504642015-10-27 21:51:13 +000050 if (RelSec->sh_type == SHT_RELA) {
51 for (const Elf_Rela &RI : Obj.relas(RelSec))
52 if (InputSectionBase<ELFT> *Succ = Sec->getRelocTarget(RI))
53 Fn(Succ);
54 } else {
55 for (const Elf_Rel &RI : Obj.rels(RelSec))
56 if (InputSectionBase<ELFT> *Succ = Sec->getRelocTarget(RI))
57 Fn(Succ);
58 }
Rui Ueyamac4aaed92015-10-22 18:49:53 +000059 }
60}
61
62// Sections listed below are special because they are used by the loader
63// just by being in an ELF file. They should not be garbage-collected.
64template <class ELFT> static bool isReserved(InputSectionBase<ELFT> *Sec) {
65 switch (Sec->getSectionHdr()->sh_type) {
66 case SHT_FINI_ARRAY:
67 case SHT_INIT_ARRAY:
68 case SHT_NOTE:
69 case SHT_PREINIT_ARRAY:
70 return true;
71 default:
72 StringRef S = Sec->getSectionName();
Rui Ueyama8a598f82015-10-22 21:42:05 +000073 return S.startswith(".init") || S.startswith(".fini") ||
Rafael Espindola8ea46e02015-11-09 17:44:10 +000074 S.startswith(".jcr");
Rui Ueyamac4aaed92015-10-22 18:49:53 +000075 }
76}
77
Rui Ueyama7924fb82015-12-24 09:50:22 +000078// This is the main function of the garbage collector.
79// Starting from GC-root sections, this function visits all reachable
80// sections to set their "Live" bits.
Rui Ueyamac4aaed92015-10-22 18:49:53 +000081template <class ELFT> void lld::elf2::markLive(SymbolTable<ELFT> *Symtab) {
Rui Ueyama92ce0e92015-11-12 19:42:43 +000082 SmallVector<InputSection<ELFT> *, 256> Q;
Rui Ueyamac4aaed92015-10-22 18:49:53 +000083
84 auto Enqueue = [&](InputSectionBase<ELFT> *Sec) {
85 if (!Sec || Sec->Live)
86 return;
87 Sec->Live = true;
Rui Ueyama92ce0e92015-11-12 19:42:43 +000088 if (InputSection<ELFT> *S = dyn_cast<InputSection<ELFT>>(Sec))
89 Q.push_back(S);
Rui Ueyamac4aaed92015-10-22 18:49:53 +000090 };
91
92 auto MarkSymbol = [&](SymbolBody *Sym) {
93 if (Sym)
Rui Ueyama2beabc92015-10-22 23:10:25 +000094 if (auto *D = dyn_cast<DefinedRegular<ELFT>>(Sym->repl()))
Rui Ueyamac4aaed92015-10-22 18:49:53 +000095 Enqueue(&D->Section);
96 };
97
98 // Add GC root symbols.
99 MarkSymbol(Config->EntrySym);
100 MarkSymbol(Symtab->find(Config->Init));
101 MarkSymbol(Symtab->find(Config->Fini));
102 for (StringRef S : Config->Undefined)
103 MarkSymbol(Symtab->find(S));
104
105 // Preserve externally-visible symbols if the symbols defined by this
106 // file could override other ELF file's symbols at runtime.
107 if (Config->Shared || Config->ExportDynamic) {
108 for (const std::pair<StringRef, Symbol *> &P : Symtab->getSymbols()) {
109 SymbolBody *B = P.second->Body;
110 if (B->getVisibility() == STV_DEFAULT)
111 MarkSymbol(B);
112 }
113 }
114
115 // Preserve special sections.
Rafael Espindola8ea46e02015-11-09 17:44:10 +0000116 for (const std::unique_ptr<ObjectFile<ELFT>> &F : Symtab->getObjectFiles()) {
117 for (InputSectionBase<ELFT> *Sec : F->getSections()) {
Rui Ueyamab2f6fc12015-11-12 19:45:58 +0000118 if (!Sec || Sec == &InputSection<ELFT>::Discarded)
119 continue;
120 if (isReserved(Sec))
121 Enqueue(Sec);
122 else if (Sec->getSectionName() == ".eh_frame")
123 // .eh_frame is special. It should be marked live so that we don't
124 // drop it, but it should not keep any section alive.
125 Sec->Live = true;
Rafael Espindola8ea46e02015-11-09 17:44:10 +0000126 }
127 }
Rui Ueyamac4aaed92015-10-22 18:49:53 +0000128
129 // Mark all reachable sections.
130 while (!Q.empty())
Rui Ueyama92ce0e92015-11-12 19:42:43 +0000131 forEachSuccessor<ELFT>(Q.pop_back_val(), Enqueue);
Rui Ueyamac4aaed92015-10-22 18:49:53 +0000132}
133
134template void lld::elf2::markLive<ELF32LE>(SymbolTable<ELF32LE> *);
135template void lld::elf2::markLive<ELF32BE>(SymbolTable<ELF32BE> *);
136template void lld::elf2::markLive<ELF64LE>(SymbolTable<ELF64LE> *);
137template void lld::elf2::markLive<ELF64BE>(SymbolTable<ELF64BE> *);