blob: 1fb450b9e6bcdbc9eb7edd5d7c51fdabd12714bc [file] [log] [blame]
Rui Ueyama411c63602015-05-28 19:09:30 +00001//===- SymbolTable.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#include "Config.h"
11#include "Driver.h"
Rui Ueyama8fd9fb92015-06-01 02:58:15 +000012#include "Error.h"
Rui Ueyama411c63602015-05-28 19:09:30 +000013#include "SymbolTable.h"
Chandler Carruthbe6e80b2015-06-29 18:50:11 +000014#include "Symbols.h"
Rui Ueyama411c63602015-05-28 19:09:30 +000015#include "llvm/ADT/STLExtras.h"
Peter Collingbourne60c16162015-06-01 20:10:10 +000016#include "llvm/LTO/LTOCodeGenerator.h"
Rui Ueyama411c63602015-05-28 19:09:30 +000017#include "llvm/Support/Debug.h"
18#include "llvm/Support/raw_ostream.h"
Rui Ueyamaf5313b32015-06-28 22:16:41 +000019#include <utility>
Rui Ueyama411c63602015-05-28 19:09:30 +000020
Rui Ueyamad68ff342015-05-31 03:57:30 +000021using namespace llvm;
22
Rui Ueyama411c63602015-05-28 19:09:30 +000023namespace lld {
24namespace coff {
25
Rui Ueyama8d3010a2015-06-30 19:35:21 +000026void SymbolTable::addFile(std::unique_ptr<InputFile> FileP) {
27 InputFile *File = FileP.get();
28 Files.push_back(std::move(FileP));
29 if (auto *F = dyn_cast<ArchiveFile>(File)) {
30 ArchiveQueue.push_back(F);
31 return;
32 }
33 ObjectQueue.push_back(File);
34 if (auto *F = dyn_cast<ObjectFile>(File)) {
35 ObjectFiles.push_back(F);
36 } else if (auto *F = dyn_cast<BitcodeFile>(File)) {
37 BitcodeFiles.push_back(F);
38 } else {
39 ImportFiles.push_back(cast<ImportFile>(File));
40 }
Rui Ueyama411c63602015-05-28 19:09:30 +000041}
42
Rafael Espindolab835ae82015-08-06 14:58:50 +000043void SymbolTable::step() {
Rui Ueyama85225b02015-07-02 03:15:15 +000044 if (queueEmpty())
Rafael Espindolab835ae82015-08-06 14:58:50 +000045 return;
46 readObjects();
47 readArchives();
Rui Ueyama85225b02015-07-02 03:15:15 +000048}
49
Rafael Espindolab835ae82015-08-06 14:58:50 +000050void SymbolTable::run() {
Rui Ueyama85225b02015-07-02 03:15:15 +000051 while (!queueEmpty())
Rafael Espindolab835ae82015-08-06 14:58:50 +000052 step();
Peter Collingbourneace2f092015-06-06 02:00:45 +000053}
54
Rafael Espindolab835ae82015-08-06 14:58:50 +000055void SymbolTable::readArchives() {
Rui Ueyama8d3010a2015-06-30 19:35:21 +000056 if (ArchiveQueue.empty())
Rafael Espindolab835ae82015-08-06 14:58:50 +000057 return;
Rui Ueyama8d3010a2015-06-30 19:35:21 +000058
59 // Add lazy symbols to the symbol table. Lazy symbols that conflict
60 // with existing undefined symbols are accumulated in LazySyms.
61 std::vector<Symbol *> LazySyms;
62 for (ArchiveFile *File : ArchiveQueue) {
63 if (Config->Verbose)
64 llvm::outs() << "Reading " << File->getShortName() << "\n";
Rafael Espindolab835ae82015-08-06 14:58:50 +000065 File->parse();
Rui Ueyama8d3010a2015-06-30 19:35:21 +000066 for (Lazy *Sym : File->getLazySymbols())
67 addLazy(Sym, &LazySyms);
68 }
69 ArchiveQueue.clear();
70
71 // Add archive member files to ObjectQueue that should resolve
72 // existing undefined symbols.
73 for (Symbol *Sym : LazySyms)
Rafael Espindolab835ae82015-08-06 14:58:50 +000074 addMemberFile(cast<Lazy>(Sym->Body));
Rui Ueyama8d3010a2015-06-30 19:35:21 +000075}
76
Rafael Espindolab835ae82015-08-06 14:58:50 +000077void SymbolTable::readObjects() {
Rui Ueyama8d3010a2015-06-30 19:35:21 +000078 if (ObjectQueue.empty())
Rafael Espindolab835ae82015-08-06 14:58:50 +000079 return;
Rui Ueyama8d3010a2015-06-30 19:35:21 +000080
81 // Add defined and undefined symbols to the symbol table.
82 std::vector<StringRef> Directives;
83 for (size_t I = 0; I < ObjectQueue.size(); ++I) {
84 InputFile *File = ObjectQueue[I];
85 if (Config->Verbose)
86 llvm::outs() << "Reading " << File->getShortName() << "\n";
Rafael Espindolab835ae82015-08-06 14:58:50 +000087 File->parse();
Rui Ueyama8d3010a2015-06-30 19:35:21 +000088 // Adding symbols may add more files to ObjectQueue
89 // (but not to ArchiveQueue).
90 for (SymbolBody *Sym : File->getSymbols())
91 if (Sym->isExternal())
Rafael Espindolab835ae82015-08-06 14:58:50 +000092 addSymbol(Sym);
Rui Ueyama8d3010a2015-06-30 19:35:21 +000093 StringRef S = File->getDirectives();
Rui Ueyamaa3d463d2015-07-04 01:39:11 +000094 if (!S.empty()) {
Rui Ueyama8d3010a2015-06-30 19:35:21 +000095 Directives.push_back(S);
Rui Ueyamaa3d463d2015-07-04 01:39:11 +000096 if (Config->Verbose)
97 llvm::outs() << "Directives: " << File->getShortName()
98 << ": " << S << "\n";
99 }
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000100 }
101 ObjectQueue.clear();
102
103 // Parse directive sections. This may add files to
104 // ArchiveQueue and ObjectQueue.
105 for (StringRef S : Directives)
Rafael Espindolab835ae82015-08-06 14:58:50 +0000106 Driver->parseDirectives(S);
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000107}
108
Rui Ueyama3d4c69c2015-07-02 02:38:59 +0000109bool SymbolTable::queueEmpty() {
110 return ArchiveQueue.empty() && ObjectQueue.empty();
111}
112
Rafael Espindolab835ae82015-08-06 14:58:50 +0000113void SymbolTable::reportRemainingUndefines(bool Resolve) {
Peter Collingbournef5339ec2015-07-07 18:38:39 +0000114 llvm::SmallPtrSet<SymbolBody *, 8> Undefs;
Rui Ueyama411c63602015-05-28 19:09:30 +0000115 for (auto &I : Symtab) {
116 Symbol *Sym = I.second;
Rui Ueyama183f53f2015-07-06 17:45:22 +0000117 auto *Undef = dyn_cast<Undefined>(Sym->Body);
Rui Ueyama411c63602015-05-28 19:09:30 +0000118 if (!Undef)
119 continue;
Rui Ueyamad7666532015-06-25 02:21:44 +0000120 StringRef Name = Undef->getName();
Peter Collingbourne2612a322015-07-04 05:28:41 +0000121 // A weak alias may have been resolved, so check for that.
122 if (Defined *D = Undef->getWeakAlias()) {
123 if (Resolve)
Rui Ueyama6bf638e2015-07-02 00:04:14 +0000124 Sym->Body = D;
Peter Collingbourne2612a322015-07-04 05:28:41 +0000125 continue;
Rui Ueyama411c63602015-05-28 19:09:30 +0000126 }
Rui Ueyamad7666532015-06-25 02:21:44 +0000127 // If we can resolve a symbol by removing __imp_ prefix, do that.
128 // This odd rule is for compatibility with MSVC linker.
129 if (Name.startswith("__imp_")) {
Rui Ueyama458d7442015-07-02 03:59:04 +0000130 Symbol *Imp = find(Name.substr(strlen("__imp_")));
Rui Ueyama183f53f2015-07-06 17:45:22 +0000131 if (Imp && isa<Defined>(Imp->Body)) {
Peter Collingbourne2612a322015-07-04 05:28:41 +0000132 if (!Resolve)
133 continue;
Rui Ueyama183f53f2015-07-06 17:45:22 +0000134 auto *D = cast<Defined>(Imp->Body);
Rui Ueyama458d7442015-07-02 03:59:04 +0000135 auto *S = new (Alloc) DefinedLocalImport(Name, D);
Rui Ueyama88e0f922015-06-25 03:31:47 +0000136 LocalImportChunks.push_back(S->getChunk());
137 Sym->Body = S;
Rui Ueyamad7666532015-06-25 02:21:44 +0000138 continue;
139 }
140 }
Rui Ueyama95925fd2015-06-28 19:35:15 +0000141 // Remaining undefined symbols are not fatal if /force is specified.
142 // They are replaced with dummy defined symbols.
Peter Collingbournef5339ec2015-07-07 18:38:39 +0000143 if (Config->Force && Resolve)
144 Sym->Body = new (Alloc) DefinedAbsolute(Name, 0);
145 Undefs.insert(Sym->Body);
Rui Ueyama411c63602015-05-28 19:09:30 +0000146 }
Peter Collingbournef5339ec2015-07-07 18:38:39 +0000147 if (Undefs.empty())
Rafael Espindolab835ae82015-08-06 14:58:50 +0000148 return;
Peter Collingbournef5339ec2015-07-07 18:38:39 +0000149 for (Undefined *U : Config->GCRoot)
150 if (Undefs.count(U->repl()))
151 llvm::errs() << "<root>: undefined symbol: " << U->getName() << "\n";
152 for (std::unique_ptr<InputFile> &File : Files)
153 if (!isa<ArchiveFile>(File.get()))
154 for (SymbolBody *Sym : File->getSymbols())
155 if (Undefs.count(Sym->repl()))
156 llvm::errs() << File->getShortName() << ": undefined symbol: "
157 << Sym->getName() << "\n";
Rafael Espindolab835ae82015-08-06 14:58:50 +0000158 if (!Config->Force)
159 error("Link failed");
Rui Ueyama411c63602015-05-28 19:09:30 +0000160}
161
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000162void SymbolTable::addLazy(Lazy *New, std::vector<Symbol *> *Accum) {
Rui Ueyama6be90992015-07-02 22:52:33 +0000163 Symbol *Sym = insert(New);
164 if (Sym->Body == New)
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000165 return;
Rui Ueyamae2eb1552015-07-05 22:05:08 +0000166 for (;;) {
167 SymbolBody *Existing = Sym->Body;
168 if (isa<Defined>(Existing))
169 return;
170 if (Lazy *L = dyn_cast<Lazy>(Existing))
171 if (L->getFileIndex() < New->getFileIndex())
172 return;
173 if (!Sym->Body.compare_exchange_strong(Existing, New))
174 continue;
175 New->setBackref(Sym);
Peter Collingbourne8e174512015-07-07 02:15:25 +0000176 if (isa<Undefined>(Existing))
177 Accum->push_back(Sym);
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000178 return;
Rui Ueyamae2eb1552015-07-05 22:05:08 +0000179 }
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000180}
181
Rafael Espindolab835ae82015-08-06 14:58:50 +0000182void SymbolTable::addSymbol(SymbolBody *New) {
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000183 // Find an existing symbol or create and insert a new one.
184 assert(isa<Defined>(New) || isa<Undefined>(New));
Rui Ueyama6be90992015-07-02 22:52:33 +0000185 Symbol *Sym = insert(New);
186 if (Sym->Body == New)
Rafael Espindolab835ae82015-08-06 14:58:50 +0000187 return;
Rui Ueyama411c63602015-05-28 19:09:30 +0000188
Rui Ueyamae2eb1552015-07-05 22:05:08 +0000189 for (;;) {
190 SymbolBody *Existing = Sym->Body;
191
192 // If we have an undefined symbol and a lazy symbol,
193 // let the lazy symbol to read a member file.
194 if (auto *L = dyn_cast<Lazy>(Existing)) {
195 // Undefined symbols with weak aliases need not to be resolved,
196 // since they would be replaced with weak aliases if they remain
197 // undefined.
198 if (auto *U = dyn_cast<Undefined>(New))
Rafael Espindolab835ae82015-08-06 14:58:50 +0000199 if (!U->WeakAlias) {
200 addMemberFile(L);
201 return;
202 }
Rui Ueyamae2eb1552015-07-05 22:05:08 +0000203 if (!Sym->Body.compare_exchange_strong(Existing, New))
204 continue;
Rafael Espindolab835ae82015-08-06 14:58:50 +0000205 return;
Rui Ueyamae2eb1552015-07-05 22:05:08 +0000206 }
207
208 // compare() returns -1, 0, or 1 if the lhs symbol is less preferable,
209 // equivalent (conflicting), or more preferable, respectively.
210 int Comp = Existing->compare(New);
Rafael Espindolab835ae82015-08-06 14:58:50 +0000211 if (Comp == 0)
212 error(Twine("duplicate symbol: ") + Existing->getDebugName() + " and " +
213 New->getDebugName());
Rui Ueyamae2eb1552015-07-05 22:05:08 +0000214 if (Comp < 0)
215 if (!Sym->Body.compare_exchange_strong(Existing, New))
216 continue;
Rafael Espindolab835ae82015-08-06 14:58:50 +0000217 return;
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000218 }
Rui Ueyama411c63602015-05-28 19:09:30 +0000219}
220
Rui Ueyama6be90992015-07-02 22:52:33 +0000221Symbol *SymbolTable::insert(SymbolBody *New) {
222 Symbol *&Sym = Symtab[New->getName()];
223 if (Sym) {
224 New->setBackref(Sym);
225 return Sym;
226 }
227 Sym = new (Alloc) Symbol(New);
228 New->setBackref(Sym);
229 return Sym;
230}
231
Rui Ueyama411c63602015-05-28 19:09:30 +0000232// Reads an archive member file pointed by a given symbol.
Rafael Espindolab835ae82015-08-06 14:58:50 +0000233void SymbolTable::addMemberFile(Lazy *Body) {
234 std::unique_ptr<InputFile> File = Body->getMember();
Rui Ueyama411c63602015-05-28 19:09:30 +0000235
236 // getMember returns an empty buffer if the member was already
237 // read from the library.
238 if (!File)
Rafael Espindolab835ae82015-08-06 14:58:50 +0000239 return;
Rui Ueyama411c63602015-05-28 19:09:30 +0000240 if (Config->Verbose)
Rui Ueyama5b2588a2015-06-08 05:43:50 +0000241 llvm::outs() << "Loaded " << File->getShortName() << " for "
Rui Ueyama411c63602015-05-28 19:09:30 +0000242 << Body->getName() << "\n";
Rui Ueyama0d2e9992015-06-23 23:56:39 +0000243 addFile(std::move(File));
Rui Ueyama411c63602015-05-28 19:09:30 +0000244}
245
246std::vector<Chunk *> SymbolTable::getChunks() {
247 std::vector<Chunk *> Res;
Rui Ueyama0d2e9992015-06-23 23:56:39 +0000248 for (ObjectFile *File : ObjectFiles) {
Rui Ueyama411c63602015-05-28 19:09:30 +0000249 std::vector<Chunk *> &V = File->getChunks();
250 Res.insert(Res.end(), V.begin(), V.end());
251 }
252 return Res;
253}
254
Rui Ueyama458d7442015-07-02 03:59:04 +0000255Symbol *SymbolTable::find(StringRef Name) {
Rui Ueyama45044f42015-06-29 01:03:53 +0000256 auto It = Symtab.find(Name);
257 if (It == Symtab.end())
258 return nullptr;
Rui Ueyama4b669892015-06-30 23:46:52 +0000259 return It->second;
Rui Ueyama45044f42015-06-29 01:03:53 +0000260}
261
Rui Ueyama506f6d12015-07-28 22:56:02 +0000262Symbol *SymbolTable::findUnderscore(StringRef Name) {
263 if (Config->Machine == I386)
264 return find(("_" + Name).str());
265 return find(Name);
266}
267
Rui Ueyamaa50387f2015-07-14 02:58:13 +0000268StringRef SymbolTable::findByPrefix(StringRef Prefix) {
269 for (auto Pair : Symtab) {
270 StringRef Name = Pair.first;
271 if (Name.startswith(Prefix))
272 return Name;
273 }
274 return "";
275}
276
277StringRef SymbolTable::findMangle(StringRef Name) {
278 if (Symbol *Sym = find(Name))
279 if (!isa<Undefined>(Sym->Body))
280 return Name;
Rui Ueyama5e706b32015-07-25 21:54:50 +0000281 if (Config->Machine != I386)
Rui Ueyamaa50387f2015-07-14 02:58:13 +0000282 return findByPrefix(("?" + Name + "@@Y").str());
283 if (!Name.startswith("_"))
284 return "";
285 // Search for x86 C function.
286 StringRef S = findByPrefix((Name + "@").str());
287 if (!S.empty())
288 return S;
289 // Search for x86 C++ non-member function.
290 return findByPrefix(("?" + Name.substr(1) + "@@Y").str());
291}
292
Rui Ueyama6bf638e2015-07-02 00:04:14 +0000293void SymbolTable::mangleMaybe(Undefined *U) {
294 if (U->WeakAlias)
295 return;
Rui Ueyama0744e872015-07-02 00:21:11 +0000296 if (!isa<Undefined>(U->repl()))
Rui Ueyama6bf638e2015-07-02 00:04:14 +0000297 return;
Rui Ueyamaa50387f2015-07-14 02:58:13 +0000298 StringRef Alias = findMangle(U->getName());
299 if (!Alias.empty())
300 U->WeakAlias = addUndefined(Alias);
Rui Ueyamaf5313b32015-06-28 22:16:41 +0000301}
302
Rui Ueyama6bf638e2015-07-02 00:04:14 +0000303Undefined *SymbolTable::addUndefined(StringRef Name) {
Rui Ueyama3d4c69c2015-07-02 02:38:59 +0000304 auto *New = new (Alloc) Undefined(Name);
305 addSymbol(New);
306 if (auto *U = dyn_cast<Undefined>(New->repl()))
307 return U;
308 return New;
Rui Ueyama360bace2015-05-31 22:31:31 +0000309}
310
Rui Ueyamacd3f99b2015-07-24 23:51:14 +0000311DefinedRelative *SymbolTable::addRelative(StringRef Name, uint64_t VA) {
312 auto *New = new (Alloc) DefinedRelative(Name, VA);
313 addSymbol(New);
314 return New;
315}
316
317DefinedAbsolute *SymbolTable::addAbsolute(StringRef Name, uint64_t VA) {
318 auto *New = new (Alloc) DefinedAbsolute(Name, VA);
319 addSymbol(New);
320 return New;
Rui Ueyama49d6cd32015-07-03 00:02:19 +0000321}
322
Peter Collingbournebe549552015-06-26 18:58:24 +0000323void SymbolTable::printMap(llvm::raw_ostream &OS) {
324 for (ObjectFile *File : ObjectFiles) {
325 OS << File->getShortName() << ":\n";
326 for (SymbolBody *Body : File->getSymbols())
327 if (auto *R = dyn_cast<DefinedRegular>(Body))
Rui Ueyamad2d23602015-08-21 07:01:08 +0000328 if (!R->isCOMDAT() || R->isLive())
Peter Collingbournebe549552015-06-26 18:58:24 +0000329 OS << Twine::utohexstr(Config->ImageBase + R->getRVA())
330 << " " << R->getName() << "\n";
331 }
332}
333
Rafael Espindolab835ae82015-08-06 14:58:50 +0000334void SymbolTable::addCombinedLTOObject() {
Peter Collingbourne60c16162015-06-01 20:10:10 +0000335 if (BitcodeFiles.empty())
Rafael Espindolab835ae82015-08-06 14:58:50 +0000336 return;
Peter Collingbourne60c16162015-06-01 20:10:10 +0000337
Peter Collingbourne2612a322015-07-04 05:28:41 +0000338 // Diagnose any undefined symbols early, but do not resolve weak externals,
339 // as resolution breaks the invariant that each Symbol points to a unique
340 // SymbolBody, which we rely on to replace DefinedBitcode symbols correctly.
Rafael Espindolab835ae82015-08-06 14:58:50 +0000341 reportRemainingUndefines(/*Resolve=*/false);
Peter Collingbourne2612a322015-07-04 05:28:41 +0000342
Peter Collingbourne60c16162015-06-01 20:10:10 +0000343 // Create an object file and add it to the symbol table by replacing any
344 // DefinedBitcode symbols with the definitions in the object file.
Rui Ueyamaefba7812015-06-09 17:52:17 +0000345 LTOCodeGenerator CG;
Peter Collingbourne526ff152015-08-14 04:47:07 +0000346 CG.setOptLevel(Config->LTOOptLevel);
Rafael Espindolab835ae82015-08-06 14:58:50 +0000347 ObjectFile *Obj = createLTOObject(&CG);
Rui Ueyamaefba7812015-06-09 17:52:17 +0000348
Peter Collingbourne60c16162015-06-01 20:10:10 +0000349 for (SymbolBody *Body : Obj->getSymbols()) {
350 if (!Body->isExternal())
351 continue;
Peter Collingbourne2612a322015-07-04 05:28:41 +0000352 // We should not see any new undefined symbols at this point, but we'll
353 // diagnose them later in reportRemainingUndefines().
Peter Collingbourne60c16162015-06-01 20:10:10 +0000354 StringRef Name = Body->getName();
Rui Ueyama6be90992015-07-02 22:52:33 +0000355 Symbol *Sym = insert(Body);
Peter Collingbourne60c16162015-06-01 20:10:10 +0000356
Rui Ueyama183f53f2015-07-06 17:45:22 +0000357 if (isa<DefinedBitcode>(Sym->Body)) {
Peter Collingbourne60c16162015-06-01 20:10:10 +0000358 Sym->Body = Body;
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000359 continue;
Peter Collingbourne60c16162015-06-01 20:10:10 +0000360 }
Rui Ueyama183f53f2015-07-06 17:45:22 +0000361 if (auto *L = dyn_cast<Lazy>(Sym->Body)) {
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000362 // We may see new references to runtime library symbols such as __chkstk
363 // here. These symbols must be wholly defined in non-bitcode files.
Rafael Espindolab835ae82015-08-06 14:58:50 +0000364 addMemberFile(L);
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000365 continue;
366 }
367 SymbolBody *Existing = Sym->Body;
368 int Comp = Existing->compare(Body);
Rafael Espindolab835ae82015-08-06 14:58:50 +0000369 if (Comp == 0)
370 error(Twine("LTO: unexpected duplicate symbol: ") + Name);
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000371 if (Comp < 0)
372 Sym->Body = Body;
Rui Ueyama0d2e9992015-06-23 23:56:39 +0000373 }
374
375 size_t NumBitcodeFiles = BitcodeFiles.size();
Rafael Espindolab835ae82015-08-06 14:58:50 +0000376 run();
377 if (BitcodeFiles.size() != NumBitcodeFiles)
378 error("LTO: late loaded symbol created new bitcode reference");
Peter Collingbourne60c16162015-06-01 20:10:10 +0000379}
380
Rui Ueyamaefba7812015-06-09 17:52:17 +0000381// Combine and compile bitcode files and then return the result
382// as a regular COFF object file.
Rafael Espindolab835ae82015-08-06 14:58:50 +0000383ObjectFile *SymbolTable::createLTOObject(LTOCodeGenerator *CG) {
Rui Ueyamaefba7812015-06-09 17:52:17 +0000384 // All symbols referenced by non-bitcode objects must be preserved.
Rui Ueyama0d2e9992015-06-23 23:56:39 +0000385 for (ObjectFile *File : ObjectFiles)
Rui Ueyamaefba7812015-06-09 17:52:17 +0000386 for (SymbolBody *Body : File->getSymbols())
Rui Ueyama0744e872015-07-02 00:21:11 +0000387 if (auto *S = dyn_cast<DefinedBitcode>(Body->repl()))
Rui Ueyamaefba7812015-06-09 17:52:17 +0000388 CG->addMustPreserveSymbol(S->getName());
389
Peter Collingbourne1b6fd1f2015-06-11 21:49:54 +0000390 // Likewise for bitcode symbols which we initially resolved to non-bitcode.
Rui Ueyama0d2e9992015-06-23 23:56:39 +0000391 for (BitcodeFile *File : BitcodeFiles)
Peter Collingbourne1b6fd1f2015-06-11 21:49:54 +0000392 for (SymbolBody *Body : File->getSymbols())
Rui Ueyama0744e872015-07-02 00:21:11 +0000393 if (isa<DefinedBitcode>(Body) && !isa<DefinedBitcode>(Body->repl()))
Peter Collingbourne1b6fd1f2015-06-11 21:49:54 +0000394 CG->addMustPreserveSymbol(Body->getName());
395
Rui Ueyamaefba7812015-06-09 17:52:17 +0000396 // Likewise for other symbols that must be preserved.
Peter Collingbourne2612a322015-07-04 05:28:41 +0000397 for (Undefined *U : Config->GCRoot) {
398 if (auto *S = dyn_cast<DefinedBitcode>(U->repl()))
399 CG->addMustPreserveSymbol(S->getName());
400 else if (auto *S = dyn_cast_or_null<DefinedBitcode>(U->getWeakAlias()))
401 CG->addMustPreserveSymbol(S->getName());
402 }
Rui Ueyamaefba7812015-06-09 17:52:17 +0000403
Peter Collingbourne0bb50d92015-08-24 22:22:58 +0000404 CG->setModule(BitcodeFiles[0]->takeModule());
Rui Ueyamaefba7812015-06-09 17:52:17 +0000405 for (unsigned I = 1, E = BitcodeFiles.size(); I != E; ++I)
406 CG->addModule(BitcodeFiles[I]->getModule());
407
408 std::string ErrMsg;
409 LTOMB = CG->compile(false, false, false, ErrMsg); // take MB ownership
Rafael Espindolab835ae82015-08-06 14:58:50 +0000410 if (!LTOMB)
411 error(ErrMsg);
Rui Ueyama0d2e9992015-06-23 23:56:39 +0000412 auto *Obj = new ObjectFile(LTOMB->getMemBufferRef());
413 Files.emplace_back(Obj);
414 ObjectFiles.push_back(Obj);
Rafael Espindolab835ae82015-08-06 14:58:50 +0000415 Obj->parse();
Rui Ueyamaefba7812015-06-09 17:52:17 +0000416 return Obj;
417}
418
Rui Ueyama411c63602015-05-28 19:09:30 +0000419} // namespace coff
420} // namespace lld