diff options
Diffstat (limited to 'llvm/test/MC/AArch64/SVE/fsubr-diagnostics.s')
| -rw-r--r-- | llvm/test/MC/AArch64/SVE/fsubr-diagnostics.s | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/llvm/test/MC/AArch64/SVE/fsubr-diagnostics.s b/llvm/test/MC/AArch64/SVE/fsubr-diagnostics.s index c8ea652ebfd..0e751f42e3f 100644 --- a/llvm/test/MC/AArch64/SVE/fsubr-diagnostics.s +++ b/llvm/test/MC/AArch64/SVE/fsubr-diagnostics.s @@ -1,5 +1,33 @@ // RUN: not llvm-mc -triple=aarch64 -show-encoding -mattr=+sve 2>&1 < %s| FileCheck %s +// ------------------------------------------------------------------------- // +// Invalid immediates (must be 0.5 or 1.0) + +fsubr z0.h, p0/m, z0.h, #0.0 +// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: Invalid floating point constant, expected 0.5 or 1.0. +// CHECK-NEXT: fsubr z0.h, p0/m, z0.h, #0.0 +// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}: + +fsubr z0.h, p0/m, z0.h, #0.4999999999999999999999999 +// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: Invalid floating point constant, expected 0.5 or 1.0. +// CHECK-NEXT: fsubr z0.h, p0/m, z0.h, #0.4999999999999999999999999 +// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}: + +fsubr z0.h, p0/m, z0.h, #0.5000000000000000000000001 +// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: Invalid floating point constant, expected 0.5 or 1.0. +// CHECK-NEXT: fsubr z0.h, p0/m, z0.h, #0.5000000000000000000000001 +// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}: + +fsubr z0.h, p0/m, z0.h, #1.0000000000000000000000001 +// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: Invalid floating point constant, expected 0.5 or 1.0. +// CHECK-NEXT: fsubr z0.h, p0/m, z0.h, #1.0000000000000000000000001 +// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}: + +fsubr z0.h, p0/m, z0.h, #0.9999999999999999999999999 +// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: Invalid floating point constant, expected 0.5 or 1.0. +// CHECK-NEXT: fsubr z0.h, p0/m, z0.h, #0.9999999999999999999999999 +// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}: + // ------------------------------------------------------------------------- // // Tied operands must match |

