mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-18 16:03:17 +00:00
Clients are responsible for initializing the targets, remove it from the disassembler API.
This will break users of the LLVMCreateDisasm API (not that I know of any). They have to call the LLVMInitializeAll* functions from llvm-c/Target.h themselves now. edis' C API in all its horribleness should be unaffected. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@144385 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
eea66f63d9
commit
178051fbae
@ -18,7 +18,6 @@
|
||||
#include "llvm/MC/MCRegisterInfo.h"
|
||||
#include "llvm/Support/MemoryObject.h"
|
||||
#include "llvm/Support/TargetRegistry.h"
|
||||
#include "llvm/Support/TargetSelect.h"
|
||||
|
||||
namespace llvm {
|
||||
class Target;
|
||||
@ -35,12 +34,6 @@ using namespace llvm;
|
||||
LLVMDisasmContextRef LLVMCreateDisasm(const char *TripleName, void *DisInfo,
|
||||
int TagType, LLVMOpInfoCallback GetOpInfo,
|
||||
LLVMSymbolLookupCallback SymbolLookUp) {
|
||||
// Initialize targets and assembly printers/parsers.
|
||||
llvm::InitializeAllTargetInfos();
|
||||
llvm::InitializeAllTargetMCs();
|
||||
llvm::InitializeAllAsmParsers();
|
||||
llvm::InitializeAllDisassemblers();
|
||||
|
||||
// Get the target.
|
||||
std::string Error;
|
||||
const Target *TheTarget = TargetRegistry::lookupTarget(TripleName, Error);
|
||||
|
@ -34,10 +34,8 @@
|
||||
#include "llvm/Support/MemoryObject.h"
|
||||
#include "llvm/Support/SourceMgr.h"
|
||||
#include "llvm/Support/TargetRegistry.h"
|
||||
#include "llvm/Support/TargetSelect.h"
|
||||
using namespace llvm;
|
||||
|
||||
bool EDDisassembler::sInitialized = false;
|
||||
EDDisassembler::DisassemblerMap_t EDDisassembler::sDisassemblers;
|
||||
|
||||
struct TripleMap {
|
||||
@ -98,20 +96,6 @@ static int getLLVMSyntaxVariant(Triple::ArchType arch,
|
||||
}
|
||||
}
|
||||
|
||||
void EDDisassembler::initialize() {
|
||||
if (sInitialized)
|
||||
return;
|
||||
|
||||
sInitialized = true;
|
||||
|
||||
InitializeAllTargetInfos();
|
||||
InitializeAllTargetMCs();
|
||||
InitializeAllAsmParsers();
|
||||
InitializeAllDisassemblers();
|
||||
}
|
||||
|
||||
#undef BRINGUP_TARGET
|
||||
|
||||
EDDisassembler *EDDisassembler::getDisassembler(Triple::ArchType arch,
|
||||
AssemblySyntax syntax) {
|
||||
CPUKey key;
|
||||
|
@ -94,8 +94,6 @@ struct EDDisassembler {
|
||||
|
||||
typedef std::map<CPUKey, EDDisassembler*> DisassemblerMap_t;
|
||||
|
||||
/// True if the disassembler registry has been initialized; false if not
|
||||
static bool sInitialized;
|
||||
/// A map from disassembler specifications to disassemblers. Populated
|
||||
/// lazily.
|
||||
static DisassemblerMap_t sDisassemblers;
|
||||
@ -116,9 +114,6 @@ struct EDDisassembler {
|
||||
static EDDisassembler *getDisassembler(llvm::StringRef str,
|
||||
AssemblySyntax syntax);
|
||||
|
||||
/// initialize - Initializes the disassembler registry and the LLVM backend
|
||||
static void initialize();
|
||||
|
||||
////////////////////////
|
||||
// Per-object members //
|
||||
////////////////////////
|
||||
|
@ -19,7 +19,4 @@
|
||||
type = Library
|
||||
name = MCDisassembler
|
||||
parent = MC
|
||||
; FIXME: This is really horrible, MCDisassembler should not in and of its own
|
||||
; accord depending on every target.
|
||||
required_libraries = all-targets MC MCParser Support
|
||||
|
||||
required_libraries = MC MCParser Support
|
||||
|
@ -17,14 +17,23 @@
|
||||
#include "../../lib/MC/MCDisassembler/EDInst.h"
|
||||
#include "../../lib/MC/MCDisassembler/EDOperand.h"
|
||||
#include "../../lib/MC/MCDisassembler/EDToken.h"
|
||||
#include "llvm/Support/TargetSelect.h"
|
||||
#include "llvm-c/EnhancedDisassembly.h"
|
||||
using namespace llvm;
|
||||
|
||||
int EDGetDisassembler(EDDisassemblerRef *disassembler,
|
||||
const char *triple,
|
||||
EDAssemblySyntax_t syntax) {
|
||||
EDDisassembler::initialize();
|
||||
|
||||
static bool initialized;
|
||||
if (!initialized) {
|
||||
// Initialize targets and assembly printers/parsers.
|
||||
llvm::InitializeAllTargetInfos();
|
||||
llvm::InitializeAllTargetMCs();
|
||||
llvm::InitializeAllAsmParsers();
|
||||
llvm::InitializeAllDisassemblers();
|
||||
initialized = true;
|
||||
}
|
||||
|
||||
EDDisassembler::AssemblySyntax Syntax;
|
||||
switch (syntax) {
|
||||
default: assert(0 && "Unknown assembly syntax!");
|
||||
|
@ -249,7 +249,6 @@ int Disassembler::disassembleEnhanced(const std::string &TS,
|
||||
break;
|
||||
}
|
||||
|
||||
EDDisassembler::initialize();
|
||||
OwningPtr<EDDisassembler>
|
||||
disassembler(EDDisassembler::getDisassembler(TS.c_str(), AS));
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user