mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-26 22:34:39 +00:00
bbccd10c81
This adds diagnostic strings for the ARM floating-point register classes, which will be used when these classes are expected by the assembler, but the provided operand is not valid. One of these, DPR, requires C++ code to select the correct error message, as that class contains different registers depending on the FPU. The rest can all have their diagnostic strings stored in the tablegen decription of them. Differential revision: https://reviews.llvm.org/D36693 llvm-svn: 315304
47 lines
2.2 KiB
ArmAsm
47 lines
2.2 KiB
ArmAsm
@ RUN: not llvm-mc -triple=armv7-linux-gnueabi %s 2>&1 | FileCheck %s
|
|
.text
|
|
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
@ CHECK-NEXT: vmov.i32 d2, #0xffffffab
|
|
@ CHECK: note: operand must be a register in range [d0, d31]
|
|
@ CHECK: note: invalid operand for instruction
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
@ CHECK-NEXT: vmov.i32 q2, #0xffffffab
|
|
@ CHECK: note: operand must be a register in range [q0, q15]
|
|
@ CHECK: note: invalid operand for instruction
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
@ CHECK-NEXT: vmov.i16 q2, #0xffab
|
|
@ CHECK: note: operand must be a register in range [q0, q15]
|
|
@ CHECK: note: invalid operand for instruction
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
@ CHECK-NEXT: vmov.i16 q2, #0xffab
|
|
@ CHECK: note: operand must be a register in range [q0, q15]
|
|
@ CHECK: note: invalid operand for instruction
|
|
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
@ CHECK-NEXT: vmvn.i32 d2, #0xffffffab
|
|
@ CHECK: note: operand must be a register in range [d0, d31]
|
|
@ CHECK: note: invalid operand for instruction
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
@ CHECK-NEXT: vmvn.i32 q2, #0xffffffab
|
|
@ CHECK: note: operand must be a register in range [q0, q15]
|
|
@ CHECK: note: invalid operand for instruction
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
@ CHECK-NEXT: vmvn.i16 q2, #0xffab
|
|
@ CHECK: note: operand must be a register in range [q0, q15]
|
|
@ CHECK: note: invalid operand for instruction
|
|
@ CHECK: error: invalid instruction, any one of the following would fix this:
|
|
@ CHECK-NEXT: vmvn.i16 q2, #0xffab
|
|
@ CHECK: note: operand must be a register in range [q0, q15]
|
|
@ CHECK: note: invalid operand for instruction
|
|
|
|
vmov.i32 d2, #0xffffffab
|
|
vmov.i32 q2, #0xffffffab
|
|
vmov.i16 q2, #0xffab
|
|
vmov.i16 q2, #0xffab
|
|
|
|
vmvn.i32 d2, #0xffffffab
|
|
vmvn.i32 q2, #0xffffffab
|
|
vmvn.i16 q2, #0xffab
|
|
vmvn.i16 q2, #0xffab
|