1 // RUN
: not llvm-mc
-triple
=aarch64
-show-encoding
-mattr
=+sme2p1
,+sme-f16f16
2>&1 < %s | FileCheck
%s
3 // --------------------------------------------------------------------------//
6 fmls za.h
[w11
, 2, vgx2
], {z12.h-z14.h
}, z8.h
[3]
7 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: invalid operand for instruction
8 // CHECK-NEXT
: fmls za.h
[w11
, 2, vgx2
], {z12.h-z14.h
}, z8.h
[3]
9 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
11 fmls za.h
[w11
, 2, vgx4
], {z12.h-z17.h
}, z7.h
12 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: invalid number of vectors
13 // CHECK-NEXT
: fmls za.h
[w11
, 2, vgx4
], {z12.h-z17.h
}, z7.h
14 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
16 fmls za.h
[w10
, 3, vgx2
], {z10.h-z11.h
}, {z21.h-z22.h
}
17 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: Invalid vector list
, expected list with
2 consecutive SVE vectors
, where the first vector is
a multiple of
2 and with matching element types
18 // CHECK-NEXT
: fmls za.h
[w10
, 3, vgx2
], {z10.h-z11.h
}, {z21.h-z22.h
}
19 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
21 fmls za.h
[w11
, 7, vgx4
], {z12.h-z15.h
}, {z9.h-z12.h
}
22 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: Invalid vector list
, expected list with
4 consecutive SVE vectors
, where the first vector is
a multiple of
4 and with matching element types
23 // CHECK-NEXT
: fmls za.h
[w11
, 7, vgx4
], {z12.h-z15.h
}, {z9.h-z12.h
}
24 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
26 // --------------------------------------------------------------------------//
27 // Invalid indexed-vector
or single-vector register
29 fmls za.h
[w8
, 0], {z0.h-z1.h
}, z16.h
[0]
30 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: Invalid restricted vector register
, expected z0.h.
.z15.h
31 // CHECK-NEXT
: fmls za.h
[w8
, 0], {z0.h-z1.h
}, z16.h
[0]
32 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
34 fmls za.h
[w8
, 1], {z0.h-z3.h
}, z16.h
35 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: Invalid restricted vector register
, expected z0.h.
.z15.h
36 // CHECK-NEXT
: fmls za.h
[w8
, 1], {z0.h-z3.h
}, z16.h
37 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
39 // --------------------------------------------------------------------------//
40 // Invalid vector select register
42 fmls za.h
[w7
, 7, vgx4
], {z12.h-z15.h
}, {z8.h-z11.h
}
43 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: operand must
be a register in range
[w8
, w11
]
44 // CHECK-NEXT
: fmls za.h
[w7
, 7, vgx4
], {z12.h-z15.h
}, {z8.h-z11.h
}
45 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
47 fmls za.h
[w12
, 7, vgx2
], {z12.h-z13.h
}, {z8.h-z9.h
}
48 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: operand must
be a register in range
[w8
, w11
]
49 // CHECK-NEXT
: fmls za.h
[w12
, 7, vgx2
], {z12.h-z13.h
}, {z8.h-z9.h
}
50 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
52 // --------------------------------------------------------------------------//
53 // Invalid vector select offset
55 fmls za.h
[w8
, -1, vgx2
], {z12.h-z13.h
}, {z8.h-z9.h
}
56 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: immediate must
be an integer in range
[0, 7].
57 // CHECK-NEXT
: fmls za.h
[w8
, -1, vgx2
], {z12.h-z13.h
}, {z8.h-z9.h
}
58 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
60 fmls za.h
[w8
, 8, vgx2
], {z12.h-z13.h
}, {z8.h-z9.h
}
61 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: immediate must
be an integer in range
[0, 7].
62 // CHECK-NEXT
: fmls za.h
[w8
, 8, vgx2
], {z12.h-z13.h
}, {z8.h-z9.h
}
63 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
65 // --------------------------------------------------------------------------//
66 // Invalid Register Suffix
68 fmls za.d
[w8
, 7, vgx2
], {z12.h-z13.h
}, {z8.h-z9.h
}
69 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: invalid matrix operand
, expected suffix
.s
70 // CHECK-NEXT
: fmls za.d
[w8
, 7, vgx2
], {z12.h-z13.h
}, {z8.h-z9.h
}
71 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
73 // --------------------------------------------------------------------------//
74 // Invalid vector lane index
76 fmls za.h
[w11
, 6, vgx2
], {z12.h-z13.h
}, z8.h
[8]
77 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: vector lane must
be an integer in range
[0, 7].
78 // CHECK-NEXT
: fmls za.h
[w11
, 6, vgx2
], {z12.h-z13.h
}, z8.h
[8]
79 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
81 fmls za.h
[w11
, 6, vgx2
], {z12.h-z13.h
}, z8.h
[-1]
82 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: vector lane must
be an integer in range
[0, 7].
83 // CHECK-NEXT
: fmls za.h
[w11
, 6, vgx2
], {z12.h-z13.h
}, z8.h
[-1]
84 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
86 fmls za.h
[w11
, 7, vgx4
], {z12.h-z15.h
}, z8.h
[-1]
87 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: vector lane must
be an integer in range
[0, 7].
88 // CHECK-NEXT
: fmls za.h
[w11
, 7, vgx4
], {z12.h-z15.h
}, z8.h
[-1]
89 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}:
91 fmls za.h
[w11
, 7, vgx4
], {z12.h-z15.h
}, z8.h
[8]
92 // CHECK
: [[@LINE-
1]]:{{[0-9]+}}: error
: vector lane must
be an integer in range
[0, 7].
93 // CHECK-NEXT
: fmls za.h
[w11
, 7, vgx4
], {z12.h-z15.h
}, z8.h
[8]
94 // CHECK-
NOT: [[@LINE-
1]]:{{[0-9]+}}: