llvm/test/MC/AArch64/ldr-pseudo-diagnostics.s
Oliver Stannard f88d08f7c5 [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



git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@253193 91177308-0d34-0410-b5e6-96231b3b80d8
2015-11-16 10:25:19 +00:00

33 lines
854 B
ArmAsm

//RUN: not llvm-mc -triple=aarch64-linux-gnu - < %s 2>&1 | FileCheck --check-prefix=CHECK-ERROR %s
// simple test
.section a, "ax", @progbits
f1:
ldr w0, =0x100000001
// CHECK-ERROR: error: Immediate too large for register
// CHECK-ERROR: ldr w0, =0x100000001
// CHECK-ERROR: ^
f2:
ldr w0, =-0x80000001
// 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: ^