forked from OSchip/llvm-project
Minor cleanup and documentation to IRMover (NFC)
From: Mehdi Amini <mehdi.amini@apple.com> llvm-svn: 263304
This commit is contained in:
parent
33d57c7547
commit
33661070c5
|
@ -58,7 +58,15 @@ public:
|
||||||
IRMover(Module &M);
|
IRMover(Module &M);
|
||||||
|
|
||||||
typedef std::function<void(GlobalValue &)> ValueAdder;
|
typedef std::function<void(GlobalValue &)> ValueAdder;
|
||||||
/// Move in the provide values.
|
|
||||||
|
/// Move in the provide values in \p ValuesToLink from \p Src.
|
||||||
|
///
|
||||||
|
/// - \p AddLazyFor is a call back that the IRMover will call when a global
|
||||||
|
/// value is referenced by one of the ValuesToLink (transitively) but was
|
||||||
|
/// not present in ValuesToLink. The GlobalValue and a ValueAdder callback
|
||||||
|
/// are passed as an argument, and the callback is expected to be called
|
||||||
|
/// if the GlobalValue needs to be added to the \p ValuesToLink and linked.
|
||||||
|
///
|
||||||
/// Returns true on error.
|
/// Returns true on error.
|
||||||
bool move(std::unique_ptr<Module> Src, ArrayRef<GlobalValue *> ValuesToLink,
|
bool move(std::unique_ptr<Module> Src, ArrayRef<GlobalValue *> ValuesToLink,
|
||||||
std::function<void(GlobalValue &GV, ValueAdder Add)> AddLazyFor,
|
std::function<void(GlobalValue &GV, ValueAdder Add)> AddLazyFor,
|
||||||
|
|
|
@ -345,10 +345,10 @@ class IRLinker;
|
||||||
/// speeds up linking for modules with many/ lazily linked functions of which
|
/// speeds up linking for modules with many/ lazily linked functions of which
|
||||||
/// few get used.
|
/// few get used.
|
||||||
class GlobalValueMaterializer final : public ValueMaterializer {
|
class GlobalValueMaterializer final : public ValueMaterializer {
|
||||||
IRLinker *TheIRLinker;
|
IRLinker &TheIRLinker;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
GlobalValueMaterializer(IRLinker *TheIRLinker) : TheIRLinker(TheIRLinker) {}
|
GlobalValueMaterializer(IRLinker &TheIRLinker) : TheIRLinker(TheIRLinker) {}
|
||||||
Value *materializeDeclFor(Value *V) override;
|
Value *materializeDeclFor(Value *V) override;
|
||||||
void materializeInitFor(GlobalValue *New, GlobalValue *Old) override;
|
void materializeInitFor(GlobalValue *New, GlobalValue *Old) override;
|
||||||
Metadata *mapTemporaryMetadata(Metadata *MD) override;
|
Metadata *mapTemporaryMetadata(Metadata *MD) override;
|
||||||
|
@ -358,10 +358,10 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
class LocalValueMaterializer final : public ValueMaterializer {
|
class LocalValueMaterializer final : public ValueMaterializer {
|
||||||
IRLinker *TheIRLinker;
|
IRLinker &TheIRLinker;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
LocalValueMaterializer(IRLinker *TheIRLinker) : TheIRLinker(TheIRLinker) {}
|
LocalValueMaterializer(IRLinker &TheIRLinker) : TheIRLinker(TheIRLinker) {}
|
||||||
Value *materializeDeclFor(Value *V) override;
|
Value *materializeDeclFor(Value *V) override;
|
||||||
void materializeInitFor(GlobalValue *New, GlobalValue *Old) override;
|
void materializeInitFor(GlobalValue *New, GlobalValue *Old) override;
|
||||||
Metadata *mapTemporaryMetadata(Metadata *MD) override;
|
Metadata *mapTemporaryMetadata(Metadata *MD) override;
|
||||||
|
@ -376,6 +376,7 @@ class IRLinker {
|
||||||
Module &DstM;
|
Module &DstM;
|
||||||
std::unique_ptr<Module> SrcM;
|
std::unique_ptr<Module> SrcM;
|
||||||
|
|
||||||
|
/// See IRMover::move().
|
||||||
std::function<void(GlobalValue &, IRMover::ValueAdder)> AddLazyFor;
|
std::function<void(GlobalValue &, IRMover::ValueAdder)> AddLazyFor;
|
||||||
|
|
||||||
TypeMapTy TypeMap;
|
TypeMapTy TypeMap;
|
||||||
|
@ -477,6 +478,11 @@ class IRLinker {
|
||||||
Constant *linkAppendingVarProto(GlobalVariable *DstGV,
|
Constant *linkAppendingVarProto(GlobalVariable *DstGV,
|
||||||
const GlobalVariable *SrcGV);
|
const GlobalVariable *SrcGV);
|
||||||
|
|
||||||
|
/// Given the GlobaValue \p SGV in the source module, and the matching
|
||||||
|
/// GlobalValue \p DGV (if any), return true if the linker will pull \p SGV
|
||||||
|
/// into the destination module.
|
||||||
|
///
|
||||||
|
/// Note this code may call the client-provided \p AddLazyFor.
|
||||||
bool shouldLink(GlobalValue *DGV, GlobalValue &SGV);
|
bool shouldLink(GlobalValue *DGV, GlobalValue &SGV);
|
||||||
Constant *linkGlobalValueProto(GlobalValue *GV, bool ForAlias);
|
Constant *linkGlobalValueProto(GlobalValue *GV, bool ForAlias);
|
||||||
|
|
||||||
|
@ -518,7 +524,7 @@ public:
|
||||||
DenseMap<unsigned, MDNode *> *ValIDToTempMDMap = nullptr,
|
DenseMap<unsigned, MDNode *> *ValIDToTempMDMap = nullptr,
|
||||||
bool IsMetadataLinkingPostpass = false)
|
bool IsMetadataLinkingPostpass = false)
|
||||||
: DstM(DstM), SrcM(std::move(SrcM)), AddLazyFor(AddLazyFor), TypeMap(Set),
|
: DstM(DstM), SrcM(std::move(SrcM)), AddLazyFor(AddLazyFor), TypeMap(Set),
|
||||||
GValMaterializer(this), LValMaterializer(this),
|
GValMaterializer(*this), LValMaterializer(*this),
|
||||||
IsMetadataLinkingPostpass(IsMetadataLinkingPostpass),
|
IsMetadataLinkingPostpass(IsMetadataLinkingPostpass),
|
||||||
ValIDToTempMDMap(ValIDToTempMDMap) {
|
ValIDToTempMDMap(ValIDToTempMDMap) {
|
||||||
for (GlobalValue *GV : ValuesToLink)
|
for (GlobalValue *GV : ValuesToLink)
|
||||||
|
@ -590,47 +596,47 @@ static void forceRenaming(GlobalValue *GV, StringRef Name) {
|
||||||
}
|
}
|
||||||
|
|
||||||
Value *GlobalValueMaterializer::materializeDeclFor(Value *V) {
|
Value *GlobalValueMaterializer::materializeDeclFor(Value *V) {
|
||||||
return TheIRLinker->materializeDeclFor(V, false);
|
return TheIRLinker.materializeDeclFor(V, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GlobalValueMaterializer::materializeInitFor(GlobalValue *New,
|
void GlobalValueMaterializer::materializeInitFor(GlobalValue *New,
|
||||||
GlobalValue *Old) {
|
GlobalValue *Old) {
|
||||||
TheIRLinker->materializeInitFor(New, Old, false);
|
TheIRLinker.materializeInitFor(New, Old, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
Metadata *GlobalValueMaterializer::mapTemporaryMetadata(Metadata *MD) {
|
Metadata *GlobalValueMaterializer::mapTemporaryMetadata(Metadata *MD) {
|
||||||
return TheIRLinker->mapTemporaryMetadata(MD);
|
return TheIRLinker.mapTemporaryMetadata(MD);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GlobalValueMaterializer::replaceTemporaryMetadata(const Metadata *OrigMD,
|
void GlobalValueMaterializer::replaceTemporaryMetadata(const Metadata *OrigMD,
|
||||||
Metadata *NewMD) {
|
Metadata *NewMD) {
|
||||||
TheIRLinker->replaceTemporaryMetadata(OrigMD, NewMD);
|
TheIRLinker.replaceTemporaryMetadata(OrigMD, NewMD);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool GlobalValueMaterializer::isMetadataNeeded(Metadata *MD) {
|
bool GlobalValueMaterializer::isMetadataNeeded(Metadata *MD) {
|
||||||
return TheIRLinker->isMetadataNeeded(MD);
|
return TheIRLinker.isMetadataNeeded(MD);
|
||||||
}
|
}
|
||||||
|
|
||||||
Value *LocalValueMaterializer::materializeDeclFor(Value *V) {
|
Value *LocalValueMaterializer::materializeDeclFor(Value *V) {
|
||||||
return TheIRLinker->materializeDeclFor(V, true);
|
return TheIRLinker.materializeDeclFor(V, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void LocalValueMaterializer::materializeInitFor(GlobalValue *New,
|
void LocalValueMaterializer::materializeInitFor(GlobalValue *New,
|
||||||
GlobalValue *Old) {
|
GlobalValue *Old) {
|
||||||
TheIRLinker->materializeInitFor(New, Old, true);
|
TheIRLinker.materializeInitFor(New, Old, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
Metadata *LocalValueMaterializer::mapTemporaryMetadata(Metadata *MD) {
|
Metadata *LocalValueMaterializer::mapTemporaryMetadata(Metadata *MD) {
|
||||||
return TheIRLinker->mapTemporaryMetadata(MD);
|
return TheIRLinker.mapTemporaryMetadata(MD);
|
||||||
}
|
}
|
||||||
|
|
||||||
void LocalValueMaterializer::replaceTemporaryMetadata(const Metadata *OrigMD,
|
void LocalValueMaterializer::replaceTemporaryMetadata(const Metadata *OrigMD,
|
||||||
Metadata *NewMD) {
|
Metadata *NewMD) {
|
||||||
TheIRLinker->replaceTemporaryMetadata(OrigMD, NewMD);
|
TheIRLinker.replaceTemporaryMetadata(OrigMD, NewMD);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool LocalValueMaterializer::isMetadataNeeded(Metadata *MD) {
|
bool LocalValueMaterializer::isMetadataNeeded(Metadata *MD) {
|
||||||
return TheIRLinker->isMetadataNeeded(MD);
|
return TheIRLinker.isMetadataNeeded(MD);
|
||||||
}
|
}
|
||||||
|
|
||||||
Value *IRLinker::materializeDeclFor(Value *V, bool ForAlias) {
|
Value *IRLinker::materializeDeclFor(Value *V, bool ForAlias) {
|
||||||
|
@ -1034,8 +1040,15 @@ bool IRLinker::shouldLink(GlobalValue *DGV, GlobalValue &SGV) {
|
||||||
if (DoneLinkingBodies)
|
if (DoneLinkingBodies)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
AddLazyFor(SGV, [this](GlobalValue &GV) { maybeAdd(&GV); });
|
|
||||||
return ValuesToLink.count(&SGV);
|
// Callback to the client to give a chance to lazily add the Global to the
|
||||||
|
// list of value to link.
|
||||||
|
bool LazilyAdded = false;
|
||||||
|
AddLazyFor(SGV, [this, &LazilyAdded](GlobalValue &GV) {
|
||||||
|
maybeAdd(&GV);
|
||||||
|
LazilyAdded = true;
|
||||||
|
});
|
||||||
|
return LazilyAdded;
|
||||||
}
|
}
|
||||||
|
|
||||||
Constant *IRLinker::linkGlobalValueProto(GlobalValue *SGV, bool ForAlias) {
|
Constant *IRLinker::linkGlobalValueProto(GlobalValue *SGV, bool ForAlias) {
|
||||||
|
@ -1054,9 +1067,8 @@ Constant *IRLinker::linkGlobalValueProto(GlobalValue *SGV, bool ForAlias) {
|
||||||
return cast<Constant>(I->second);
|
return cast<Constant>(I->second);
|
||||||
}
|
}
|
||||||
|
|
||||||
DGV = nullptr;
|
if (!ShouldLink && ForAlias)
|
||||||
if (ShouldLink || !ForAlias)
|
DGV = nullptr;
|
||||||
DGV = getLinkedToGlobal(SGV);
|
|
||||||
|
|
||||||
// Handle the ultra special appending linkage case first.
|
// Handle the ultra special appending linkage case first.
|
||||||
assert(!DGV || SGV->hasAppendingLinkage() == DGV->hasAppendingLinkage());
|
assert(!DGV || SGV->hasAppendingLinkage() == DGV->hasAppendingLinkage());
|
||||||
|
|
Loading…
Reference in New Issue