Index: llvm/trunk/lib/Target/AArch64/AsmParser/AArch64AsmParser.cpp =================================================================== --- llvm/trunk/lib/Target/AArch64/AsmParser/AArch64AsmParser.cpp +++ llvm/trunk/lib/Target/AArch64/AsmParser/AArch64AsmParser.cpp @@ -3178,7 +3178,7 @@ if (Operands.size() < 2 || !static_cast(*Operands[1]).isReg()) - return true; + return Error(Loc, "Only valid when first operand is register"); bool IsXReg = AArch64MCRegisterClasses[AArch64::GPR64allRegClassID].contains( Index: llvm/trunk/test/MC/AArch64/ldr-pseudo-diagnostics.s =================================================================== --- llvm/trunk/test/MC/AArch64/ldr-pseudo-diagnostics.s +++ llvm/trunk/test/MC/AArch64/ldr-pseudo-diagnostics.s @@ -12,3 +12,21 @@ // 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: ^