blob: a18f4cc25bcc2ad4e8661cf19f60c4f28703e70c [file] [log] [blame]
Mikhail Glushenkov59a5afa2009-03-03 10:04:23 +00001//===- lib/Linker/LinkModules.cpp - Module Linker Implementation ----------===//
Misha Brukman10468d82005-04-21 22:55:34 +00002//
Chandler Carruth2946cd72019-01-19 08:50:56 +00003// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
Misha Brukman10468d82005-04-21 22:55:34 +00006//
Reid Spencer361e5132004-11-12 20:37:43 +00007//===----------------------------------------------------------------------===//
8//
9// This file implements the LLVM module linker.
10//
Reid Spencer361e5132004-11-12 20:37:43 +000011//===----------------------------------------------------------------------===//
12
Rafael Espindolacaabe222015-12-10 14:19:35 +000013#include "LinkDiagnosticInfo.h"
Chandler Carruthed0881b2012-12-03 16:50:05 +000014#include "llvm-c/Linker.h"
Bill Wendling66f02412012-02-11 11:38:06 +000015#include "llvm/ADT/SetVector.h"
Peter Collingbourne7c702112017-02-03 16:58:19 +000016#include "llvm/IR/Comdat.h"
Rafael Espindolad12b4a32014-10-25 04:06:10 +000017#include "llvm/IR/DiagnosticPrinter.h"
Peter Collingbourne7c702112017-02-03 16:58:19 +000018#include "llvm/IR/GlobalValue.h"
Rafael Espindola9d2bfc42015-12-14 23:17:03 +000019#include "llvm/IR/LLVMContext.h"
Peter Collingbourne7c702112017-02-03 16:58:19 +000020#include "llvm/IR/Module.h"
Teresa Johnson488a8002016-02-10 18:11:31 +000021#include "llvm/Linker/Linker.h"
Peter Collingbourne1eaa97f2016-05-27 05:21:35 +000022#include "llvm/Support/Error.h"
Reid Spencer361e5132004-11-12 20:37:43 +000023using namespace llvm;
24
Chris Lattnereee6f992008-06-16 21:00:18 +000025namespace {
Rafael Espindolac84f6082014-11-25 06:11:24 +000026
27/// This is an implementation class for the LinkModules function, which is the
28/// entrypoint for this file.
29class ModuleLinker {
Rafael Espindolacaabe222015-12-10 14:19:35 +000030 IRMover &Mover;
Rafael Espindola40358fb2016-02-16 18:50:12 +000031 std::unique_ptr<Module> SrcM;
Rafael Espindolac84f6082014-11-25 06:11:24 +000032
Rafael Espindola4b5ec262015-12-02 22:59:04 +000033 SetVector<GlobalValue *> ValuesToLink;
Chris Lattnerb1ed91f2011-07-09 17:41:24 +000034
Duncan P. N. Exon Smithe8681232015-04-22 04:11:00 +000035 /// For symbol clashes, prefer those from Src.
Artem Belevich020d4fb2015-09-01 17:55:55 +000036 unsigned Flags;
Duncan P. N. Exon Smithe8681232015-04-22 04:11:00 +000037
Jonas Devlieghere5eb9c812017-03-13 18:08:11 +000038 /// List of global value names that should be internalized.
39 StringSet<> Internalize;
40
41 /// Function that will perform the actual internalization. The reason for a
42 /// callback is that the linker cannot call internalizeModule without
43 /// creating a circular dependency between IPO and the linker.
44 std::function<void(Module &, const StringSet<> &)> InternalizeCallback;
45
Rafael Espindolacaabe222015-12-10 14:19:35 +000046 /// Used as the callback for lazy linking.
47 /// The mover has just hit GV and we have to decide if it, and other members
48 /// of the same comdat, should be linked. Every member to be linked is passed
49 /// to Add.
Benjamin Kramerc321e532016-06-08 19:09:22 +000050 void addLazyFor(GlobalValue &GV, const IRMover::ValueAdder &Add);
Rafael Espindolabaa3bf82015-12-01 15:19:48 +000051
Artem Belevich020d4fb2015-09-01 17:55:55 +000052 bool shouldOverrideFromSrc() { return Flags & Linker::OverrideFromSrc; }
53 bool shouldLinkOnlyNeeded() { return Flags & Linker::LinkOnlyNeeded; }
Artem Belevich020d4fb2015-09-01 17:55:55 +000054
Rafael Espindolac84f6082014-11-25 06:11:24 +000055 bool shouldLinkFromSource(bool &LinkFromSrc, const GlobalValue &Dest,
56 const GlobalValue &Src);
Rafael Espindolaed6dc372014-05-09 14:39:25 +000057
Rafael Espindolacaabe222015-12-10 14:19:35 +000058 /// Should we have mover and linker error diag info?
Rafael Espindolac84f6082014-11-25 06:11:24 +000059 bool emitError(const Twine &Message) {
Rafael Espindola40358fb2016-02-16 18:50:12 +000060 SrcM->getContext().diagnose(LinkDiagnosticInfo(DS_Error, Message));
Rafael Espindolac84f6082014-11-25 06:11:24 +000061 return true;
62 }
Rafael Espindolaed6dc372014-05-09 14:39:25 +000063
Rafael Espindola0e309fe2015-12-01 19:50:54 +000064 bool getComdatLeader(Module &M, StringRef ComdatName,
Rafael Espindolac84f6082014-11-25 06:11:24 +000065 const GlobalVariable *&GVar);
66 bool computeResultingSelectionKind(StringRef ComdatName,
67 Comdat::SelectionKind Src,
68 Comdat::SelectionKind Dst,
69 Comdat::SelectionKind &Result,
70 bool &LinkFromSrc);
71 std::map<const Comdat *, std::pair<Comdat::SelectionKind, bool>>
72 ComdatsChosen;
73 bool getComdatResult(const Comdat *SrcC, Comdat::SelectionKind &SK,
74 bool &LinkFromSrc);
Rafael Espindola1ee9fbd2016-03-24 00:06:03 +000075 // Keep track of the lazy linked global members of each comdat in source.
76 DenseMap<const Comdat *, std::vector<GlobalValue *>> LazyComdatMembers;
Rafael Espindola4160f5d2014-10-27 23:02:10 +000077
Rafael Espindolac84f6082014-11-25 06:11:24 +000078 /// Given a global in the source module, return the global in the
79 /// destination module that is being linked to, if any.
80 GlobalValue *getLinkedToGlobal(const GlobalValue *SrcGV) {
Rafael Espindolacaabe222015-12-10 14:19:35 +000081 Module &DstM = Mover.getModule();
Rafael Espindolac84f6082014-11-25 06:11:24 +000082 // If the source has no name it can't link. If it has local linkage,
83 // there is no name match-up going on.
Teresa Johnson4504c1b2016-01-08 15:00:00 +000084 if (!SrcGV->hasName() || GlobalValue::isLocalLinkage(SrcGV->getLinkage()))
Rafael Espindolac84f6082014-11-25 06:11:24 +000085 return nullptr;
Eli Bendersky7da92ed2014-02-20 22:19:24 +000086
Rafael Espindolac84f6082014-11-25 06:11:24 +000087 // Otherwise see if we have a match in the destination module's symtab.
Teresa Johnson4504c1b2016-01-08 15:00:00 +000088 GlobalValue *DGV = DstM.getNamedValue(SrcGV->getName());
Rafael Espindolac84f6082014-11-25 06:11:24 +000089 if (!DGV)
90 return nullptr;
Rafael Espindolaed6dc372014-05-09 14:39:25 +000091
Rafael Espindolac84f6082014-11-25 06:11:24 +000092 // If we found a global with the same name in the dest module, but it has
93 // internal linkage, we are really not doing any linkage here.
94 if (DGV->hasLocalLinkage())
95 return nullptr;
Rafael Espindoladbb0bd12014-09-09 15:21:00 +000096
Rafael Espindolac84f6082014-11-25 06:11:24 +000097 // Otherwise, we do in fact link to the destination global.
98 return DGV;
99 }
Rafael Espindolaed6dc372014-05-09 14:39:25 +0000100
Rafael Espindola370d5282016-03-22 21:35:47 +0000101 /// Drop GV if it is a member of a comdat that we are dropping.
102 /// This can happen with COFF's largest selection kind.
103 void dropReplacedComdat(GlobalValue &GV,
104 const DenseSet<const Comdat *> &ReplacedDstComdats);
105
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000106 bool linkIfNeeded(GlobalValue &GV);
Teresa Johnsonc7ed52f2015-11-03 00:14:15 +0000107
Teresa Johnson4504c1b2016-01-08 15:00:00 +0000108public:
Jonas Devlieghere5eb9c812017-03-13 18:08:11 +0000109 ModuleLinker(IRMover &Mover, std::unique_ptr<Module> SrcM, unsigned Flags,
110 std::function<void(Module &, const StringSet<> &)>
111 InternalizeCallback = {})
112 : Mover(Mover), SrcM(std::move(SrcM)), Flags(Flags),
113 InternalizeCallback(std::move(InternalizeCallback)) {}
Teresa Johnson4504c1b2016-01-08 15:00:00 +0000114
115 bool run();
116};
Teresa Johnson4504c1b2016-01-08 15:00:00 +0000117}
118
Rafael Espindolaeb5e0a72015-11-29 14:33:06 +0000119static GlobalValue::VisibilityTypes
120getMinVisibility(GlobalValue::VisibilityTypes A,
121 GlobalValue::VisibilityTypes B) {
122 if (A == GlobalValue::HiddenVisibility || B == GlobalValue::HiddenVisibility)
123 return GlobalValue::HiddenVisibility;
124 if (A == GlobalValue::ProtectedVisibility ||
125 B == GlobalValue::ProtectedVisibility)
126 return GlobalValue::ProtectedVisibility;
127 return GlobalValue::DefaultVisibility;
128}
129
Rafael Espindola0e309fe2015-12-01 19:50:54 +0000130bool ModuleLinker::getComdatLeader(Module &M, StringRef ComdatName,
David Majnemerdad0a642014-06-27 18:19:56 +0000131 const GlobalVariable *&GVar) {
Rafael Espindola0e309fe2015-12-01 19:50:54 +0000132 const GlobalValue *GVal = M.getNamedValue(ComdatName);
David Majnemerdad0a642014-06-27 18:19:56 +0000133 if (const auto *GA = dyn_cast_or_null<GlobalAlias>(GVal)) {
134 GVal = GA->getBaseObject();
135 if (!GVal)
136 // We cannot resolve the size of the aliasee yet.
137 return emitError("Linking COMDATs named '" + ComdatName +
138 "': COMDAT key involves incomputable alias size.");
139 }
140
141 GVar = dyn_cast_or_null<GlobalVariable>(GVal);
142 if (!GVar)
143 return emitError(
144 "Linking COMDATs named '" + ComdatName +
145 "': GlobalVariable required for data dependent selection!");
146
147 return false;
148}
149
150bool ModuleLinker::computeResultingSelectionKind(StringRef ComdatName,
151 Comdat::SelectionKind Src,
152 Comdat::SelectionKind Dst,
153 Comdat::SelectionKind &Result,
154 bool &LinkFromSrc) {
Rafael Espindolacaabe222015-12-10 14:19:35 +0000155 Module &DstM = Mover.getModule();
David Majnemerdad0a642014-06-27 18:19:56 +0000156 // The ability to mix Comdat::SelectionKind::Any with
157 // Comdat::SelectionKind::Largest is a behavior that comes from COFF.
158 bool DstAnyOrLargest = Dst == Comdat::SelectionKind::Any ||
159 Dst == Comdat::SelectionKind::Largest;
160 bool SrcAnyOrLargest = Src == Comdat::SelectionKind::Any ||
161 Src == Comdat::SelectionKind::Largest;
162 if (DstAnyOrLargest && SrcAnyOrLargest) {
163 if (Dst == Comdat::SelectionKind::Largest ||
164 Src == Comdat::SelectionKind::Largest)
165 Result = Comdat::SelectionKind::Largest;
166 else
167 Result = Comdat::SelectionKind::Any;
168 } else if (Src == Dst) {
169 Result = Dst;
170 } else {
171 return emitError("Linking COMDATs named '" + ComdatName +
172 "': invalid selection kinds!");
173 }
174
175 switch (Result) {
176 case Comdat::SelectionKind::Any:
177 // Go with Dst.
178 LinkFromSrc = false;
179 break;
180 case Comdat::SelectionKind::NoDuplicates:
181 return emitError("Linking COMDATs named '" + ComdatName +
182 "': noduplicates has been violated!");
183 case Comdat::SelectionKind::ExactMatch:
184 case Comdat::SelectionKind::Largest:
185 case Comdat::SelectionKind::SameSize: {
186 const GlobalVariable *DstGV;
187 const GlobalVariable *SrcGV;
188 if (getComdatLeader(DstM, ComdatName, DstGV) ||
Rafael Espindola40358fb2016-02-16 18:50:12 +0000189 getComdatLeader(*SrcM, ComdatName, SrcGV))
David Majnemerdad0a642014-06-27 18:19:56 +0000190 return true;
191
Rafael Espindola0e309fe2015-12-01 19:50:54 +0000192 const DataLayout &DstDL = DstM.getDataLayout();
Rafael Espindola40358fb2016-02-16 18:50:12 +0000193 const DataLayout &SrcDL = SrcM->getDataLayout();
Manuel Jacob5f6eaac2016-01-16 20:30:46 +0000194 uint64_t DstSize = DstDL.getTypeAllocSize(DstGV->getValueType());
195 uint64_t SrcSize = SrcDL.getTypeAllocSize(SrcGV->getValueType());
David Majnemerdad0a642014-06-27 18:19:56 +0000196 if (Result == Comdat::SelectionKind::ExactMatch) {
197 if (SrcGV->getInitializer() != DstGV->getInitializer())
198 return emitError("Linking COMDATs named '" + ComdatName +
199 "': ExactMatch violated!");
200 LinkFromSrc = false;
201 } else if (Result == Comdat::SelectionKind::Largest) {
202 LinkFromSrc = SrcSize > DstSize;
203 } else if (Result == Comdat::SelectionKind::SameSize) {
204 if (SrcSize != DstSize)
205 return emitError("Linking COMDATs named '" + ComdatName +
206 "': SameSize violated!");
207 LinkFromSrc = false;
208 } else {
209 llvm_unreachable("unknown selection kind");
210 }
211 break;
212 }
213 }
214
215 return false;
216}
217
218bool ModuleLinker::getComdatResult(const Comdat *SrcC,
219 Comdat::SelectionKind &Result,
220 bool &LinkFromSrc) {
Rafael Espindolacaabe222015-12-10 14:19:35 +0000221 Module &DstM = Mover.getModule();
Rafael Espindolab16196a2014-08-11 17:07:34 +0000222 Comdat::SelectionKind SSK = SrcC->getSelectionKind();
David Majnemerdad0a642014-06-27 18:19:56 +0000223 StringRef ComdatName = SrcC->getName();
Rafael Espindola0e309fe2015-12-01 19:50:54 +0000224 Module::ComdatSymTabType &ComdatSymTab = DstM.getComdatSymbolTable();
David Majnemerdad0a642014-06-27 18:19:56 +0000225 Module::ComdatSymTabType::iterator DstCI = ComdatSymTab.find(ComdatName);
Rafael Espindola2ef3f292014-08-11 16:55:42 +0000226
Rafael Espindolab16196a2014-08-11 17:07:34 +0000227 if (DstCI == ComdatSymTab.end()) {
228 // Use the comdat if it is only available in one of the modules.
229 LinkFromSrc = true;
230 Result = SSK;
Rafael Espindola2ef3f292014-08-11 16:55:42 +0000231 return false;
Rafael Espindolab16196a2014-08-11 17:07:34 +0000232 }
Rafael Espindola2ef3f292014-08-11 16:55:42 +0000233
234 const Comdat *DstC = &DstCI->second;
Rafael Espindola2ef3f292014-08-11 16:55:42 +0000235 Comdat::SelectionKind DSK = DstC->getSelectionKind();
236 return computeResultingSelectionKind(ComdatName, SSK, DSK, Result,
237 LinkFromSrc);
David Majnemerdad0a642014-06-27 18:19:56 +0000238}
James Molloyf6f121e2013-05-28 15:17:05 +0000239
Rafael Espindolad12b4a32014-10-25 04:06:10 +0000240bool ModuleLinker::shouldLinkFromSource(bool &LinkFromSrc,
241 const GlobalValue &Dest,
Rafael Espindoladbb0bd12014-09-09 15:21:00 +0000242 const GlobalValue &Src) {
Teresa Johnsone5a61912015-12-17 17:14:09 +0000243
Duncan P. N. Exon Smithe8681232015-04-22 04:11:00 +0000244 // Should we unconditionally use the Src?
Artem Belevich020d4fb2015-09-01 17:55:55 +0000245 if (shouldOverrideFromSrc()) {
Duncan P. N. Exon Smithe8681232015-04-22 04:11:00 +0000246 LinkFromSrc = true;
247 return false;
248 }
249
Rafael Espindola778fcc72014-11-02 13:28:57 +0000250 // We always have to add Src if it has appending linkage.
251 if (Src.hasAppendingLinkage()) {
252 LinkFromSrc = true;
253 return false;
254 }
255
Rafael Espindolad4bcefc2014-10-24 18:13:04 +0000256 bool SrcIsDeclaration = Src.isDeclarationForLinker();
257 bool DestIsDeclaration = Dest.isDeclarationForLinker();
Rafael Espindoladbb0bd12014-09-09 15:21:00 +0000258
259 if (SrcIsDeclaration) {
260 // If Src is external or if both Src & Dest are external.. Just link the
261 // external globals, we aren't adding anything.
Rafael Espindolad12b4a32014-10-25 04:06:10 +0000262 if (Src.hasDLLImportStorageClass()) {
Rafael Espindoladbb0bd12014-09-09 15:21:00 +0000263 // If one of GVs is marked as DLLImport, result should be dllimport'ed.
Rafael Espindolad12b4a32014-10-25 04:06:10 +0000264 LinkFromSrc = DestIsDeclaration;
265 return false;
266 }
Rafael Espindoladbb0bd12014-09-09 15:21:00 +0000267 // If the Dest is weak, use the source linkage.
Rafael Espindolaed11bd22015-12-09 22:44:00 +0000268 if (Dest.hasExternalWeakLinkage()) {
269 LinkFromSrc = true;
270 return false;
271 }
272 // Link an available_externally over a declaration.
273 LinkFromSrc = !Src.isDeclaration() && Dest.isDeclaration();
Rafael Espindolad12b4a32014-10-25 04:06:10 +0000274 return false;
Rafael Espindoladbb0bd12014-09-09 15:21:00 +0000275 }
276
Rafael Espindolad12b4a32014-10-25 04:06:10 +0000277 if (DestIsDeclaration) {
Rafael Espindoladbb0bd12014-09-09 15:21:00 +0000278 // If Dest is external but Src is not:
Rafael Espindolad12b4a32014-10-25 04:06:10 +0000279 LinkFromSrc = true;
280 return false;
281 }
Rafael Espindoladbb0bd12014-09-09 15:21:00 +0000282
Rafael Espindola09106052014-09-09 15:59:12 +0000283 if (Src.hasCommonLinkage()) {
Rafael Espindolad12b4a32014-10-25 04:06:10 +0000284 if (Dest.hasLinkOnceLinkage() || Dest.hasWeakLinkage()) {
285 LinkFromSrc = true;
Rafael Espindola09106052014-09-09 15:59:12 +0000286 return false;
Rafael Espindolad12b4a32014-10-25 04:06:10 +0000287 }
288
289 if (!Dest.hasCommonLinkage()) {
290 LinkFromSrc = false;
291 return false;
292 }
Rafael Espindola09106052014-09-09 15:59:12 +0000293
Mehdi Aminia28d91d2015-03-10 02:37:25 +0000294 const DataLayout &DL = Dest.getParent()->getDataLayout();
Manuel Jacob5f6eaac2016-01-16 20:30:46 +0000295 uint64_t DestSize = DL.getTypeAllocSize(Dest.getValueType());
296 uint64_t SrcSize = DL.getTypeAllocSize(Src.getValueType());
Rafael Espindolad12b4a32014-10-25 04:06:10 +0000297 LinkFromSrc = SrcSize > DestSize;
298 return false;
Rafael Espindola09106052014-09-09 15:59:12 +0000299 }
300
Rafael Espindoladbb0bd12014-09-09 15:21:00 +0000301 if (Src.isWeakForLinker()) {
302 assert(!Dest.hasExternalWeakLinkage());
303 assert(!Dest.hasAvailableExternallyLinkage());
Rafael Espindola09106052014-09-09 15:59:12 +0000304
Rafael Espindolad12b4a32014-10-25 04:06:10 +0000305 if (Dest.hasLinkOnceLinkage() && Src.hasWeakLinkage()) {
306 LinkFromSrc = true;
307 return false;
308 }
Rafael Espindoladbb0bd12014-09-09 15:21:00 +0000309
Rafael Espindolad12b4a32014-10-25 04:06:10 +0000310 LinkFromSrc = false;
Rafael Espindola09106052014-09-09 15:59:12 +0000311 return false;
Rafael Espindoladbb0bd12014-09-09 15:21:00 +0000312 }
313
314 if (Dest.isWeakForLinker()) {
315 assert(Src.hasExternalLinkage());
Rafael Espindolad12b4a32014-10-25 04:06:10 +0000316 LinkFromSrc = true;
317 return false;
Rafael Espindoladbb0bd12014-09-09 15:21:00 +0000318 }
319
320 assert(!Src.hasExternalWeakLinkage());
321 assert(!Dest.hasExternalWeakLinkage());
322 assert(Dest.hasExternalLinkage() && Src.hasExternalLinkage() &&
323 "Unexpected linkage type!");
324 return emitError("Linking globals named '" + Src.getName() +
325 "': symbol multiply defined!");
326}
327
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000328bool ModuleLinker::linkIfNeeded(GlobalValue &GV) {
329 GlobalValue *DGV = getLinkedToGlobal(&GV);
330
Benoit Belleyb1a9ad82017-08-09 20:58:39 +0000331 if (shouldLinkOnlyNeeded()) {
332 // Always import variables with appending linkage.
333 if (!GV.hasAppendingLinkage()) {
334 // Don't import globals unless they are referenced by the destination
335 // module.
336 if (!DGV)
337 return false;
338 // Don't import globals that are already defined in the destination module
339 if (!DGV->isDeclaration())
340 return false;
341 }
342 }
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000343
Rafael Espindola4b5ec262015-12-02 22:59:04 +0000344 if (DGV && !GV.hasLocalLinkage() && !GV.hasAppendingLinkage()) {
345 auto *DGVar = dyn_cast<GlobalVariable>(DGV);
346 auto *SGVar = dyn_cast<GlobalVariable>(&GV);
347 if (DGVar && SGVar) {
348 if (DGVar->isDeclaration() && SGVar->isDeclaration() &&
349 (!DGVar->isConstant() || !SGVar->isConstant())) {
350 DGVar->setConstant(false);
351 SGVar->setConstant(false);
352 }
353 if (DGVar->hasCommonLinkage() && SGVar->hasCommonLinkage()) {
354 unsigned Align = std::max(DGVar->getAlignment(), SGVar->getAlignment());
355 SGVar->setAlignment(Align);
356 DGVar->setAlignment(Align);
357 }
358 }
359
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000360 GlobalValue::VisibilityTypes Visibility =
361 getMinVisibility(DGV->getVisibility(), GV.getVisibility());
362 DGV->setVisibility(Visibility);
363 GV.setVisibility(Visibility);
Rafael Espindola4b5ec262015-12-02 22:59:04 +0000364
Peter Collingbourne96efdd62016-06-14 21:01:22 +0000365 GlobalValue::UnnamedAddr UnnamedAddr = GlobalValue::getMinUnnamedAddr(
366 DGV->getUnnamedAddr(), GV.getUnnamedAddr());
367 DGV->setUnnamedAddr(UnnamedAddr);
368 GV.setUnnamedAddr(UnnamedAddr);
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000369 }
370
Peter Collingbourne7c702112017-02-03 16:58:19 +0000371 if (!DGV && !shouldOverrideFromSrc() &&
372 (GV.hasLocalLinkage() || GV.hasLinkOnceLinkage() ||
373 GV.hasAvailableExternallyLinkage()))
Rafael Espindola4b5ec262015-12-02 22:59:04 +0000374 return false;
375
Rafael Espindolabd03c502015-12-07 16:31:41 +0000376 if (GV.isDeclaration())
377 return false;
378
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000379 if (const Comdat *SC = GV.getComdat()) {
380 bool LinkFromSrc;
381 Comdat::SelectionKind SK;
382 std::tie(SK, LinkFromSrc) = ComdatsChosen[SC];
Rafael Espindolaf2e71242016-03-23 21:16:33 +0000383 if (!LinkFromSrc)
384 return false;
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000385 }
Rafael Espindola4b5ec262015-12-02 22:59:04 +0000386
387 bool LinkFromSrc = true;
388 if (DGV && shouldLinkFromSource(LinkFromSrc, *DGV, GV))
389 return true;
390 if (LinkFromSrc)
391 ValuesToLink.insert(&GV);
392 return false;
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000393}
394
Benjamin Kramerc321e532016-06-08 19:09:22 +0000395void ModuleLinker::addLazyFor(GlobalValue &GV, const IRMover::ValueAdder &Add) {
Rafael Espindolacaabe222015-12-10 14:19:35 +0000396 // Add these to the internalize list
Peter Collingbournec387e702017-02-02 05:12:15 +0000397 if (!GV.hasLinkOnceLinkage() && !GV.hasAvailableExternallyLinkage() &&
398 !shouldLinkOnlyNeeded())
Rafael Espindolacaabe222015-12-10 14:19:35 +0000399 return;
400
Jonas Devlieghere5eb9c812017-03-13 18:08:11 +0000401 if (InternalizeCallback)
Rafael Espindolacaabe222015-12-10 14:19:35 +0000402 Internalize.insert(GV.getName());
403 Add(GV);
404
405 const Comdat *SC = GV.getComdat();
406 if (!SC)
407 return;
Rafael Espindola1ee9fbd2016-03-24 00:06:03 +0000408 for (GlobalValue *GV2 : LazyComdatMembers[SC]) {
Rafael Espindolae1c42ac2016-03-24 15:23:01 +0000409 GlobalValue *DGV = getLinkedToGlobal(GV2);
410 bool LinkFromSrc = true;
411 if (DGV && shouldLinkFromSource(LinkFromSrc, *DGV, *GV2))
412 return;
413 if (!LinkFromSrc)
414 continue;
Jonas Devlieghere5eb9c812017-03-13 18:08:11 +0000415 if (InternalizeCallback)
Rafael Espindolacaabe222015-12-10 14:19:35 +0000416 Internalize.insert(GV2->getName());
417 Add(*GV2);
418 }
419}
420
Rafael Espindola370d5282016-03-22 21:35:47 +0000421void ModuleLinker::dropReplacedComdat(
422 GlobalValue &GV, const DenseSet<const Comdat *> &ReplacedDstComdats) {
423 Comdat *C = GV.getComdat();
424 if (!C)
425 return;
426 if (!ReplacedDstComdats.count(C))
427 return;
428 if (GV.use_empty()) {
429 GV.eraseFromParent();
430 return;
431 }
432
433 if (auto *F = dyn_cast<Function>(&GV)) {
434 F->deleteBody();
435 } else if (auto *Var = dyn_cast<GlobalVariable>(&GV)) {
436 Var->setInitializer(nullptr);
437 } else {
438 auto &Alias = cast<GlobalAlias>(GV);
439 Module &M = *Alias.getParent();
440 PointerType &Ty = *cast<PointerType>(Alias.getType());
441 GlobalValue *Declaration;
442 if (auto *FTy = dyn_cast<FunctionType>(Alias.getValueType())) {
443 Declaration = Function::Create(FTy, GlobalValue::ExternalLinkage, "", &M);
444 } else {
445 Declaration =
446 new GlobalVariable(M, Ty.getElementType(), /*isConstant*/ false,
447 GlobalValue::ExternalLinkage,
448 /*Initializer*/ nullptr);
449 }
450 Declaration->takeName(&Alias);
451 Alias.replaceAllUsesWith(Declaration);
452 Alias.eraseFromParent();
453 }
454}
455
Chris Lattnerb1ed91f2011-07-09 17:41:24 +0000456bool ModuleLinker::run() {
Rafael Espindola370d5282016-03-22 21:35:47 +0000457 Module &DstM = Mover.getModule();
458 DenseSet<const Comdat *> ReplacedDstComdats;
459
Rafael Espindola40358fb2016-02-16 18:50:12 +0000460 for (const auto &SMEC : SrcM->getComdatSymbolTable()) {
David Majnemerdad0a642014-06-27 18:19:56 +0000461 const Comdat &C = SMEC.getValue();
462 if (ComdatsChosen.count(&C))
463 continue;
464 Comdat::SelectionKind SK;
465 bool LinkFromSrc;
466 if (getComdatResult(&C, SK, LinkFromSrc))
467 return true;
468 ComdatsChosen[&C] = std::make_pair(SK, LinkFromSrc);
Rafael Espindola370d5282016-03-22 21:35:47 +0000469
470 if (!LinkFromSrc)
471 continue;
472
473 Module::ComdatSymTabType &ComdatSymTab = DstM.getComdatSymbolTable();
474 Module::ComdatSymTabType::iterator DstCI = ComdatSymTab.find(C.getName());
475 if (DstCI == ComdatSymTab.end())
476 continue;
477
478 // The source comdat is replacing the dest one.
479 const Comdat *DstC = &DstCI->second;
480 ReplacedDstComdats.insert(DstC);
481 }
482
483 // Alias have to go first, since we are not able to find their comdats
484 // otherwise.
485 for (auto I = DstM.alias_begin(), E = DstM.alias_end(); I != E;) {
486 GlobalAlias &GV = *I++;
487 dropReplacedComdat(GV, ReplacedDstComdats);
488 }
489
490 for (auto I = DstM.global_begin(), E = DstM.global_end(); I != E;) {
491 GlobalVariable &GV = *I++;
492 dropReplacedComdat(GV, ReplacedDstComdats);
493 }
494
495 for (auto I = DstM.begin(), E = DstM.end(); I != E;) {
496 Function &GV = *I++;
497 dropReplacedComdat(GV, ReplacedDstComdats);
David Majnemerdad0a642014-06-27 18:19:56 +0000498 }
499
Rafael Espindola40358fb2016-02-16 18:50:12 +0000500 for (GlobalVariable &GV : SrcM->globals())
Rafael Espindola1ee9fbd2016-03-24 00:06:03 +0000501 if (GV.hasLinkOnceLinkage())
502 if (const Comdat *SC = GV.getComdat())
503 LazyComdatMembers[SC].push_back(&GV);
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000504
Rafael Espindola40358fb2016-02-16 18:50:12 +0000505 for (Function &SF : *SrcM)
Rafael Espindola1ee9fbd2016-03-24 00:06:03 +0000506 if (SF.hasLinkOnceLinkage())
507 if (const Comdat *SC = SF.getComdat())
508 LazyComdatMembers[SC].push_back(&SF);
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000509
Rafael Espindola40358fb2016-02-16 18:50:12 +0000510 for (GlobalAlias &GA : SrcM->aliases())
Rafael Espindola1ee9fbd2016-03-24 00:06:03 +0000511 if (GA.hasLinkOnceLinkage())
512 if (const Comdat *SC = GA.getComdat())
513 LazyComdatMembers[SC].push_back(&GA);
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000514
Chris Lattnerb1ed91f2011-07-09 17:41:24 +0000515 // Insert all of the globals in src into the DstM module... without linking
516 // initializers (which could refer to functions not yet mapped over).
Rafael Espindola40358fb2016-02-16 18:50:12 +0000517 for (GlobalVariable &GV : SrcM->globals())
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000518 if (linkIfNeeded(GV))
Chris Lattnerb1ed91f2011-07-09 17:41:24 +0000519 return true;
520
Rafael Espindola40358fb2016-02-16 18:50:12 +0000521 for (Function &SF : *SrcM)
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000522 if (linkIfNeeded(SF))
Chris Lattnerb1ed91f2011-07-09 17:41:24 +0000523 return true;
524
Rafael Espindola40358fb2016-02-16 18:50:12 +0000525 for (GlobalAlias &GA : SrcM->aliases())
Rafael Espindolabaa3bf82015-12-01 15:19:48 +0000526 if (linkIfNeeded(GA))
Chris Lattnerb1ed91f2011-07-09 17:41:24 +0000527 return true;
528
Rafael Espindolacaabe222015-12-10 14:19:35 +0000529 for (unsigned I = 0; I < ValuesToLink.size(); ++I) {
530 GlobalValue *GV = ValuesToLink[I];
531 const Comdat *SC = GV->getComdat();
532 if (!SC)
533 continue;
Rafael Espindola42e03232016-03-24 14:58:44 +0000534 for (GlobalValue *GV2 : LazyComdatMembers[SC]) {
535 GlobalValue *DGV = getLinkedToGlobal(GV2);
536 bool LinkFromSrc = true;
537 if (DGV && shouldLinkFromSource(LinkFromSrc, *DGV, *GV2))
538 return true;
539 if (LinkFromSrc)
540 ValuesToLink.insert(GV2);
541 }
Rafael Espindolabeadd562014-12-08 18:05:48 +0000542 }
543
Jonas Devlieghere5eb9c812017-03-13 18:08:11 +0000544 if (InternalizeCallback) {
Rafael Espindolacaabe222015-12-10 14:19:35 +0000545 for (GlobalValue *GV : ValuesToLink)
546 Internalize.insert(GV->getName());
547 }
Teresa Johnson10632932015-11-06 17:50:53 +0000548
Peter Collingbourne1eaa97f2016-05-27 05:21:35 +0000549 // FIXME: Propagate Errors through to the caller instead of emitting
550 // diagnostics.
551 bool HasErrors = false;
552 if (Error E = Mover.move(std::move(SrcM), ValuesToLink.getArrayRef(),
553 [this](GlobalValue &GV, IRMover::ValueAdder Add) {
554 addLazyFor(GV, Add);
Teresa Johnson4b9b3792016-10-12 18:39:29 +0000555 },
Peter Collingbourne7c702112017-02-03 16:58:19 +0000556 /* IsPerformingImport */ false)) {
Peter Collingbourne1eaa97f2016-05-27 05:21:35 +0000557 handleAllErrors(std::move(E), [&](ErrorInfoBase &EIB) {
558 DstM.getContext().diagnose(LinkDiagnosticInfo(DS_Error, EIB.message()));
559 HasErrors = true;
560 });
561 }
562 if (HasErrors)
Teresa Johnson189b2522015-11-06 17:50:48 +0000563 return true;
Peter Collingbourne1eaa97f2016-05-27 05:21:35 +0000564
Jonas Devlieghere5eb9c812017-03-13 18:08:11 +0000565 if (InternalizeCallback)
566 InternalizeCallback(DstM, Internalize);
Teresa Johnson189b2522015-11-06 17:50:48 +0000567
Anton Korobeynikov26098882008-03-05 23:21:39 +0000568 return false;
569}
Reid Spencer361e5132004-11-12 20:37:43 +0000570
Rafael Espindola9d2bfc42015-12-14 23:17:03 +0000571Linker::Linker(Module &M) : Mover(M) {}
Rafael Espindola3df61b72013-05-04 03:48:37 +0000572
Jonas Devlieghere5eb9c812017-03-13 18:08:11 +0000573bool Linker::linkInModule(
574 std::unique_ptr<Module> Src, unsigned Flags,
575 std::function<void(Module &, const StringSet<> &)> InternalizeCallback) {
576 ModuleLinker ModLinker(Mover, std::move(Src), Flags,
577 std::move(InternalizeCallback));
Teresa Johnsonbef54362015-12-18 19:28:59 +0000578 return ModLinker.run();
Rafael Espindola434e9562015-12-16 23:16:33 +0000579}
580
Chris Lattnerb1ed91f2011-07-09 17:41:24 +0000581//===----------------------------------------------------------------------===//
582// LinkModules entrypoint.
583//===----------------------------------------------------------------------===//
584
Rafael Espindola18c89412014-10-27 02:35:46 +0000585/// This function links two modules together, with the resulting Dest module
586/// modified to be the composite of the two input modules. If an error occurs,
587/// true is returned and ErrorMsg (if not null) is set to indicate the problem.
588/// Upon failure, the Dest module could be in a modified state, and shouldn't be
589/// relied on to be consistent.
Jonas Devlieghere5eb9c812017-03-13 18:08:11 +0000590bool Linker::linkModules(
591 Module &Dest, std::unique_ptr<Module> Src, unsigned Flags,
592 std::function<void(Module &, const StringSet<> &)> InternalizeCallback) {
Rafael Espindola9d2bfc42015-12-14 23:17:03 +0000593 Linker L(Dest);
Jonas Devlieghere5eb9c812017-03-13 18:08:11 +0000594 return L.linkInModule(std::move(Src), Flags, std::move(InternalizeCallback));
Rafael Espindola4160f5d2014-10-27 23:02:10 +0000595}
596
Bill Wendlinga3aeb982012-05-09 08:55:40 +0000597//===----------------------------------------------------------------------===//
598// C API.
599//===----------------------------------------------------------------------===//
600
Rafael Espindola434e9562015-12-16 23:16:33 +0000601LLVMBool LLVMLinkModules2(LLVMModuleRef Dest, LLVMModuleRef Src) {
602 Module *D = unwrap(Dest);
603 std::unique_ptr<Module> M(unwrap(Src));
604 return Linker::linkModules(*D, std::move(M));
605}