Minor cleanup and documentation to IRMover (NFC)

From: Mehdi Amini <mehdi.amini@apple.com>
llvm-svn: 263304
This commit is contained in:
Mehdi Amini 2016-03-11 22:19:06 +00:00
parent 33d57c7547
commit 33661070c5
2 changed files with 41 additions and 21 deletions

View File

@ -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,

View File

@ -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());