ARM IAS: fix after r198172

The DPR and SPR register lists are also register lists.  Furthermore, the
registers need not be checked individually since the register type can be
checked via the list kind.  Use that to simplify the logic and fix the incorrect
assertion.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@198174 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Saleem Abdulrasool 2013-12-29 18:53:16 +00:00
parent dd2836776f
commit ee6d3cd701

View File

@ -5112,13 +5112,13 @@ bool ARMAsmParser::ParseInstruction(ParseInstructionInfo &Info, StringRef Name,
SMLoc NameLoc, SMLoc NameLoc,
SmallVectorImpl<MCParsedAsmOperand*> &Operands) { SmallVectorImpl<MCParsedAsmOperand*> &Operands) {
// FIXME: Can this be done via tablegen in some fashion? // FIXME: Can this be done via tablegen in some fashion?
bool HasPrecisionRestrictions; bool RequireVFPRegisterList;
bool AcceptDoublePrecisionOnly; bool AcceptDoublePrecisionOnly;
bool AcceptSinglePrecisionOnly; bool AcceptSinglePrecisionOnly;
HasPrecisionRestrictions = Name.startswith("fldm") || Name.startswith("fstm"); RequireVFPRegisterList = Name.startswith("fldm") || Name.startswith("fstm");
AcceptDoublePrecisionOnly = AcceptDoublePrecisionOnly =
HasPrecisionRestrictions && (Name.back() == 'd' || Name.back() == 'x'); RequireVFPRegisterList && (Name.back() == 'd' || Name.back() == 'x');
AcceptSinglePrecisionOnly = HasPrecisionRestrictions && Name.back() == 's'; AcceptSinglePrecisionOnly = RequireVFPRegisterList && Name.back() == 's';
// Apply mnemonic aliases before doing anything else, as the destination // Apply mnemonic aliases before doing anything else, as the destination
// mnemonic may include suffices and we want to handle them normally. // mnemonic may include suffices and we want to handle them normally.
@ -5288,24 +5288,14 @@ bool ARMAsmParser::ParseInstruction(ParseInstructionInfo &Info, StringRef Name,
Parser.Lex(); // Consume the EndOfStatement Parser.Lex(); // Consume the EndOfStatement
if (HasPrecisionRestrictions) { if (RequireVFPRegisterList) {
ARMOperand *Op = static_cast<ARMOperand*>(Operands.back()); ARMOperand *Op = static_cast<ARMOperand*>(Operands.back());
assert(Op->isRegList()); if (AcceptSinglePrecisionOnly && !Op->isSPRRegList())
const SmallVectorImpl<unsigned> &RegList = Op->getRegList(); return Error(Op->getStartLoc(),
for (SmallVectorImpl<unsigned>::const_iterator RLI = RegList.begin(), "VFP/Neon single precision register expected");
RLE = RegList.end(); if (AcceptDoublePrecisionOnly && !Op->isDPRRegList())
RLI != RLE; ++RLI) { return Error(Op->getStartLoc(),
if (AcceptSinglePrecisionOnly && "VFP/Neon double precision register expected");
!ARMMCRegisterClasses[ARM::SPRRegClassID].contains(*RLI))
return Error(Op->getStartLoc(),
"VFP/Neon single precision register expected");
else if (AcceptDoublePrecisionOnly &&
!ARMMCRegisterClasses[ARM::DPRRegClassID].contains(*RLI))
return Error(Op->getStartLoc(),
"VFP/Neon double precision register expected");
else
llvm_unreachable("must have single or double precision restrictions");
}
} }
// Some instructions, mostly Thumb, have forms for the same mnemonic that // Some instructions, mostly Thumb, have forms for the same mnemonic that