mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-10 02:36:06 +00:00
70975eef57
Switch Interpreter and JIT's "run" methods to take a Function and a vector of GenericValues. Move (almost all of) the stuff that constructs a canonical call to main() into lli (new methods "callAsMain", "makeStringVector"). Nuke getCurrentExecutablePath(), enableTracing(), getCurrentFunction(), isStopped(), and many dead decls from interpreter. Add linux strdup() support to interpreter. Make interpreter's atexit handler runner and JIT's runAtExitHandlers() look more alike, in preparation for refactoring. atexit() is spelled "atexit", not "at_exit". git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@8366 91177308-0d34-0410-b5e6-96231b3b80d8
89 lines
2.6 KiB
C++
89 lines
2.6 KiB
C++
//===- ExecutionEngine.h - Abstract Execution Engine Interface --*- C++ -*-===//
|
|
//
|
|
// This file defines the abstract interface that implements execution support
|
|
// for LLVM.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef EXECUTION_ENGINE_H
|
|
#define EXECUTION_ENGINE_H
|
|
|
|
#include <vector>
|
|
#include <string>
|
|
#include <map>
|
|
#include <cassert>
|
|
class Constant;
|
|
class Type;
|
|
class GlobalValue;
|
|
class Function;
|
|
class Module;
|
|
class TargetData;
|
|
union GenericValue;
|
|
|
|
class ExecutionEngine {
|
|
Module &CurMod;
|
|
const TargetData *TD;
|
|
|
|
protected:
|
|
// GlobalAddress - A mapping between LLVM global values and their actualized
|
|
// version...
|
|
std::map<const GlobalValue*, void *> GlobalAddress;
|
|
|
|
void setTargetData(const TargetData &td) {
|
|
TD = &td;
|
|
}
|
|
public:
|
|
ExecutionEngine(Module *M) : CurMod(*M) {
|
|
assert(M && "Module is null?");
|
|
}
|
|
virtual ~ExecutionEngine();
|
|
|
|
Module &getModule() const { return CurMod; }
|
|
const TargetData &getTargetData() const { return *TD; }
|
|
|
|
/// run - Start execution with the specified function, arguments, and
|
|
/// environment.
|
|
///
|
|
virtual GenericValue run(Function *F,
|
|
const std::vector<GenericValue> &ArgValues) = 0;
|
|
|
|
static ExecutionEngine *create (Module *M, bool ForceInterpreter,
|
|
bool TraceMode);
|
|
|
|
void addGlobalMapping(const Function *F, void *Addr) {
|
|
void *&CurVal = GlobalAddress[(const GlobalValue*)F];
|
|
assert(CurVal == 0 && "GlobalMapping already established!");
|
|
CurVal = Addr;
|
|
}
|
|
|
|
// getPointerToGlobalIfAvailable - This returns the address of the specified
|
|
// global value if it is available, otherwise it returns null.
|
|
//
|
|
void *getPointerToGlobalIfAvailable(const GlobalValue *GV) {
|
|
std::map<const GlobalValue*, void*>::iterator I = GlobalAddress.find(GV);
|
|
return I != GlobalAddress.end() ? I->second : 0;
|
|
}
|
|
|
|
// getPointerToGlobal - This returns the address of the specified global
|
|
// value. This may involve code generation if it's a function.
|
|
//
|
|
void *getPointerToGlobal(const GlobalValue *GV);
|
|
|
|
// getPointerToFunction - The different EE's represent function bodies in
|
|
// different ways. They should each implement this to say what a function
|
|
// pointer should look like.
|
|
//
|
|
virtual void *getPointerToFunction(Function *F) = 0;
|
|
|
|
protected:
|
|
void emitGlobals();
|
|
|
|
public: // FIXME: protected: // API shared among subclasses
|
|
GenericValue getConstantValue(const Constant *C);
|
|
void StoreValueToMemory(GenericValue Val, GenericValue *Ptr, const Type *Ty);
|
|
GenericValue LoadValueFromMemory(GenericValue *Ptr, const Type *Ty);
|
|
void InitializeMemory(const Constant *Init, void *Addr);
|
|
};
|
|
|
|
#endif
|