[AArch64] ldr= pseudo-instruction silently ignored if register invalid

The AArch64 assembler was silently ignoring instructions like this:
  ldr foo, =bar

AArch64AsmParser::parseOperand was returning true as the parse failed, but was
not calling AArch64AsmParser::Error to report this to the user, so the
instruction was ignored without printing an error message.

Differential Revision: http://reviews.llvm.org/D14651

llvm-svn: 253193
This commit is contained in:
Oliver Stannard 2015-11-16 10:25:19 +00:00
parent d4d2357f26
commit db9081bf89
2 changed files with 19 additions and 1 deletions

View File

@ -3178,7 +3178,7 @@ bool AArch64AsmParser::parseOperand(OperandVector &Operands, bool isCondCode,
if (Operands.size() < 2 ||
!static_cast<AArch64Operand &>(*Operands[1]).isReg())
return true;
return Error(Loc, "Only valid when first operand is register");
bool IsXReg =
AArch64MCRegisterClasses[AArch64::GPR64allRegClassID].contains(

View File

@ -12,3 +12,21 @@ f2:
// CHECK-ERROR: error: Immediate too large for register
// CHECK-ERROR: ldr w0, =-0x80000001
// CHECK-ERROR: ^
f3:
ldr foo, =1
// CHECK-ERROR: error: Only valid when first operand is register
// CHECK-ERROR: ldr foo, =1
// CHECK-ERROR: ^
f4:
add r0, r0, =1
// CHECK-ERROR: error: unexpected token in operand
// CHECK-ERROR: add r0, r0, =1
// CHECK-ERROR: ^
f5:
ldr x0, =())
// CHECK-ERROR: error: unknown token in expression
// CHECK-ERROR: ldr x0, =())
// CHECK-ERROR: ^