diff options
| author | Lang Hames <lhames@gmail.com> | 2018-11-13 01:25:34 +0000 |
|---|---|---|
| committer | Lang Hames <lhames@gmail.com> | 2018-11-13 01:25:34 +0000 |
| commit | 575515fddf9003c0a5f680c52bfa9893ceb4c20c (patch) | |
| tree | 521a7ee8bc12714c4218020051bf5852459018eb /llvm/examples/Kaleidoscope/BuildingAJIT/Chapter2/KaleidoscopeJIT.h | |
| parent | 5bf0c1554088b30beb9f350d088aadfe6031ac37 (diff) | |
| download | bcm5719-llvm-575515fddf9003c0a5f680c52bfa9893ceb4c20c.tar.gz bcm5719-llvm-575515fddf9003c0a5f680c52bfa9893ceb4c20c.zip | |
[BuildingAJIT] Update chapter 2 to use the ORCv2 APIs.
llvm-svn: 346726
Diffstat (limited to 'llvm/examples/Kaleidoscope/BuildingAJIT/Chapter2/KaleidoscopeJIT.h')
| -rw-r--r-- | llvm/examples/Kaleidoscope/BuildingAJIT/Chapter2/KaleidoscopeJIT.h | 109 |
1 files changed, 47 insertions, 62 deletions
diff --git a/llvm/examples/Kaleidoscope/BuildingAJIT/Chapter2/KaleidoscopeJIT.h b/llvm/examples/Kaleidoscope/BuildingAJIT/Chapter2/KaleidoscopeJIT.h index 7c803b138c0..1060256ec0d 100644 --- a/llvm/examples/Kaleidoscope/BuildingAJIT/Chapter2/KaleidoscopeJIT.h +++ b/llvm/examples/Kaleidoscope/BuildingAJIT/Chapter2/KaleidoscopeJIT.h @@ -14,29 +14,23 @@ #ifndef LLVM_EXECUTIONENGINE_ORC_KALEIDOSCOPEJIT_H #define LLVM_EXECUTIONENGINE_ORC_KALEIDOSCOPEJIT_H -#include "llvm/ADT/STLExtras.h" -#include "llvm/ExecutionEngine/ExecutionEngine.h" +#include "llvm/ADT/StringRef.h" #include "llvm/ExecutionEngine/JITSymbol.h" #include "llvm/ExecutionEngine/Orc/CompileUtils.h" +#include "llvm/ExecutionEngine/Orc/Core.h" +#include "llvm/ExecutionEngine/Orc/ExecutionUtils.h" #include "llvm/ExecutionEngine/Orc/IRCompileLayer.h" #include "llvm/ExecutionEngine/Orc/IRTransformLayer.h" -#include "llvm/ExecutionEngine/Orc/LambdaResolver.h" +#include "llvm/ExecutionEngine/Orc/JITTargetMachineBuilder.h" #include "llvm/ExecutionEngine/Orc/RTDyldObjectLinkingLayer.h" -#include "llvm/ExecutionEngine/RTDyldMemoryManager.h" #include "llvm/ExecutionEngine/SectionMemoryManager.h" #include "llvm/IR/DataLayout.h" +#include "llvm/IR/LLVMContext.h" #include "llvm/IR/LegacyPassManager.h" -#include "llvm/IR/Mangler.h" -#include "llvm/Support/DynamicLibrary.h" -#include "llvm/Support/raw_ostream.h" -#include "llvm/Target/TargetMachine.h" #include "llvm/Transforms/InstCombine/InstCombine.h" #include "llvm/Transforms/Scalar.h" #include "llvm/Transforms/Scalar/GVN.h" -#include <algorithm> #include <memory> -#include <string> -#include <vector> namespace llvm { namespace orc { @@ -44,69 +38,60 @@ namespace orc { class KaleidoscopeJIT { private: ExecutionSession ES; - std::shared_ptr<SymbolResolver> Resolver; - std::unique_ptr<TargetMachine> TM; - const DataLayout DL; - LegacyRTDyldObjectLinkingLayer ObjectLayer; - LegacyIRCompileLayer<decltype(ObjectLayer), SimpleCompiler> CompileLayer; + RTDyldObjectLinkingLayer ObjectLayer; + IRCompileLayer CompileLayer; + IRTransformLayer OptimizeLayer; - using OptimizeFunction = - std::function<std::unique_ptr<Module>(std::unique_ptr<Module>)>; - - LegacyIRTransformLayer<decltype(CompileLayer), OptimizeFunction> OptimizeLayer; + DataLayout DL; + MangleAndInterner Mangle; + ThreadSafeContext Ctx; public: - KaleidoscopeJIT() - : Resolver(createLegacyLookupResolver( - ES, - [this](const std::string &Name) -> JITSymbol { - if (auto Sym = OptimizeLayer.findSymbol(Name, false)) - return Sym; - else if (auto Err = Sym.takeError()) - return std::move(Err); - if (auto SymAddr = - RTDyldMemoryManager::getSymbolAddressInProcess(Name)) - return JITSymbol(SymAddr, JITSymbolFlags::Exported); - return nullptr; - }, - [](Error Err) { cantFail(std::move(Err), "lookupFlags failed"); })), - TM(EngineBuilder().selectTarget()), DL(TM->createDataLayout()), - ObjectLayer(ES, - [this](VModuleKey) { - return LegacyRTDyldObjectLinkingLayer::Resources{ - std::make_shared<SectionMemoryManager>(), Resolver}; - }), - CompileLayer(ObjectLayer, SimpleCompiler(*TM)), - OptimizeLayer(CompileLayer, [this](std::unique_ptr<Module> M) { - return optimizeModule(std::move(M)); - }) { - llvm::sys::DynamicLibrary::LoadLibraryPermanently(nullptr); + + KaleidoscopeJIT(JITTargetMachineBuilder JTMB, DataLayout DL) + : ObjectLayer(ES, + []() { return llvm::make_unique<SectionMemoryManager>(); }), + CompileLayer(ES, ObjectLayer, ConcurrentIRCompiler(std::move(JTMB))), + OptimizeLayer(ES, CompileLayer, optimizeModule), + DL(std::move(DL)), Mangle(ES, this->DL), + Ctx(llvm::make_unique<LLVMContext>()) { + ES.getMainJITDylib().setGenerator( + cantFail(DynamicLibrarySearchGenerator::GetForCurrentProcess(DL))); } - TargetMachine &getTargetMachine() { return *TM; } + const DataLayout &getDataLayout() const { return DL; } + + LLVMContext &getContext() { return *Ctx.getContext(); } + + static Expected<std::unique_ptr<KaleidoscopeJIT>> Create() { + auto JTMB = JITTargetMachineBuilder::detectHost(); - VModuleKey addModule(std::unique_ptr<Module> M) { - // Add the module to the JIT with a new VModuleKey. - auto K = ES.allocateVModule(); - cantFail(OptimizeLayer.addModule(K, std::move(M))); - return K; + if (!JTMB) + return JTMB.takeError(); + + auto DL = JTMB->getDefaultDataLayoutForTarget(); + if (!DL) + return DL.takeError(); + + return llvm::make_unique<KaleidoscopeJIT>(std::move(*JTMB), std::move(*DL)); } - JITSymbol findSymbol(const std::string Name) { - std::string MangledName; - raw_string_ostream MangledNameStream(MangledName); - Mangler::getNameWithPrefix(MangledNameStream, Name, DL); - return OptimizeLayer.findSymbol(MangledNameStream.str(), true); + Error addModule(std::unique_ptr<Module> M) { + return OptimizeLayer.add(ES.getMainJITDylib(), + ThreadSafeModule(std::move(M), Ctx)); } - void removeModule(VModuleKey K) { - cantFail(OptimizeLayer.removeModule(K)); + Expected<JITEvaluatedSymbol> lookup(StringRef Name) { + return ES.lookup({&ES.getMainJITDylib()}, Mangle(Name.str())); } private: - std::unique_ptr<Module> optimizeModule(std::unique_ptr<Module> M) { + + static Expected<ThreadSafeModule> + optimizeModule(ThreadSafeModule TSM, + const MaterializationResponsibility &R) { // Create a function pass manager. - auto FPM = llvm::make_unique<legacy::FunctionPassManager>(M.get()); + auto FPM = llvm::make_unique<legacy::FunctionPassManager>(TSM.getModule()); // Add some optimizations. FPM->add(createInstructionCombiningPass()); @@ -117,10 +102,10 @@ private: // Run the optimizations over all functions in the module being added to // the JIT. - for (auto &F : *M) + for (auto &F : *TSM.getModule()) FPM->run(F); - return M; + return TSM; } }; |

