mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
0c795d6187
- Less boilerplate == good. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@77052 91177308-0d34-0410-b5e6-96231b3b80d8
64 lines
1.7 KiB
C++
64 lines
1.7 KiB
C++
//===-- X86AsmParser.cpp - Parse X86 assembly to MCInst instructions ------===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "X86.h"
|
|
#include "llvm/ADT/SmallVector.h"
|
|
#include "llvm/MC/MCAsmParser.h"
|
|
#include "llvm/Target/TargetRegistry.h"
|
|
#include "llvm/Target/TargetAsmParser.h"
|
|
using namespace llvm;
|
|
|
|
namespace {
|
|
struct X86Operand {
|
|
};
|
|
|
|
class X86ATTAsmParser : public TargetAsmParser {
|
|
bool ParseOperand(X86Operand &Op);
|
|
|
|
bool MatchInstruction(const char *Name,
|
|
llvm::SmallVector<X86Operand, 3> &Operands,
|
|
MCInst &Inst);
|
|
|
|
public:
|
|
explicit X86ATTAsmParser(const Target &);
|
|
|
|
virtual bool ParseInstruction(MCAsmParser &AP, const char *Name,
|
|
MCInst &Inst);
|
|
};
|
|
}
|
|
|
|
X86ATTAsmParser::X86ATTAsmParser(const Target &T)
|
|
: TargetAsmParser(T)
|
|
{
|
|
}
|
|
|
|
bool X86ATTAsmParser::ParseOperand(X86Operand &Op) {
|
|
return true;
|
|
}
|
|
|
|
bool
|
|
X86ATTAsmParser::MatchInstruction(const char *Name,
|
|
llvm::SmallVector<X86Operand, 3> &Operands,
|
|
MCInst &Inst) {
|
|
return false;
|
|
}
|
|
|
|
bool X86ATTAsmParser::ParseInstruction(MCAsmParser &AP, const char *Name,
|
|
MCInst &Inst) {
|
|
llvm::SmallVector<X86Operand, 3> Operands;
|
|
|
|
return MatchInstruction(Name, Operands, Inst);
|
|
}
|
|
|
|
// Force static initialization.
|
|
extern "C" void LLVMInitializeX86AsmParser() {
|
|
RegisterAsmParser<X86ATTAsmParser> X(TheX86_32Target);
|
|
RegisterAsmParser<X86ATTAsmParser> Y(TheX86_64Target);
|
|
}
|