264 lines
10 KiB
ArmAsm
264 lines
10 KiB
ArmAsm
// RUN: not llvm-mc -triple=aarch64 -show-encoding -mattr=+sme 2>&1 < %s| FileCheck %s
|
|
|
|
// ------------------------------------------------------------------------- //
|
|
// Invalid predicate (expected: p0-p7)
|
|
|
|
mova z0.b, p8/m, za0h.b[w12, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid restricted predicate register, expected p0..p7 (without element suffix)
|
|
// CHECK-NEXT: mova z0.b, p8/m, za0h.b[w12, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
// ------------------------------------------------------------------------- //
|
|
// Invalid tile
|
|
|
|
// tile-to-vector
|
|
|
|
mova z0.b, p0/m, za1h.b[w12, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: unexpected token in argument list
|
|
// CHECK-NEXT: mova z0.b, p0/m, za1h.b[w12, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.h, p0/m, za2h.h[w12, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: unexpected token in argument list
|
|
// CHECK-NEXT: mova z0.h, p0/m, za2h.h[w12, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.s, p0/m, za4h.s[w12, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: unexpected token in argument list
|
|
// CHECK-NEXT: mova z0.s, p0/m, za4h.s[w12, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.d, p0/m, za8h.d[w12, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: unexpected token in argument list
|
|
// CHECK-NEXT: mova z0.d, p0/m, za8h.d[w12, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.q, p0/m, za16h.q[w12, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: unexpected token in argument list
|
|
// CHECK-NEXT: mova z0.q, p0/m, za16h.q[w12, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
// vector-to-tile
|
|
|
|
mova za1h.b[w12, 0], p0/m, z0.b
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: unexpected token in argument list
|
|
// CHECK-NEXT: mova za1h.b[w12, 0], p0/m, z0.b
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za2h.h[w12, 0], p0/m, z0.h
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: unexpected token in argument list
|
|
// CHECK-NEXT: mova za2h.h[w12, 0], p0/m, z0.h
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za4h.s[w12, 0], p0/m, z0.s
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: unexpected token in argument list
|
|
// CHECK-NEXT: mova za4h.s[w12, 0], p0/m, z0.s
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za8h.d[w12, 0], p0/m, z0.d
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: unexpected token in argument list
|
|
// CHECK-NEXT: mova za8h.d[w12, 0], p0/m, z0.d
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za16h.q[w12, 0], p0/m, z0.q
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: unexpected token in argument list
|
|
// CHECK-NEXT: mova za16h.q[w12, 0], p0/m, z0.q
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
// ------------------------------------------------------------------------- //
|
|
// Invalid matrix operand
|
|
|
|
// tile-to-vector
|
|
|
|
mova z0.b, p0/m, za0h.h[w12, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid matrix operand, expected za0h.b or za0v.b
|
|
// CHECK-NEXT: mova z0.b, p0/m, za0h.h[w12, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.h, p0/m, za[w12, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid matrix operand, expected za[0-1]h.h or za[0-1]v.h
|
|
// CHECK-NEXT: mova z0.h, p0/m, za[w12, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.s, p0/m, za2.s[w12, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid matrix operand, expected za[0-3]h.s or za[0-3]v.s
|
|
// CHECK-NEXT: mova z0.s, p0/m, za2.s[w12, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.d, p0/m, za2v.s[w12, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid matrix operand, expected za[0-7]h.d or za[0-7]v.d
|
|
// CHECK-NEXT: mova z0.d, p0/m, za2v.s[w12, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.q, p0/m, za0h.b[w12, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid matrix operand, expected za[0-15]h.q or za[0-15]v.q
|
|
// CHECK-NEXT: mova z0.q, p0/m, za0h.b[w12, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
// vector-to-tile, only one test here since the intended instruction variant is
|
|
// ambiguous when failing to match on the first operand.
|
|
|
|
mova za[w12, 0], p0/m, z0.b
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid matrix operand, expected za[0-15]h.q or za[0-15]v.q
|
|
// CHECK-NEXT: mova za[w12, 0], p0/m, z0.b
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
// ------------------------------------------------------------------------- //
|
|
// Invalid vector select register (expected: w12-w15)
|
|
|
|
mova z0.h, p0/m, za0h.h[w11, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: operand must be a register in range [w12, w15]
|
|
// CHECK-NEXT: mova z0.h, p0/m, za0h.h[w11, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.s, p0/m, za0h.s[w16, 0]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: operand must be a register in range [w12, w15]
|
|
// CHECK-NEXT: mova z0.s, p0/m, za0h.s[w16, 0]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za0h.d[w11, 0], p0/m, z0.d
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: operand must be a register in range [w12, w15]
|
|
// CHECK-NEXT: mova za0h.d[w11, 0], p0/m, z0.d
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za0h.q[w16, 0], p0/m, z0.q
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: operand must be a register in range [w12, w15]
|
|
// CHECK-NEXT: mova za0h.q[w16, 0], p0/m, z0.q
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
// ------------------------------------------------------------------------- //
|
|
// Invalid vector select offset
|
|
//
|
|
// expected: .b => 0-15, .h => 0-7, .s => 0-3, .d => 0-1, .q => NONE
|
|
|
|
// tile-to-vector
|
|
|
|
mova z0.b, p0/m, za0h.b[w12, 16]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 15].
|
|
// CHECK-NEXT: mova z0.b, p0/m, za0h.b[w12, 16]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.h, p0/m, za0h.h[w12, 8]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 7].
|
|
// CHECK-NEXT: mova z0.h, p0/m, za0h.h[w12, 8]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.s, p0/m, za0h.s[w12, 4]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 3].
|
|
// CHECK-NEXT: mova z0.s, p0/m, za0h.s[w12, 4]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.d, p0/m, za0h.d[w12, 2]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 1].
|
|
// CHECK-NEXT: mova z0.d, p0/m, za0h.d[w12, 2]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova z0.q, p0/m, za0h.q[w12, 1]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be 0.
|
|
// CHECK-NEXT: mova z0.q, p0/m, za0h.q[w12, 1]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mov z0.b, p0/m, za0h.b[w12, 16]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 15].
|
|
// CHECK-NEXT: mov z0.b, p0/m, za0h.b[w12, 16]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mov z0.h, p0/m, za0h.h[w12, 8]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 7].
|
|
// CHECK-NEXT: mov z0.h, p0/m, za0h.h[w12, 8]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mov z0.s, p0/m, za0h.s[w12, 4]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 3].
|
|
// CHECK-NEXT: mov z0.s, p0/m, za0h.s[w12, 4]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mov z0.d, p0/m, za0h.d[w12, 2]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 1].
|
|
// CHECK-NEXT: mov z0.d, p0/m, za0h.d[w12, 2]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mov z0.q, p0/m, za0h.q[w12, 1]
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be 0.
|
|
// CHECK-NEXT: mov z0.q, p0/m, za0h.q[w12, 1]
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
// vector-to-tile
|
|
|
|
mova za0h.b[w12, 16], p0/m, z0.b
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 15].
|
|
// CHECK-NEXT: mova za0h.b[w12, 16], p0/m, z0.b
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za0h.h[w12, 8], p0/m, z0.h
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 7].
|
|
// CHECK-NEXT: mova za0h.h[w12, 8], p0/m, z0.h
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za0h.s[w12, 4], p0/m, z0.s
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 3].
|
|
// CHECK-NEXT: mova za0h.s[w12, 4], p0/m, z0.s
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za0h.d[w12, 2], p0/m, z0.d
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 1].
|
|
// CHECK-NEXT: mova za0h.d[w12, 2], p0/m, z0.d
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za0h.q[w12, 1], p0/m, z0.q
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be 0.
|
|
// CHECK-NEXT: mova za0h.q[w12, 1], p0/m, z0.q
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mov za0h.b[w12, 16], p0/m, z0.b
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 15].
|
|
// CHECK-NEXT: mov za0h.b[w12, 16], p0/m, z0.b
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mov za0h.h[w12, 8], p0/m, z0.h
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 7].
|
|
// CHECK-NEXT: mov za0h.h[w12, 8], p0/m, z0.h
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mov za0h.s[w12, 4], p0/m, z0.s
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 3].
|
|
// CHECK-NEXT: mov za0h.s[w12, 4], p0/m, z0.s
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mov za0h.d[w12, 2], p0/m, z0.d
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be an integer in range [0, 1].
|
|
// CHECK-NEXT: mov za0h.d[w12, 2], p0/m, z0.d
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mov za0h.q[w12, 1], p0/m, z0.q
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: immediate must be 0.
|
|
// CHECK-NEXT: mov za0h.q[w12, 1], p0/m, z0.q
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
// ------------------------------------------------------------------------- //
|
|
// Invalid ZPR element width
|
|
|
|
mova za0h.b[w12, 0], p0/m, z0.h
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid element width
|
|
// CHECK-NEXT: mova za0h.b[w12, 0], p0/m, z0.h
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za0h.h[w12, 0], p0/m, z0.s
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid element width
|
|
// CHECK-NEXT: mova za0h.h[w12, 0], p0/m, z0.s
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za0h.s[w12, 0], p0/m, z0.d
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid element width
|
|
// CHECK-NEXT: mova za0h.s[w12, 0], p0/m, z0.d
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za0h.d[w12, 0], p0/m, z0.q
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid element width
|
|
// CHECK-NEXT: mova za0h.d[w12, 0], p0/m, z0.q
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|
|
|
|
mova za0h.q[w12, 0], p0/m, z0.b
|
|
// CHECK: [[@LINE-1]]:{{[0-9]+}}: error: invalid element width
|
|
// CHECK-NEXT: mova za0h.q[w12, 0], p0/m, z0.b
|
|
// CHECK-NOT: [[@LINE-1]]:{{[0-9]+}}:
|