LLVM
10.0.0svn
|
#include "ARMFeatures.h"
#include "ARMBaseInstrInfo.h"
#include "Utils/ARMBaseInfo.h"
#include "MCTargetDesc/ARMAddressingModes.h"
#include "MCTargetDesc/ARMBaseInfo.h"
#include "MCTargetDesc/ARMInstPrinter.h"
#include "MCTargetDesc/ARMMCExpr.h"
#include "MCTargetDesc/ARMMCTargetDesc.h"
#include "TargetInfo/ARMTargetInfo.h"
#include "llvm/ADT/APFloat.h"
#include "llvm/ADT/APInt.h"
#include "llvm/ADT/None.h"
#include "llvm/ADT/STLExtras.h"
#include "llvm/ADT/SmallSet.h"
#include "llvm/ADT/SmallVector.h"
#include "llvm/ADT/StringMap.h"
#include "llvm/ADT/StringRef.h"
#include "llvm/ADT/StringSwitch.h"
#include "llvm/ADT/Triple.h"
#include "llvm/ADT/Twine.h"
#include "llvm/MC/MCContext.h"
#include "llvm/MC/MCExpr.h"
#include "llvm/MC/MCInst.h"
#include "llvm/MC/MCInstrDesc.h"
#include "llvm/MC/MCInstrInfo.h"
#include "llvm/MC/MCObjectFileInfo.h"
#include "llvm/MC/MCParser/MCAsmLexer.h"
#include "llvm/MC/MCParser/MCAsmParser.h"
#include "llvm/MC/MCParser/MCAsmParserExtension.h"
#include "llvm/MC/MCParser/MCAsmParserUtils.h"
#include "llvm/MC/MCParser/MCParsedAsmOperand.h"
#include "llvm/MC/MCParser/MCTargetAsmParser.h"
#include "llvm/MC/MCRegisterInfo.h"
#include "llvm/MC/MCSection.h"
#include "llvm/MC/MCStreamer.h"
#include "llvm/MC/MCSubtargetInfo.h"
#include "llvm/MC/MCSymbol.h"
#include "llvm/MC/SubtargetFeature.h"
#include "llvm/Support/ARMBuildAttributes.h"
#include "llvm/Support/ARMEHABI.h"
#include "llvm/Support/Casting.h"
#include "llvm/Support/CommandLine.h"
#include "llvm/Support/Compiler.h"
#include "llvm/Support/ErrorHandling.h"
#include "llvm/Support/MathExtras.h"
#include "llvm/Support/SMLoc.h"
#include "llvm/Support/TargetParser.h"
#include "llvm/Support/TargetRegistry.h"
#include "llvm/Support/raw_ostream.h"
#include <algorithm>
#include <cassert>
#include <cstddef>
#include <cstdint>
#include <iterator>
#include <limits>
#include <memory>
#include <string>
#include <utility>
#include <vector>
#include "ARMGenAsmMatcher.inc"
Go to the source code of this file.
Namespaces | |
llvm | |
This class represents lattice values for constants. | |
Macros | |
#define | DEBUG_TYPE "asm-parser" |
#define | GET_OPERAND_DIAGNOSTIC_TYPES |
Auto-generated Match Functions | |
{ | |
#define | GET_ASSEMBLER_HEADER |
Enumerations | |
enum | ImplicitItModeTy |
enum | VectorLaneTy |
Functions | |
template<> | |
bool | llvm::IsCPSRDead< MCInst > (const MCInst *Instr) |
Variables | |
const MCInstrDesc | llvm::ARMInsts [] |
#define DEBUG_TYPE "asm-parser" |
Definition at line 69 of file ARMAsmParser.cpp.
#define GET_ASSEMBLER_HEADER |
Definition at line 543 of file ARMAsmParser.cpp.
#define GET_MATCHER_IMPLEMENTATION |
Definition at line 11507 of file ARMAsmParser.cpp.
#define GET_MNEMONIC_SPELL_CHECKER |
Definition at line 11508 of file ARMAsmParser.cpp.
#define GET_OPERAND_DIAGNOSTIC_TYPES |
Definition at line 601 of file ARMAsmParser.cpp.
#define GET_REGISTER_MATCHER |
Definition at line 11505 of file ARMAsmParser.cpp.
#define GET_SUBTARGET_FEATURE_NAME |
Definition at line 11506 of file ARMAsmParser.cpp.
|
strong |
Definition at line 79 of file ARMAsmParser.cpp.
enum VectorLaneTy |
Definition at line 96 of file ARMAsmParser.cpp.
|
static |
Referenced by doesIgnoreDataTypeSuffix().
|
static |
Referenced by llvm::IsCPSRDead< MCInst >().
|
static |
Definition at line 7150 of file ARMAsmParser.cpp.
References llvm::MCInst::getNumOperands(), llvm::MCInst::getOperand(), llvm::MCOperand::getReg(), and llvm::isARMLowRegister().
Referenced by getRealVLDOpcode().
Definition at line 6694 of file ARMAsmParser.cpp.
References applyMnemonicAliases(), llvm::SmallVectorTemplateCommon< T, typename >::begin(), llvm::MCRegisterClass::contains(), llvm::AsmToken::getIdentifier(), llvm::MCRegisterClass::getRegister(), llvm::MCAsmParser::getTok(), llvm::GPR, llvm::AsmToken::Identifier, Info, llvm::SmallVectorImpl< T >::insert(), llvm::AsmToken::is(), isThumb(), MRI, llvm::SmallVectorBase::size(), and llvm::StringRef::startswith().
|
static |
Definition at line 7283 of file ARMAsmParser.cpp.
References llvm::ARM::isVpred(), llvm::MCInstrDesc::NumOperands, llvm::MCOperandInfo::OperandType, and llvm::MCInstrDesc::OpInfo.
Referenced by isVectorPredicable().
Definition at line 4243 of file ARMAsmParser.cpp.
References contains(), llvm_unreachable, R2, R4, and R6.
Referenced by insertNoDuplicates().
Definition at line 8042 of file ARMAsmParser.cpp.
References llvm::MCInst::addOperand(), llvm::AArch64ISD::ADR, llvm::ARMCC::AL, llvm::ARM_AM::asr, assert(), llvm::MCInst::begin(), checkLowRegisterList(), llvm::MCConstantExpr::create(), llvm::MCSymbolRefExpr::create(), llvm::MCBinaryExpr::createAdd(), llvm::MCOperand::createExpr(), llvm::MCOperand::createImm(), llvm::MCOperand::createReg(), llvm::MCStreamer::EmitLabel(), llvm::ARMISD::FMSTAT, llvm::MCOperand::getExpr(), llvm::MCOperand::getImm(), llvm::MCInst::getNumOperands(), llvm::MCInst::getOpcode(), llvm::MCInst::getOperand(), getRealVSTOpcode(), llvm::MCOperand::getReg(), llvm::ARM_AM::getSOImmVal(), llvm::ARM_AM::getSORegOffset(), llvm::ARM_AM::getSORegOpc(), llvm::ARM_AM::getSORegShOp(), llvm::ARM_AM::getT2SOImmVal(), llvm::getToken(), llvm::MCInstrDesc::hasOptionalDef(), I, llvm::MCInst::insert(), llvm::isARMLowRegister(), llvm::MCOperand::isExpr(), llvm::MCOperand::isImm(), llvm::MCOperandInfo::isOptionalDef(), llvm::MCOperand::isReg(), isThumb(), llvm_unreachable, llvm::ARM_AM::lsl, llvm::ARM_AM::lsr, llvm::MCInstrDesc::NumOperands, llvm::MCInstrDesc::OpInfo, Reg, llvm::MCOperandInfo::RegClass, llvm::ARM_AM::ror, llvm::ARM_AM::rotr32(), llvm::ARM_AM::rrx, llvm::MCInst::setOpcode(), llvm::ARMII::ThumbArithFlagSetting, llvm::MCInstrDesc::TSFlags, and llvm::MCSymbolRefExpr::VK_None.
Definition at line 7933 of file ARMAsmParser.cpp.
References llvm_unreachable.
Referenced by getRealVLDOpcode().
Referenced by llvm::IsCPSRDead< MCInst >().
|
static |
Definition at line 4265 of file ARMAsmParser.cpp.
References llvm::ARM_PROC::A, llvm::AsmToken::Caret, llvm::StringSwitch< T, R >::Case(), llvm::AsmToken::Comma, llvm::MCRegisterClass::contains(), contains(), llvm::ARM_TSB::CSYNC, llvm::StringSwitch< T, R >::Default(), llvm::AsmToken::Dollar, llvm::dyn_cast(), llvm::numbers::e, E, llvm::SmallVectorImpl< T >::emplace_back(), llvm::StringRef::equals_lower(), llvm::Error, llvm::ARM_PROC::F, llvm::AsmToken::getEndLoc(), llvm::MCRegisterClass::getID(), llvm::AsmToken::getIntVal(), llvm::AsmToken::getLoc(), getNextRegister(), llvm::ARMInstPrinter::getRegisterName(), llvm::AsmToken::getString(), llvm::MCAsmParser::getTok(), llvm::MCConstantExpr::getValue(), llvm::AsmToken::Hash, llvm::ARM_PROC::I, I, llvm::AsmToken::Identifier, llvm::AsmToken::Integer, llvm::AsmToken::is(), llvm::ARM_MB::ISH, llvm::ARM_MB::ISHLD, llvm::ARM_MB::ISHST, llvm::AsmToken::isNot(), llvm::AsmToken::LBrac, llvm::AsmToken::LCurly, llvm::ARM_MB::LD, llvm::MCAsmParser::Lex(), llvm::StringRef::lower(), llvm::BitmaskEnumDetail::Mask(), llvm::MatchOperand_NoMatch, llvm::MatchOperand_ParseFail, llvm::MatchOperand_Success, llvm::AsmToken::Minus, MRI, llvm::ARM_MB::NSH, llvm::ARM_MB::NSHLD, llvm::ARM_MB::NSHST, llvm::ARM_MB::OSH, llvm::ARM_MB::OSHLD, llvm::ARM_MB::OSHST, llvm::SmallVectorTemplateBase< T, bool >::push_back(), llvm::AsmToken::RBrac, llvm::AsmToken::RCurly, Reg, Registers, llvm::ARM_MB::RESERVED_0, llvm::ARM_ISB::RESERVED_0, llvm::StringRef::size(), llvm::StringRef::slice(), llvm::ARM_MB::ST, llvm::StringRef::substr(), std::swap(), llvm::ARM_MB::SY, llvm::ARM_ISB::SY, and llvm::Warning.
Definition at line 7178 of file ARMAsmParser.cpp.
References llvm::Error, llvm::MCInst::getOpcode(), llvm::MCInst::getOperand(), llvm::MCOperand::getReg(), listContainsReg(), llvm::SPII::Load, and MRI.
Referenced by isVectorPredicable().
Definition at line 6682 of file ARMAsmParser.cpp.
|
static |
Definition at line 7291 of file ARMAsmParser.cpp.
References llvm::Error, findFirstVectorPredOperandIdx(), llvm::MCInst::getOpcode(), instIsBreakpoint(), and llvm::MCInstrDesc::isPredicable().
Definition at line 7167 of file ARMAsmParser.cpp.
References llvm::numbers::e, llvm::MCInst::getNumOperands(), llvm::MCInst::getOperand(), and llvm::MCOperand::getReg().
Referenced by instIsBreakpoint().
void LLVMInitializeARMAsmParser | ( | ) |
Force static initialization.
Definition at line 11498 of file ARMAsmParser.cpp.
References B, llvm::getTheARMBETarget(), llvm::getTheARMLETarget(), llvm::getTheThumbBETarget(), llvm::getTheThumbLETarget(), X, and Y.
MatchCoprocessorOperandName - Try to parse an coprocessor related instruction with a symbolic operand name.
We accept "crN" syntax for GAS compatibility. <operand-name> ::= <prefix><number> If CoprocOp is 'c', then: <prefix> ::= c | cr If CoprocOp is 'p', then : <prefix> ::= p <number> ::= integer in range [0, 15]
Definition at line 4105 of file ARMAsmParser.cpp.
References llvm::ARMCondCodeFromString(), llvm::StringRef::drop_front(), llvm::dyn_cast(), E, llvm::Error, llvm::AsmToken::getEndLoc(), llvm::AsmToken::getLoc(), llvm::AsmToken::getString(), llvm::MCAsmParser::getTok(), llvm::MCConstantExpr::getValue(), llvm::AsmToken::Identifier, llvm::AsmToken::is(), llvm::AsmToken::isNot(), llvm::isValidCoprocessorNumber(), llvm::AsmToken::LCurly, llvm::MCAsmParser::Lex(), llvm::StringRef::lower(), llvm::MatchOperand_NoMatch, llvm::MatchOperand_ParseFail, llvm::MatchOperand_Success, llvm::SmallVectorTemplateBase< T, bool >::push_back(), llvm::AsmToken::RCurly, Reg, and llvm::StringRef::size().