mirror of
https://github.com/RPCSX/llvm.git
synced 2025-02-15 10:39:47 +00:00
ExecutionEngine: fix JIT/MCJIT selectTarget() duplication
This prepares for making JITCtor/MCJITCtor take a TargetMachine* directly from clients like EngineBuilder. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@131025 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
bf4e10f2f6
commit
71cbac6a83
@ -210,6 +210,14 @@ public:
|
||||
CodeModel::Model CMM =
|
||||
CodeModel::Default);
|
||||
|
||||
/// selectTarget - Pick a target either via -march or by guessing the native
|
||||
/// arch. Add any CPU features specified via -mcpu or -mattr.
|
||||
static TargetMachine *selectTarget(Module *M,
|
||||
StringRef MArch,
|
||||
StringRef MCPU,
|
||||
const SmallVectorImpl<std::string>& MAttrs,
|
||||
std::string *Err);
|
||||
|
||||
/// addModule - Add a Module to the list of modules that we can JIT from.
|
||||
/// Note that this takes ownership of the Module: when the ExecutionEngine is
|
||||
/// destroyed, it destroys the Module as well.
|
||||
|
@ -1,6 +1,7 @@
|
||||
add_llvm_library(LLVMExecutionEngine
|
||||
ExecutionEngine.cpp
|
||||
ExecutionEngineBindings.cpp
|
||||
TargetSelect.cpp
|
||||
)
|
||||
|
||||
add_subdirectory(Interpreter)
|
||||
|
@ -9,5 +9,4 @@ add_llvm_library(LLVMJIT
|
||||
JITEmitter.cpp
|
||||
JITMemoryManager.cpp
|
||||
OProfileJITEventListener.cpp
|
||||
TargetSelect.cpp
|
||||
)
|
||||
|
@ -228,14 +228,21 @@ ExecutionEngine *JIT::createJIT(Module *M,
|
||||
StringRef MCPU,
|
||||
const SmallVectorImpl<std::string>& MAttrs) {
|
||||
// Try to register the program as a source of symbols to resolve against.
|
||||
//
|
||||
// FIXME: Don't do this here.
|
||||
sys::DynamicLibrary::LoadLibraryPermanently(0, NULL);
|
||||
|
||||
// Pick a target either via -march or by guessing the native arch.
|
||||
TargetMachine *TM = JIT::selectTarget(M, MArch, MCPU, MAttrs, ErrorStr);
|
||||
//
|
||||
// FIXME: This should be lifted out of here, it isn't something which should
|
||||
// be part of the JIT policy, rather the burden for this selection should be
|
||||
// pushed to clients.
|
||||
TargetMachine *TM =
|
||||
ExecutionEngine::selectTarget(M, MArch, MCPU, MAttrs, ErrorStr);
|
||||
if (!TM || (ErrorStr && ErrorStr->length() > 0)) return 0;
|
||||
TM->setCodeModel(CMM);
|
||||
|
||||
// If the target supports JIT code generation, create a the JIT.
|
||||
// If the target supports JIT code generation, create the JIT.
|
||||
if (TargetJITInfo *TJ = TM->getJITInfo()) {
|
||||
return new JIT(M, *TM, *TJ, JMM, OptLevel, GVsWithCode);
|
||||
} else {
|
||||
|
@ -181,14 +181,6 @@ public:
|
||||
///
|
||||
JITCodeEmitter *getCodeEmitter() const { return JCE; }
|
||||
|
||||
/// selectTarget - Pick a target either via -march or by guessing the native
|
||||
/// arch. Add any CPU features specified via -mcpu or -mattr.
|
||||
static TargetMachine *selectTarget(Module *M,
|
||||
StringRef MArch,
|
||||
StringRef MCPU,
|
||||
const SmallVectorImpl<std::string>& MAttrs,
|
||||
std::string *Err);
|
||||
|
||||
static ExecutionEngine *createJIT(Module *M,
|
||||
std::string *ErrorStr,
|
||||
JITMemoryManager *JMM,
|
||||
|
@ -1,5 +1,4 @@
|
||||
add_llvm_library(LLVMMCJIT
|
||||
MCJIT.cpp
|
||||
TargetSelect.cpp
|
||||
Intercept.cpp
|
||||
)
|
||||
|
@ -52,7 +52,8 @@ ExecutionEngine *MCJIT::createJIT(Module *M,
|
||||
// FIXME: This should be lifted out of here, it isn't something which should
|
||||
// be part of the JIT policy, rather the burden for this selection should be
|
||||
// pushed to clients.
|
||||
TargetMachine *TM = MCJIT::selectTarget(M, MArch, MCPU, MAttrs, ErrorStr);
|
||||
TargetMachine *TM =
|
||||
ExecutionEngine::selectTarget(M, MArch, MCPU, MAttrs, ErrorStr);
|
||||
if (!TM || (ErrorStr && ErrorStr->length() > 0)) return 0;
|
||||
TM->setCodeModel(CMM);
|
||||
|
||||
|
@ -76,13 +76,6 @@ public:
|
||||
MCJITCtor = createJIT;
|
||||
}
|
||||
|
||||
// FIXME: This routine is scheduled for termination. Do not use it.
|
||||
static TargetMachine *selectTarget(Module *M,
|
||||
StringRef MArch,
|
||||
StringRef MCPU,
|
||||
const SmallVectorImpl<std::string>& MAttrs,
|
||||
std::string *Err);
|
||||
|
||||
static ExecutionEngine *createJIT(Module *M,
|
||||
std::string *ErrorStr,
|
||||
JITMemoryManager *JMM,
|
||||
|
Loading…
x
Reference in New Issue
Block a user