2 // RUN
: llvm-mc
-triple
=aarch64
-show-encoding
-mattr
=+sme2p2
,+sme-f64f64
< %s \
3 // RUN
: | FileCheck
%s
--check-prefixes
=CHECK-ENCODING
,CHECK-INST
4 // RUN
: not llvm-mc
-triple
=aarch64
-show-encoding
< %s
2>&1 \
5 // RUN
: | FileCheck
%s
--check-prefix
=CHECK-ERROR
6 // RUN
: llvm-mc
-triple
=aarch64
-filetype
=obj
-mattr
=+sme2p2
,+sme-f64f64
< %s \
7 // RUN
: | llvm-objdump
-d
--mattr
=+sme2p2
,+sme-f64f64
- | FileCheck
%s
--check-prefix
=CHECK-INST
8 // RUN
: llvm-mc
-triple
=aarch64
-filetype
=obj
-mattr
=+sme2p2
,+sme-f64f64
< %s \
9 // RUN
: | llvm-objdump
-d
--mattr
=-sme2p2
- | FileCheck
%s
--check-prefix
=CHECK-UNKNOWN
10 // Disassemble encoding
and check the re-encoding
(-show-encoding
) matches.
11 // RUN
: llvm-mc
-triple
=aarch64
-show-encoding
-mattr
=+sme2p2
,+sme-f64f64
< %s \
12 // RUN
: | sed
'/.text/d' | sed
's/.*encoding: //g' \
13 // RUN
: | llvm-mc
-triple
=aarch64
-mattr
=+sme2p2
,+sme-f64f64
-disassemble
-show-encoding \
14 // RUN
: | FileCheck
%s
--check-prefixes
=CHECK-ENCODING
,CHECK-INST
21 fmop4a za0.d
, z0.d
, z16.d
// 10000000-11000000-00000000-00001000
22 // CHECK-INST
: fmop4a za0.d
, z0.d
, z16.d
23 // CHECK-ENCODING
: [0x08,0x00,0xc0,0x80]
24 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
25 // CHECK-UNKNOWN
: 80c00008
<unknown
>
27 fmop4a za5.d
, z10.d
, z20.d
// 10000000-11000100-00000001-01001101
28 // CHECK-INST
: fmop4a za5.d
, z10.d
, z20.d
29 // CHECK-ENCODING
: [0x4d,0x01,0xc4,0x80]
30 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
31 // CHECK-UNKNOWN
: 80c4014d
<unknown
>
33 fmop4a za7.d
, z14.d
, z30.d
// 10000000-11001110-00000001-11001111
34 // CHECK-INST
: fmop4a za7.d
, z14.d
, z30.d
35 // CHECK-ENCODING
: [0xcf,0x01,0xce,0x80]
36 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
37 // CHECK-UNKNOWN
: 80ce01cf
<unknown
>
39 // Single
and multiple vectors
41 fmop4a za0.d
, z0.d
, {z16.d-z17.d
} // 10000000-11010000-00000000-00001000
42 // CHECK-INST
: fmop4a za0.d
, z0.d
, { z16.d
, z17.d
}
43 // CHECK-ENCODING
: [0x08,0x00,0xd0,0x80]
44 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
45 // CHECK-UNKNOWN
: 80d00008
<unknown
>
47 fmop4a za5.d
, z10.d
, {z20.d-z21.d
} // 10000000-11010100-00000001-01001101
48 // CHECK-INST
: fmop4a za5.d
, z10.d
, { z20.d
, z21.d
}
49 // CHECK-ENCODING
: [0x4d,0x01,0xd4,0x80]
50 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
51 // CHECK-UNKNOWN
: 80d4014d
<unknown
>
53 fmop4a za7.d
, z14.d
, {z30.d-z31.d
} // 10000000-11011110-00000001-11001111
54 // CHECK-INST
: fmop4a za7.d
, z14.d
, { z30.d
, z31.d
}
55 // CHECK-ENCODING
: [0xcf,0x01,0xde,0x80]
56 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
57 // CHECK-UNKNOWN
: 80de01cf
<unknown
>
59 // Multiple
and single vectors
61 fmop4a za0.d
, {z0.d-z1.d
}, z16.d
// 10000000-11000000-00000010-00001000
62 // CHECK-INST
: fmop4a za0.d
, { z0.d
, z1.d
}, z16.d
63 // CHECK-ENCODING
: [0x08,0x02,0xc0,0x80]
64 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
65 // CHECK-UNKNOWN
: 80c00208
<unknown
>
67 fmop4a za5.d
, {z10.d-z11.d
}, z20.d
// 10000000-11000100-00000011-01001101
68 // CHECK-INST
: fmop4a za5.d
, { z10.d
, z11.d
}, z20.d
69 // CHECK-ENCODING
: [0x4d,0x03,0xc4,0x80]
70 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
71 // CHECK-UNKNOWN
: 80c4034d
<unknown
>
73 fmop4a za7.d
, {z14.d-z15.d
}, z30.d
// 10000000-11001110-00000011-11001111
74 // CHECK-INST
: fmop4a za7.d
, { z14.d
, z15.d
}, z30.d
75 // CHECK-ENCODING
: [0xcf,0x03,0xce,0x80]
76 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
77 // CHECK-UNKNOWN
: 80ce03cf
<unknown
>
81 fmop4a za0.d
, {z0.d-z1.d
}, {z16.d-z17.d
} // 10000000-11010000-00000010-00001000
82 // CHECK-INST
: fmop4a za0.d
, { z0.d
, z1.d
}, { z16.d
, z17.d
}
83 // CHECK-ENCODING
: [0x08,0x02,0xd0,0x80]
84 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
85 // CHECK-UNKNOWN
: 80d00208
<unknown
>
87 fmop4a za5.d
, {z10.d-z11.d
}, {z20.d-z21.d
} // 10000000-11010100-00000011-01001101
88 // CHECK-INST
: fmop4a za5.d
, { z10.d
, z11.d
}, { z20.d
, z21.d
}
89 // CHECK-ENCODING
: [0x4d,0x03,0xd4,0x80]
90 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
91 // CHECK-UNKNOWN
: 80d4034d
<unknown
>
93 fmop4a za7.d
, {z14.d-z15.d
}, {z30.d-z31.d
} // 10000000-11011110-00000011-11001111
94 // CHECK-INST
: fmop4a za7.d
, { z14.d
, z15.d
}, { z30.d
, z31.d
}
95 // CHECK-ENCODING
: [0xcf,0x03,0xde,0x80]
96 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
97 // CHECK-UNKNOWN
: 80de03cf
<unknown
>
104 fmop4s za0.d
, z0.d
, z16.d
// 10000000-11000000-00000000-00011000
105 // CHECK-INST
: fmop4s za0.d
, z0.d
, z16.d
106 // CHECK-ENCODING
: [0x18,0x00,0xc0,0x80]
107 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
108 // CHECK-UNKNOWN
: 80c00018
<unknown
>
110 fmop4s za5.d
, z10.d
, z20.d
// 10000000-11000100-00000001-01011101
111 // CHECK-INST
: fmop4s za5.d
, z10.d
, z20.d
112 // CHECK-ENCODING
: [0x5d,0x01,0xc4,0x80]
113 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
114 // CHECK-UNKNOWN
: 80c4015d
<unknown
>
116 fmop4s za7.d
, z14.d
, z30.d
// 10000000-11001110-00000001-11011111
117 // CHECK-INST
: fmop4s za7.d
, z14.d
, z30.d
118 // CHECK-ENCODING
: [0xdf,0x01,0xce,0x80]
119 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
120 // CHECK-UNKNOWN
: 80ce01df
<unknown
>
122 // Single
and multiple vectors
124 fmop4s za0.d
, z0.d
, {z16.d-z17.d
} // 10000000-11010000-00000000-00011000
125 // CHECK-INST
: fmop4s za0.d
, z0.d
, { z16.d
, z17.d
}
126 // CHECK-ENCODING
: [0x18,0x00,0xd0,0x80]
127 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
128 // CHECK-UNKNOWN
: 80d00018
<unknown
>
130 fmop4s za5.d
, z10.d
, {z20.d-z21.d
} // 10000000-11010100-00000001-01011101
131 // CHECK-INST
: fmop4s za5.d
, z10.d
, { z20.d
, z21.d
}
132 // CHECK-ENCODING
: [0x5d,0x01,0xd4,0x80]
133 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
134 // CHECK-UNKNOWN
: 80d4015d
<unknown
>
136 fmop4s za7.d
, z14.d
, {z30.d-z31.d
} // 10000000-11011110-00000001-11011111
137 // CHECK-INST
: fmop4s za7.d
, z14.d
, { z30.d
, z31.d
}
138 // CHECK-ENCODING
: [0xdf,0x01,0xde,0x80]
139 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
140 // CHECK-UNKNOWN
: 80de01df
<unknown
>
142 // Multiple
and single vectors
144 fmop4s za0.d
, {z0.d-z1.d
}, z16.d
// 10000000-11000000-00000010-00011000
145 // CHECK-INST
: fmop4s za0.d
, { z0.d
, z1.d
}, z16.d
146 // CHECK-ENCODING
: [0x18,0x02,0xc0,0x80]
147 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
148 // CHECK-UNKNOWN
: 80c00218
<unknown
>
150 fmop4s za5.d
, {z10.d-z11.d
}, z20.d
// 10000000-11000100-00000011-01011101
151 // CHECK-INST
: fmop4s za5.d
, { z10.d
, z11.d
}, z20.d
152 // CHECK-ENCODING
: [0x5d,0x03,0xc4,0x80]
153 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
154 // CHECK-UNKNOWN
: 80c4035d
<unknown
>
156 fmop4s za7.d
, {z14.d-z15.d
}, z30.d
// 10000000-11001110-00000011-11011111
157 // CHECK-INST
: fmop4s za7.d
, { z14.d
, z15.d
}, z30.d
158 // CHECK-ENCODING
: [0xdf,0x03,0xce,0x80]
159 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
160 // CHECK-UNKNOWN
: 80ce03df
<unknown
>
164 fmop4s za0.d
, {z0.d-z1.d
}, {z16.d-z17.d
} // 10000000-11010000-00000010-00011000
165 // CHECK-INST
: fmop4s za0.d
, { z0.d
, z1.d
}, { z16.d
, z17.d
}
166 // CHECK-ENCODING
: [0x18,0x02,0xd0,0x80]
167 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
168 // CHECK-UNKNOWN
: 80d00218
<unknown
>
170 fmop4s za5.d
, {z10.d-z11.d
}, {z20.d-z21.d
} // 10000000-11010100-00000011-01011101
171 // CHECK-INST
: fmop4s za5.d
, { z10.d
, z11.d
}, { z20.d
, z21.d
}
172 // CHECK-ENCODING
: [0x5d,0x03,0xd4,0x80]
173 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
174 // CHECK-UNKNOWN
: 80d4035d
<unknown
>
176 fmop4s za7.d
, {z14.d-z15.d
}, {z30.d-z31.d
} // 10000000-11011110-00000011-11011111
177 // CHECK-INST
: fmop4s za7.d
, { z14.d
, z15.d
}, { z30.d
, z31.d
}
178 // CHECK-ENCODING
: [0xdf,0x03,0xde,0x80]
179 // CHECK-ERROR
: instruction requires
: sme2p2 sme-f64f64
180 // CHECK-UNKNOWN
: 80de03df
<unknown
>