blob: df9da4c36650dbbe4715e3aed1684cf97e227d36 [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 Ueyamaf4d05d72015-09-19 01:48:26 +000015#include "lld/Core/Parallel.h"
Rafael Espindola35dad132015-12-04 02:42:47 +000016#include "llvm/IR/LLVMContext.h"
Peter Collingbourne765aa2d2016-07-14 21:30:37 +000017#include "llvm/LTO/legacy/LTOCodeGenerator.h"
Rui Ueyama411c63602015-05-28 19:09:30 +000018#include "llvm/Support/Debug.h"
19#include "llvm/Support/raw_ostream.h"
Rui Ueyamaf5313b32015-06-28 22:16:41 +000020#include <utility>
Rui Ueyama411c63602015-05-28 19:09:30 +000021
Rui Ueyamad68ff342015-05-31 03:57:30 +000022using namespace llvm;
23
Rui Ueyama411c63602015-05-28 19:09:30 +000024namespace lld {
25namespace coff {
26
Rui Ueyama8d3010a2015-06-30 19:35:21 +000027void SymbolTable::addFile(std::unique_ptr<InputFile> FileP) {
Rui Ueyama98a98cf2015-09-21 19:12:36 +000028#if LLVM_ENABLE_THREADS
29 std::launch Policy = std::launch::async;
30#else
31 std::launch Policy = std::launch::deferred;
32#endif
33
Rui Ueyama8d3010a2015-06-30 19:35:21 +000034 InputFile *File = FileP.get();
35 Files.push_back(std::move(FileP));
36 if (auto *F = dyn_cast<ArchiveFile>(File)) {
Rui Ueyama997b3572015-09-20 03:11:16 +000037 ArchiveQueue.push_back(
Rui Ueyama98a98cf2015-09-21 19:12:36 +000038 std::async(Policy, [=]() { F->parse(); return F; }));
Rui Ueyama8d3010a2015-06-30 19:35:21 +000039 return;
40 }
Rui Ueyama997b3572015-09-20 03:11:16 +000041 ObjectQueue.push_back(
Rui Ueyama98a98cf2015-09-21 19:12:36 +000042 std::async(Policy, [=]() { File->parse(); return File; }));
Rui Ueyama8d3010a2015-06-30 19:35:21 +000043 if (auto *F = dyn_cast<ObjectFile>(File)) {
44 ObjectFiles.push_back(F);
45 } else if (auto *F = dyn_cast<BitcodeFile>(File)) {
46 BitcodeFiles.push_back(F);
47 } else {
48 ImportFiles.push_back(cast<ImportFile>(File));
49 }
Rui Ueyama411c63602015-05-28 19:09:30 +000050}
51
Rafael Espindolab835ae82015-08-06 14:58:50 +000052void SymbolTable::step() {
Rui Ueyama85225b02015-07-02 03:15:15 +000053 if (queueEmpty())
Rafael Espindolab835ae82015-08-06 14:58:50 +000054 return;
55 readObjects();
56 readArchives();
Rui Ueyama85225b02015-07-02 03:15:15 +000057}
58
Rafael Espindolab835ae82015-08-06 14:58:50 +000059void SymbolTable::run() {
Rui Ueyama85225b02015-07-02 03:15:15 +000060 while (!queueEmpty())
Rafael Espindolab835ae82015-08-06 14:58:50 +000061 step();
Peter Collingbourneace2f092015-06-06 02:00:45 +000062}
63
Rafael Espindolab835ae82015-08-06 14:58:50 +000064void SymbolTable::readArchives() {
Rui Ueyama8d3010a2015-06-30 19:35:21 +000065 if (ArchiveQueue.empty())
Rafael Espindolab835ae82015-08-06 14:58:50 +000066 return;
Rui Ueyama8d3010a2015-06-30 19:35:21 +000067
68 // Add lazy symbols to the symbol table. Lazy symbols that conflict
69 // with existing undefined symbols are accumulated in LazySyms.
70 std::vector<Symbol *> LazySyms;
Rui Ueyama997b3572015-09-20 03:11:16 +000071 for (std::future<ArchiveFile *> &Future : ArchiveQueue) {
72 ArchiveFile *File = Future.get();
Rui Ueyama8d3010a2015-06-30 19:35:21 +000073 if (Config->Verbose)
74 llvm::outs() << "Reading " << File->getShortName() << "\n";
Rafael Espindolafb497d72015-09-02 16:07:11 +000075 for (Lazy &Sym : File->getLazySymbols())
76 addLazy(&Sym, &LazySyms);
Rui Ueyama8d3010a2015-06-30 19:35:21 +000077 }
78 ArchiveQueue.clear();
79
80 // Add archive member files to ObjectQueue that should resolve
81 // existing undefined symbols.
82 for (Symbol *Sym : LazySyms)
Rafael Espindolab835ae82015-08-06 14:58:50 +000083 addMemberFile(cast<Lazy>(Sym->Body));
Rui Ueyama8d3010a2015-06-30 19:35:21 +000084}
85
Rafael Espindolab835ae82015-08-06 14:58:50 +000086void SymbolTable::readObjects() {
Rui Ueyama8d3010a2015-06-30 19:35:21 +000087 if (ObjectQueue.empty())
Rafael Espindolab835ae82015-08-06 14:58:50 +000088 return;
Rui Ueyama8d3010a2015-06-30 19:35:21 +000089
90 // Add defined and undefined symbols to the symbol table.
91 std::vector<StringRef> Directives;
Rui Ueyama997b3572015-09-20 03:11:16 +000092 for (size_t I = 0; I < ObjectQueue.size(); ++I) {
93 InputFile *File = ObjectQueue[I].get();
94 if (Config->Verbose)
95 llvm::outs() << "Reading " << File->getShortName() << "\n";
96 // Adding symbols may add more files to ObjectQueue
97 // (but not to ArchiveQueue).
98 for (SymbolBody *Sym : File->getSymbols())
99 if (Sym->isExternal())
100 addSymbol(Sym);
101 StringRef S = File->getDirectives();
102 if (!S.empty()) {
103 Directives.push_back(S);
Rui Ueyamaa3d463d2015-07-04 01:39:11 +0000104 if (Config->Verbose)
Rui Ueyama997b3572015-09-20 03:11:16 +0000105 llvm::outs() << "Directives: " << File->getShortName()
106 << ": " << S << "\n";
Rui Ueyamaa3d463d2015-07-04 01:39:11 +0000107 }
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000108 }
109 ObjectQueue.clear();
110
111 // Parse directive sections. This may add files to
112 // ArchiveQueue and ObjectQueue.
113 for (StringRef S : Directives)
Rafael Espindolab835ae82015-08-06 14:58:50 +0000114 Driver->parseDirectives(S);
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000115}
116
Rui Ueyama3d4c69c2015-07-02 02:38:59 +0000117bool SymbolTable::queueEmpty() {
118 return ArchiveQueue.empty() && ObjectQueue.empty();
119}
120
Rafael Espindolab835ae82015-08-06 14:58:50 +0000121void SymbolTable::reportRemainingUndefines(bool Resolve) {
Peter Collingbournef5339ec2015-07-07 18:38:39 +0000122 llvm::SmallPtrSet<SymbolBody *, 8> Undefs;
Rui Ueyama411c63602015-05-28 19:09:30 +0000123 for (auto &I : Symtab) {
124 Symbol *Sym = I.second;
Rui Ueyama183f53f2015-07-06 17:45:22 +0000125 auto *Undef = dyn_cast<Undefined>(Sym->Body);
Rui Ueyama411c63602015-05-28 19:09:30 +0000126 if (!Undef)
127 continue;
Rui Ueyamad7666532015-06-25 02:21:44 +0000128 StringRef Name = Undef->getName();
Peter Collingbourne2612a322015-07-04 05:28:41 +0000129 // A weak alias may have been resolved, so check for that.
130 if (Defined *D = Undef->getWeakAlias()) {
131 if (Resolve)
Rui Ueyama6bf638e2015-07-02 00:04:14 +0000132 Sym->Body = D;
Peter Collingbourne2612a322015-07-04 05:28:41 +0000133 continue;
Rui Ueyama411c63602015-05-28 19:09:30 +0000134 }
Rui Ueyamad7666532015-06-25 02:21:44 +0000135 // If we can resolve a symbol by removing __imp_ prefix, do that.
136 // This odd rule is for compatibility with MSVC linker.
137 if (Name.startswith("__imp_")) {
Rui Ueyama458d7442015-07-02 03:59:04 +0000138 Symbol *Imp = find(Name.substr(strlen("__imp_")));
Rui Ueyama183f53f2015-07-06 17:45:22 +0000139 if (Imp && isa<Defined>(Imp->Body)) {
Peter Collingbourne2612a322015-07-04 05:28:41 +0000140 if (!Resolve)
141 continue;
Rui Ueyama183f53f2015-07-06 17:45:22 +0000142 auto *D = cast<Defined>(Imp->Body);
Rui Ueyama458d7442015-07-02 03:59:04 +0000143 auto *S = new (Alloc) DefinedLocalImport(Name, D);
Rui Ueyama88e0f922015-06-25 03:31:47 +0000144 LocalImportChunks.push_back(S->getChunk());
145 Sym->Body = S;
Rui Ueyamad7666532015-06-25 02:21:44 +0000146 continue;
147 }
148 }
Rui Ueyama95925fd2015-06-28 19:35:15 +0000149 // Remaining undefined symbols are not fatal if /force is specified.
150 // They are replaced with dummy defined symbols.
Peter Collingbournef5339ec2015-07-07 18:38:39 +0000151 if (Config->Force && Resolve)
152 Sym->Body = new (Alloc) DefinedAbsolute(Name, 0);
153 Undefs.insert(Sym->Body);
Rui Ueyama411c63602015-05-28 19:09:30 +0000154 }
Peter Collingbournef5339ec2015-07-07 18:38:39 +0000155 if (Undefs.empty())
Rafael Espindolab835ae82015-08-06 14:58:50 +0000156 return;
Peter Collingbournef5339ec2015-07-07 18:38:39 +0000157 for (Undefined *U : Config->GCRoot)
158 if (Undefs.count(U->repl()))
159 llvm::errs() << "<root>: undefined symbol: " << U->getName() << "\n";
160 for (std::unique_ptr<InputFile> &File : Files)
161 if (!isa<ArchiveFile>(File.get()))
162 for (SymbolBody *Sym : File->getSymbols())
163 if (Undefs.count(Sym->repl()))
164 llvm::errs() << File->getShortName() << ": undefined symbol: "
165 << Sym->getName() << "\n";
Rafael Espindolab835ae82015-08-06 14:58:50 +0000166 if (!Config->Force)
Rui Ueyamabb579542016-07-15 01:12:24 +0000167 fatal("link failed");
Rui Ueyama411c63602015-05-28 19:09:30 +0000168}
169
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000170void SymbolTable::addLazy(Lazy *New, std::vector<Symbol *> *Accum) {
Rui Ueyama6be90992015-07-02 22:52:33 +0000171 Symbol *Sym = insert(New);
172 if (Sym->Body == New)
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000173 return;
Rui Ueyama1cce3002015-09-20 00:00:05 +0000174 SymbolBody *Existing = Sym->Body;
175 if (isa<Defined>(Existing))
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000176 return;
Rui Ueyama1cce3002015-09-20 00:00:05 +0000177 if (Lazy *L = dyn_cast<Lazy>(Existing))
178 if (L->getFileIndex() < New->getFileIndex())
179 return;
180 Sym->Body = New;
181 New->setBackref(Sym);
182 if (isa<Undefined>(Existing))
183 Accum->push_back(Sym);
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000184}
185
Rafael Espindolab835ae82015-08-06 14:58:50 +0000186void SymbolTable::addSymbol(SymbolBody *New) {
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000187 // Find an existing symbol or create and insert a new one.
188 assert(isa<Defined>(New) || isa<Undefined>(New));
Rui Ueyama6be90992015-07-02 22:52:33 +0000189 Symbol *Sym = insert(New);
190 if (Sym->Body == New)
Rafael Espindolab835ae82015-08-06 14:58:50 +0000191 return;
Rui Ueyama1cce3002015-09-20 00:00:05 +0000192 SymbolBody *Existing = Sym->Body;
Rui Ueyama411c63602015-05-28 19:09:30 +0000193
Rui Ueyama1cce3002015-09-20 00:00:05 +0000194 // If we have an undefined symbol and a lazy symbol,
195 // let the lazy symbol to read a member file.
196 if (auto *L = dyn_cast<Lazy>(Existing)) {
197 // Undefined symbols with weak aliases need not to be resolved,
198 // since they would be replaced with weak aliases if they remain
199 // undefined.
200 if (auto *U = dyn_cast<Undefined>(New)) {
201 if (!U->WeakAlias) {
202 addMemberFile(L);
203 return;
204 }
Rui Ueyamae2eb1552015-07-05 22:05:08 +0000205 }
Rui Ueyama1cce3002015-09-20 00:00:05 +0000206 Sym->Body = New;
Rafael Espindolab835ae82015-08-06 14:58:50 +0000207 return;
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000208 }
Rui Ueyama1cce3002015-09-20 00:00:05 +0000209
210 // compare() returns -1, 0, or 1 if the lhs symbol is less preferable,
211 // equivalent (conflicting), or more preferable, respectively.
212 int Comp = Existing->compare(New);
213 if (Comp == 0)
Rui Ueyama5694ebb2016-07-15 01:06:40 +0000214 fatal("duplicate symbol: " + Existing->getDebugName() + " and " +
Rui Ueyama1cce3002015-09-20 00:00:05 +0000215 New->getDebugName());
216 if (Comp < 0)
217 Sym->Body = New;
Rui Ueyama411c63602015-05-28 19:09:30 +0000218}
219
Rui Ueyama6be90992015-07-02 22:52:33 +0000220Symbol *SymbolTable::insert(SymbolBody *New) {
221 Symbol *&Sym = Symtab[New->getName()];
222 if (Sym) {
223 New->setBackref(Sym);
224 return Sym;
225 }
226 Sym = new (Alloc) Symbol(New);
227 New->setBackref(Sym);
228 return Sym;
229}
230
Rui Ueyama411c63602015-05-28 19:09:30 +0000231// Reads an archive member file pointed by a given symbol.
Rafael Espindolab835ae82015-08-06 14:58:50 +0000232void SymbolTable::addMemberFile(Lazy *Body) {
233 std::unique_ptr<InputFile> File = Body->getMember();
Rui Ueyama411c63602015-05-28 19:09:30 +0000234
235 // getMember returns an empty buffer if the member was already
236 // read from the library.
237 if (!File)
Rafael Espindolab835ae82015-08-06 14:58:50 +0000238 return;
Rui Ueyama411c63602015-05-28 19:09:30 +0000239 if (Config->Verbose)
Rui Ueyama5b2588a2015-06-08 05:43:50 +0000240 llvm::outs() << "Loaded " << File->getShortName() << " for "
Rui Ueyama411c63602015-05-28 19:09:30 +0000241 << Body->getName() << "\n";
Rui Ueyama0d2e9992015-06-23 23:56:39 +0000242 addFile(std::move(File));
Rui Ueyama411c63602015-05-28 19:09:30 +0000243}
244
245std::vector<Chunk *> SymbolTable::getChunks() {
246 std::vector<Chunk *> Res;
Rui Ueyama0d2e9992015-06-23 23:56:39 +0000247 for (ObjectFile *File : ObjectFiles) {
Rui Ueyama411c63602015-05-28 19:09:30 +0000248 std::vector<Chunk *> &V = File->getChunks();
249 Res.insert(Res.end(), V.begin(), V.end());
250 }
251 return Res;
252}
253
Rui Ueyama458d7442015-07-02 03:59:04 +0000254Symbol *SymbolTable::find(StringRef Name) {
Rui Ueyama45044f42015-06-29 01:03:53 +0000255 auto It = Symtab.find(Name);
256 if (It == Symtab.end())
257 return nullptr;
Rui Ueyama4b669892015-06-30 23:46:52 +0000258 return It->second;
Rui Ueyama45044f42015-06-29 01:03:53 +0000259}
260
Rui Ueyama506f6d12015-07-28 22:56:02 +0000261Symbol *SymbolTable::findUnderscore(StringRef Name) {
262 if (Config->Machine == I386)
263 return find(("_" + Name).str());
264 return find(Name);
265}
266
Rui Ueyamaa50387f2015-07-14 02:58:13 +0000267StringRef SymbolTable::findByPrefix(StringRef Prefix) {
268 for (auto Pair : Symtab) {
269 StringRef Name = Pair.first;
270 if (Name.startswith(Prefix))
271 return Name;
272 }
273 return "";
274}
275
276StringRef SymbolTable::findMangle(StringRef Name) {
277 if (Symbol *Sym = find(Name))
278 if (!isa<Undefined>(Sym->Body))
279 return Name;
Rui Ueyama5e706b32015-07-25 21:54:50 +0000280 if (Config->Machine != I386)
Rui Ueyamaa50387f2015-07-14 02:58:13 +0000281 return findByPrefix(("?" + Name + "@@Y").str());
282 if (!Name.startswith("_"))
283 return "";
284 // Search for x86 C function.
285 StringRef S = findByPrefix((Name + "@").str());
286 if (!S.empty())
287 return S;
288 // Search for x86 C++ non-member function.
289 return findByPrefix(("?" + Name.substr(1) + "@@Y").str());
290}
291
Rui Ueyama6bf638e2015-07-02 00:04:14 +0000292void SymbolTable::mangleMaybe(Undefined *U) {
293 if (U->WeakAlias)
294 return;
Rui Ueyama0744e872015-07-02 00:21:11 +0000295 if (!isa<Undefined>(U->repl()))
Rui Ueyama6bf638e2015-07-02 00:04:14 +0000296 return;
Rui Ueyamaa50387f2015-07-14 02:58:13 +0000297 StringRef Alias = findMangle(U->getName());
298 if (!Alias.empty())
299 U->WeakAlias = addUndefined(Alias);
Rui Ueyamaf5313b32015-06-28 22:16:41 +0000300}
301
Rui Ueyama6bf638e2015-07-02 00:04:14 +0000302Undefined *SymbolTable::addUndefined(StringRef Name) {
Rui Ueyama3d4c69c2015-07-02 02:38:59 +0000303 auto *New = new (Alloc) Undefined(Name);
304 addSymbol(New);
305 if (auto *U = dyn_cast<Undefined>(New->repl()))
306 return U;
307 return New;
Rui Ueyama360bace2015-05-31 22:31:31 +0000308}
309
Rui Ueyamacd3f99b2015-07-24 23:51:14 +0000310DefinedRelative *SymbolTable::addRelative(StringRef Name, uint64_t VA) {
311 auto *New = new (Alloc) DefinedRelative(Name, VA);
312 addSymbol(New);
313 return New;
314}
315
316DefinedAbsolute *SymbolTable::addAbsolute(StringRef Name, uint64_t VA) {
317 auto *New = new (Alloc) DefinedAbsolute(Name, VA);
318 addSymbol(New);
319 return New;
Rui Ueyama49d6cd32015-07-03 00:02:19 +0000320}
321
Peter Collingbournebe549552015-06-26 18:58:24 +0000322void SymbolTable::printMap(llvm::raw_ostream &OS) {
323 for (ObjectFile *File : ObjectFiles) {
324 OS << File->getShortName() << ":\n";
325 for (SymbolBody *Body : File->getSymbols())
326 if (auto *R = dyn_cast<DefinedRegular>(Body))
Rui Ueyama63dd8762015-09-16 23:55:52 +0000327 if (R->getChunk()->isLive())
Peter Collingbournebe549552015-06-26 18:58:24 +0000328 OS << Twine::utohexstr(Config->ImageBase + R->getRVA())
329 << " " << R->getName() << "\n";
330 }
331}
332
Peter Collingbournedf5783b2015-08-28 22:16:09 +0000333void SymbolTable::addCombinedLTOObject(ObjectFile *Obj) {
Peter Collingbourne60c16162015-06-01 20:10:10 +0000334 for (SymbolBody *Body : Obj->getSymbols()) {
335 if (!Body->isExternal())
336 continue;
Peter Collingbourne2612a322015-07-04 05:28:41 +0000337 // We should not see any new undefined symbols at this point, but we'll
338 // diagnose them later in reportRemainingUndefines().
Peter Collingbourne60c16162015-06-01 20:10:10 +0000339 StringRef Name = Body->getName();
Rui Ueyama6be90992015-07-02 22:52:33 +0000340 Symbol *Sym = insert(Body);
Rafael Espindolaa5cefff2016-05-26 20:31:06 +0000341 SymbolBody *Existing = Sym->Body;
Peter Collingbourne60c16162015-06-01 20:10:10 +0000342
Rafael Espindolaa5cefff2016-05-26 20:31:06 +0000343 if (Existing == Body)
344 continue;
345
346 if (isa<DefinedBitcode>(Existing)) {
Peter Collingbourne60c16162015-06-01 20:10:10 +0000347 Sym->Body = Body;
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000348 continue;
Peter Collingbourne60c16162015-06-01 20:10:10 +0000349 }
Rafael Espindolaa5cefff2016-05-26 20:31:06 +0000350 if (auto *L = dyn_cast<Lazy>(Existing)) {
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000351 // We may see new references to runtime library symbols such as __chkstk
352 // here. These symbols must be wholly defined in non-bitcode files.
Rafael Espindolab835ae82015-08-06 14:58:50 +0000353 addMemberFile(L);
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000354 continue;
355 }
Rafael Espindolaa5cefff2016-05-26 20:31:06 +0000356
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000357 int Comp = Existing->compare(Body);
Rafael Espindolab835ae82015-08-06 14:58:50 +0000358 if (Comp == 0)
Rui Ueyama5694ebb2016-07-15 01:06:40 +0000359 fatal("LTO: unexpected duplicate symbol: " + Name);
Rui Ueyama8d3010a2015-06-30 19:35:21 +0000360 if (Comp < 0)
361 Sym->Body = Body;
Rui Ueyama0d2e9992015-06-23 23:56:39 +0000362 }
Peter Collingbournedf5783b2015-08-28 22:16:09 +0000363}
364
365void SymbolTable::addCombinedLTOObjects() {
366 if (BitcodeFiles.empty())
367 return;
368
369 // Diagnose any undefined symbols early, but do not resolve weak externals,
370 // as resolution breaks the invariant that each Symbol points to a unique
371 // SymbolBody, which we rely on to replace DefinedBitcode symbols correctly.
372 reportRemainingUndefines(/*Resolve=*/false);
373
374 // Create an object file and add it to the symbol table by replacing any
375 // DefinedBitcode symbols with the definitions in the object file.
Rui Ueyama34b60f12016-04-14 21:41:44 +0000376 LTOCodeGenerator CG(BitcodeFile::Context);
Peter Collingbournedf5783b2015-08-28 22:16:09 +0000377 CG.setOptLevel(Config->LTOOptLevel);
378 std::vector<ObjectFile *> Objs = createLTOObjects(&CG);
379
380 for (ObjectFile *Obj : Objs)
381 addCombinedLTOObject(Obj);
Rui Ueyama0d2e9992015-06-23 23:56:39 +0000382
383 size_t NumBitcodeFiles = BitcodeFiles.size();
Rafael Espindolab835ae82015-08-06 14:58:50 +0000384 run();
385 if (BitcodeFiles.size() != NumBitcodeFiles)
Rui Ueyama60604792016-07-14 23:37:14 +0000386 fatal("LTO: late loaded symbol created new bitcode reference");
Peter Collingbourne60c16162015-06-01 20:10:10 +0000387}
388
Rui Ueyamaefba7812015-06-09 17:52:17 +0000389// Combine and compile bitcode files and then return the result
Peter Collingbournedf5783b2015-08-28 22:16:09 +0000390// as a vector of regular COFF object files.
391std::vector<ObjectFile *> SymbolTable::createLTOObjects(LTOCodeGenerator *CG) {
Rui Ueyamaefba7812015-06-09 17:52:17 +0000392 // All symbols referenced by non-bitcode objects must be preserved.
Rui Ueyama0d2e9992015-06-23 23:56:39 +0000393 for (ObjectFile *File : ObjectFiles)
Rui Ueyamaefba7812015-06-09 17:52:17 +0000394 for (SymbolBody *Body : File->getSymbols())
Rui Ueyama0744e872015-07-02 00:21:11 +0000395 if (auto *S = dyn_cast<DefinedBitcode>(Body->repl()))
Rui Ueyamaefba7812015-06-09 17:52:17 +0000396 CG->addMustPreserveSymbol(S->getName());
397
Peter Collingbourne1b6fd1f2015-06-11 21:49:54 +0000398 // Likewise for bitcode symbols which we initially resolved to non-bitcode.
Rui Ueyama0d2e9992015-06-23 23:56:39 +0000399 for (BitcodeFile *File : BitcodeFiles)
Peter Collingbourne1b6fd1f2015-06-11 21:49:54 +0000400 for (SymbolBody *Body : File->getSymbols())
Rui Ueyama0744e872015-07-02 00:21:11 +0000401 if (isa<DefinedBitcode>(Body) && !isa<DefinedBitcode>(Body->repl()))
Peter Collingbourne1b6fd1f2015-06-11 21:49:54 +0000402 CG->addMustPreserveSymbol(Body->getName());
403
Rui Ueyamaefba7812015-06-09 17:52:17 +0000404 // Likewise for other symbols that must be preserved.
Peter Collingbourne2612a322015-07-04 05:28:41 +0000405 for (Undefined *U : Config->GCRoot) {
406 if (auto *S = dyn_cast<DefinedBitcode>(U->repl()))
407 CG->addMustPreserveSymbol(S->getName());
408 else if (auto *S = dyn_cast_or_null<DefinedBitcode>(U->getWeakAlias()))
409 CG->addMustPreserveSymbol(S->getName());
410 }
Rui Ueyamaefba7812015-06-09 17:52:17 +0000411
Peter Collingbourne0bb50d92015-08-24 22:22:58 +0000412 CG->setModule(BitcodeFiles[0]->takeModule());
Rui Ueyamaefba7812015-06-09 17:52:17 +0000413 for (unsigned I = 1, E = BitcodeFiles.size(); I != E; ++I)
Peter Collingbourne70507e52015-11-17 23:30:59 +0000414 CG->addModule(BitcodeFiles[I]->takeModule().get());
Rui Ueyamaefba7812015-06-09 17:52:17 +0000415
Rui Ueyama41519722015-09-17 22:54:08 +0000416 bool DisableVerify = true;
417#ifdef NDEBUG
418 DisableVerify = false;
419#endif
Yunzhong Gaofbee8922015-11-17 20:48:12 +0000420 if (!CG->optimize(DisableVerify, false, false, false))
Rui Ueyama60604792016-07-14 23:37:14 +0000421 fatal(""); // optimize() should have emitted any error message.
Peter Collingbournedf5783b2015-08-28 22:16:09 +0000422
423 Objs.resize(Config->LTOJobs);
424 // Use std::list to avoid invalidation of pointers in OSPtrs.
425 std::list<raw_svector_ostream> OSs;
426 std::vector<raw_pwrite_stream *> OSPtrs;
Davide Italianoeeae1242016-04-09 23:00:31 +0000427 for (SmallString<0> &Obj : Objs) {
Peter Collingbournedf5783b2015-08-28 22:16:09 +0000428 OSs.emplace_back(Obj);
429 OSPtrs.push_back(&OSs.back());
430 }
431
Yunzhong Gaofbee8922015-11-17 20:48:12 +0000432 if (!CG->compileOptimized(OSPtrs))
Rui Ueyama60604792016-07-14 23:37:14 +0000433 fatal(""); // compileOptimized() should have emitted any error message.
Peter Collingbournedf5783b2015-08-28 22:16:09 +0000434
435 std::vector<ObjectFile *> ObjFiles;
Davide Italianoeeae1242016-04-09 23:00:31 +0000436 for (SmallString<0> &Obj : Objs) {
Davide Italiano3774afb2016-04-12 22:05:38 +0000437 auto *ObjFile = new ObjectFile(MemoryBufferRef(Obj, "<LTO object>"));
Peter Collingbournedf5783b2015-08-28 22:16:09 +0000438 Files.emplace_back(ObjFile);
439 ObjectFiles.push_back(ObjFile);
440 ObjFile->parse();
441 ObjFiles.push_back(ObjFile);
442 }
443
444 return ObjFiles;
Rui Ueyamaefba7812015-06-09 17:52:17 +0000445}
446
Rui Ueyama411c63602015-05-28 19:09:30 +0000447} // namespace coff
448} // namespace lld