summaryrefslogtreecommitdiffstats
path: root/llvm/tools
diff options
context:
space:
mode:
authorLang Hames <lhames@gmail.com>2018-02-06 21:25:11 +0000
committerLang Hames <lhames@gmail.com>2018-02-06 21:25:11 +0000
commit4b546c91452c5735ada1430f8a6943328e4dba4e (patch)
tree633421ee6cc4d06fce9ce73f625992e7dbedc6fe /llvm/tools
parentffe72034a6d688efcd7035fe9caf5964f00037c0 (diff)
downloadbcm5719-llvm-4b546c91452c5735ada1430f8a6943328e4dba4e.tar.gz
bcm5719-llvm-4b546c91452c5735ada1430f8a6943328e4dba4e.zip
[ORC] Start migrating ORC layers to use the new ORC Core.h APIs.
In particular this patch switches RTDyldObjectLinkingLayer to use orc::SymbolResolver and threads the requried changse (ExecutionSession references and VModuleKeys) through the existing layer APIs. The purpose of the new resolver interface is to improve query performance and better support parallelism, both in JIT'd code and within the compiler itself. The most visibile change is switch of the <Layer>::addModule signatures from: Expected<Handle> addModule(std::shared_ptr<ModuleType> Mod, std::shared_ptr<JITSymbolResolver> Resolver) to: Expected<Handle> addModule(VModuleKey K, std::shared_ptr<ModuleType> Mod); Typical usage of addModule will now look like: auto K = ES.allocateVModuleKey(); Resolvers[K] = createSymbolResolver(...); Layer.addModule(K, std::move(Mod)); See the BuildingAJIT tutorial code for example usage. llvm-svn: 324405
Diffstat (limited to 'llvm/tools')
-rw-r--r--llvm/tools/lli/OrcLazyJIT.h92
1 files changed, 74 insertions, 18 deletions
diff --git a/llvm/tools/lli/OrcLazyJIT.h b/llvm/tools/lli/OrcLazyJIT.h
index a5cc804bb04..66c5c5b63f2 100644
--- a/llvm/tools/lli/OrcLazyJIT.h
+++ b/llvm/tools/lli/OrcLazyJIT.h
@@ -61,13 +61,38 @@ public:
std::unique_ptr<CompileCallbackMgr> CCMgr,
IndirectStubsManagerBuilder IndirectStubsMgrBuilder,
bool InlineStubs)
- : TM(std::move(TM)), DL(this->TM->createDataLayout()),
+ : ES(SSP), TM(std::move(TM)), DL(this->TM->createDataLayout()),
CCMgr(std::move(CCMgr)),
- ObjectLayer([]() { return std::make_shared<SectionMemoryManager>(); }),
+ ObjectLayer(ES,
+ [](orc::VModuleKey) {
+ return std::make_shared<SectionMemoryManager>();
+ },
+ [&](orc::VModuleKey K) {
+ auto ResolverI = Resolvers.find(K);
+ assert(ResolverI != Resolvers.end() &&
+ "Missing resolver for module K");
+ auto Resolver = std::move(ResolverI->second);
+ Resolvers.erase(ResolverI);
+ return Resolver;
+ }),
CompileLayer(ObjectLayer, orc::SimpleCompiler(*this->TM)),
IRDumpLayer(CompileLayer, createDebugDumper()),
- CODLayer(IRDumpLayer, extractSingleFunction, *this->CCMgr,
- std::move(IndirectStubsMgrBuilder), InlineStubs),
+ CODLayer(
+ ES, IRDumpLayer,
+ [&](orc::VModuleKey K) {
+ auto ResolverI = Resolvers.find(K);
+ assert(ResolverI != Resolvers.end() &&
+ "Missing resolver for module K");
+ auto Resolver = std::move(ResolverI->second);
+ Resolvers.erase(ResolverI);
+ return Resolver;
+ },
+ [&](orc::VModuleKey K, std::shared_ptr<orc::SymbolResolver> R) {
+ assert(!Resolvers.count(K) && "Resolver already present");
+ Resolvers[K] = std::move(R);
+ },
+ extractSingleFunction, *this->CCMgr,
+ std::move(IndirectStubsMgrBuilder), InlineStubs),
CXXRuntimeOverrides(
[this](const std::string &S) { return mangle(S); }) {}
@@ -114,24 +139,50 @@ public:
// 2) Check for C++ runtime overrides.
// 3) Search the host process (LLI)'s symbol table.
if (!ModulesHandle) {
- auto Resolver =
- orc::createLambdaResolver(
- [this](const std::string &Name) -> JITSymbol {
- if (auto Sym = CODLayer.findSymbol(Name, true))
- return Sym;
- return CXXRuntimeOverrides.searchOverrides(Name);
+ auto LegacyLookupInDylib = [this](const std::string &Name) -> JITSymbol {
+ if (auto Sym = CODLayer.findSymbol(Name, true))
+ return Sym;
+ else if (auto Err = Sym.takeError())
+ return std::move(Err);
+ return CXXRuntimeOverrides.searchOverrides(Name);
+ };
+
+ auto LegacyLookup =
+ [this, LegacyLookupInDylib](const std::string &Name) -> JITSymbol {
+ if (auto Sym = LegacyLookupInDylib(Name))
+ return Sym;
+ else if (auto Err = Sym.takeError())
+ return std::move(Err);
+
+ if (auto Addr = RTDyldMemoryManager::getSymbolAddressInProcess(Name))
+ return JITSymbol(Addr, JITSymbolFlags::Exported);
+
+ return nullptr;
+ };
+
+ auto K = ES.allocateVModule();
+ assert(!Resolvers.count(K) && "Resolver already present");
+ Resolvers[K] = orc::createSymbolResolver(
+ [this, LegacyLookupInDylib](orc::SymbolFlagsMap &SymbolFlags,
+ const orc::SymbolNameSet &Symbols) {
+ auto NotFoundViaLegacyLookup = lookupFlagsWithLegacyFn(
+ SymbolFlags, Symbols, LegacyLookupInDylib);
+ if (!NotFoundViaLegacyLookup) {
+ logAllUnhandledErrors(NotFoundViaLegacyLookup.takeError(), errs(),
+ "OrcLazyJIT lookupFlags error: ");
+ SymbolFlags.clear();
+ return orc::SymbolNameSet();
+ }
+ return std::move(*NotFoundViaLegacyLookup);
},
- [](const std::string &Name) {
- if (auto Addr =
- RTDyldMemoryManager::getSymbolAddressInProcess(Name))
- return JITSymbol(Addr, JITSymbolFlags::Exported);
- return JITSymbol(nullptr);
- }
- );
+ [LegacyLookup](orc::AsynchronousSymbolQuery &Query,
+ orc::SymbolNameSet Symbols) {
+ return lookupWithLegacyFn(Query, Symbols, LegacyLookup);
+ });
// Add the module to the JIT.
if (auto ModulesHandleOrErr =
- CODLayer.addModule(std::move(M), std::move(Resolver)))
+ CODLayer.addModule(std::move(K), std::move(M)))
ModulesHandle = std::move(*ModulesHandleOrErr);
else
return ModulesHandleOrErr.takeError();
@@ -178,6 +229,11 @@ private:
static TransformFtor createDebugDumper();
+ orc::SymbolStringPool SSP;
+ orc::ExecutionSession ES;
+
+ std::map<orc::VModuleKey, std::shared_ptr<orc::SymbolResolver>> Resolvers;
+
std::unique_ptr<TargetMachine> TM;
DataLayout DL;
SectionMemoryManager CCMgrMemMgr;
OpenPOWER on IntegriCloud