forked from OSchip/llvm-project
Eliminate the dependency of ExecutionEngine on the JIT/Interpreter libraries.
Now you can build a tool with just the JIT or just the interpreter. llvm-svn: 26946
This commit is contained in:
parent
d3a3365904
commit
2d52c1b8b9
|
@ -13,8 +13,6 @@
|
|||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#define DEBUG_TYPE "jit"
|
||||
#include "Interpreter/Interpreter.h"
|
||||
#include "JIT/JIT.h"
|
||||
#include "llvm/Constants.h"
|
||||
#include "llvm/DerivedTypes.h"
|
||||
#include "llvm/Module.h"
|
||||
|
@ -26,6 +24,7 @@
|
|||
#include "llvm/Support/Debug.h"
|
||||
#include "llvm/System/DynamicLibrary.h"
|
||||
#include "llvm/Target/TargetData.h"
|
||||
#include <iostream>
|
||||
using namespace llvm;
|
||||
|
||||
namespace {
|
||||
|
@ -33,6 +32,9 @@ namespace {
|
|||
Statistic<> NumGlobals ("lli", "Number of global vars initialized");
|
||||
}
|
||||
|
||||
ExecutionEngine::EECtorFn ExecutionEngine::JITCtor = 0;
|
||||
ExecutionEngine::EECtorFn ExecutionEngine::InterpCtor = 0;
|
||||
|
||||
ExecutionEngine::ExecutionEngine(ModuleProvider *P) :
|
||||
CurMod(*P->getModule()), MP(P) {
|
||||
assert(P && "ModuleProvider is null?");
|
||||
|
@ -163,24 +165,12 @@ ExecutionEngine *ExecutionEngine::create(ModuleProvider *MP,
|
|||
ExecutionEngine *EE = 0;
|
||||
|
||||
// Unless the interpreter was explicitly selected, try making a JIT.
|
||||
if (!ForceInterpreter)
|
||||
EE = JIT::create(MP, IL);
|
||||
if (!ForceInterpreter && JITCtor)
|
||||
EE = JITCtor(MP, IL);
|
||||
|
||||
// If we can't make a JIT, make an interpreter instead.
|
||||
if (EE == 0) {
|
||||
try {
|
||||
Module *M = MP->materializeModule();
|
||||
try {
|
||||
EE = Interpreter::create(M, IL);
|
||||
} catch (...) {
|
||||
std::cerr << "Error creating the interpreter!\n";
|
||||
}
|
||||
} catch (std::string& errmsg) {
|
||||
std::cerr << "Error reading the bytecode file: " << errmsg << "\n";
|
||||
} catch (...) {
|
||||
std::cerr << "Error reading the bytecode file!\n";
|
||||
}
|
||||
}
|
||||
if (EE == 0 && InterpCtor)
|
||||
EE = InterpCtor(MP, IL);
|
||||
|
||||
if (EE == 0)
|
||||
delete IL;
|
||||
|
|
|
@ -17,11 +17,24 @@
|
|||
#include "llvm/CodeGen/IntrinsicLowering.h"
|
||||
#include "llvm/DerivedTypes.h"
|
||||
#include "llvm/Module.h"
|
||||
#include "llvm/ModuleProvider.h"
|
||||
using namespace llvm;
|
||||
|
||||
static struct RegisterInterp {
|
||||
RegisterInterp() { Interpreter::Register(); }
|
||||
} InterpRegistrator;
|
||||
|
||||
/// create - Create a new interpreter object. This can never fail.
|
||||
///
|
||||
ExecutionEngine *Interpreter::create(Module *M, IntrinsicLowering *IL) {
|
||||
ExecutionEngine *Interpreter::create(ModuleProvider *MP,
|
||||
IntrinsicLowering *IL) {
|
||||
Module *M;
|
||||
try {
|
||||
M = MP->materializeModule();
|
||||
} catch (...) {
|
||||
return 0; // error materializing the module.
|
||||
}
|
||||
|
||||
bool isLittleEndian = false;
|
||||
switch (M->getEndianness()) {
|
||||
case Module::LittleEndian: isLittleEndian = true; break;
|
||||
|
|
|
@ -102,11 +102,15 @@ public:
|
|||
///
|
||||
void runAtExitHandlers();
|
||||
|
||||
static void Register() {
|
||||
InterpCtor = create;
|
||||
}
|
||||
|
||||
/// create - Create an interpreter ExecutionEngine. This can never fail. The
|
||||
/// specified IntrinsicLowering implementation will be deleted when the
|
||||
/// Interpreter execution engine is destroyed.
|
||||
///
|
||||
static ExecutionEngine *create(Module *M, IntrinsicLowering *IL);
|
||||
static ExecutionEngine *create(ModuleProvider *M, IntrinsicLowering *IL);
|
||||
|
||||
/// run - Start execution with the specified function and arguments.
|
||||
///
|
||||
|
|
|
@ -26,9 +26,12 @@
|
|||
#include "llvm/Target/TargetMachine.h"
|
||||
#include "llvm/Target/TargetJITInfo.h"
|
||||
#include <iostream>
|
||||
|
||||
using namespace llvm;
|
||||
|
||||
static struct RegisterJIT {
|
||||
RegisterJIT() { JIT::Register(); }
|
||||
} JITRegistrator;
|
||||
|
||||
JIT::JIT(ModuleProvider *MP, TargetMachine &tm, TargetJITInfo &tji)
|
||||
: ExecutionEngine(MP), TM(tm), TJI(tji), state(MP) {
|
||||
setTargetData(TM.getTargetData());
|
||||
|
|
|
@ -60,6 +60,10 @@ class JIT : public ExecutionEngine {
|
|||
public:
|
||||
~JIT();
|
||||
|
||||
static void Register() {
|
||||
JITCtor = create;
|
||||
}
|
||||
|
||||
/// getJITInfo - Return the target JIT information structure.
|
||||
///
|
||||
TargetJITInfo &getJITInfo() const { return TJI; }
|
||||
|
|
Loading…
Reference in New Issue