forked from OSchip/llvm-project
Change ModuleLinker to take a set of GlobalValues to import instead of a single one
For efficiency reason, when importing multiple functions for the same Module, we can avoid reparsing it every time. Differential Revision: http://reviews.llvm.org/D15102 From: Mehdi Amini <mehdi.amini@apple.com> llvm-svn: 254486
This commit is contained in:
parent
2d91266473
commit
ffe2e4aae0
|
@ -82,7 +82,7 @@ public:
|
|||
/// Returns true on error.
|
||||
bool linkInModule(Module &Src, unsigned Flags = Flags::None,
|
||||
const FunctionInfoIndex *Index = nullptr,
|
||||
Function *FuncToImport = nullptr);
|
||||
DenseSet<const GlobalValue *> *FuncToImport = nullptr);
|
||||
|
||||
static bool linkModules(Module &Dest, Module &Src,
|
||||
DiagnosticHandlerFunction DiagnosticHandler,
|
||||
|
|
|
@ -406,7 +406,7 @@ class ModuleLinker {
|
|||
|
||||
/// Function to import from source module, all other functions are
|
||||
/// imported as declarations instead of definitions.
|
||||
Function *ImportFunction;
|
||||
DenseSet<const GlobalValue *> *ImportFunction;
|
||||
|
||||
/// Set to true if the given FunctionInfoIndex contains any functions
|
||||
/// from this source module, in which case we must conservatively assume
|
||||
|
@ -425,7 +425,7 @@ public:
|
|||
ModuleLinker(Module &DstM, Linker::IdentifiedStructTypeSet &Set, Module &SrcM,
|
||||
DiagnosticHandlerFunction DiagnosticHandler, unsigned Flags,
|
||||
const FunctionInfoIndex *Index = nullptr,
|
||||
Function *FuncToImport = nullptr)
|
||||
DenseSet<const GlobalValue *> *FuncToImport = nullptr)
|
||||
: DstM(DstM), SrcM(SrcM), TypeMap(Set), ValMaterializer(this),
|
||||
DiagnosticHandler(DiagnosticHandler), Flags(Flags), ImportIndex(Index),
|
||||
ImportFunction(FuncToImport) {
|
||||
|
@ -632,7 +632,7 @@ bool ModuleLinker::doImportAsDefinition(const GlobalValue *SGV) {
|
|||
return true;
|
||||
// Only import the function requested for importing.
|
||||
auto *SF = dyn_cast<Function>(SGV);
|
||||
if (SF && SF == ImportFunction)
|
||||
if (SF && ImportFunction->count(SF))
|
||||
return true;
|
||||
// Otherwise no.
|
||||
return false;
|
||||
|
@ -1058,7 +1058,7 @@ bool ModuleLinker::shouldLinkFromSource(bool &LinkFromSrc,
|
|||
if (isa<Function>(&Src)) {
|
||||
// For functions, LinkFromSrc iff this is the function requested
|
||||
// for importing. For variables, decide below normally.
|
||||
LinkFromSrc = (&Src == ImportFunction);
|
||||
LinkFromSrc = ImportFunction->count(&Src);
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -2033,7 +2033,7 @@ Linker::Linker(Module &M)
|
|||
|
||||
bool Linker::linkInModule(Module &Src, unsigned Flags,
|
||||
const FunctionInfoIndex *Index,
|
||||
Function *FuncToImport) {
|
||||
DenseSet<const GlobalValue *> *FuncToImport) {
|
||||
ModuleLinker TheLinker(Composite, IdentifiedStructTypes, Src,
|
||||
DiagnosticHandler, Flags, Index, FuncToImport);
|
||||
bool RetCode = TheLinker.run();
|
||||
|
|
|
@ -182,7 +182,10 @@ bool FunctionImporter::importFunctions(Module &M) {
|
|||
}
|
||||
|
||||
// Link in the specified function.
|
||||
if (L.linkInModule(Module, Linker::Flags::None, &Index, F))
|
||||
DenseSet<const GlobalValue *> FunctionsToImport;
|
||||
FunctionsToImport.insert(F);
|
||||
if (L.linkInModule(Module, Linker::Flags::None, &Index,
|
||||
&FunctionsToImport))
|
||||
report_fatal_error("Function Import: link error");
|
||||
|
||||
// Process the newly imported function and add callees to the worklist.
|
||||
|
@ -194,6 +197,7 @@ bool FunctionImporter::importFunctions(Module &M) {
|
|||
|
||||
Changed = true;
|
||||
}
|
||||
|
||||
return Changed;
|
||||
}
|
||||
|
||||
|
|
|
@ -198,7 +198,10 @@ static bool importFunctions(const char *argv0, LLVMContext &Context,
|
|||
}
|
||||
|
||||
// Link in the specified function.
|
||||
if (L.linkInModule(*M, Linker::Flags::None, Index.get(), F))
|
||||
DenseSet<const GlobalValue *> FunctionToImport;
|
||||
FunctionToImport.insert(F);
|
||||
if (L.linkInModule(*M, Linker::Flags::None, Index.get(),
|
||||
&FunctionToImport))
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
|
|
Loading…
Reference in New Issue