mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-09 11:25:55 +00:00
ExecutionEngine: fix JIT/MCJIT selectTarget() duplication (v2)
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@131316 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -569,6 +569,14 @@ public:
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// 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);
|
||||||
|
|
||||||
ExecutionEngine *create();
|
ExecutionEngine *create();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@@ -1,6 +1,7 @@
|
|||||||
add_llvm_library(LLVMExecutionEngine
|
add_llvm_library(LLVMExecutionEngine
|
||||||
ExecutionEngine.cpp
|
ExecutionEngine.cpp
|
||||||
ExecutionEngineBindings.cpp
|
ExecutionEngineBindings.cpp
|
||||||
|
TargetSelect.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
add_subdirectory(Interpreter)
|
add_subdirectory(Interpreter)
|
||||||
|
@@ -9,5 +9,4 @@ add_llvm_library(LLVMJIT
|
|||||||
JITEmitter.cpp
|
JITEmitter.cpp
|
||||||
JITMemoryManager.cpp
|
JITMemoryManager.cpp
|
||||||
OProfileJITEventListener.cpp
|
OProfileJITEventListener.cpp
|
||||||
TargetSelect.cpp
|
|
||||||
)
|
)
|
||||||
|
@@ -228,14 +228,21 @@ ExecutionEngine *JIT::createJIT(Module *M,
|
|||||||
StringRef MCPU,
|
StringRef MCPU,
|
||||||
const SmallVectorImpl<std::string>& MAttrs) {
|
const SmallVectorImpl<std::string>& MAttrs) {
|
||||||
// Try to register the program as a source of symbols to resolve against.
|
// Try to register the program as a source of symbols to resolve against.
|
||||||
|
//
|
||||||
|
// FIXME: Don't do this here.
|
||||||
sys::DynamicLibrary::LoadLibraryPermanently(0, NULL);
|
sys::DynamicLibrary::LoadLibraryPermanently(0, NULL);
|
||||||
|
|
||||||
// Pick a target either via -march or by guessing the native arch.
|
// 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 =
|
||||||
|
EngineBuilder::selectTarget(M, MArch, MCPU, MAttrs, ErrorStr);
|
||||||
if (!TM || (ErrorStr && ErrorStr->length() > 0)) return 0;
|
if (!TM || (ErrorStr && ErrorStr->length() > 0)) return 0;
|
||||||
TM->setCodeModel(CMM);
|
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()) {
|
if (TargetJITInfo *TJ = TM->getJITInfo()) {
|
||||||
return new JIT(M, *TM, *TJ, JMM, OptLevel, GVsWithCode);
|
return new JIT(M, *TM, *TJ, JMM, OptLevel, GVsWithCode);
|
||||||
} else {
|
} else {
|
||||||
|
@@ -181,14 +181,6 @@ public:
|
|||||||
///
|
///
|
||||||
JITCodeEmitter *getCodeEmitter() const { return JCE; }
|
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,
|
static ExecutionEngine *createJIT(Module *M,
|
||||||
std::string *ErrorStr,
|
std::string *ErrorStr,
|
||||||
JITMemoryManager *JMM,
|
JITMemoryManager *JMM,
|
||||||
|
@@ -1,5 +1,4 @@
|
|||||||
add_llvm_library(LLVMMCJIT
|
add_llvm_library(LLVMMCJIT
|
||||||
MCJIT.cpp
|
MCJIT.cpp
|
||||||
TargetSelect.cpp
|
|
||||||
Intercept.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
|
// 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
|
// be part of the JIT policy, rather the burden for this selection should be
|
||||||
// pushed to clients.
|
// pushed to clients.
|
||||||
TargetMachine *TM = MCJIT::selectTarget(M, MArch, MCPU, MAttrs, ErrorStr);
|
TargetMachine *TM =
|
||||||
|
EngineBuilder::selectTarget(M, MArch, MCPU, MAttrs, ErrorStr);
|
||||||
if (!TM || (ErrorStr && ErrorStr->length() > 0)) return 0;
|
if (!TM || (ErrorStr && ErrorStr->length() > 0)) return 0;
|
||||||
TM->setCodeModel(CMM);
|
TM->setCodeModel(CMM);
|
||||||
|
|
||||||
|
@@ -76,13 +76,6 @@ public:
|
|||||||
MCJITCtor = createJIT;
|
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,
|
static ExecutionEngine *createJIT(Module *M,
|
||||||
std::string *ErrorStr,
|
std::string *ErrorStr,
|
||||||
JITMemoryManager *JMM,
|
JITMemoryManager *JMM,
|
||||||
|
@@ -1,91 +0,0 @@
|
|||||||
//===-- TargetSelect.cpp - Target Chooser Code ----------------------------===//
|
|
||||||
//
|
|
||||||
// The LLVM Compiler Infrastructure
|
|
||||||
//
|
|
||||||
// This file is distributed under the University of Illinois Open Source
|
|
||||||
// License. See LICENSE.TXT for details.
|
|
||||||
//
|
|
||||||
//===----------------------------------------------------------------------===//
|
|
||||||
//
|
|
||||||
// This just asks the TargetRegistry for the appropriate JIT to use, and allows
|
|
||||||
// the user to specify a specific one on the commandline with -march=x. Clients
|
|
||||||
// should initialize targets prior to calling createJIT.
|
|
||||||
//
|
|
||||||
//===----------------------------------------------------------------------===//
|
|
||||||
|
|
||||||
#include "MCJIT.h"
|
|
||||||
#include "llvm/Module.h"
|
|
||||||
#include "llvm/ADT/Triple.h"
|
|
||||||
#include "llvm/Support/CommandLine.h"
|
|
||||||
#include "llvm/Support/raw_ostream.h"
|
|
||||||
#include "llvm/Support/Host.h"
|
|
||||||
#include "llvm/Target/SubtargetFeature.h"
|
|
||||||
#include "llvm/Target/TargetMachine.h"
|
|
||||||
#include "llvm/Target/TargetRegistry.h"
|
|
||||||
using namespace llvm;
|
|
||||||
|
|
||||||
/// selectTarget - Pick a target either via -march or by guessing the native
|
|
||||||
/// arch. Add any CPU features specified via -mcpu or -mattr.
|
|
||||||
TargetMachine *MCJIT::selectTarget(Module *Mod,
|
|
||||||
StringRef MArch,
|
|
||||||
StringRef MCPU,
|
|
||||||
const SmallVectorImpl<std::string>& MAttrs,
|
|
||||||
std::string *ErrorStr) {
|
|
||||||
Triple TheTriple(Mod->getTargetTriple());
|
|
||||||
if (TheTriple.getTriple().empty())
|
|
||||||
TheTriple.setTriple(sys::getHostTriple());
|
|
||||||
|
|
||||||
// Adjust the triple to match what the user requested.
|
|
||||||
const Target *TheTarget = 0;
|
|
||||||
if (!MArch.empty()) {
|
|
||||||
for (TargetRegistry::iterator it = TargetRegistry::begin(),
|
|
||||||
ie = TargetRegistry::end(); it != ie; ++it) {
|
|
||||||
if (MArch == it->getName()) {
|
|
||||||
TheTarget = &*it;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!TheTarget) {
|
|
||||||
*ErrorStr = "No available targets are compatible with this -march, "
|
|
||||||
"see -version for the available targets.\n";
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Adjust the triple to match (if known), otherwise stick with the
|
|
||||||
// module/host triple.
|
|
||||||
Triple::ArchType Type = Triple::getArchTypeForLLVMName(MArch);
|
|
||||||
if (Type != Triple::UnknownArch)
|
|
||||||
TheTriple.setArch(Type);
|
|
||||||
} else {
|
|
||||||
std::string Error;
|
|
||||||
TheTarget = TargetRegistry::lookupTarget(TheTriple.getTriple(), Error);
|
|
||||||
if (TheTarget == 0) {
|
|
||||||
if (ErrorStr)
|
|
||||||
*ErrorStr = Error;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!TheTarget->hasJIT()) {
|
|
||||||
errs() << "WARNING: This target JIT is not designed for the host you are"
|
|
||||||
<< " running. If bad things happen, please choose a different "
|
|
||||||
<< "-march switch.\n";
|
|
||||||
}
|
|
||||||
|
|
||||||
// Package up features to be passed to target/subtarget
|
|
||||||
std::string FeaturesStr;
|
|
||||||
if (!MCPU.empty() || !MAttrs.empty()) {
|
|
||||||
SubtargetFeatures Features;
|
|
||||||
Features.setCPU(MCPU);
|
|
||||||
for (unsigned i = 0; i != MAttrs.size(); ++i)
|
|
||||||
Features.AddFeature(MAttrs[i]);
|
|
||||||
FeaturesStr = Features.getString();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Allocate a target...
|
|
||||||
TargetMachine *Target =
|
|
||||||
TheTarget->createTargetMachine(TheTriple.getTriple(), FeaturesStr);
|
|
||||||
assert(Target && "Could not allocate target machine!");
|
|
||||||
return Target;
|
|
||||||
}
|
|
@@ -13,7 +13,7 @@
|
|||||||
//
|
//
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
#include "JIT.h"
|
#include "llvm/ExecutionEngine/ExecutionEngine.h"
|
||||||
#include "llvm/Module.h"
|
#include "llvm/Module.h"
|
||||||
#include "llvm/ADT/Triple.h"
|
#include "llvm/ADT/Triple.h"
|
||||||
#include "llvm/Support/CommandLine.h"
|
#include "llvm/Support/CommandLine.h"
|
||||||
@@ -26,11 +26,11 @@ using namespace llvm;
|
|||||||
|
|
||||||
/// selectTarget - Pick a target either via -march or by guessing the native
|
/// selectTarget - Pick a target either via -march or by guessing the native
|
||||||
/// arch. Add any CPU features specified via -mcpu or -mattr.
|
/// arch. Add any CPU features specified via -mcpu or -mattr.
|
||||||
TargetMachine *JIT::selectTarget(Module *Mod,
|
TargetMachine *EngineBuilder::selectTarget(Module *Mod,
|
||||||
StringRef MArch,
|
StringRef MArch,
|
||||||
StringRef MCPU,
|
StringRef MCPU,
|
||||||
const SmallVectorImpl<std::string>& MAttrs,
|
const SmallVectorImpl<std::string>& MAttrs,
|
||||||
std::string *ErrorStr) {
|
std::string *ErrorStr) {
|
||||||
Triple TheTriple(Mod->getTargetTriple());
|
Triple TheTriple(Mod->getTargetTriple());
|
||||||
if (TheTriple.getTriple().empty())
|
if (TheTriple.getTriple().empty())
|
||||||
TheTriple.setTriple(sys::getHostTriple());
|
TheTriple.setTriple(sys::getHostTriple());
|
Reference in New Issue
Block a user