Skip to content

Commit

Permalink
Eliminate the dependency of ExecutionEngine on the JIT/Interpreter li…
Browse files Browse the repository at this point in the history
…braries.

Now you can build a tool with just the JIT or just the interpreter.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@26946 91177308-0d34-0410-b5e6-96231b3b80d8
  • Loading branch information
lattner committed Mar 22, 2006
1 parent 765c93c commit 2fe4bb0
Show file tree
Hide file tree
Showing 5 changed files with 35 additions and 21 deletions.
26 changes: 8 additions & 18 deletions lib/ExecutionEngine/ExecutionEngine.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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"
Expand All @@ -26,13 +24,17 @@
#include "llvm/Support/Debug.h"
#include "llvm/System/DynamicLibrary.h"
#include "llvm/Target/TargetData.h"
#include <iostream>
using namespace llvm;

namespace {
Statistic<> NumInitBytes("lli", "Number of bytes of global vars initialized");
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?");
Expand Down Expand Up @@ -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;
Expand Down
15 changes: 14 additions & 1 deletion lib/ExecutionEngine/Interpreter/Interpreter.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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;
Expand Down
6 changes: 5 additions & 1 deletion lib/ExecutionEngine/Interpreter/Interpreter.h
Original file line number Diff line number Diff line change
Expand Up @@ -102,11 +102,15 @@ class Interpreter : public ExecutionEngine, public InstVisitor<Interpreter> {
///
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.
///
Expand Down
5 changes: 4 additions & 1 deletion lib/ExecutionEngine/JIT/JIT.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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());
Expand Down
4 changes: 4 additions & 0 deletions lib/ExecutionEngine/JIT/JIT.h
Original file line number Diff line number Diff line change
Expand Up @@ -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; }
Expand Down

0 comments on commit 2fe4bb0

Please sign in to comment.