Skip to content

Commit

Permalink
Temporarily Revert "Nuke the old JIT." as it's not quite ready to
Browse files Browse the repository at this point in the history
be deleted. This will be reapplied as soon as possible and before
the 3.6 branch date at any rate.

Approved by Jim Grosbach, Lang Hames, Rafael Espindola.

This reverts commits r215111, 215115, 215116, 215117, 215136.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@215154 91177308-0d34-0410-b5e6-96231b3b80d8
  • Loading branch information
echristo committed Aug 7, 2014
1 parent 9fbb012 commit aa5b9c0
Show file tree
Hide file tree
Showing 258 changed files with 12,512 additions and 184 deletions.
7 changes: 6 additions & 1 deletion Makefile.rules
Original file line number Diff line number Diff line change
Expand Up @@ -1673,13 +1673,18 @@ $(ObjDir)/%GenAsmMatcher.inc.tmp : %.td $(ObjDir)/.dir $(LLVM_TBLGEN)
$(TARGET:%=$(ObjDir)/%GenMCCodeEmitter.inc.tmp): \
$(ObjDir)/%GenMCCodeEmitter.inc.tmp: %.td $(ObjDir)/.dir $(LLVM_TBLGEN)
$(Echo) "Building $(<F) MC code emitter with tblgen"
$(Verb) $(LLVMTableGen) -gen-emitter -o $(call SYSPATH, $@) $<
$(Verb) $(LLVMTableGen) -gen-emitter -mc-emitter -o $(call SYSPATH, $@) $<

$(TARGET:%=$(ObjDir)/%GenMCPseudoLowering.inc.tmp): \
$(ObjDir)/%GenMCPseudoLowering.inc.tmp: %.td $(ObjDir)/.dir $(LLVM_TBLGEN)
$(Echo) "Building $(<F) MC Pseudo instruction expander with tblgen"
$(Verb) $(LLVMTableGen) -gen-pseudo-lowering -o $(call SYSPATH, $@) $<

$(TARGET:%=$(ObjDir)/%GenCodeEmitter.inc.tmp): \
$(ObjDir)/%GenCodeEmitter.inc.tmp: %.td $(ObjDir)/.dir $(LLVM_TBLGEN)
$(Echo) "Building $(<F) code emitter with tblgen"
$(Verb) $(LLVMTableGen) -gen-emitter -o $(call SYSPATH, $@) $<

$(TARGET:%=$(ObjDir)/%GenDAGISel.inc.tmp): \
$(ObjDir)/%GenDAGISel.inc.tmp : %.td $(ObjDir)/.dir $(LLVM_TBLGEN)
$(Echo) "Building $(<F) DAG instruction selector implementation with tblgen"
Expand Down
2 changes: 1 addition & 1 deletion bindings/ocaml/executionengine/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@

LEVEL := ../../..
LIBRARYNAME := llvm_executionengine
UsedComponents := executionengine mcjit interpreter native
UsedComponents := executionengine jit interpreter native
UsedOcamlInterfaces := llvm llvm_target

include ../Makefile.ocaml
2 changes: 1 addition & 1 deletion bindings/ocaml/executionengine/executionengine_ocaml.c
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@
/* Force the LLVM interpreter and JIT to be linked in. */
void llvm_initialize(void) {
LLVMLinkInInterpreter();
LLVMLinkInMCJIT();
LLVMLinkInJIT();
}

/* unit -> bool */
Expand Down
3 changes: 2 additions & 1 deletion docs/TableGen/BackEnds.rst
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,8 @@ returns the (currently, 32-bit unsigned) value of the instruction.
**Output**: C++ code, implementing the target's CodeEmitter
class by overriding the virtual functions as ``<Target>CodeEmitter::function()``.

**Usage**: Used to include directly at the end of ``<Target>MCCodeEmitter.cpp``.
**Usage**: Used to include directly at the end of ``<Target>CodeEmitter.cpp``, and
with option `-mc-emitter` to be included in ``<Target>MCCodeEmitter.cpp``.

RegisterInfo
------------
Expand Down
2 changes: 1 addition & 1 deletion examples/BrainF/BrainFDriver.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@

#include "BrainF.h"
#include "llvm/Bitcode/ReaderWriter.h"
#include "llvm/ExecutionEngine/ExecutionEngine.h"
#include "llvm/ExecutionEngine/GenericValue.h"
#include "llvm/ExecutionEngine/JIT.h"
#include "llvm/IR/Constants.h"
#include "llvm/IR/Verifier.h"
#include "llvm/Support/CommandLine.h"
Expand Down
1 change: 1 addition & 0 deletions examples/BrainF/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ set(LLVM_LINK_COMPONENTS
BitWriter
Core
ExecutionEngine
JIT
MC
Support
nativecodegen
Expand Down
2 changes: 2 additions & 0 deletions examples/ExceptionDemo/ExceptionDemo.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1964,8 +1964,10 @@ int main(int argc, char *argv[]) {
// Build engine with JIT
llvm::EngineBuilder factory(module);
factory.setEngineKind(llvm::EngineKind::JIT);
factory.setAllocateGVsWithCode(false);
factory.setTargetOptions(Opts);
factory.setMCJITMemoryManager(MemMgr);
factory.setUseMCJIT(true);
llvm::ExecutionEngine *executionEngine = factory.create();

{
Expand Down
1 change: 1 addition & 0 deletions examples/Fibonacci/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ set(LLVM_LINK_COMPONENTS
Core
ExecutionEngine
Interpreter
JIT
MC
Support
nativecodegen
Expand Down
1 change: 1 addition & 0 deletions examples/Fibonacci/fibonacci.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
#include "llvm/IR/Verifier.h"
#include "llvm/ExecutionEngine/GenericValue.h"
#include "llvm/ExecutionEngine/Interpreter.h"
#include "llvm/ExecutionEngine/JIT.h"
#include "llvm/IR/Constants.h"
#include "llvm/IR/DerivedTypes.h"
#include "llvm/IR/Instructions.h"
Expand Down
1 change: 1 addition & 0 deletions examples/HowToUseJIT/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ set(LLVM_LINK_COMPONENTS
Core
ExecutionEngine
Interpreter
JIT
MC
Support
nativecodegen
Expand Down
2 changes: 2 additions & 0 deletions examples/HowToUseJIT/HowToUseJIT.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@

#include "llvm/ExecutionEngine/GenericValue.h"
#include "llvm/ExecutionEngine/Interpreter.h"
#include "llvm/ExecutionEngine/JIT.h"
#include "llvm/IR/Constants.h"
#include "llvm/IR/DerivedTypes.h"
#include "llvm/IR/IRBuilder.h"
Expand Down Expand Up @@ -125,6 +126,7 @@ int main() {

// Import result of execution:
outs() << "Result: " << gv.IntVal << "\n";
EE->freeMachineCodeForFunction(FooF);
delete EE;
llvm_shutdown();
return 0;
Expand Down
1 change: 1 addition & 0 deletions examples/Kaleidoscope/Chapter4/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ set(LLVM_LINK_COMPONENTS
Core
ExecutionEngine
InstCombine
JIT
MC
ScalarOpts
Support
Expand Down
1 change: 1 addition & 0 deletions examples/Kaleidoscope/Chapter4/toy.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
#include "llvm/Analysis/Passes.h"
#include "llvm/ExecutionEngine/ExecutionEngine.h"
#include "llvm/ExecutionEngine/JIT.h"
#include "llvm/IR/DataLayout.h"
#include "llvm/IR/DerivedTypes.h"
#include "llvm/IR/IRBuilder.h"
Expand Down
1 change: 1 addition & 0 deletions examples/Kaleidoscope/Chapter5/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ set(LLVM_LINK_COMPONENTS
Core
ExecutionEngine
InstCombine
JIT
MC
ScalarOpts
Support
Expand Down
1 change: 1 addition & 0 deletions examples/Kaleidoscope/Chapter5/toy.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
#include "llvm/Analysis/Passes.h"
#include "llvm/ExecutionEngine/ExecutionEngine.h"
#include "llvm/ExecutionEngine/JIT.h"
#include "llvm/IR/DataLayout.h"
#include "llvm/IR/DerivedTypes.h"
#include "llvm/IR/IRBuilder.h"
Expand Down
1 change: 1 addition & 0 deletions examples/Kaleidoscope/Chapter6/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ set(LLVM_LINK_COMPONENTS
Core
ExecutionEngine
InstCombine
JIT
MC
ScalarOpts
Support
Expand Down
1 change: 1 addition & 0 deletions examples/Kaleidoscope/Chapter6/toy.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
#include "llvm/Analysis/Passes.h"
#include "llvm/ExecutionEngine/ExecutionEngine.h"
#include "llvm/ExecutionEngine/JIT.h"
#include "llvm/IR/DataLayout.h"
#include "llvm/IR/DerivedTypes.h"
#include "llvm/IR/IRBuilder.h"
Expand Down
1 change: 1 addition & 0 deletions examples/Kaleidoscope/Chapter7/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ set(LLVM_LINK_COMPONENTS
Core
ExecutionEngine
InstCombine
JIT
MC
ScalarOpts
Support
Expand Down
1 change: 1 addition & 0 deletions examples/Kaleidoscope/Chapter7/toy.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
#include "llvm/Analysis/Passes.h"
#include "llvm/ExecutionEngine/ExecutionEngine.h"
#include "llvm/ExecutionEngine/JIT.h"
#include "llvm/IR/DataLayout.h"
#include "llvm/IR/DerivedTypes.h"
#include "llvm/IR/IRBuilder.h"
Expand Down
1 change: 1 addition & 0 deletions examples/Kaleidoscope/MCJIT/cached/toy-jit.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

#include "llvm/Analysis/Passes.h"
#include "llvm/ExecutionEngine/ExecutionEngine.h"
#include "llvm/ExecutionEngine/JIT.h"
#include "llvm/IR/DataLayout.h"
#include "llvm/IR/DerivedTypes.h"
#include "llvm/IR/IRBuilder.h"
Expand Down
1 change: 1 addition & 0 deletions examples/Kaleidoscope/MCJIT/cached/toy.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -897,6 +897,7 @@ ExecutionEngine *MCJITHelper::compileModule(Module *M) {
std::string ErrStr;
ExecutionEngine *NewEngine = EngineBuilder(M)
.setErrorStr(&ErrStr)
.setUseMCJIT(true)
.setMCJITMemoryManager(new HelpingMemoryManager(this))
.create();
if (!NewEngine) {
Expand Down
129 changes: 121 additions & 8 deletions examples/Kaleidoscope/MCJIT/complete/toy.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
#include "llvm/Analysis/Passes.h"
#include "llvm/ExecutionEngine/ExecutionEngine.h"
#include "llvm/ExecutionEngine/JIT.h"
#include "llvm/ExecutionEngine/MCJIT.h"
#include "llvm/ExecutionEngine/ObjectCache.h"
#include "llvm/ExecutionEngine/SectionMemoryManager.h"
Expand Down Expand Up @@ -51,6 +52,10 @@ namespace {
cl::desc("Dump IR from modules to stderr on shutdown"),
cl::init(false));

cl::opt<bool> UseMCJIT(
"use-mcjit", cl::desc("Use the MCJIT execution engine"),
cl::init(true));

cl::opt<bool> EnableLazyCompilation(
"enable-lazy-compilation", cl::desc("Enable lazy compilation when using the MCJIT engine"),
cl::init(true));
Expand Down Expand Up @@ -787,6 +792,96 @@ class BaseHelper
virtual void dump();
};

//===----------------------------------------------------------------------===//
// Helper class for JIT execution engine
//===----------------------------------------------------------------------===//

class JITHelper : public BaseHelper {
public:
JITHelper(LLVMContext &Context) {
// Make the module, which holds all the code.
if (!InputIR.empty()) {
TheModule = parseInputIR(InputIR, Context);
} else {
TheModule = new Module("my cool jit", Context);
}

// Create the JIT. This takes ownership of the module.
std::string ErrStr;
TheExecutionEngine = EngineBuilder(TheModule).setErrorStr(&ErrStr).create();
if (!TheExecutionEngine) {
fprintf(stderr, "Could not create ExecutionEngine: %s\n", ErrStr.c_str());
exit(1);
}

TheFPM = new FunctionPassManager(TheModule);

// Set up the optimizer pipeline. Start with registering info about how the
// target lays out data structures.
TheFPM->add(new DataLayout(*TheExecutionEngine->getDataLayout()));
// Provide basic AliasAnalysis support for GVN.
TheFPM->add(createBasicAliasAnalysisPass());
// Promote allocas to registers.
TheFPM->add(createPromoteMemoryToRegisterPass());
// Do simple "peephole" optimizations and bit-twiddling optzns.
TheFPM->add(createInstructionCombiningPass());
// Reassociate expressions.
TheFPM->add(createReassociatePass());
// Eliminate Common SubExpressions.
TheFPM->add(createGVNPass());
// Simplify the control flow graph (deleting unreachable blocks, etc).
TheFPM->add(createCFGSimplificationPass());

TheFPM->doInitialization();
}

virtual ~JITHelper() {
if (TheFPM)
delete TheFPM;
if (TheExecutionEngine)
delete TheExecutionEngine;
}

virtual Function *getFunction(const std::string FnName) {
assert(TheModule);
return TheModule->getFunction(FnName);
}

virtual Module *getModuleForNewFunction() {
assert(TheModule);
return TheModule;
}

virtual void *getPointerToFunction(Function* F) {
assert(TheExecutionEngine);
return TheExecutionEngine->getPointerToFunction(F);
}

virtual void *getPointerToNamedFunction(const std::string &Name) {
return TheExecutionEngine->getPointerToNamedFunction(Name);
}

virtual void runFPM(Function &F) {
assert(TheFPM);
TheFPM->run(F);
}

virtual void closeCurrentModule() {
// This should never be called for JIT
assert(false);
}

virtual void dump() {
assert(TheModule);
TheModule->dump();
}

private:
Module *TheModule;
ExecutionEngine *TheExecutionEngine;
FunctionPassManager *TheFPM;
};

//===----------------------------------------------------------------------===//
// MCJIT helper class
//===----------------------------------------------------------------------===//
Expand Down Expand Up @@ -939,6 +1034,7 @@ ExecutionEngine *MCJITHelper::compileModule(Module *M) {
std::string ErrStr;
ExecutionEngine *EE = EngineBuilder(M)
.setErrorStr(&ErrStr)
.setUseMCJIT(true)
.setMCJITMemoryManager(new HelpingMemoryManager(this))
.create();
if (!EE) {
Expand Down Expand Up @@ -1098,8 +1194,10 @@ Value *UnaryExprAST::Codegen() {
Value *OperandV = Operand->Codegen();
if (OperandV == 0) return 0;
Function *F;
F = TheHelper->getFunction(
MakeLegalFunctionName(std::string("unary") + Opcode));
if (UseMCJIT)
F = TheHelper->getFunction(MakeLegalFunctionName(std::string("unary")+Opcode));
else
F = TheHelper->getFunction(std::string("unary")+Opcode);
if (F == 0)
return ErrorV("Unknown unary operator");

Expand Down Expand Up @@ -1148,7 +1246,10 @@ Value *BinaryExprAST::Codegen() {
// If it wasn't a builtin binary operator, it must be a user defined one. Emit
// a call to it.
Function *F;
F = TheHelper->getFunction(MakeLegalFunctionName(std::string("binary")+Op));
if (UseMCJIT)
F = TheHelper->getFunction(MakeLegalFunctionName(std::string("binary")+Op));
else
F = TheHelper->getFunction(std::string("binary")+Op);
assert(F && "binary operator not found!");

Value *Ops[] = { L, R };
Expand Down Expand Up @@ -1381,7 +1482,10 @@ Function *PrototypeAST::Codegen() {
Doubles, false);

std::string FnName;
FnName = MakeLegalFunctionName(Name);
if (UseMCJIT)
FnName = MakeLegalFunctionName(Name);
else
FnName = Name;

Module* M = TheHelper->getModuleForNewFunction();
Function *F = Function::Create(FT, Function::ExternalLinkage, FnName, M);
Expand Down Expand Up @@ -1456,6 +1560,10 @@ Function *FunctionAST::Codegen() {
// Validate the generated code, checking for consistency.
verifyFunction(*TheFunction);

// Optimize the function.
if (!UseMCJIT)
TheHelper->runFPM(*TheFunction);

return TheFunction;
}

Expand All @@ -1473,7 +1581,7 @@ Function *FunctionAST::Codegen() {

static void HandleDefinition() {
if (FunctionAST *F = ParseDefinition()) {
if (EnableLazyCompilation)
if (UseMCJIT && EnableLazyCompilation)
TheHelper->closeCurrentModule();
Function *LF = F->Codegen();
if (LF && VerboseOutput) {
Expand Down Expand Up @@ -1563,8 +1671,10 @@ double printlf() {

int main(int argc, char **argv) {
InitializeNativeTarget();
InitializeNativeTargetAsmPrinter();
InitializeNativeTargetAsmParser();
if (UseMCJIT) {
InitializeNativeTargetAsmPrinter();
InitializeNativeTargetAsmParser();
}
LLVMContext &Context = getGlobalContext();

cl::ParseCommandLineOptions(argc, argv,
Expand All @@ -1580,7 +1690,10 @@ int main(int argc, char **argv) {
BinopPrecedence['*'] = 40; // highest.

// Make the Helper, which holds all the code.
TheHelper = new MCJITHelper(Context);
if (UseMCJIT)
TheHelper = new MCJITHelper(Context);
else
TheHelper = new JITHelper(Context);

// Prime the first token.
if (!SuppressPrompts)
Expand Down
Loading

0 comments on commit aa5b9c0

Please sign in to comment.