1 /* aarch64-tbl.h -- AArch64 opcode description table and instruction
2 operand description table.
3 Copyright (C) 2012-2019 Free Software Foundation, Inc.
5 This file is part of the GNU opcodes library.
7 This library is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3, or (at your option)
12 It is distributed in the hope that it will be useful, but WITHOUT
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
14 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
15 License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this file; see the file COPYING. If not, write to the
19 Free Software Foundation, 51 Franklin Street - Fifth Floor, Boston,
20 MA 02110-1301, USA. */
22 #include "aarch64-opc.h"
25 #error VERIFIER must be defined.
30 #define OPND(x) AARCH64_OPND_##x
32 #define OP1(a) {OPND(a)}
33 #define OP2(a,b) {OPND(a), OPND(b)}
34 #define OP3(a,b,c) {OPND(a), OPND(b), OPND(c)}
35 #define OP4(a,b,c,d) {OPND(a), OPND(b), OPND(c), OPND(d)}
36 #define OP5(a,b,c,d,e) {OPND(a), OPND(b), OPND(c), OPND(d), OPND(e)}
38 #define QLF(x) AARCH64_OPND_QLF_##x
39 #define QLF1(a) {QLF(a)}
40 #define QLF2(a,b) {QLF(a), QLF(b)}
41 #define QLF3(a,b,c) {QLF(a), QLF(b), QLF(c)}
42 #define QLF4(a,b,c,d) {QLF(a), QLF(b), QLF(c), QLF(d)}
43 #define QLF5(a,b,c,d,e) {QLF(a), QLF(b), QLF(c), QLF(d), QLF(e)}
45 /* Qualifiers list. */
47 /* e.g. MSR <systemreg>, <Xt>. */
53 /* e.g. MRS <Xt>, <systemreg>. */
59 /* e.g. SYS #<op1>, <Cn>, <Cm>, #<op2>{, <Xt>}. */
62 QLF5(NIL,CR,CR,NIL,X), \
65 /* e.g. SYSL <Xt>, #<op1>, <Cn>, <Cm>, #<op2>. */
68 QLF5(X,NIL,CR,CR,NIL), \
71 /* e.g. ADRP <Xd>, <label>. */
77 /* e.g. TCANCEL #<imm>. */
83 /* e.g. B.<cond> <label>. */
84 #define QL_PCREL_NIL \
89 /* e.g. TBZ <Xt>, #<imm>, <label>. */
92 QLF3(X,imm_0_63,NIL), \
95 /* e.g. BL <label>. */
101 /* e.g. LDRSW <Xt>, <label>. */
107 /* e.g. LDR <Wt>, <label>. */
114 /* e.g. LDR <Dt>, <label>. */
115 #define QL_FP_PCREL \
122 /* e.g. PRFM <prfop>, <label>. */
123 #define QL_PRFM_PCREL \
134 /* e.g. STG <Xt|SP>, [<Xn|SP>, #<imm9>]. */
141 /* e.g. RBIT <Wd>, <Wn>. */
148 /* e.g. CMN <Wn|WSP>, <Wm>{, <extend> {#<amount>}}. */
156 /* e.g. MOV <Wd|WSP>, <Wn|WSP>, at least one SP. */
165 /* e.g. REV <Wd>, <Wn>. */
171 /* e.g. REV32 <Xd>, <Xn>. */
183 /* e.g. CRC32B <Wd>, <Wn>, <Wm>. */
189 /* e.g. SMULH <Xd>, <Xn>, <Xm>. */
195 /* e.g. CRC32X <Wd>, <Wn>, <Xm>. */
201 /* e.g. UDIV <Xd>, <Xn>, <Xm>. */
208 /* e.g. ADDS <Xd>, <Xn|SP>, <R><m>{, <extend> {#<amount>}}. */
216 /* e.g. MADD <Xd>, <Xn>, <Xm>, <Xa>. */
223 /* e.g. SMADDL <Xd>, <Wn>, <Wm>, <Xa>. */
229 /* e.g. SMADDL <Xd>, <Wn>, <Wm>, <Xa>. */
235 /* e.g. CSINC <Xd>, <Xn>, <Xm>, <cond>. */
238 QLF4(W, W, W, NIL), \
239 QLF4(X, X, X, NIL), \
242 /* e.g. CSET <Wd>, <cond>. */
249 /* e.g. BFM <Wd>, <Wn>, #<immr>, #<imms>. */
252 QLF4(W,W,imm_0_31,imm_0_31), \
253 QLF4(X,X,imm_0_63,imm_0_63), \
256 /* e.g. ADDG <Xd>, <Xn>, #<uimm10>, #<uimm4>. */
259 QLF4(X,X,NIL,imm_0_15), \
262 /* e.g. BFC <Wd>, #<immr>, #<imms>. */
265 QLF3 (W, imm_0_31, imm_1_32), \
266 QLF3 (X, imm_0_63, imm_1_64), \
269 /* e.g. UBFIZ <Wd>, <Wn>, #<lsb>, #<width>. */
272 QLF4(W,W,imm_0_31,imm_1_32), \
273 QLF4(X,X,imm_0_63,imm_1_64), \
276 /* e.g. SCVTF <Sd>, <Xn>, #<fbits>. */
279 QLF3(S_D,W,imm_1_32), \
280 QLF3(S_S,W,imm_1_32), \
281 QLF3(S_D,X,imm_1_64), \
282 QLF3(S_S,X,imm_1_64), \
285 /* e.g. SCVTF <Hd>, <Xn>, #<fbits>. */
286 #define QL_FIX2FP_H \
288 QLF3 (S_H, W, imm_1_32), \
289 QLF3 (S_H, X, imm_1_64), \
292 /* e.g. FCVTZS <Wd>, <Dn>, #<fbits>. */
295 QLF3(W,S_D,imm_1_32), \
296 QLF3(W,S_S,imm_1_32), \
297 QLF3(X,S_D,imm_1_64), \
298 QLF3(X,S_S,imm_1_64), \
301 /* e.g. FCVTZS <Wd>, <Hn>, #<fbits>. */
302 #define QL_FP2FIX_H \
304 QLF3 (W, S_H, imm_1_32), \
305 QLF3 (X, S_H, imm_1_64), \
308 /* e.g. SCVTF <Dd>, <Wn>. */
317 /* e.g. FMOV <Dd>, <Xn>. */
318 #define QL_INT2FP_FMOV \
324 /* e.g. SCVTF <Hd>, <Wn>. */
325 #define QL_INT2FP_H \
331 /* e.g. FCVTNS <Xd>, <Dn>. */
340 /* e.g. FMOV <Xd>, <Dn>. */
341 #define QL_FP2INT_FMOV \
347 /* e.g. FCVTNS <Hd>, <Wn>. */
348 #define QL_FP2INT_H \
354 /* e.g. FJCVTZS <Wd>, <Dn>. */
355 #define QL_FP2INT_W_D \
360 /* e.g. FMOV <Xd>, <Vn>.D[1]. */
366 /* e.g. FMOV <Vd>.D[1], <Xn>. */
372 /* e.g. EXTR <Xd>, <Xn>, <Xm>, #<lsb>. */
375 QLF4(W,W,W,imm_0_31), \
376 QLF4(X,X,X,imm_0_63), \
379 /* e.g. LSL <Wd>, <Wn>, #<uimm>. */
382 QLF3(W,W,imm_0_31), \
383 QLF3(X,X,imm_0_63), \
386 /* e.g. UXTH <Xd>, <Wn>. */
393 /* e.g. UXTW <Xd>, <Wn>. */
399 /* e.g. SQSHL <V><d>, <V><n>, #<shift>. */
402 QLF3(S_B , S_B , S_B ), \
403 QLF3(S_H , S_H , S_H ), \
404 QLF3(S_S , S_S , S_S ), \
405 QLF3(S_D , S_D , S_D ) \
408 /* e.g. SSHR <V><d>, <V><n>, #<shift>. */
409 #define QL_SSHIFT_D \
411 QLF3(S_D , S_D , S_D ) \
414 /* e.g. UCVTF <Vd>.<T>, <Vn>.<T>, #<fbits>. */
415 #define QL_SSHIFT_SD \
417 QLF3(S_S , S_S , S_S ), \
418 QLF3(S_D , S_D , S_D ) \
421 /* e.g. UCVTF <Vd>.<T>, <Vn>.<T>, #<fbits>. */
422 #define QL_SSHIFT_H \
424 QLF3 (S_H, S_H, S_H) \
427 /* e.g. SQSHRUN <Vb><d>, <Va><n>, #<shift>. */
430 QLF3(S_B , S_H , S_B ), \
431 QLF3(S_H , S_S , S_H ), \
432 QLF3(S_S , S_D , S_S ), \
435 /* e.g. SSHR <Vd>.<T>, <Vn>.<T>, #<shift>.
436 The register operand variant qualifiers are deliberately used for the
437 immediate operand to ease the operand encoding/decoding and qualifier
438 sequence matching. */
441 QLF3(V_8B , V_8B , V_8B ), \
442 QLF3(V_16B, V_16B, V_16B), \
443 QLF3(V_4H , V_4H , V_4H ), \
444 QLF3(V_8H , V_8H , V_8H ), \
445 QLF3(V_2S , V_2S , V_2S ), \
446 QLF3(V_4S , V_4S , V_4S ), \
447 QLF3(V_2D , V_2D , V_2D ) \
450 /* e.g. SCVTF <Vd>.<T>, <Vn>.<T>, #<fbits>. */
451 #define QL_VSHIFT_SD \
453 QLF3(V_2S , V_2S , V_2S ), \
454 QLF3(V_4S , V_4S , V_4S ), \
455 QLF3(V_2D , V_2D , V_2D ) \
458 /* e.g. SCVTF <Vd>.<T>, <Vn>.<T>, #<fbits>. */
459 #define QL_VSHIFT_H \
461 QLF3 (V_4H, V_4H, V_4H), \
462 QLF3 (V_8H, V_8H, V_8H) \
465 /* e.g. SHRN<Q> <Vd>.<Tb>, <Vn>.<Ta>, #<shift>. */
468 QLF3(V_8B , V_8H , V_8B ), \
469 QLF3(V_4H , V_4S , V_4H ), \
470 QLF3(V_2S , V_2D , V_2S ), \
473 /* e.g. SHRN<Q> <Vd>.<Tb>, <Vn>.<Ta>, #<shift>. */
474 #define QL_VSHIFTN2 \
476 QLF3(V_16B, V_8H, V_16B), \
477 QLF3(V_8H , V_4S , V_8H ), \
478 QLF3(V_4S , V_2D , V_4S ), \
481 /* e.g. SSHLL<Q> <Vd>.<Ta>, <Vn>.<Tb>, #<shift>.
482 the 3rd qualifier is used to help the encoding. */
485 QLF3(V_8H , V_8B , V_8B ), \
486 QLF3(V_4S , V_4H , V_4H ), \
487 QLF3(V_2D , V_2S , V_2S ), \
490 /* e.g. SSHLL<Q> <Vd>.<Ta>, <Vn>.<Tb>, #<shift>. */
491 #define QL_VSHIFTL2 \
493 QLF3(V_8H , V_16B, V_16B), \
494 QLF3(V_4S , V_8H , V_8H ), \
495 QLF3(V_2D , V_4S , V_4S ), \
501 QLF3(V_8B , V_16B, V_8B ), \
502 QLF3(V_16B, V_16B, V_16B), \
511 /* e.g. ABS <V><d>, <V><n>. */
517 /* e.g. CMGT <V><d>, <V><n>, #0. */
518 #define QL_SISD_CMP_0 \
520 QLF3(S_D, S_D, NIL), \
523 /* e.g. FCMEQ <V><d>, <V><n>, #0. */
524 #define QL_SISD_FCMP_0 \
526 QLF3(S_S, S_S, NIL), \
527 QLF3(S_D, S_D, NIL), \
530 /* e.g. FCMEQ <V><d>, <V><n>, #0. */
531 #define QL_SISD_FCMP_H_0 \
533 QLF3 (S_H, S_H, NIL), \
536 /* e.g. FMAXNMP <V><d>, <Vn>.<T>. */
537 #define QL_SISD_PAIR \
543 /* e.g. FMAXNMP <V><d>, <Vn>.<T>. */
544 #define QL_SISD_PAIR_H \
549 /* e.g. ADDP <V><d>, <Vn>.<T>. */
550 #define QL_SISD_PAIR_D \
555 /* e.g. DUP <V><d>, <Vn>.<T>[<index>]. */
564 /* e.g. FCVTNS <V><d>, <V><n>. */
565 #define QL_S_2SAMESD \
571 /* e.g. FCVTNS <V><d>, <V><n>. */
572 #define QL_S_2SAMEH \
577 /* e.g. SQXTN <Vb><d>, <Va><n>. */
578 #define QL_SISD_NARROW \
585 /* e.g. FCVTXN <Vb><d>, <Va><n>. */
586 #define QL_SISD_NARROW_S \
602 /* FMOV <Dd>, <Dn>. */
609 /* FMOV <Hd>, <Hn>. */
615 /* e.g. SQADD <V><d>, <V><n>, <V><m>. */
618 QLF3(S_B, S_B, S_B), \
619 QLF3(S_H, S_H, S_H), \
620 QLF3(S_S, S_S, S_S), \
621 QLF3(S_D, S_D, S_D), \
624 /* e.g. CMGE <V><d>, <V><n>, <V><m>. */
625 #define QL_S_3SAMED \
627 QLF3(S_D, S_D, S_D), \
630 /* e.g. SQDMULH <V><d>, <V><n>, <V><m>. */
633 QLF3(S_H, S_H, S_H), \
634 QLF3(S_S, S_S, S_S), \
637 /* e.g. SQDMLAL <Va><d>, <Vb><n>, <Vb><m>. */
638 #define QL_SISDL_HS \
640 QLF3(S_S, S_H, S_H), \
641 QLF3(S_D, S_S, S_S), \
644 /* FMUL <Sd>, <Sn>, <Sm>. */
647 QLF3(S_S, S_S, S_S), \
648 QLF3(S_D, S_D, S_D), \
651 /* FMUL <Hd>, <Hn>, <Hm>. */
654 QLF3 (S_H, S_H, S_H), \
657 /* FMADD <Dd>, <Dn>, <Dm>, <Da>. */
660 QLF4(S_S, S_S, S_S, S_S), \
661 QLF4(S_D, S_D, S_D, S_D), \
664 /* FMADD <Hd>, <Hn>, <Hm>, <Ha>. */
667 QLF4 (S_H, S_H, S_H, S_H), \
670 /* e.g. FCMP <Dn>, #0.0. */
677 /* e.g. FCMP <Hn>, #0.0. */
683 /* FCSEL <Sd>, <Sn>, <Sm>, <cond>. */
686 QLF4(S_S, S_S, S_S, NIL), \
687 QLF4(S_D, S_D, S_D, NIL), \
690 /* FCSEL <Hd>, <Hn>, <Hm>, <cond>. */
691 #define QL_FP_COND_H \
693 QLF4 (S_H, S_H, S_H, NIL), \
696 /* e.g. CCMN <Xn>, <Xm>, #<nzcv>, <cond>. */
699 QLF4(W, W, NIL, NIL), \
700 QLF4(X, X, NIL, NIL), \
703 /* e.g. CCMN <Xn>, #<imm>, #<nzcv>, <cond>, */
704 #define QL_CCMP_IMM \
706 QLF4(W, NIL, NIL, NIL), \
707 QLF4(X, NIL, NIL, NIL), \
710 /* e.g. FCCMP <Sn>, <Sm>, #<nzcv>, <cond>. */
713 QLF4(S_S, S_S, NIL, NIL), \
714 QLF4(S_D, S_D, NIL, NIL), \
717 /* e.g. FCCMP <Sn>, <Sm>, #<nzcv>, <cond>. */
720 QLF4 (S_H, S_H, NIL, NIL), \
723 /* e.g. DUP <Vd>.<T>, <Vn>.<Ts>[<index>]. */
735 /* e.g. DUP <Vd>.<T>, <Wn>. */
747 /* e.g. INS <Vd>.<Ts>[<index>], <Wn>. */
756 /* e.g. SMOV <Wd>, <Vn>.<Ts>[<index>]. */
766 /* e.g. UMOV <Wd>, <Vn>.<Ts>[<index>]. */
775 /* e.g. MOV <Wd>, <Vn>.<Ts>[<index>]. */
782 /* e.g. SUQADD <Vd>.<T>, <Vn>.<T>. */
785 QLF2(V_8B , V_8B ), \
786 QLF2(V_16B, V_16B), \
787 QLF2(V_4H , V_4H ), \
788 QLF2(V_8H , V_8H ), \
789 QLF2(V_2S , V_2S ), \
790 QLF2(V_4S , V_4S ), \
791 QLF2(V_2D , V_2D ), \
794 /* e.g. URSQRTE <Vd>.<T>, <Vn>.<T>. */
797 QLF2(V_2S , V_2S ), \
798 QLF2(V_4S , V_4S ), \
801 /* e.g. REV32 <Vd>.<T>, <Vn>.<T>. */
802 #define QL_V2SAMEBH \
804 QLF2(V_8B , V_8B ), \
805 QLF2(V_16B, V_16B), \
806 QLF2(V_4H , V_4H ), \
807 QLF2(V_8H , V_8H ), \
810 /* e.g. FRINTN <Vd>.<T>, <Vn>.<T>. */
811 #define QL_V2SAMESD \
813 QLF2(V_2S , V_2S ), \
814 QLF2(V_4S , V_4S ), \
815 QLF2(V_2D , V_2D ), \
818 /* e.g. REV64 <Vd>.<T>, <Vn>.<T>. */
819 #define QL_V2SAMEBHS \
821 QLF2(V_8B , V_8B ), \
822 QLF2(V_16B, V_16B), \
823 QLF2(V_4H , V_4H ), \
824 QLF2(V_8H , V_8H ), \
825 QLF2(V_2S , V_2S ), \
826 QLF2(V_4S , V_4S ), \
829 /* e.g. FCMGT <Vd>.<T>, <Vd>.<T>>, #0.0. */
836 /* e.g. REV16 <Vd>.<T>, <Vn>.<T>. */
839 QLF2(V_8B , V_8B ), \
840 QLF2(V_16B, V_16B), \
843 /* e.g. SADDLP <Vd>.<Ta>, <Vn>.<Tb>. */
844 #define QL_V2PAIRWISELONGBHS \
846 QLF2(V_4H , V_8B ), \
847 QLF2(V_8H , V_16B), \
848 QLF2(V_2S , V_4H ), \
849 QLF2(V_4S , V_8H ), \
850 QLF2(V_1D , V_2S ), \
851 QLF2(V_2D , V_4S ), \
854 /* e.g. SHLL<Q> <Vd>.<Ta>, <Vn>.<Tb>, #<shift>. */
855 #define QL_V2LONGBHS \
857 QLF2(V_8H , V_8B ), \
858 QLF2(V_4S , V_4H ), \
859 QLF2(V_2D , V_2S ), \
862 /* e.g. SHLL<Q> <Vd>.<Ta>, <Vn>.<Tb>, #<shift>. */
863 #define QL_V2LONGBHS2 \
865 QLF2(V_8H , V_16B), \
866 QLF2(V_4S , V_8H ), \
867 QLF2(V_2D , V_4S ), \
873 QLF3(V_8B , V_8B , V_8B ), \
874 QLF3(V_16B, V_16B, V_16B), \
875 QLF3(V_4H , V_4H , V_4H ), \
876 QLF3(V_8H , V_8H , V_8H ), \
877 QLF3(V_2S , V_2S , V_2S ), \
878 QLF3(V_4S , V_4S , V_4S ), \
879 QLF3(V_2D , V_2D , V_2D ) \
883 #define QL_V3SAMEBHS \
885 QLF3(V_8B , V_8B , V_8B ), \
886 QLF3(V_16B, V_16B, V_16B), \
887 QLF3(V_4H , V_4H , V_4H ), \
888 QLF3(V_8H , V_8H , V_8H ), \
889 QLF3(V_2S , V_2S , V_2S ), \
890 QLF3(V_4S , V_4S , V_4S ), \
893 /* e.g. FCVTXN<Q> <Vd>.<Tb>, <Vn>.<Ta>. */
896 QLF2(V_2S , V_2D ), \
899 /* e.g. FCVTXN<Q> <Vd>.<Tb>, <Vn>.<Ta>. */
900 #define QL_V2NARRS2 \
902 QLF2(V_4S , V_2D ), \
905 /* e.g. FCVTN<Q> <Vd>.<Tb>, <Vn>.<Ta>. */
906 #define QL_V2NARRHS \
908 QLF2(V_4H , V_4S ), \
909 QLF2(V_2S , V_2D ), \
912 /* e.g. FCVTN<Q> <Vd>.<Tb>, <Vn>.<Ta>. */
913 #define QL_V2NARRHS2 \
915 QLF2(V_8H , V_4S ), \
916 QLF2(V_4S , V_2D ), \
919 /* e.g. FCVTL<Q> <Vd>.<Ta>, <Vn>.<Tb>. */
920 #define QL_V2LONGHS \
922 QLF2(V_4S , V_4H ), \
923 QLF2(V_2D , V_2S ), \
926 /* e.g. FCVTL<Q> <Vd>.<Ta>, <Vn>.<Tb>. */
927 #define QL_V2LONGHS2 \
929 QLF2(V_4S , V_8H ), \
930 QLF2(V_2D , V_4S ), \
933 /* e.g. XTN<Q> <Vd>.<Tb>, <Vn>.<Ta>. */
934 #define QL_V2NARRBHS \
936 QLF2(V_8B , V_8H ), \
937 QLF2(V_4H , V_4S ), \
938 QLF2(V_2S , V_2D ), \
941 /* e.g. XTN<Q> <Vd>.<Tb>, <Vn>.<Ta>. */
942 #define QL_V2NARRBHS2 \
944 QLF2(V_16B, V_8H ), \
945 QLF2(V_8H , V_4S ), \
946 QLF2(V_4S , V_2D ), \
952 QLF2(V_8B , V_8B ), \
953 QLF2(V_16B, V_16B), \
957 #define QL_V2SAME16B \
959 QLF2(V_16B, V_16B), \
963 #define QL_V2SAME4S \
969 #define QL_V3SAME4S \
971 QLF3(V_4S, V_4S, V_4S), \
977 QLF3(V_8B , V_8B , V_8B ), \
978 QLF3(V_16B, V_16B, V_16B), \
981 /* e.g. EXT <Vd>.<T>, <Vn>.<T>, <Vm>.<T>, #<index>. */
984 QLF4(V_8B , V_8B , V_8B , imm_0_7), \
985 QLF4(V_16B, V_16B, V_16B, imm_0_15), \
989 #define QL_V3SAMEHS \
991 QLF3(V_4H , V_4H , V_4H ), \
992 QLF3(V_8H , V_8H , V_8H ), \
993 QLF3(V_2S , V_2S , V_2S ), \
994 QLF3(V_4S , V_4S , V_4S ), \
998 #define QL_V3SAMESD \
1000 QLF3(V_2S , V_2S , V_2S ), \
1001 QLF3(V_4S , V_4S , V_4S ), \
1002 QLF3(V_2D , V_2D , V_2D ) \
1005 /* e.g. FCMLA <Vd>.<T>, <Vn>.<T>, <Vm>.<T>, #<rotate>. */
1006 #define QL_V3SAMEHSD_ROT \
1008 QLF4 (V_4H, V_4H, V_4H, NIL), \
1009 QLF4 (V_8H, V_8H, V_8H, NIL), \
1010 QLF4 (V_2S, V_2S, V_2S, NIL), \
1011 QLF4 (V_4S, V_4S, V_4S, NIL), \
1012 QLF4 (V_2D, V_2D, V_2D, NIL), \
1015 /* e.g. FMAXNM <Vd>.<T>, <Vn>.<T>, <Vm>.<T>. */
1016 #define QL_V3SAMEH \
1018 QLF3 (V_4H , V_4H , V_4H ), \
1019 QLF3 (V_8H , V_8H , V_8H ), \
1022 /* e.g. SQDMLAL<Q> <Vd>.<Ta>, <Vn>.<Tb>, <Vm>.<Tb>. */
1023 #define QL_V3LONGHS \
1025 QLF3(V_4S , V_4H , V_4H ), \
1026 QLF3(V_2D , V_2S , V_2S ), \
1029 /* e.g. SQDMLAL<Q> <Vd>.<Ta>, <Vn>.<Tb>, <Vm>.<Tb>. */
1030 #define QL_V3LONGHS2 \
1032 QLF3(V_4S , V_8H , V_8H ), \
1033 QLF3(V_2D , V_4S , V_4S ), \
1036 /* e.g. SADDL<Q> <Vd>.<Ta>, <Vn>.<Tb>, <Vm>.<Tb>. */
1037 #define QL_V3LONGBHS \
1039 QLF3(V_8H , V_8B , V_8B ), \
1040 QLF3(V_4S , V_4H , V_4H ), \
1041 QLF3(V_2D , V_2S , V_2S ), \
1044 /* e.g. SADDL<Q> <Vd>.<Ta>, <Vn>.<Tb>, <Vm>.<Tb>. */
1045 #define QL_V3LONGBHS2 \
1047 QLF3(V_8H , V_16B , V_16B ), \
1048 QLF3(V_4S , V_8H , V_8H ), \
1049 QLF3(V_2D , V_4S , V_4S ), \
1052 /* e.g. SADDW<Q> <Vd>.<Ta>, <Vn>.<Ta>, <Vm>.<Tb>. */
1053 #define QL_V3WIDEBHS \
1055 QLF3(V_8H , V_8H , V_8B ), \
1056 QLF3(V_4S , V_4S , V_4H ), \
1057 QLF3(V_2D , V_2D , V_2S ), \
1060 /* e.g. SADDW<Q> <Vd>.<Ta>, <Vn>.<Ta>, <Vm>.<Tb>. */
1061 #define QL_V3WIDEBHS2 \
1063 QLF3(V_8H , V_8H , V_16B ), \
1064 QLF3(V_4S , V_4S , V_8H ), \
1065 QLF3(V_2D , V_2D , V_4S ), \
1068 /* e.g. ADDHN<Q> <Vd>.<Tb>, <Vn>.<Ta>, <Vm>.<Ta>. */
1069 #define QL_V3NARRBHS \
1071 QLF3(V_8B , V_8H , V_8H ), \
1072 QLF3(V_4H , V_4S , V_4S ), \
1073 QLF3(V_2S , V_2D , V_2D ), \
1076 /* e.g. ADDHN<Q> <Vd>.<Tb>, <Vn>.<Ta>, <Vm>.<Ta>. */
1077 #define QL_V3NARRBHS2 \
1079 QLF3(V_16B , V_8H , V_8H ), \
1080 QLF3(V_8H , V_4S , V_4S ), \
1081 QLF3(V_4S , V_2D , V_2D ), \
1085 #define QL_V3LONGB \
1087 QLF3(V_8H , V_8B , V_8B ), \
1090 /* e.g. PMULL crypto. */
1091 #define QL_V3LONGD \
1093 QLF3(V_1Q , V_1D , V_1D ), \
1097 #define QL_V3LONGB2 \
1099 QLF3(V_8H , V_16B, V_16B), \
1102 /* e.g. PMULL2 crypto. */
1103 #define QL_V3LONGD2 \
1105 QLF3(V_1Q , V_2D , V_2D ), \
1111 QLF3(S_Q, S_S, V_4S), \
1114 /* e.g. SHA256H2. */
1115 #define QL_SHA256UPT \
1117 QLF3(S_Q, S_Q, V_4S), \
1120 /* e.g. LDXRB <Wt>, [<Xn|SP>{,#0}]. */
1121 #define QL_W1_LDST_EXC \
1126 /* e.g. LDXR <Xt>, [<Xn|SP>{,#0}]. */
1133 /* e.g. STXRB <Ws>, <Wt>, [<Xn|SP>{,#0}]. */
1134 #define QL_W2_LDST_EXC \
1139 /* e.g. STXR <Ws>, <Xt>, [<Xn|SP>{,#0}]. */
1140 #define QL_R2_LDST_EXC \
1146 /* e.g. LDRAA <Xt>, [<Xn|SP>{,#imm}]. */
1152 /* e.g. LDXP <Xt1>, <Xt2>, [<Xn|SP>{,#0}]. */
1159 /* e.g. CASP <Xt1>, <Xt1+1>, <Xt2>, <Xt2+1>, [<Xn|SP>{,#0}]. */
1162 QLF5(W, W, W, W, NIL), \
1163 QLF5(X, X, X, X, NIL), \
1166 /* e.g. STXP <Ws>, <Xt1>, <Xt2>, [<Xn|SP>{,#0}]. */
1167 #define QL_R3_LDST_EXC \
1169 QLF4(W, W, W, NIL), \
1170 QLF4(W, X, X, NIL), \
1173 /* e.g. STR <Qt>, [<Xn|SP>, <R><m>{, <extend> {<amount>}}]. */
1174 #define QL_LDST_FP \
1183 /* e.g. STR <Xt>, [<Xn|SP>, <R><m>{, <extend> {<amount>}}]. */
1190 /* e.g. STRB <Wt>, [<Xn|SP>, <R><m>{, <extend> {<amount>}}]. */
1191 #define QL_LDST_W8 \
1196 /* e.g. LDRSB <Wt>, [<Xn|SP>, <R><m>{, <extend> {<amount>}}]. */
1197 #define QL_LDST_R8 \
1203 /* e.g. STRH <Wt>, [<Xn|SP>, <R><m>{, <extend> {<amount>}}]. */
1204 #define QL_LDST_W16 \
1209 /* e.g. LDRSW <Xt>, [<Xn|SP>, <R><m>{, <extend> {<amount>}}]. */
1210 #define QL_LDST_X32 \
1215 /* e.g. LDRSH <Wt>, [<Xn|SP>, <R><m>{, <extend> {<amount>}}]. */
1216 #define QL_LDST_R16 \
1222 /* e.g. PRFM <prfop>, [<Xn|SP>, <R><m>{, <extend> {<amount>}}]. */
1223 #define QL_LDST_PRFM \
1228 /* e.g. LDG <Xt>, [<Xn|SP>{, #<simm>}]. */
1234 /* e.g. LDPSW <Xt1>, <Xt2>, [<Xn|SP>{, #<imm>}]. */
1235 #define QL_LDST_PAIR_X32 \
1240 /* e.g. STGP <Xt1>, <Xt2>, [<Xn|SP>{, #<imm>}]. */
1243 QLF3(X, X, imm_tag), \
1246 /* e.g. STP <Wt1>, <Wt2>, [<Xn|SP>, #<imm>]!. */
1247 #define QL_LDST_PAIR_R \
1253 /* e.g. STNP <Qt1>, <Qt2>, [<Xn|SP>{, #<imm>}]. */
1254 #define QL_LDST_PAIR_FP \
1256 QLF3(S_S, S_S, S_S), \
1257 QLF3(S_D, S_D, S_D), \
1258 QLF3(S_Q, S_Q, S_Q), \
1261 /* e.g. LD3 {<Vt>.<T>, <Vt2>.<T>, <Vt3>.<T>}, [<Xn|SP>]. */
1262 #define QL_SIMD_LDST \
1273 /* e.g. LD1 {<Vt>.<T>, <Vt2>.<T>, <Vt3>.<T>}, [<Xn|SP>]. */
1274 #define QL_SIMD_LDST_ANY \
1286 /* e.g. LD4 {<Vt>.<T>, <Vt2a>.<T>, <Vt3a>.<T>, <Vt4a>.<T>}[<index>], [<Xn|SP>]. */
1287 #define QL_SIMD_LDSTONE \
1295 /* e.g. ADDV <V><d>, <Vn>.<T>. */
1305 /* e.g. FMINV <V><d>, <Vn>.<T>. */
1306 #define QL_XLANES_FP \
1311 /* e.g. FMINV <V><d>, <Vn>.<T>. */
1312 #define QL_XLANES_FP_H \
1318 /* e.g. SADDLV <V><d>, <Vn>.<T>. */
1319 #define QL_XLANES_L \
1328 /* e.g. MUL <Vd>.<T>, <Vn>.<T>, <Vm>.<Ts>[<index>]. */
1329 #define QL_ELEMENT \
1331 QLF3(V_4H, V_4H, S_H), \
1332 QLF3(V_8H, V_8H, S_H), \
1333 QLF3(V_2S, V_2S, S_S), \
1334 QLF3(V_4S, V_4S, S_S), \
1337 /* e.g. SMLAL <Vd>.<Ta>, <Vn>.<Tb>, <Vm>.<Ts>[<index>]. */
1338 #define QL_ELEMENT_L \
1340 QLF3(V_4S, V_4H, S_H), \
1341 QLF3(V_2D, V_2S, S_S), \
1344 /* e.g. SMLAL2 <Vd>.<Ta>, <Vn>.<Tb>, <Vm>.<Ts>[<index>]. */
1345 #define QL_ELEMENT_L2 \
1347 QLF3(V_4S, V_8H, S_H), \
1348 QLF3(V_2D, V_4S, S_S), \
1351 /* e.g. FMLA <V><d>, <V><n>, <Vm>.<Ts>[<index>]. */
1352 #define QL_ELEMENT_FP \
1354 QLF3(V_2S, V_2S, S_S), \
1355 QLF3(V_4S, V_4S, S_S), \
1356 QLF3(V_2D, V_2D, S_D), \
1359 /* e.g. FMLA <V><d>, <V><n>, <Vm>.<Ts>[<index>]. */
1360 #define QL_ELEMENT_FP_H \
1362 QLF3 (V_4H, V_4H, S_H), \
1363 QLF3 (V_8H, V_8H, S_H), \
1366 /* e.g. FCMLA <Vd>.<T>, <Vn>.<T>, <Vm>.<Ts>[<index>], #<rotate>. */
1367 #define QL_ELEMENT_ROT \
1369 QLF4 (V_4H, V_4H, S_H, NIL), \
1370 QLF4 (V_8H, V_8H, S_H, NIL), \
1371 QLF4 (V_4S, V_4S, S_S, NIL), \
1374 /* e.g. MOVI <Vd>.4S, #<imm8> {, LSL #<amount>}. */
1375 #define QL_SIMD_IMM_S0W \
1381 /* e.g. MOVI <Vd>.4S, #<imm8>, MSL #<amount>. */
1382 #define QL_SIMD_IMM_S1W \
1388 /* e.g. MOVI <Vd>.4H, #<imm8> {, LSL #<amount>}. */
1389 #define QL_SIMD_IMM_S0H \
1395 /* e.g. FMOV <Vd>.<T>, #<imm>. */
1396 #define QL_SIMD_IMM_S \
1402 /* e.g. MOVI <Vd>.8B, #<imm8> {, LSL #<amount>}. */
1403 #define QL_SIMD_IMM_B \
1408 /* e.g. MOVI <Dd>, #<imm>. */
1409 #define QL_SIMD_IMM_D \
1414 /* e.g. FMOV <Vd>.<T>, #<imm>. */
1415 #define QL_SIMD_IMM_H \
1421 /* e.g. MOVI <Vd>.2D, #<imm>. */
1422 #define QL_SIMD_IMM_V2D \
1427 /* The naming convention for SVE macros is:
1429 OP_SVE_<operands>[_<sizes>]*
1431 <operands> contains one character per operand, using the following scheme:
1433 - U: the operand is unqualified (NIL).
1435 - [BHSD]: the operand has a S_[BHSD] qualifier and the choice of
1436 qualifier is the same for all variants. This is used for both
1437 .[BHSD] suffixes on an SVE predicate or vector register and
1438 scalar FPRs of the form [BHSD]<number>.
1440 - [WX]: the operand has a [WX] qualifier and the choice of qualifier
1441 is the same for all variants.
1443 - [ZM]: the operand has a /[ZM] suffix and the choice of suffix
1444 is the same for all variants.
1446 - V: the operand has a S_[BHSD] qualifier and the choice of qualifier
1447 is not the same for all variants.
1449 - R: the operand has a [WX] qualifier and the choice of qualifier is
1450 not the same for all variants.
1452 - P: the operand has a /[ZM] suffix and the choice of suffix is not
1453 the same for all variants.
1455 The _<sizes>, if present, give the subset of [BHSD] that are accepted
1456 by the V entries in <operands>. */
1465 #define OP_SVE_BBU \
1467 QLF3(S_B,S_B,NIL), \
1469 #define OP_SVE_BBB \
1471 QLF3(S_B,S_B,S_B), \
1473 #define OP_SVE_BBBU \
1475 QLF4(S_B,S_B,S_B,NIL), \
1477 #define OP_SVE_BMB \
1479 QLF3(S_B,P_M,S_B), \
1481 #define OP_SVE_BPB \
1483 QLF3(S_B,P_Z,S_B), \
1484 QLF3(S_B,P_M,S_B), \
1486 #define OP_SVE_BUB \
1488 QLF3(S_B,NIL,S_B), \
1490 #define OP_SVE_BUBB \
1492 QLF4(S_B,NIL,S_B,S_B), \
1494 #define OP_SVE_BUU \
1496 QLF3(S_B,NIL,NIL), \
1502 #define OP_SVE_BZB \
1504 QLF3(S_B,P_Z,S_B), \
1506 #define OP_SVE_BZBB \
1508 QLF4(S_B,P_Z,S_B,S_B), \
1510 #define OP_SVE_BZU \
1512 QLF3(S_B,P_Z,NIL), \
1518 #define OP_SVE_DDD \
1520 QLF3(S_D,S_D,S_D), \
1522 #define OP_SVE_DDDD \
1524 QLF4(S_D,S_D,S_D,S_D), \
1526 #define OP_SVE_DMD \
1528 QLF3(S_D,P_M,S_D), \
1530 #define OP_SVE_DMH \
1532 QLF3(S_D,P_M,S_H), \
1534 #define OP_SVE_DMS \
1536 QLF3(S_D,P_M,S_S), \
1542 #define OP_SVE_DUD \
1544 QLF3(S_D,NIL,S_D), \
1546 #define OP_SVE_DUU \
1548 QLF3(S_D,NIL,NIL), \
1550 #define OP_SVE_DUV_BHS \
1552 QLF3(S_D,NIL,S_B), \
1553 QLF3(S_D,NIL,S_H), \
1554 QLF3(S_D,NIL,S_S), \
1556 #define OP_SVE_DUV_BHSD \
1558 QLF3(S_D,NIL,S_B), \
1559 QLF3(S_D,NIL,S_H), \
1560 QLF3(S_D,NIL,S_S), \
1561 QLF3(S_D,NIL,S_D), \
1563 #define OP_SVE_DZD \
1565 QLF3(S_D,P_Z,S_D), \
1567 #define OP_SVE_DZU \
1569 QLF3(S_D,P_Z,NIL), \
1575 #define OP_SVE_HHH \
1577 QLF3(S_H,S_H,S_H), \
1579 #define OP_SVE_HHHU \
1581 QLF4(S_H,S_H,S_H,NIL), \
1583 #define OP_SVE_HMH \
1585 QLF3(S_H,P_M,S_H), \
1587 #define OP_SVE_HMD \
1589 QLF3(S_H,P_M,S_D), \
1591 #define OP_SVE_HMS \
1593 QLF3(S_H,P_M,S_S), \
1599 #define OP_SVE_HUU \
1601 QLF3(S_H,NIL,NIL), \
1603 #define OP_SVE_HZU \
1605 QLF3(S_H,P_Z,NIL), \
1612 #define OP_SVE_RURV_BHSD \
1614 QLF4(W,NIL,W,S_B), \
1615 QLF4(W,NIL,W,S_H), \
1616 QLF4(W,NIL,W,S_S), \
1617 QLF4(X,NIL,X,S_D), \
1619 #define OP_SVE_RUV_BHSD \
1626 #define OP_SVE_SMD \
1628 QLF3(S_S,P_M,S_D), \
1630 #define OP_SVE_SSS \
1632 QLF3(S_S,S_S,S_S), \
1634 #define OP_SVE_SSSU \
1636 QLF4(S_S,S_S,S_S,NIL), \
1638 #define OP_SVE_SMH \
1640 QLF3(S_S,P_M,S_H), \
1642 #define OP_SVE_SHH \
1644 QLF3(S_S,S_H,S_H), \
1646 #define OP_SVE_SMS \
1648 QLF3(S_S,P_M,S_S), \
1654 #define OP_SVE_SUS \
1656 QLF3(S_S,NIL,S_S), \
1658 #define OP_SVE_SUU \
1660 QLF3(S_S,NIL,NIL), \
1662 #define OP_SVE_SZS \
1664 QLF3(S_S,P_Z,S_S), \
1666 #define OP_SVE_SBBU \
1668 QLF4(S_S,S_B,S_B,NIL), \
1670 #define OP_SVE_DSS \
1672 QLF3(S_D,S_S,S_S), \
1674 #define OP_SVE_DHHU \
1676 QLF4(S_D,S_H,S_H,NIL), \
1678 #define OP_SVE_SZU \
1680 QLF3(S_S,P_Z,NIL), \
1686 #define OP_SVE_UUD \
1688 QLF3(NIL,NIL,S_D), \
1690 #define OP_SVE_UUS \
1692 QLF3(NIL,NIL,S_S), \
1694 #define OP_SVE_VMR_BHSD \
1701 #define OP_SVE_VMU_HSD \
1703 QLF3(S_H,P_M,NIL), \
1704 QLF3(S_S,P_M,NIL), \
1705 QLF3(S_D,P_M,NIL), \
1707 #define OP_SVE_VMVD_BHS \
1709 QLF4(S_B,P_M,S_B,S_D), \
1710 QLF4(S_H,P_M,S_H,S_D), \
1711 QLF4(S_S,P_M,S_S,S_D), \
1713 #define OP_SVE_VMVU_BHSD \
1715 QLF4(S_B,P_M,S_B,NIL), \
1716 QLF4(S_H,P_M,S_H,NIL), \
1717 QLF4(S_S,P_M,S_S,NIL), \
1718 QLF4(S_D,P_M,S_D,NIL), \
1720 #define OP_SVE_VMVU_HSD \
1722 QLF4(S_H,P_M,S_H,NIL), \
1723 QLF4(S_S,P_M,S_S,NIL), \
1724 QLF4(S_D,P_M,S_D,NIL), \
1726 #define OP_SVE_VMVV_BHSD \
1728 QLF4(S_B,P_M,S_B,S_B), \
1729 QLF4(S_H,P_M,S_H,S_H), \
1730 QLF4(S_S,P_M,S_S,S_S), \
1731 QLF4(S_D,P_M,S_D,S_D), \
1733 #define OP_SVE_VMVV_HSD \
1735 QLF4(S_H,P_M,S_H,S_H), \
1736 QLF4(S_S,P_M,S_S,S_S), \
1737 QLF4(S_D,P_M,S_D,S_D), \
1739 #define OP_SVE_VMVV_SD \
1741 QLF4(S_S,P_M,S_S,S_S), \
1742 QLF4(S_D,P_M,S_D,S_D), \
1744 #define OP_SVE_VMVVU_HSD \
1746 QLF5(S_H,P_M,S_H,S_H,NIL), \
1747 QLF5(S_S,P_M,S_S,S_S,NIL), \
1748 QLF5(S_D,P_M,S_D,S_D,NIL), \
1750 #define OP_SVE_VMV_BHSD \
1752 QLF3(S_B,P_M,S_B), \
1753 QLF3(S_H,P_M,S_H), \
1754 QLF3(S_S,P_M,S_S), \
1755 QLF3(S_D,P_M,S_D), \
1757 #define OP_SVE_VMV_HSD \
1759 QLF3(S_H,P_M,S_H), \
1760 QLF3(S_S,P_M,S_S), \
1761 QLF3(S_D,P_M,S_D), \
1763 #define OP_SVE_VMV_HSD_BHS \
1765 QLF3(S_H,P_M,S_B), \
1766 QLF3(S_S,P_M,S_H), \
1767 QLF3(S_D,P_M,S_S), \
1769 #define OP_SVE_VVU_HSD_BHS \
1771 QLF3(S_H,S_B,NIL), \
1772 QLF3(S_S,S_H,NIL), \
1773 QLF3(S_D,S_S,NIL), \
1775 #define OP_SVE_VMV_SD \
1777 QLF3(S_S,P_M,S_S), \
1778 QLF3(S_D,P_M,S_D), \
1780 #define OP_SVE_VM_HSD \
1786 #define OP_SVE_VPU_BHSD \
1788 QLF3(S_B,P_Z,NIL), \
1789 QLF3(S_B,P_M,NIL), \
1790 QLF3(S_H,P_Z,NIL), \
1791 QLF3(S_H,P_M,NIL), \
1792 QLF3(S_S,P_Z,NIL), \
1793 QLF3(S_S,P_M,NIL), \
1794 QLF3(S_D,P_Z,NIL), \
1795 QLF3(S_D,P_M,NIL), \
1797 #define OP_SVE_VPV_BHSD \
1799 QLF3(S_B,P_Z,S_B), \
1800 QLF3(S_B,P_M,S_B), \
1801 QLF3(S_H,P_Z,S_H), \
1802 QLF3(S_H,P_M,S_H), \
1803 QLF3(S_S,P_Z,S_S), \
1804 QLF3(S_S,P_M,S_S), \
1805 QLF3(S_D,P_Z,S_D), \
1806 QLF3(S_D,P_M,S_D), \
1808 #define OP_SVE_VRR_BHSD \
1815 #define OP_SVE_VRU_BHSD \
1822 #define OP_SVE_VR_BHSD \
1829 #define OP_SVE_VUR_BHSD \
1836 #define OP_SVE_VUU_BHSD \
1838 QLF3(S_B,NIL,NIL), \
1839 QLF3(S_H,NIL,NIL), \
1840 QLF3(S_S,NIL,NIL), \
1841 QLF3(S_D,NIL,NIL), \
1843 #define OP_SVE_VUVV_BHSD \
1845 QLF4(S_B,NIL,S_B,S_B), \
1846 QLF4(S_H,NIL,S_H,S_H), \
1847 QLF4(S_S,NIL,S_S,S_S), \
1848 QLF4(S_D,NIL,S_D,S_D), \
1850 #define OP_SVE_VUVV_HSD \
1852 QLF4(S_H,NIL,S_H,S_H), \
1853 QLF4(S_S,NIL,S_S,S_S), \
1854 QLF4(S_D,NIL,S_D,S_D), \
1856 #define OP_SVE_VUV_BHSD \
1858 QLF3(S_B,NIL,S_B), \
1859 QLF3(S_H,NIL,S_H), \
1860 QLF3(S_S,NIL,S_S), \
1861 QLF3(S_D,NIL,S_D), \
1863 #define OP_SVE_VUV_HSD \
1865 QLF3(S_H,NIL,S_H), \
1866 QLF3(S_S,NIL,S_S), \
1867 QLF3(S_D,NIL,S_D), \
1869 #define OP_SVE_VUV_SD \
1871 QLF3(S_S,NIL,S_S), \
1872 QLF3(S_D,NIL,S_D), \
1874 #define OP_SVE_VU_BHSD \
1881 #define OP_SVE_VU_HSD \
1887 #define OP_SVE_VU_HSD \
1893 #define OP_SVE_VVD_BHS \
1895 QLF3(S_B,S_B,S_D), \
1896 QLF3(S_H,S_H,S_D), \
1897 QLF3(S_S,S_S,S_D), \
1899 #define OP_SVE_VVU_BHSD \
1901 QLF3(S_B,S_B,NIL), \
1902 QLF3(S_H,S_H,NIL), \
1903 QLF3(S_S,S_S,NIL), \
1904 QLF3(S_D,S_D,NIL), \
1906 #define OP_SVE_VVVU_H \
1908 QLF4(S_H,S_H,S_H,NIL), \
1910 #define OP_SVE_VVVU_S \
1912 QLF4(S_S,S_S,S_S,NIL), \
1914 #define OP_SVE_VVVU_SD_BH \
1916 QLF4(S_S,S_B,S_B,NIL), \
1917 QLF4(S_D,S_H,S_H,NIL), \
1919 #define OP_SVE_VVVU_HSD \
1921 QLF4(S_H,S_H,S_H,NIL), \
1922 QLF4(S_S,S_S,S_S,NIL), \
1923 QLF4(S_D,S_D,S_D,NIL), \
1925 #define OP_SVE_VVVU_BHSD \
1927 QLF4(S_B,S_B,S_B,NIL), \
1928 QLF4(S_H,S_H,S_H,NIL), \
1929 QLF4(S_S,S_S,S_S,NIL), \
1930 QLF4(S_D,S_D,S_D,NIL), \
1932 #define OP_SVE_VVV_BHSD \
1934 QLF3(S_B,S_B,S_B), \
1935 QLF3(S_H,S_H,S_H), \
1936 QLF3(S_S,S_S,S_S), \
1937 QLF3(S_D,S_D,S_D), \
1939 #define OP_SVE_VVV_D \
1941 QLF3(S_D,S_D,S_D), \
1943 #define OP_SVE_VVV_D_H \
1945 QLF3(S_D,S_H,S_H), \
1947 #define OP_SVE_VVV_H \
1949 QLF3(S_H,S_H,S_H), \
1951 #define OP_SVE_VVV_HSD \
1953 QLF3(S_H,S_H,S_H), \
1954 QLF3(S_S,S_S,S_S), \
1955 QLF3(S_D,S_D,S_D), \
1957 #define OP_SVE_VVV_S \
1959 QLF3(S_S,S_S,S_S), \
1961 #define OP_SVE_VVV_S_B \
1963 QLF3(S_S,S_B,S_B), \
1965 #define OP_SVE_VVV_QHD_DBS \
1967 QLF3(S_Q,S_D,S_D), \
1968 QLF3(S_H,S_B,S_B), \
1969 QLF3(S_D,S_S,S_S), \
1971 #define OP_SVE_VVV_HSD_BHS \
1973 QLF3(S_H,S_B,S_B), \
1974 QLF3(S_S,S_H,S_H), \
1975 QLF3(S_D,S_S,S_S), \
1977 #define OP_SVE_VVV_HSD_BHS2 \
1979 QLF3(S_H,S_H,S_B), \
1980 QLF3(S_S,S_S,S_H), \
1981 QLF3(S_D,S_D,S_S), \
1983 #define OP_SVE_VVV_BHS_HSD \
1985 QLF3(S_B,S_H,S_H), \
1986 QLF3(S_H,S_S,S_S), \
1987 QLF3(S_S,S_D,S_D), \
1989 #define OP_SVE_VV_BHS_HSD \
1995 #define OP_SVE_VVV_SD_BH \
1997 QLF3(S_S,S_B,S_B), \
1998 QLF3(S_D,S_H,S_H), \
2000 #define OP_SVE_VVV_SD \
2002 QLF3(S_S,S_S,S_S), \
2003 QLF3(S_D,S_D,S_D), \
2005 #define OP_SVE_VV_BHSD \
2012 #define OP_SVE_VV_BHSDQ \
2020 #define OP_SVE_VV_HSD \
2026 #define OP_SVE_VVU_BHS_HSD \
2028 QLF3(S_B,S_H,NIL), \
2029 QLF3(S_H,S_S,NIL), \
2030 QLF3(S_S,S_D,NIL), \
2032 #define OP_SVE_VV_HSD_BHS \
2038 #define OP_SVE_VV_SD \
2043 #define OP_SVE_VWW_BHSD \
2050 #define OP_SVE_VXX_BHSD \
2057 #define OP_SVE_VZVD_BHS \
2059 QLF4(S_B,P_Z,S_B,S_D), \
2060 QLF4(S_H,P_Z,S_H,S_D), \
2061 QLF4(S_S,P_Z,S_S,S_D), \
2063 #define OP_SVE_VZVU_BHSD \
2065 QLF4(S_B,P_Z,S_B,NIL), \
2066 QLF4(S_H,P_Z,S_H,NIL), \
2067 QLF4(S_S,P_Z,S_S,NIL), \
2068 QLF4(S_D,P_Z,S_D,NIL), \
2070 #define OP_SVE_VZVV_BHSD \
2072 QLF4(S_B,P_Z,S_B,S_B), \
2073 QLF4(S_H,P_Z,S_H,S_H), \
2074 QLF4(S_S,P_Z,S_S,S_S), \
2075 QLF4(S_D,P_Z,S_D,S_D), \
2077 #define OP_SVE_VZVV_HSD \
2079 QLF4(S_H,P_Z,S_H,S_H), \
2080 QLF4(S_S,P_Z,S_S,S_S), \
2081 QLF4(S_D,P_Z,S_D,S_D), \
2083 #define OP_SVE_VZVV_SD \
2085 QLF4(S_S,P_Z,S_S,S_S), \
2086 QLF4(S_D,P_Z,S_D,S_D), \
2088 #define OP_SVE_VZVV_BH \
2090 QLF4(S_B,P_Z,S_B,S_B), \
2091 QLF4(S_H,P_Z,S_H,S_H), \
2093 #define OP_SVE_VZV_SD \
2095 QLF3(S_S,P_Z,S_S), \
2096 QLF3(S_D,P_Z,S_D), \
2098 #define OP_SVE_VZV_HSD \
2100 QLF3(S_H,P_Z,S_H), \
2101 QLF3(S_S,P_Z,S_S), \
2102 QLF3(S_D,P_Z,S_D), \
2104 #define OP_SVE_V_HSD \
2114 #define OP_SVE_WV_BHSD \
2125 #define OP_SVE_XUV_BHSD \
2132 #define OP_SVE_XVW_BHSD \
2139 #define OP_SVE_XV_BHSD \
2146 #define OP_SVE_XWU \
2150 #define OP_SVE_XXU \
2154 /* e.g. UDOT <Vd>.2S, <Vn>.8B, <Vm>.8B. */
2157 QLF3(V_2S, V_8B, V_8B), \
2158 QLF3(V_4S, V_16B, V_16B),\
2161 /* e.g. UDOT <Vd>.2S, <Vn>.8B, <Vm>.4B[<index>]. */
2164 QLF3(V_2S, V_8B, S_4B),\
2165 QLF3(V_4S, V_16B, S_4B),\
2168 /* e.g. SHA512H <Qd>, <Qn>, <Vm>.2D\f. */
2169 #define QL_SHA512UPT \
2171 QLF3(S_Q, S_Q, V_2D), \
2174 /* e.g. SHA512SU0 <Vd.2D>, <Vn>.2D\f. */
2175 #define QL_V2SAME2D \
2180 /* e.g. SHA512SU1 <Vd>.2D, <Vn>.2D, <Vm>.2D>. */
2181 #define QL_V3SAME2D \
2183 QLF3(V_2D, V_2D, V_2D), \
2186 /* e.g. EOR3 <Vd>.16B, <Vn>.16B, <Vm>.16B, <Va>.16B. */
2187 #define QL_V4SAME16B \
2189 QLF4(V_16B, V_16B, V_16B, V_16B), \
2192 /* e.g. SM3SS1 <Vd>.4S, <Vn>.4S, <Vm>.4S, <Va>.4S. */
2193 #define QL_V4SAME4S \
2195 QLF4(V_4S, V_4S, V_4S, V_4S), \
2198 /* e.g. XAR <Vd>.2D, <Vn>.2D, <Vm>.2D, #<imm6>. */
2201 QLF4(V_2D, V_2D, V_2D, imm_0_63), \
2204 /* e.g. SM3TT1A <Vd>.4S, <Vn>.4S, <Vm>.S[<imm2>]. */
2207 QLF3(V_4S, V_4S, S_S),\
2210 /* e.g. FMLAL <Vd>.2S, <Vn>.2H, <Vm>.2H. */
2211 #define QL_V3FML2S \
2213 QLF3(V_2S, V_2H, V_2H),\
2216 /* e.g. FMLAL <Vd>.4S, <Vn>.4H, <Vm>.4H. */
2217 #define QL_V3FML4S \
2219 QLF3(V_4S, V_4H, V_4H),\
2222 /* e.g. FMLAL <Vd>.2S, <Vn>.2H, <Vm>.H[<index>]. */
2223 #define QL_V2FML2S \
2225 QLF3(V_2S, V_2H, S_H),\
2228 /* e.g. FMLAL <Vd>.4S, <Vn>.4H, <Vm>.H[<index>]. */
2229 #define QL_V2FML4S \
2231 QLF3(V_4S, V_4H, S_H),\
2234 /* e.g. RMIF <Xn>, #<shift>, #<mask>. */
2237 QLF3(X, imm_0_63, imm_0_15),\
2240 /* e.g. SETF8 <Wn>. */
2246 /* e.g. STLURB <Wt>, [<Xn|SP>{,#<simm>}]. */
2252 /* e.g. STLURB <Xt>, [<Xn|SP>{,#<simm>}]. */
2260 static const aarch64_feature_set aarch64_feature_v8
=
2261 AARCH64_FEATURE (AARCH64_FEATURE_V8
, 0);
2262 static const aarch64_feature_set aarch64_feature_fp
=
2263 AARCH64_FEATURE (AARCH64_FEATURE_FP
, 0);
2264 static const aarch64_feature_set aarch64_feature_simd
=
2265 AARCH64_FEATURE (AARCH64_FEATURE_SIMD
, 0);
2266 static const aarch64_feature_set aarch64_feature_crypto
=
2267 AARCH64_FEATURE (AARCH64_FEATURE_CRYPTO
| AARCH64_FEATURE_AES
2268 | AARCH64_FEATURE_SHA2
| AARCH64_FEATURE_SIMD
| AARCH64_FEATURE_FP
, 0);
2269 static const aarch64_feature_set aarch64_feature_crc
=
2270 AARCH64_FEATURE (AARCH64_FEATURE_CRC
, 0);
2271 static const aarch64_feature_set aarch64_feature_lse
=
2272 AARCH64_FEATURE (AARCH64_FEATURE_LSE
, 0);
2273 static const aarch64_feature_set aarch64_feature_lor
=
2274 AARCH64_FEATURE (AARCH64_FEATURE_LOR
, 0);
2275 static const aarch64_feature_set aarch64_feature_rdma
=
2276 AARCH64_FEATURE (AARCH64_FEATURE_RDMA
, 0);
2277 static const aarch64_feature_set aarch64_feature_ras
=
2278 AARCH64_FEATURE (AARCH64_FEATURE_RAS
, 0);
2279 static const aarch64_feature_set aarch64_feature_v8_2
=
2280 AARCH64_FEATURE (AARCH64_FEATURE_V8_2
, 0);
2281 static const aarch64_feature_set aarch64_feature_fp_f16
=
2282 AARCH64_FEATURE (AARCH64_FEATURE_F16
| AARCH64_FEATURE_FP
, 0);
2283 static const aarch64_feature_set aarch64_feature_simd_f16
=
2284 AARCH64_FEATURE (AARCH64_FEATURE_F16
| AARCH64_FEATURE_SIMD
, 0);
2285 static const aarch64_feature_set aarch64_feature_stat_profile
=
2286 AARCH64_FEATURE (AARCH64_FEATURE_PROFILE
, 0);
2287 static const aarch64_feature_set aarch64_feature_sve
=
2288 AARCH64_FEATURE (AARCH64_FEATURE_SVE
, 0);
2289 static const aarch64_feature_set aarch64_feature_v8_3
=
2290 AARCH64_FEATURE (AARCH64_FEATURE_V8_3
, 0);
2291 static const aarch64_feature_set aarch64_feature_fp_v8_3
=
2292 AARCH64_FEATURE (AARCH64_FEATURE_V8_3
| AARCH64_FEATURE_FP
, 0);
2293 static const aarch64_feature_set aarch64_feature_compnum
=
2294 AARCH64_FEATURE (AARCH64_FEATURE_COMPNUM
, 0);
2295 static const aarch64_feature_set aarch64_feature_rcpc
=
2296 AARCH64_FEATURE (AARCH64_FEATURE_RCPC
, 0);
2297 static const aarch64_feature_set aarch64_feature_dotprod
=
2298 AARCH64_FEATURE (AARCH64_FEATURE_V8_2
| AARCH64_FEATURE_DOTPROD
, 0);
2299 static const aarch64_feature_set aarch64_feature_sha2
=
2300 AARCH64_FEATURE (AARCH64_FEATURE_V8
| AARCH64_FEATURE_SHA2
, 0);
2301 static const aarch64_feature_set aarch64_feature_aes
=
2302 AARCH64_FEATURE (AARCH64_FEATURE_V8
| AARCH64_FEATURE_AES
, 0);
2303 static const aarch64_feature_set aarch64_feature_v8_4
=
2304 AARCH64_FEATURE (AARCH64_FEATURE_V8_4
, 0);
2305 static const aarch64_feature_set aarch64_feature_crypto_v8_2
=
2306 AARCH64_FEATURE (AARCH64_FEATURE_V8_2
| AARCH64_FEATURE_CRYPTO
2307 | AARCH64_FEATURE_SIMD
| AARCH64_FEATURE_FP
, 0);
2308 static const aarch64_feature_set aarch64_feature_sm4
=
2309 AARCH64_FEATURE (AARCH64_FEATURE_V8_2
| AARCH64_FEATURE_SM4
2310 | AARCH64_FEATURE_SIMD
| AARCH64_FEATURE_FP
, 0);
2311 static const aarch64_feature_set aarch64_feature_sha3
=
2312 AARCH64_FEATURE (AARCH64_FEATURE_V8_2
| AARCH64_FEATURE_SHA2
2313 | AARCH64_FEATURE_SHA3
| AARCH64_FEATURE_SIMD
| AARCH64_FEATURE_FP
, 0);
2314 static const aarch64_feature_set aarch64_feature_fp_16_v8_2
=
2315 AARCH64_FEATURE (AARCH64_FEATURE_V8_2
| AARCH64_FEATURE_F16_FML
2316 | AARCH64_FEATURE_F16
| AARCH64_FEATURE_FP
, 0);
2317 static const aarch64_feature_set aarch64_feature_v8_5
=
2318 AARCH64_FEATURE (AARCH64_FEATURE_V8_5
, 0);
2319 static const aarch64_feature_set aarch64_feature_flagmanip
=
2320 AARCH64_FEATURE (AARCH64_FEATURE_FLAGMANIP
, 0);
2321 static const aarch64_feature_set aarch64_feature_frintts
=
2322 AARCH64_FEATURE (AARCH64_FEATURE_FRINTTS
, 0);
2323 static const aarch64_feature_set aarch64_feature_sb
=
2324 AARCH64_FEATURE (AARCH64_FEATURE_SB
, 0);
2325 static const aarch64_feature_set aarch64_feature_predres
=
2326 AARCH64_FEATURE (AARCH64_FEATURE_PREDRES
, 0);
2327 static const aarch64_feature_set aarch64_feature_bti
=
2328 AARCH64_FEATURE (AARCH64_FEATURE_BTI
, 0);
2329 static const aarch64_feature_set aarch64_feature_memtag
=
2330 AARCH64_FEATURE (AARCH64_FEATURE_V8_5
| AARCH64_FEATURE_MEMTAG
, 0);
2331 static const aarch64_feature_set aarch64_feature_tme
=
2332 AARCH64_FEATURE (AARCH64_FEATURE_TME
, 0);
2333 static const aarch64_feature_set aarch64_feature_sve2
=
2334 AARCH64_FEATURE (AARCH64_FEATURE_SVE2
, 0);
2335 static const aarch64_feature_set aarch64_feature_sve2aes
=
2336 AARCH64_FEATURE (AARCH64_FEATURE_SVE2
| AARCH64_FEATURE_SVE2_AES
, 0);
2337 static const aarch64_feature_set aarch64_feature_sve2sha3
=
2338 AARCH64_FEATURE (AARCH64_FEATURE_SVE2
| AARCH64_FEATURE_SVE2_SHA3
, 0);
2339 static const aarch64_feature_set aarch64_feature_sve2sm4
=
2340 AARCH64_FEATURE (AARCH64_FEATURE_SVE2
| AARCH64_FEATURE_SVE2_SM4
, 0);
2341 static const aarch64_feature_set aarch64_feature_sve2bitperm
=
2342 AARCH64_FEATURE (AARCH64_FEATURE_SVE2
| AARCH64_FEATURE_SVE2_BITPERM
, 0);
2345 #define CORE &aarch64_feature_v8
2346 #define FP &aarch64_feature_fp
2347 #define SIMD &aarch64_feature_simd
2348 #define CRYPTO &aarch64_feature_crypto
2349 #define CRC &aarch64_feature_crc
2350 #define LSE &aarch64_feature_lse
2351 #define LOR &aarch64_feature_lor
2352 #define RDMA &aarch64_feature_rdma
2353 #define FP_F16 &aarch64_feature_fp_f16
2354 #define SIMD_F16 &aarch64_feature_simd_f16
2355 #define RAS &aarch64_feature_ras
2356 #define STAT_PROFILE &aarch64_feature_stat_profile
2357 #define ARMV8_2 &aarch64_feature_v8_2
2358 #define SVE &aarch64_feature_sve
2359 #define ARMV8_3 &aarch64_feature_v8_3
2360 #define FP_V8_3 &aarch64_feature_fp_v8_3
2361 #define COMPNUM &aarch64_feature_compnum
2362 #define RCPC &aarch64_feature_rcpc
2363 #define SHA2 &aarch64_feature_sha2
2364 #define AES &aarch64_feature_aes
2365 #define ARMV8_4 &aarch64_feature_v8_4
2366 #define SHA3 &aarch64_feature_sha3
2367 #define SM4 &aarch64_feature_sm4
2368 #define CRYPTO_V8_2 &aarch64_feature_crypto_v8_2
2369 #define FP_F16_V8_2 &aarch64_feature_fp_16_v8_2
2370 #define DOTPROD &aarch64_feature_dotprod
2371 #define ARMV8_5 &aarch64_feature_v8_5
2372 #define FLAGMANIP &aarch64_feature_flagmanip
2373 #define FRINTTS &aarch64_feature_frintts
2374 #define SB &aarch64_feature_sb
2375 #define PREDRES &aarch64_feature_predres
2376 #define BTI &aarch64_feature_bti
2377 #define MEMTAG &aarch64_feature_memtag
2378 #define TME &aarch64_feature_tme
2379 #define SVE2 &aarch64_feature_sve2
2380 #define SVE2_AES &aarch64_feature_sve2aes
2381 #define SVE2_SHA3 &aarch64_feature_sve2sha3
2382 #define SVE2_SM4 &aarch64_feature_sve2sm4
2383 #define SVE2_BITPERM &aarch64_feature_sve2bitperm
2385 #define CORE_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS) \
2386 { NAME, OPCODE, MASK, CLASS, OP, CORE, OPS, QUALS, FLAGS, 0, 0, NULL }
2387 #define __FP_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS) \
2388 { NAME, OPCODE, MASK, CLASS, OP, FP, OPS, QUALS, FLAGS, 0, 0, NULL }
2389 #define SIMD_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS) \
2390 { NAME, OPCODE, MASK, CLASS, OP, SIMD, OPS, QUALS, FLAGS, 0, 0, NULL }
2391 #define _SIMD_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,VERIFIER) \
2392 { NAME, OPCODE, MASK, CLASS, OP, SIMD, OPS, QUALS, FLAGS, 0, 0, VERIFIER }
2393 #define CRYP_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2394 { NAME, OPCODE, MASK, CLASS, 0, CRYPTO, OPS, QUALS, FLAGS, 0, 0, NULL }
2395 #define _CRC_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2396 { NAME, OPCODE, MASK, CLASS, 0, CRC, OPS, QUALS, FLAGS, 0, 0, NULL }
2397 #define _LSE_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2398 { NAME, OPCODE, MASK, CLASS, 0, LSE, OPS, QUALS, FLAGS, 0, 0, NULL }
2399 #define _LOR_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2400 { NAME, OPCODE, MASK, CLASS, 0, LOR, OPS, QUALS, FLAGS, 0, 0, NULL }
2401 #define RDMA_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2402 { NAME, OPCODE, MASK, CLASS, 0, RDMA, OPS, QUALS, FLAGS, 0, 0, NULL }
2403 #define FF16_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2404 { NAME, OPCODE, MASK, CLASS, 0, FP_F16, OPS, QUALS, FLAGS, 0, 0, NULL }
2405 #define SF16_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2406 { NAME, OPCODE, MASK, CLASS, 0, SIMD_F16, OPS, QUALS, FLAGS, 0, 0, NULL }
2407 #define V8_2_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS) \
2408 { NAME, OPCODE, MASK, CLASS, OP, ARMV8_2, OPS, QUALS, FLAGS, 0, 0, NULL }
2409 #define _SVE_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,TIED) \
2410 { NAME, OPCODE, MASK, CLASS, OP, SVE, OPS, QUALS, \
2411 FLAGS | F_STRICT, 0, TIED, NULL }
2412 #define _SVE_INSNC(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,CONSTRAINTS,TIED) \
2413 { NAME, OPCODE, MASK, CLASS, OP, SVE, OPS, QUALS, \
2414 FLAGS | F_STRICT, CONSTRAINTS, TIED, NULL }
2415 #define V8_3_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2416 { NAME, OPCODE, MASK, CLASS, 0, ARMV8_3, OPS, QUALS, FLAGS, 0, 0, NULL }
2417 #define CNUM_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS) \
2418 { NAME, OPCODE, MASK, CLASS, OP, COMPNUM, OPS, QUALS, FLAGS, 0, 0, NULL }
2419 #define RCPC_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2420 { NAME, OPCODE, MASK, CLASS, 0, RCPC, OPS, QUALS, FLAGS, 0, 0, NULL }
2421 #define SHA2_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2422 { NAME, OPCODE, MASK, CLASS, 0, SHA2, OPS, QUALS, FLAGS, 0, 0, NULL }
2423 #define AES_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2424 { NAME, OPCODE, MASK, CLASS, 0, AES, OPS, QUALS, FLAGS, 0, 0, NULL }
2425 #define V8_4_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2426 { NAME, OPCODE, MASK, CLASS, 0, ARMV8_4, OPS, QUALS, FLAGS, 0, 0, NULL }
2427 #define CRYPTO_V8_2_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2428 { NAME, OPCODE, MASK, CLASS, 0, CRYPTO_V8_2, OPS, QUALS, FLAGS, 0, NULL }
2429 #define SHA3_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2430 { NAME, OPCODE, MASK, CLASS, 0, SHA3, OPS, QUALS, FLAGS, 0, 0, NULL }
2431 #define SM4_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2432 { NAME, OPCODE, MASK, CLASS, 0, SM4, OPS, QUALS, FLAGS, 0, 0, NULL }
2433 #define FP16_V8_2_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2434 { NAME, OPCODE, MASK, CLASS, 0, FP_F16_V8_2, OPS, QUALS, FLAGS, 0, 0, NULL }
2435 #define DOT_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2436 { NAME, OPCODE, MASK, CLASS, 0, DOTPROD, OPS, QUALS, FLAGS, 0, 0, NULL }
2437 #define V8_5_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2438 { NAME, OPCODE, MASK, CLASS, 0, ARMV8_5, OPS, QUALS, FLAGS, 0, 0, NULL }
2439 #define FLAGMANIP_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2440 { NAME, OPCODE, MASK, CLASS, 0, FLAGMANIP, OPS, QUALS, FLAGS, 0, 0, NULL }
2441 #define FRINTTS_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2442 { NAME, OPCODE, MASK, CLASS, 0, FRINTTS, OPS, QUALS, FLAGS, 0, 0, NULL }
2443 #define SB_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2444 { NAME, OPCODE, MASK, CLASS, 0, SB, OPS, QUALS, FLAGS, 0, 0, NULL }
2445 #define PREDRES_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2446 { NAME, OPCODE, MASK, CLASS, 0, PREDRES, OPS, QUALS, FLAGS, 0, 0, NULL }
2447 #define BTI_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2448 { NAME, OPCODE, MASK, CLASS, 0, BTI, OPS, QUALS, FLAGS, 0, 0, NULL }
2449 #define MEMTAG_INSN(NAME,OPCODE,MASK,CLASS,OPS,QUALS,FLAGS) \
2450 { NAME, OPCODE, MASK, CLASS, 0, MEMTAG, OPS, QUALS, FLAGS, 0, 0, NULL }
2451 #define _TME_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS) \
2452 { NAME, OPCODE, MASK, CLASS, OP, TME, OPS, QUALS, FLAGS, 0, 0, NULL }
2453 #define SVE2_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,TIED) \
2454 { NAME, OPCODE, MASK, CLASS, OP, SVE2, OPS, QUALS, \
2455 FLAGS | F_STRICT, 0, TIED, NULL }
2456 #define SVE2_INSNC(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,CONSTRAINTS,TIED) \
2457 { NAME, OPCODE, MASK, CLASS, OP, SVE2, OPS, QUALS, \
2458 FLAGS | F_STRICT, CONSTRAINTS, TIED, NULL }
2459 #define SVE2AES_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,TIED) \
2460 { NAME, OPCODE, MASK, CLASS, OP, SVE2_AES, OPS, QUALS, \
2461 FLAGS | F_STRICT, 0, TIED, NULL }
2462 #define SVE2SHA3_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,TIED) \
2463 { NAME, OPCODE, MASK, CLASS, OP, SVE2_SHA3, OPS, QUALS, \
2464 FLAGS | F_STRICT, 0, TIED, NULL }
2465 #define SVE2SM4_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,TIED) \
2466 { NAME, OPCODE, MASK, CLASS, OP, SVE2_SM4, OPS, QUALS, \
2467 FLAGS | F_STRICT, 0, TIED, NULL }
2468 #define SVE2SM4_INSNC(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,CONSTRAINTS,TIED) \
2469 { NAME, OPCODE, MASK, CLASS, OP, SVE2_SM4, OPS, QUALS, \
2470 FLAGS | F_STRICT, CONSTRAINTS, TIED, NULL }
2471 #define SVE2BITPERM_INSN(NAME,OPCODE,MASK,CLASS,OP,OPS,QUALS,FLAGS,TIED) \
2472 { NAME, OPCODE, MASK, CLASS, OP, SVE2_BITPERM, OPS, QUALS, \
2473 FLAGS | F_STRICT, 0, TIED, NULL }
2475 struct aarch64_opcode aarch64_opcode_table
[] =
2477 /* Add/subtract (with carry). */
2478 CORE_INSN ("adc", 0x1a000000, 0x7fe0fc00, addsub_carry
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_SF
),
2479 CORE_INSN ("adcs", 0x3a000000, 0x7fe0fc00, addsub_carry
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_SF
),
2480 CORE_INSN ("sbc", 0x5a000000, 0x7fe0fc00, addsub_carry
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_HAS_ALIAS
| F_SF
),
2481 CORE_INSN ("ngc", 0x5a0003e0, 0x7fe0ffe0, addsub_carry
, 0, OP2 (Rd
, Rm
), QL_I2SAME
, F_ALIAS
| F_SF
),
2482 CORE_INSN ("sbcs", 0x7a000000, 0x7fe0fc00, addsub_carry
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_HAS_ALIAS
| F_SF
),
2483 CORE_INSN ("ngcs", 0x7a0003e0, 0x7fe0ffe0, addsub_carry
, 0, OP2 (Rd
, Rm
), QL_I2SAME
, F_ALIAS
| F_SF
),
2484 /* Add/subtract (extended register). */
2485 CORE_INSN ("add", 0x0b200000, 0x7fe00000, addsub_ext
, 0, OP3 (Rd_SP
, Rn_SP
, Rm_EXT
), QL_I3_EXT
, F_SF
),
2486 CORE_INSN ("adds", 0x2b200000, 0x7fe00000, addsub_ext
, 0, OP3 (Rd
, Rn_SP
, Rm_EXT
), QL_I3_EXT
, F_HAS_ALIAS
| F_SF
),
2487 CORE_INSN ("cmn", 0x2b20001f, 0x7fe0001f, addsub_ext
, 0, OP2 (Rn_SP
, Rm_EXT
), QL_I2_EXT
, F_ALIAS
| F_SF
),
2488 CORE_INSN ("sub", 0x4b200000, 0x7fe00000, addsub_ext
, 0, OP3 (Rd_SP
, Rn_SP
, Rm_EXT
), QL_I3_EXT
, F_SF
),
2489 CORE_INSN ("subs", 0x6b200000, 0x7fe00000, addsub_ext
, 0, OP3 (Rd
, Rn_SP
, Rm_EXT
), QL_I3_EXT
, F_HAS_ALIAS
| F_SF
),
2490 CORE_INSN ("cmp", 0x6b20001f, 0x7fe0001f, addsub_ext
, 0, OP2 (Rn_SP
, Rm_EXT
), QL_I2_EXT
, F_ALIAS
| F_SF
),
2491 /* Add/subtract (immediate). */
2492 CORE_INSN ("add", 0x11000000, 0x7f000000, addsub_imm
, OP_ADD
, OP3 (Rd_SP
, Rn_SP
, AIMM
), QL_R2NIL
, F_HAS_ALIAS
| F_SF
),
2493 CORE_INSN ("mov", 0x11000000, 0x7ffffc00, addsub_imm
, 0, OP2 (Rd_SP
, Rn_SP
), QL_I2SP
, F_ALIAS
| F_SF
),
2494 CORE_INSN ("adds", 0x31000000, 0x7f000000, addsub_imm
, 0, OP3 (Rd
, Rn_SP
, AIMM
), QL_R2NIL
, F_HAS_ALIAS
| F_SF
),
2495 CORE_INSN ("cmn", 0x3100001f, 0x7f00001f, addsub_imm
, 0, OP2 (Rn_SP
, AIMM
), QL_R1NIL
, F_ALIAS
| F_SF
),
2496 CORE_INSN ("sub", 0x51000000, 0x7f000000, addsub_imm
, 0, OP3 (Rd_SP
, Rn_SP
, AIMM
), QL_R2NIL
, F_SF
),
2497 CORE_INSN ("subs", 0x71000000, 0x7f000000, addsub_imm
, 0, OP3 (Rd
, Rn_SP
, AIMM
), QL_R2NIL
, F_HAS_ALIAS
| F_SF
),
2498 CORE_INSN ("cmp", 0x7100001f, 0x7f00001f, addsub_imm
, 0, OP2 (Rn_SP
, AIMM
), QL_R1NIL
, F_ALIAS
| F_SF
),
2499 MEMTAG_INSN ("addg", 0x91800000, 0xffc0c000, addsub_imm
, OP4 (Rd_SP
, Rn_SP
, UIMM10
, UIMM4_ADDG
), QL_ADDG
, 0),
2500 MEMTAG_INSN ("subg", 0xd1800000, 0xffc0c000, addsub_imm
, OP4 (Rd_SP
, Rn_SP
, UIMM10
, UIMM4_ADDG
), QL_ADDG
, 0),
2501 /* Add/subtract (shifted register). */
2502 CORE_INSN ("add", 0x0b000000, 0x7f200000, addsub_shift
, 0, OP3 (Rd
, Rn
, Rm_SFT
), QL_I3SAMER
, F_SF
),
2503 CORE_INSN ("adds", 0x2b000000, 0x7f200000, addsub_shift
, 0, OP3 (Rd
, Rn
, Rm_SFT
), QL_I3SAMER
, F_HAS_ALIAS
| F_SF
),
2504 CORE_INSN ("cmn", 0x2b00001f, 0x7f20001f, addsub_shift
, 0, OP2 (Rn
, Rm_SFT
), QL_I2SAME
, F_ALIAS
| F_SF
),
2505 CORE_INSN ("sub", 0x4b000000, 0x7f200000, addsub_shift
, 0, OP3 (Rd
, Rn
, Rm_SFT
), QL_I3SAMER
, F_HAS_ALIAS
| F_SF
),
2506 CORE_INSN ("neg", 0x4b0003e0, 0x7f2003e0, addsub_shift
, 0, OP2 (Rd
, Rm_SFT
), QL_I2SAME
, F_ALIAS
| F_SF
),
2507 CORE_INSN ("subs", 0x6b000000, 0x7f200000, addsub_shift
, 0, OP3 (Rd
, Rn
, Rm_SFT
), QL_I3SAMER
, F_HAS_ALIAS
| F_SF
),
2508 CORE_INSN ("cmp", 0x6b00001f, 0x7f20001f, addsub_shift
, 0, OP2 (Rn
, Rm_SFT
), QL_I2SAME
, F_ALIAS
| F_SF
| F_P1
),
2509 CORE_INSN ("negs", 0x6b0003e0, 0x7f2003e0, addsub_shift
, 0, OP2 (Rd
, Rm_SFT
), QL_I2SAME
, F_ALIAS
| F_SF
),
2510 /* AdvSIMD across lanes. */
2511 SIMD_INSN ("saddlv", 0x0e303800, 0xbf3ffc00, asimdall
, 0, OP2 (Fd
, Vn
), QL_XLANES_L
, F_SIZEQ
),
2512 SIMD_INSN ("smaxv", 0x0e30a800, 0xbf3ffc00, asimdall
, 0, OP2 (Fd
, Vn
), QL_XLANES
, F_SIZEQ
),
2513 SIMD_INSN ("sminv", 0x0e31a800, 0xbf3ffc00, asimdall
, 0, OP2 (Fd
, Vn
), QL_XLANES
, F_SIZEQ
),
2514 SIMD_INSN ("addv", 0x0e31b800, 0xbf3ffc00, asimdall
, 0, OP2 (Fd
, Vn
), QL_XLANES
, F_SIZEQ
),
2515 SIMD_INSN ("uaddlv", 0x2e303800, 0xbf3ffc00, asimdall
, 0, OP2 (Fd
, Vn
), QL_XLANES_L
, F_SIZEQ
),
2516 SIMD_INSN ("umaxv", 0x2e30a800, 0xbf3ffc00, asimdall
, 0, OP2 (Fd
, Vn
), QL_XLANES
, F_SIZEQ
),
2517 SIMD_INSN ("uminv", 0x2e31a800, 0xbf3ffc00, asimdall
, 0, OP2 (Fd
, Vn
), QL_XLANES
, F_SIZEQ
),
2518 SIMD_INSN ("fmaxnmv",0x2e30c800, 0xbfbffc00, asimdall
, 0, OP2 (Fd
, Vn
), QL_XLANES_FP
, F_SIZEQ
),
2519 SF16_INSN ("fmaxnmv",0x0e30c800, 0xbffffc00, asimdall
, OP2 (Fd
, Vn
), QL_XLANES_FP_H
, F_SIZEQ
),
2520 SIMD_INSN ("fmaxv", 0x2e30f800, 0xbfbffc00, asimdall
, 0, OP2 (Fd
, Vn
), QL_XLANES_FP
, F_SIZEQ
),
2521 SF16_INSN ("fmaxv", 0x0e30f800, 0xbffffc00, asimdall
, OP2 (Fd
, Vn
), QL_XLANES_FP_H
, F_SIZEQ
),
2522 SIMD_INSN ("fminnmv",0x2eb0c800, 0xbfbffc00, asimdall
, 0, OP2 (Fd
, Vn
), QL_XLANES_FP
, F_SIZEQ
),
2523 SF16_INSN ("fminnmv",0x0eb0c800, 0xbffffc00, asimdall
, OP2 (Fd
, Vn
), QL_XLANES_FP_H
, F_SIZEQ
),
2524 SIMD_INSN ("fminv", 0x2eb0f800, 0xbfbffc00, asimdall
, 0, OP2 (Fd
, Vn
), QL_XLANES_FP
, F_SIZEQ
),
2525 SF16_INSN ("fminv", 0x0eb0f800, 0xbffffc00, asimdall
, OP2 (Fd
, Vn
), QL_XLANES_FP_H
, F_SIZEQ
),
2526 /* AdvSIMD three different. */
2527 SIMD_INSN ("saddl", 0x0e200000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2528 SIMD_INSN ("saddl2", 0x4e200000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2529 SIMD_INSN ("saddw", 0x0e201000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3WIDEBHS
, F_SIZEQ
),
2530 SIMD_INSN ("saddw2", 0x4e201000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3WIDEBHS2
, F_SIZEQ
),
2531 SIMD_INSN ("ssubl", 0x0e202000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2532 SIMD_INSN ("ssubl2", 0x4e202000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2533 SIMD_INSN ("ssubw", 0x0e203000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3WIDEBHS
, F_SIZEQ
),
2534 SIMD_INSN ("ssubw2", 0x4e203000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3WIDEBHS2
, F_SIZEQ
),
2535 SIMD_INSN ("addhn", 0x0e204000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3NARRBHS
, F_SIZEQ
),
2536 SIMD_INSN ("addhn2", 0x4e204000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3NARRBHS2
, F_SIZEQ
),
2537 SIMD_INSN ("sabal", 0x0e205000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2538 SIMD_INSN ("sabal2", 0x4e205000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2539 SIMD_INSN ("subhn", 0x0e206000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3NARRBHS
, F_SIZEQ
),
2540 SIMD_INSN ("subhn2", 0x4e206000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3NARRBHS2
, F_SIZEQ
),
2541 SIMD_INSN ("sabdl", 0x0e207000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2542 SIMD_INSN ("sabdl2", 0x4e207000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2543 SIMD_INSN ("smlal", 0x0e208000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2544 SIMD_INSN ("smlal2", 0x4e208000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2545 SIMD_INSN ("sqdmlal", 0x0e209000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGHS
, F_SIZEQ
),
2546 SIMD_INSN ("sqdmlal2",0x4e209000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGHS2
, F_SIZEQ
),
2547 SIMD_INSN ("smlsl", 0x0e20a000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2548 SIMD_INSN ("smlsl2", 0x4e20a000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2549 SIMD_INSN ("sqdmlsl", 0x0e20b000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGHS
, F_SIZEQ
),
2550 SIMD_INSN ("sqdmlsl2",0x4e20b000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGHS2
, F_SIZEQ
),
2551 SIMD_INSN ("smull", 0x0e20c000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2552 SIMD_INSN ("smull2", 0x4e20c000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2553 SIMD_INSN ("sqdmull", 0x0e20d000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGHS
, F_SIZEQ
),
2554 SIMD_INSN ("sqdmull2",0x4e20d000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGHS2
, F_SIZEQ
),
2555 SIMD_INSN ("pmull", 0x0e20e000, 0xffe0fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGB
, 0),
2556 AES_INSN ("pmull", 0x0ee0e000, 0xffe0fc00, asimddiff
, OP3 (Vd
, Vn
, Vm
), QL_V3LONGD
, 0),
2557 SIMD_INSN ("pmull2", 0x4e20e000, 0xffe0fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGB2
, 0),
2558 AES_INSN ("pmull2", 0x4ee0e000, 0xffe0fc00, asimddiff
, OP3 (Vd
, Vn
, Vm
), QL_V3LONGD2
, 0),
2559 SIMD_INSN ("uaddl", 0x2e200000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2560 SIMD_INSN ("uaddl2", 0x6e200000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2561 SIMD_INSN ("uaddw", 0x2e201000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3WIDEBHS
, F_SIZEQ
),
2562 SIMD_INSN ("uaddw2", 0x6e201000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3WIDEBHS2
, F_SIZEQ
),
2563 SIMD_INSN ("usubl", 0x2e202000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2564 SIMD_INSN ("usubl2", 0x6e202000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2565 SIMD_INSN ("usubw", 0x2e203000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3WIDEBHS
, F_SIZEQ
),
2566 SIMD_INSN ("usubw2", 0x6e203000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3WIDEBHS2
, F_SIZEQ
),
2567 SIMD_INSN ("raddhn", 0x2e204000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3NARRBHS
, F_SIZEQ
),
2568 SIMD_INSN ("raddhn2", 0x6e204000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3NARRBHS2
, F_SIZEQ
),
2569 SIMD_INSN ("uabal", 0x2e205000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2570 SIMD_INSN ("uabal2", 0x6e205000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2571 SIMD_INSN ("rsubhn", 0x2e206000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3NARRBHS
, F_SIZEQ
),
2572 SIMD_INSN ("rsubhn2", 0x6e206000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3NARRBHS2
, F_SIZEQ
),
2573 SIMD_INSN ("uabdl", 0x2e207000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2574 SIMD_INSN ("uabdl2", 0x6e207000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2575 SIMD_INSN ("umlal", 0x2e208000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2576 SIMD_INSN ("umlal2", 0x6e208000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2577 SIMD_INSN ("umlsl", 0x2e20a000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2578 SIMD_INSN ("umlsl2", 0x6e20a000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2579 SIMD_INSN ("umull", 0x2e20c000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS
, F_SIZEQ
),
2580 SIMD_INSN ("umull2", 0x6e20c000, 0xff20fc00, asimddiff
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3LONGBHS2
, F_SIZEQ
),
2581 /* AdvSIMD vector x indexed element. */
2582 SIMD_INSN ("smlal", 0x0f002000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L
, F_SIZEQ
),
2583 SIMD_INSN ("smlal2", 0x4f002000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L2
, F_SIZEQ
),
2584 SIMD_INSN ("sqdmlal", 0x0f003000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L
, F_SIZEQ
),
2585 SIMD_INSN ("sqdmlal2",0x4f003000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L2
, F_SIZEQ
),
2586 SIMD_INSN ("smlsl", 0x0f006000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L
, F_SIZEQ
),
2587 SIMD_INSN ("smlsl2", 0x4f006000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L2
, F_SIZEQ
),
2588 SIMD_INSN ("sqdmlsl", 0x0f007000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L
, F_SIZEQ
),
2589 SIMD_INSN ("sqdmlsl2",0x4f007000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L2
, F_SIZEQ
),
2590 SIMD_INSN ("mul", 0x0f008000, 0xbf00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT
, F_SIZEQ
),
2591 SIMD_INSN ("smull", 0x0f00a000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L
, F_SIZEQ
),
2592 SIMD_INSN ("smull2", 0x4f00a000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L2
, F_SIZEQ
),
2593 SIMD_INSN ("sqdmull", 0x0f00b000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L
, F_SIZEQ
),
2594 SIMD_INSN ("sqdmull2",0x4f00b000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L2
, F_SIZEQ
),
2595 SIMD_INSN ("sqdmulh", 0x0f00c000, 0xbf00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT
, F_SIZEQ
),
2596 SIMD_INSN ("sqrdmulh",0x0f00d000, 0xbf00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT
, F_SIZEQ
),
2597 _SIMD_INSN ("fmla", 0x0f801000, 0xbf80f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em
), QL_ELEMENT_FP
, F_SIZEQ
, VERIFIER (elem_sd
)),
2598 SF16_INSN ("fmla", 0x0f001000, 0xbfc0f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_FP_H
, F_SIZEQ
),
2599 _SIMD_INSN ("fmls", 0x0f805000, 0xbf80f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em
), QL_ELEMENT_FP
, F_SIZEQ
, VERIFIER (elem_sd
)),
2600 SF16_INSN ("fmls", 0x0f005000, 0xbfc0f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_FP_H
, F_SIZEQ
),
2601 _SIMD_INSN ("fmul", 0x0f809000, 0xbf80f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em
), QL_ELEMENT_FP
, F_SIZEQ
, VERIFIER (elem_sd
)),
2602 SF16_INSN ("fmul", 0x0f009000, 0xbfc0f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_FP_H
, F_SIZEQ
),
2603 SIMD_INSN ("mla", 0x2f000000, 0xbf00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT
, F_SIZEQ
),
2604 SIMD_INSN ("umlal", 0x2f002000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L
, F_SIZEQ
),
2605 SIMD_INSN ("umlal2", 0x6f002000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L2
, F_SIZEQ
),
2606 SIMD_INSN ("mls", 0x2f004000, 0xbf00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT
, F_SIZEQ
),
2607 SIMD_INSN ("umlsl", 0x2f006000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L
, F_SIZEQ
),
2608 SIMD_INSN ("umlsl2", 0x6f006000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L2
, F_SIZEQ
),
2609 SIMD_INSN ("umull", 0x2f00a000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L
, F_SIZEQ
),
2610 SIMD_INSN ("umull2", 0x6f00a000, 0xff00f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_L2
, F_SIZEQ
),
2611 _SIMD_INSN ("fmulx", 0x2f809000, 0xbf80f400, asimdelem
, 0, OP3 (Vd
, Vn
, Em
), QL_ELEMENT_FP
, F_SIZEQ
, VERIFIER (elem_sd
)),
2612 SF16_INSN ("fmulx", 0x2f009000, 0xbfc0f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT_FP_H
, F_SIZEQ
),
2613 RDMA_INSN ("sqrdmlah",0x2f00d000, 0xbf00f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT
, F_SIZEQ
),
2614 RDMA_INSN ("sqrdmlsh",0x2f00f000, 0xbf00f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_ELEMENT
, F_SIZEQ
),
2615 CNUM_INSN ("fcmla", 0x2f001000, 0xbf009400, asimdelem
, OP_FCMLA_ELEM
, OP4 (Vd
, Vn
, Em
, IMM_ROT2
), QL_ELEMENT_ROT
, F_SIZEQ
),
2617 SIMD_INSN ("ext", 0x2e000000, 0xbfe08400, asimdext
, 0, OP4 (Vd
, Vn
, Vm
, IDX
), QL_VEXT
, F_SIZEQ
),
2618 /* AdvSIMD modified immediate. */
2619 SIMD_INSN ("movi", 0x0f000400, 0xbff89c00, asimdimm
, 0, OP2 (Vd
, SIMD_IMM_SFT
), QL_SIMD_IMM_S0W
, F_SIZEQ
),
2620 SIMD_INSN ("orr", 0x0f001400, 0xbff89c00, asimdimm
, 0, OP2 (Vd
, SIMD_IMM_SFT
), QL_SIMD_IMM_S0W
, F_SIZEQ
),
2621 SIMD_INSN ("movi", 0x0f008400, 0xbff8dc00, asimdimm
, 0, OP2 (Vd
, SIMD_IMM_SFT
), QL_SIMD_IMM_S0H
, F_SIZEQ
),
2622 SIMD_INSN ("orr", 0x0f009400, 0xbff8dc00, asimdimm
, 0, OP2 (Vd
, SIMD_IMM_SFT
), QL_SIMD_IMM_S0H
, F_SIZEQ
),
2623 SIMD_INSN ("movi", 0x0f00c400, 0xbff8ec00, asimdimm
, 0, OP2 (Vd
, SIMD_IMM_SFT
), QL_SIMD_IMM_S1W
, F_SIZEQ
),
2624 SIMD_INSN ("movi", 0x0f00e400, 0xbff8fc00, asimdimm
, 0, OP2 (Vd
, SIMD_IMM_SFT
), QL_SIMD_IMM_B
, F_SIZEQ
),
2625 SIMD_INSN ("fmov", 0x0f00f400, 0xbff8fc00, asimdimm
, 0, OP2 (Vd
, SIMD_FPIMM
), QL_SIMD_IMM_S
, F_SIZEQ
),
2626 SF16_INSN ("fmov", 0x0f00fc00, 0xbff8fc00, asimdimm
, OP2 (Vd
, SIMD_FPIMM
), QL_SIMD_IMM_H
, F_SIZEQ
),
2627 SIMD_INSN ("mvni", 0x2f000400, 0xbff89c00, asimdimm
, 0, OP2 (Vd
, SIMD_IMM_SFT
), QL_SIMD_IMM_S0W
, F_SIZEQ
),
2628 SIMD_INSN ("bic", 0x2f001400, 0xbff89c00, asimdimm
, 0, OP2 (Vd
, SIMD_IMM_SFT
), QL_SIMD_IMM_S0W
, F_SIZEQ
),
2629 SIMD_INSN ("mvni", 0x2f008400, 0xbff8dc00, asimdimm
, 0, OP2 (Vd
, SIMD_IMM_SFT
), QL_SIMD_IMM_S0H
, F_SIZEQ
),
2630 SIMD_INSN ("bic", 0x2f009400, 0xbff8dc00, asimdimm
, 0, OP2 (Vd
, SIMD_IMM_SFT
), QL_SIMD_IMM_S0H
, F_SIZEQ
),
2631 SIMD_INSN ("mvni", 0x2f00c400, 0xbff8ec00, asimdimm
, 0, OP2 (Vd
, SIMD_IMM_SFT
), QL_SIMD_IMM_S1W
, F_SIZEQ
),
2632 SIMD_INSN ("movi", 0x2f00e400, 0xfff8fc00, asimdimm
, 0, OP2 (Sd
, SIMD_IMM
), QL_SIMD_IMM_D
, F_SIZEQ
),
2633 SIMD_INSN ("movi", 0x6f00e400, 0xfff8fc00, asimdimm
, 0, OP2 (Vd
, SIMD_IMM
), QL_SIMD_IMM_V2D
, F_SIZEQ
),
2634 SIMD_INSN ("fmov", 0x6f00f400, 0xfff8fc00, asimdimm
, 0, OP2 (Vd
, SIMD_FPIMM
), QL_SIMD_IMM_V2D
, F_SIZEQ
),
2636 SIMD_INSN ("dup", 0x0e000400, 0xbfe0fc00, asimdins
, 0, OP2 (Vd
, En
), QL_DUP_VX
, F_T
),
2637 SIMD_INSN ("dup", 0x0e000c00, 0xbfe0fc00, asimdins
, 0, OP2 (Vd
, Rn
), QL_DUP_VR
, F_T
),
2638 SIMD_INSN ("smov",0x0e002c00, 0xbfe0fc00, asimdins
, 0, OP2 (Rd
, En
), QL_SMOV
, F_GPRSIZE_IN_Q
),
2639 SIMD_INSN ("umov",0x0e003c00, 0xbfe0fc00, asimdins
, 0, OP2 (Rd
, En
), QL_UMOV
, F_HAS_ALIAS
| F_GPRSIZE_IN_Q
),
2640 SIMD_INSN ("mov", 0x0e003c00, 0xbfe0fc00, asimdins
, 0, OP2 (Rd
, En
), QL_MOV
, F_ALIAS
| F_GPRSIZE_IN_Q
),
2641 SIMD_INSN ("ins", 0x4e001c00, 0xffe0fc00, asimdins
, 0, OP2 (Ed
, Rn
), QL_INS_XR
, F_HAS_ALIAS
),
2642 SIMD_INSN ("mov", 0x4e001c00, 0xffe0fc00, asimdins
, 0, OP2 (Ed
, Rn
), QL_INS_XR
, F_ALIAS
),
2643 SIMD_INSN ("ins", 0x6e000400, 0xffe08400, asimdins
, 0, OP2 (Ed
, En
), QL_S_2SAME
, F_HAS_ALIAS
),
2644 SIMD_INSN ("mov", 0x6e000400, 0xffe08400, asimdins
, 0, OP2 (Ed
, En
), QL_S_2SAME
, F_ALIAS
),
2645 /* AdvSIMD two-reg misc. */
2646 FRINTTS_INSN ("frint32z", 0x0e21e800, 0xbfbffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2647 FRINTTS_INSN ("frint32x", 0x2e21e800, 0xbfbffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2648 FRINTTS_INSN ("frint64z", 0x0e21f800, 0xbfbffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2649 FRINTTS_INSN ("frint64x", 0x2e21f800, 0xbfbffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2650 SIMD_INSN ("rev64", 0x0e200800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMEBHS
, F_SIZEQ
),
2651 SIMD_INSN ("rev16", 0x0e201800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMEB
, F_SIZEQ
),
2652 SIMD_INSN ("saddlp",0x0e202800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2PAIRWISELONGBHS
, F_SIZEQ
),
2653 SIMD_INSN ("suqadd",0x0e203800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAME
, F_SIZEQ
),
2654 SIMD_INSN ("cls", 0x0e204800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMEBHS
, F_SIZEQ
),
2655 SIMD_INSN ("cnt", 0x0e205800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMEB
, F_SIZEQ
),
2656 SIMD_INSN ("sadalp",0x0e206800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2PAIRWISELONGBHS
, F_SIZEQ
),
2657 SIMD_INSN ("sqabs", 0x0e207800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAME
, F_SIZEQ
),
2658 SIMD_INSN ("cmgt", 0x0e208800, 0xbf3ffc00, asimdmisc
, 0, OP3 (Vd
, Vn
, IMM0
), QL_V2SAME
, F_SIZEQ
),
2659 SIMD_INSN ("cmeq", 0x0e209800, 0xbf3ffc00, asimdmisc
, 0, OP3 (Vd
, Vn
, IMM0
), QL_V2SAME
, F_SIZEQ
),
2660 SIMD_INSN ("cmlt", 0x0e20a800, 0xbf3ffc00, asimdmisc
, 0, OP3 (Vd
, Vn
, IMM0
), QL_V2SAME
, F_SIZEQ
),
2661 SIMD_INSN ("abs", 0x0e20b800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAME
, F_SIZEQ
),
2662 SIMD_INSN ("xtn", 0x0e212800, 0xff3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2NARRBHS
, F_SIZEQ
),
2663 SIMD_INSN ("xtn2", 0x4e212800, 0xff3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2NARRBHS2
, F_SIZEQ
),
2664 SIMD_INSN ("sqxtn", 0xe214800, 0xff3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2NARRBHS
, F_SIZEQ
),
2665 SIMD_INSN ("sqxtn2",0x4e214800, 0xff3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2NARRBHS2
, F_SIZEQ
),
2666 SIMD_INSN ("fcvtn", 0x0e216800, 0xffbffc00, asimdmisc
, OP_FCVTN
, OP2 (Vd
, Vn
), QL_V2NARRHS
, F_MISC
),
2667 SIMD_INSN ("fcvtn2", 0x4e216800, 0xffbffc00, asimdmisc
, OP_FCVTN2
, OP2 (Vd
, Vn
), QL_V2NARRHS2
, F_MISC
),
2668 SIMD_INSN ("fcvtl", 0x0e217800, 0xffbffc00, asimdmisc
, OP_FCVTL
, OP2 (Vd
, Vn
), QL_V2LONGHS
, F_MISC
),
2669 SIMD_INSN ("fcvtl2", 0x4e217800, 0xffbffc00, asimdmisc
, OP_FCVTL2
, OP2 (Vd
, Vn
), QL_V2LONGHS2
, F_MISC
),
2670 SIMD_INSN ("frintn", 0x0e218800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2671 SF16_INSN ("frintn", 0x0e798800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2672 SIMD_INSN ("frintm", 0x0e219800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2673 SF16_INSN ("frintm", 0x0e799800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2674 SIMD_INSN ("fcvtns", 0x0e21a800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2675 SF16_INSN ("fcvtns", 0x0e79a800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2676 SIMD_INSN ("fcvtms", 0x0e21b800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2677 SF16_INSN ("fcvtms", 0x0e79b800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2678 SIMD_INSN ("fcvtas", 0x0e21c800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2679 SF16_INSN ("fcvtas", 0x0e79c800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2680 SIMD_INSN ("scvtf", 0x0e21d800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2681 SF16_INSN ("scvtf", 0x0e79d800, 0xbfbffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2682 SIMD_INSN ("fcmgt", 0x0ea0c800, 0xbfbffc00, asimdmisc
, 0, OP3 (Vd
, Vn
, FPIMM0
), QL_V2SAMESD
, F_SIZEQ
),
2683 SF16_INSN ("fcmgt", 0x0ef8c800, 0xbffffc00, asimdmisc
, OP3 (Vd
, Vn
, FPIMM0
), QL_V2SAMEH
, F_SIZEQ
),
2684 SIMD_INSN ("fcmeq", 0x0ea0d800, 0xbfbffc00, asimdmisc
, 0, OP3 (Vd
, Vn
, FPIMM0
), QL_V2SAMESD
, F_SIZEQ
),
2685 SF16_INSN ("fcmeq", 0x0ef8d800, 0xbffffc00, asimdmisc
, OP3 (Vd
, Vn
, FPIMM0
), QL_V2SAMEH
, F_SIZEQ
),
2686 SIMD_INSN ("fcmlt", 0x0ea0e800, 0xbfbffc00, asimdmisc
, 0, OP3 (Vd
, Vn
, FPIMM0
), QL_V2SAMESD
, F_SIZEQ
),
2687 SF16_INSN ("fcmlt", 0x0ef8e800, 0xbffffc00, asimdmisc
, OP3 (Vd
, Vn
, FPIMM0
), QL_V2SAMEH
, F_SIZEQ
),
2688 SIMD_INSN ("fabs", 0x0ea0f800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2689 SF16_INSN ("fabs", 0x0ef8f800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2690 SIMD_INSN ("frintp", 0x0ea18800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2691 SF16_INSN ("frintp", 0x0ef98800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2692 SIMD_INSN ("frintz", 0x0ea19800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2693 SF16_INSN ("frintz", 0x0ef99800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2694 SIMD_INSN ("fcvtps", 0x0ea1a800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2695 SF16_INSN ("fcvtps", 0x0ef9a800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2696 SIMD_INSN ("fcvtzs", 0x0ea1b800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2697 SF16_INSN ("fcvtzs", 0x0ef9b800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2698 SIMD_INSN ("urecpe", 0x0ea1c800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMES
, F_SIZEQ
),
2699 SIMD_INSN ("frecpe", 0x0ea1d800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2700 SF16_INSN ("frecpe", 0x0ef9d800, 0xbfbffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2701 SIMD_INSN ("rev32", 0x2e200800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMEBH
, F_SIZEQ
),
2702 SIMD_INSN ("uaddlp", 0x2e202800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2PAIRWISELONGBHS
, F_SIZEQ
),
2703 SIMD_INSN ("usqadd", 0x2e203800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAME
, F_SIZEQ
),
2704 SIMD_INSN ("clz", 0x2e204800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMEBHS
, F_SIZEQ
),
2705 SIMD_INSN ("uadalp", 0x2e206800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2PAIRWISELONGBHS
, F_SIZEQ
),
2706 SIMD_INSN ("sqneg", 0x2e207800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAME
, F_SIZEQ
),
2707 SIMD_INSN ("cmge", 0x2e208800, 0xbf3ffc00, asimdmisc
, 0, OP3 (Vd
, Vn
, IMM0
), QL_V2SAME
, F_SIZEQ
),
2708 SIMD_INSN ("cmle", 0x2e209800, 0xbf3ffc00, asimdmisc
, 0, OP3 (Vd
, Vn
, IMM0
), QL_V2SAME
, F_SIZEQ
),
2709 SIMD_INSN ("neg", 0x2e20b800, 0xbf3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAME
, F_SIZEQ
),
2710 SIMD_INSN ("sqxtun", 0x2e212800, 0xff3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2NARRBHS
, F_SIZEQ
),
2711 SIMD_INSN ("sqxtun2",0x6e212800, 0xff3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2NARRBHS2
, F_SIZEQ
),
2712 SIMD_INSN ("shll", 0x2e213800, 0xff3ffc00, asimdmisc
, 0, OP3 (Vd
, Vn
, SHLL_IMM
), QL_V2LONGBHS
, F_SIZEQ
),
2713 SIMD_INSN ("shll2", 0x6e213800, 0xff3ffc00, asimdmisc
, 0, OP3 (Vd
, Vn
, SHLL_IMM
), QL_V2LONGBHS2
, F_SIZEQ
),
2714 SIMD_INSN ("uqxtn", 0x2e214800, 0xff3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2NARRBHS
, F_SIZEQ
),
2715 SIMD_INSN ("uqxtn2", 0x6e214800, 0xff3ffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2NARRBHS2
, F_SIZEQ
),
2716 SIMD_INSN ("fcvtxn", 0x2e616800, 0xfffffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2NARRS
, 0),
2717 SIMD_INSN ("fcvtxn2",0x6e616800, 0xfffffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2NARRS2
, 0),
2718 SIMD_INSN ("frinta", 0x2e218800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2719 SF16_INSN ("frinta", 0x2e798800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2720 SIMD_INSN ("frintx", 0x2e219800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2721 SF16_INSN ("frintx", 0x2e799800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2722 SIMD_INSN ("fcvtnu", 0x2e21a800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2723 SF16_INSN ("fcvtnu", 0x2e79a800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2724 SIMD_INSN ("fcvtmu", 0x2e21b800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2725 SF16_INSN ("fcvtmu", 0x2e79b800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2726 SIMD_INSN ("fcvtau", 0x2e21c800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2727 SF16_INSN ("fcvtau", 0x2e79c800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2728 SIMD_INSN ("ucvtf", 0x2e21d800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2729 SF16_INSN ("ucvtf", 0x2e79d800, 0xbfbffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2730 SIMD_INSN ("not", 0x2e205800, 0xbffffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMEB
, F_SIZEQ
| F_HAS_ALIAS
),
2731 SIMD_INSN ("mvn", 0x2e205800, 0xbffffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMEB
, F_SIZEQ
| F_ALIAS
),
2732 SIMD_INSN ("rbit", 0x2e605800, 0xbffffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMEB
, F_SIZEQ
),
2733 SIMD_INSN ("fcmge", 0x2ea0c800, 0xbfbffc00, asimdmisc
, 0, OP3 (Vd
, Vn
, FPIMM0
), QL_V2SAMESD
, F_SIZEQ
),
2734 SF16_INSN ("fcmge", 0x2ef8c800, 0xbffffc00, asimdmisc
, OP3 (Vd
, Vn
, FPIMM0
), QL_V2SAMEH
, F_SIZEQ
),
2735 SIMD_INSN ("fcmle", 0x2ea0d800, 0xbfbffc00, asimdmisc
, 0, OP3 (Vd
, Vn
, FPIMM0
), QL_V2SAMESD
, F_SIZEQ
),
2736 SF16_INSN ("fcmle", 0x2ef8d800, 0xbffffc00, asimdmisc
, OP3 (Vd
, Vn
, FPIMM0
), QL_V2SAMEH
, F_SIZEQ
),
2737 SIMD_INSN ("fneg", 0x2ea0f800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2738 SF16_INSN ("fneg", 0x2ef8f800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2739 SIMD_INSN ("frinti", 0x2ea19800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2740 SF16_INSN ("frinti", 0x2ef99800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2741 SIMD_INSN ("fcvtpu", 0x2ea1a800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2742 SF16_INSN ("fcvtpu", 0x2ef9a800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2743 SIMD_INSN ("fcvtzu", 0x2ea1b800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2744 SF16_INSN ("fcvtzu", 0x2ef9b800, 0xbffffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2745 SIMD_INSN ("ursqrte",0x2ea1c800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMES
, F_SIZEQ
),
2746 SIMD_INSN ("frsqrte",0x2ea1d800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2747 SF16_INSN ("frsqrte",0x2ef9d800, 0xbfbffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2748 SIMD_INSN ("fsqrt", 0x2ea1f800, 0xbfbffc00, asimdmisc
, 0, OP2 (Vd
, Vn
), QL_V2SAMESD
, F_SIZEQ
),
2749 SF16_INSN ("fsqrt", 0x2ef9f800, 0xbfbffc00, asimdmisc
, OP2 (Vd
, Vn
), QL_V2SAMEH
, F_SIZEQ
),
2750 /* AdvSIMD ZIP/UZP/TRN. */
2751 SIMD_INSN ("uzp1", 0xe001800, 0xbf20fc00, asimdperm
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2752 SIMD_INSN ("trn1", 0xe002800, 0xbf20fc00, asimdperm
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2753 SIMD_INSN ("zip1", 0xe003800, 0xbf20fc00, asimdperm
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2754 SIMD_INSN ("uzp2", 0xe005800, 0xbf20fc00, asimdperm
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2755 SIMD_INSN ("trn2", 0xe006800, 0xbf20fc00, asimdperm
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2756 SIMD_INSN ("zip2", 0xe007800, 0xbf20fc00, asimdperm
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2757 /* AdvSIMD three same. */
2758 SIMD_INSN ("shadd", 0xe200400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2759 SIMD_INSN ("sqadd", 0xe200c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2760 SIMD_INSN ("srhadd", 0xe201400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2761 SIMD_INSN ("shsub", 0xe202400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2762 SIMD_INSN ("sqsub", 0xe202c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2763 SIMD_INSN ("cmgt", 0xe203400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2764 SIMD_INSN ("cmge", 0xe203c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2765 SIMD_INSN ("sshl", 0xe204400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2766 SIMD_INSN ("sqshl", 0xe204c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2767 SIMD_INSN ("srshl", 0xe205400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2768 SIMD_INSN ("sqrshl", 0xe205c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2769 SIMD_INSN ("smax", 0xe206400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2770 SIMD_INSN ("smin", 0xe206c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2771 SIMD_INSN ("sabd", 0xe207400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2772 SIMD_INSN ("saba", 0xe207c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2773 SIMD_INSN ("add", 0xe208400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2774 SIMD_INSN ("cmtst", 0xe208c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2775 SIMD_INSN ("mla", 0xe209400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2776 SIMD_INSN ("mul", 0xe209c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2777 SIMD_INSN ("smaxp", 0xe20a400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2778 SIMD_INSN ("sminp", 0xe20ac00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2779 SIMD_INSN ("sqdmulh", 0xe20b400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEHS
, F_SIZEQ
),
2780 SIMD_INSN ("addp", 0xe20bc00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2781 SIMD_INSN ("fmaxnm", 0xe20c400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2782 SF16_INSN ("fmaxnm", 0xe400400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2783 SIMD_INSN ("fmla", 0xe20cc00, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2784 SF16_INSN ("fmla", 0xe400c00, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2785 SIMD_INSN ("fadd", 0xe20d400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2786 SF16_INSN ("fadd", 0xe401400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2787 SIMD_INSN ("fmulx", 0xe20dc00, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2788 SF16_INSN ("fmulx", 0xe401c00, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2789 SIMD_INSN ("fcmeq", 0xe20e400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2790 SF16_INSN ("fcmeq", 0xe402400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2791 SIMD_INSN ("fmax", 0xe20f400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2792 SF16_INSN ("fmax", 0xe403400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2793 SIMD_INSN ("frecps", 0xe20fc00, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2794 SF16_INSN ("frecps", 0xe403c00, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2795 SIMD_INSN ("and", 0xe201c00, 0xbfe0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEB
, F_SIZEQ
),
2796 SIMD_INSN ("bic", 0xe601c00, 0xbfe0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEB
, F_SIZEQ
),
2797 SIMD_INSN ("fminnm", 0xea0c400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2798 SF16_INSN ("fminnm", 0xec00400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2799 SIMD_INSN ("fmls", 0xea0cc00, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2800 SF16_INSN ("fmls", 0xec00c00, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2801 SIMD_INSN ("fsub", 0xea0d400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2802 SF16_INSN ("fsub", 0xec01400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2803 SIMD_INSN ("fmin", 0xea0f400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2804 SF16_INSN ("fmin", 0xec03400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2805 SIMD_INSN ("frsqrts", 0xea0fc00, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2806 SF16_INSN ("frsqrts", 0xec03c00, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2807 SIMD_INSN ("orr", 0xea01c00, 0xbfe0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEB
, F_HAS_ALIAS
| F_SIZEQ
),
2808 SIMD_INSN ("mov", 0xea01c00, 0xbfe0fc00, asimdsame
, OP_MOV_V
, OP2 (Vd
, Vn
), QL_V2SAMEB
, F_ALIAS
| F_CONV
),
2809 SIMD_INSN ("orn", 0xee01c00, 0xbfe0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEB
, F_SIZEQ
),
2810 SIMD_INSN ("uhadd", 0x2e200400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2811 SIMD_INSN ("uqadd", 0x2e200c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2812 SIMD_INSN ("urhadd", 0x2e201400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2813 SIMD_INSN ("uhsub", 0x2e202400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2814 SIMD_INSN ("uqsub", 0x2e202c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2815 SIMD_INSN ("cmhi", 0x2e203400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2816 SIMD_INSN ("cmhs", 0x2e203c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2817 SIMD_INSN ("ushl", 0x2e204400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2818 SIMD_INSN ("uqshl", 0x2e204c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2819 SIMD_INSN ("urshl", 0x2e205400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2820 SIMD_INSN ("uqrshl", 0x2e205c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2821 SIMD_INSN ("umax", 0x2e206400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2822 SIMD_INSN ("umin", 0x2e206c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2823 SIMD_INSN ("uabd", 0x2e207400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2824 SIMD_INSN ("uaba", 0x2e207c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2825 SIMD_INSN ("sub", 0x2e208400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2826 SIMD_INSN ("cmeq", 0x2e208c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAME
, F_SIZEQ
),
2827 SIMD_INSN ("mls", 0x2e209400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2828 SIMD_INSN ("pmul", 0x2e209c00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEB
, F_SIZEQ
),
2829 SIMD_INSN ("umaxp", 0x2e20a400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2830 SIMD_INSN ("uminp", 0x2e20ac00, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEBHS
, F_SIZEQ
),
2831 SIMD_INSN ("sqrdmulh", 0x2e20b400, 0xbf20fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEHS
, F_SIZEQ
),
2832 SIMD_INSN ("fmaxnmp", 0x2e20c400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2833 SF16_INSN ("fmaxnmp", 0x2e400400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2834 SIMD_INSN ("faddp", 0x2e20d400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2835 SF16_INSN ("faddp", 0x2e401400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2836 SIMD_INSN ("fmul", 0x2e20dc00, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2837 SF16_INSN ("fmul", 0x2e401c00, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2838 SIMD_INSN ("fcmge", 0x2e20e400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2839 SF16_INSN ("fcmge", 0x2e402400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2840 SIMD_INSN ("facge", 0x2e20ec00, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2841 SF16_INSN ("facge", 0x2e402c00, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2842 SIMD_INSN ("fmaxp", 0x2e20f400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2843 SF16_INSN ("fmaxp", 0x2e403400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2844 SIMD_INSN ("fdiv", 0x2e20fc00, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2845 SF16_INSN ("fdiv", 0x2e403c00, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2846 SIMD_INSN ("eor", 0x2e201c00, 0xbfe0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEB
, F_SIZEQ
),
2847 SIMD_INSN ("bsl", 0x2e601c00, 0xbfe0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEB
, F_SIZEQ
),
2848 SIMD_INSN ("fminnmp", 0x2ea0c400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2849 SF16_INSN ("fminnmp", 0x2ec00400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2850 SIMD_INSN ("fabd", 0x2ea0d400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2851 SF16_INSN ("fabd", 0x2ec01400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2852 SIMD_INSN ("fcmgt", 0x2ea0e400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2853 SF16_INSN ("fcmgt", 0x2ec02400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2854 SIMD_INSN ("facgt", 0x2ea0ec00, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2855 SF16_INSN ("facgt", 0x2ec02c00, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2856 SIMD_INSN ("fminp", 0x2ea0f400, 0xbfa0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMESD
, F_SIZEQ
),
2857 SF16_INSN ("fminp", 0x2ec03400, 0xbfe0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEH
, F_SIZEQ
),
2858 SIMD_INSN ("bit", 0x2ea01c00, 0xbfe0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEB
, F_SIZEQ
),
2859 SIMD_INSN ("bif", 0x2ee01c00, 0xbfe0fc00, asimdsame
, 0, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEB
, F_SIZEQ
),
2860 /* AdvSIMD three same extension. */
2861 RDMA_INSN ("sqrdmlah",0x2e008400, 0xbf20fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEHS
, F_SIZEQ
),
2862 RDMA_INSN ("sqrdmlsh",0x2e008c00, 0xbf20fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3SAMEHS
, F_SIZEQ
),
2863 CNUM_INSN ("fcmla", 0x2e00c400, 0xbf20e400, asimdsame
, 0, OP4 (Vd
, Vn
, Vm
, IMM_ROT1
), QL_V3SAMEHSD_ROT
, F_SIZEQ
),
2864 CNUM_INSN ("fcadd", 0x2e00e400, 0xbf20ec00, asimdsame
, 0, OP4 (Vd
, Vn
, Vm
, IMM_ROT3
), QL_V3SAMEHSD_ROT
, F_SIZEQ
),
2865 /* AdvSIMD shift by immediate. */
2866 SIMD_INSN ("sshr", 0xf000400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT
, 0),
2867 SIMD_INSN ("ssra", 0xf001400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT
, 0),
2868 SIMD_INSN ("srshr", 0xf002400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT
, 0),
2869 SIMD_INSN ("srsra", 0xf003400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT
, 0),
2870 SIMD_INSN ("shl", 0xf005400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSL
), QL_VSHIFT
, 0),
2871 SIMD_INSN ("sqshl", 0xf007400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSL
), QL_VSHIFT
, 0),
2872 SIMD_INSN ("shrn", 0xf008400, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN
, 0),
2873 SIMD_INSN ("shrn2", 0x4f008400, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN2
, 0),
2874 SIMD_INSN ("rshrn", 0xf008c00, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN
, 0),
2875 SIMD_INSN ("rshrn2", 0x4f008c00, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN2
, 0),
2876 SIMD_INSN ("sqshrn", 0xf009400, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN
, 0),
2877 SIMD_INSN ("sqshrn2", 0x4f009400, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN2
, 0),
2878 SIMD_INSN ("sqrshrn", 0xf009c00, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN
, 0),
2879 SIMD_INSN ("sqrshrn2", 0x4f009c00, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN2
, 0),
2880 SIMD_INSN ("sshll", 0xf00a400, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSL
), QL_VSHIFTL
, F_HAS_ALIAS
),
2881 SIMD_INSN ("sxtl", 0xf00a400, 0xff87fc00, asimdshf
, OP_SXTL
, OP2 (Vd
, Vn
), QL_V2LONGBHS
, F_ALIAS
| F_CONV
),
2882 SIMD_INSN ("sshll2", 0x4f00a400, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSL
), QL_VSHIFTL2
, F_HAS_ALIAS
),
2883 SIMD_INSN ("sxtl2", 0x4f00a400, 0xff87fc00, asimdshf
, OP_SXTL2
, OP2 (Vd
, Vn
), QL_V2LONGBHS2
, F_ALIAS
| F_CONV
),
2884 SIMD_INSN ("scvtf", 0xf00e400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT_SD
, 0),
2885 SF16_INSN ("scvtf", 0xf10e400, 0xbf80fc00, asimdshf
, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT_H
, 0),
2886 SIMD_INSN ("fcvtzs", 0xf00fc00, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT_SD
, 0),
2887 SF16_INSN ("fcvtzs", 0xf10fc00, 0xbf80fc00, asimdshf
, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT_H
, 0),
2888 SIMD_INSN ("ushr", 0x2f000400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT
, 0),
2889 SIMD_INSN ("usra", 0x2f001400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT
, 0),
2890 SIMD_INSN ("urshr", 0x2f002400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT
, 0),
2891 SIMD_INSN ("ursra", 0x2f003400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT
, 0),
2892 SIMD_INSN ("sri", 0x2f004400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT
, 0),
2893 SIMD_INSN ("sli", 0x2f005400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSL
), QL_VSHIFT
, 0),
2894 SIMD_INSN ("sqshlu", 0x2f006400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSL
), QL_VSHIFT
, 0),
2895 SIMD_INSN ("uqshl", 0x2f007400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSL
), QL_VSHIFT
, 0),
2896 SIMD_INSN ("sqshrun", 0x2f008400, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN
, 0),
2897 SIMD_INSN ("sqshrun2", 0x6f008400, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN2
, 0),
2898 SIMD_INSN ("sqrshrun", 0x2f008c00, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN
, 0),
2899 SIMD_INSN ("sqrshrun2", 0x6f008c00, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN2
, 0),
2900 SIMD_INSN ("uqshrn", 0x2f009400, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN
, 0),
2901 SIMD_INSN ("uqshrn2", 0x6f009400, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN2
, 0),
2902 SIMD_INSN ("uqrshrn", 0x2f009c00, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN
, 0),
2903 SIMD_INSN ("uqrshrn2", 0x6f009c00, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFTN2
, 0),
2904 SIMD_INSN ("ushll", 0x2f00a400, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSL
), QL_VSHIFTL
, F_HAS_ALIAS
),
2905 SIMD_INSN ("uxtl", 0x2f00a400, 0xff87fc00, asimdshf
, OP_UXTL
, OP2 (Vd
, Vn
), QL_V2LONGBHS
, F_ALIAS
| F_CONV
),
2906 SIMD_INSN ("ushll2", 0x6f00a400, 0xff80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSL
), QL_VSHIFTL2
, F_HAS_ALIAS
),
2907 SIMD_INSN ("uxtl2", 0x6f00a400, 0xff87fc00, asimdshf
, OP_UXTL2
, OP2 (Vd
, Vn
), QL_V2LONGBHS2
, F_ALIAS
| F_CONV
),
2908 SIMD_INSN ("ucvtf", 0x2f00e400, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT_SD
, 0),
2909 SF16_INSN ("ucvtf", 0x2f10e400, 0xbf80fc00, asimdshf
, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT_H
, 0),
2910 SIMD_INSN ("fcvtzu", 0x2f00fc00, 0xbf80fc00, asimdshf
, 0, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT_SD
, 0),
2911 SF16_INSN ("fcvtzu", 0x2f10fc00, 0xbf80fc00, asimdshf
, OP3 (Vd
, Vn
, IMM_VLSR
), QL_VSHIFT_H
, 0),
2912 /* AdvSIMD TBL/TBX. */
2913 SIMD_INSN ("tbl", 0xe000000, 0xbfe09c00, asimdtbl
, 0, OP3 (Vd
, LVn
, Vm
), QL_TABLE
, F_SIZEQ
),
2914 SIMD_INSN ("tbx", 0xe001000, 0xbfe09c00, asimdtbl
, 0, OP3 (Vd
, LVn
, Vm
), QL_TABLE
, F_SIZEQ
),
2915 /* AdvSIMD scalar three different. */
2916 SIMD_INSN ("sqdmlal", 0x5e209000, 0xff20fc00, asisddiff
, 0, OP3 (Sd
, Sn
, Sm
), QL_SISDL_HS
, F_SSIZE
),
2917 SIMD_INSN ("sqdmlsl", 0x5e20b000, 0xff20fc00, asisddiff
, 0, OP3 (Sd
, Sn
, Sm
), QL_SISDL_HS
, F_SSIZE
),
2918 SIMD_INSN ("sqdmull", 0x5e20d000, 0xff20fc00, asisddiff
, 0, OP3 (Sd
, Sn
, Sm
), QL_SISDL_HS
, F_SSIZE
),
2919 /* AdvSIMD scalar x indexed element. */
2920 SIMD_INSN ("sqdmlal", 0x5f003000, 0xff00f400, asisdelem
, 0, OP3 (Sd
, Sn
, Em16
), QL_SISDL_HS
, F_SSIZE
),
2921 SIMD_INSN ("sqdmlsl", 0x5f007000, 0xff00f400, asisdelem
, 0, OP3 (Sd
, Sn
, Em16
), QL_SISDL_HS
, F_SSIZE
),
2922 SIMD_INSN ("sqdmull", 0x5f00b000, 0xff00f400, asisdelem
, 0, OP3 (Sd
, Sn
, Em16
), QL_SISDL_HS
, F_SSIZE
),
2923 SIMD_INSN ("sqdmulh", 0x5f00c000, 0xff00f400, asisdelem
, 0, OP3 (Sd
, Sn
, Em16
), QL_SISD_HS
, F_SSIZE
),
2924 SIMD_INSN ("sqrdmulh", 0x5f00d000, 0xff00f400, asisdelem
, 0, OP3 (Sd
, Sn
, Em16
), QL_SISD_HS
, F_SSIZE
),
2925 _SIMD_INSN ("fmla", 0x5f801000, 0xff80f400, asisdelem
, 0, OP3 (Sd
, Sn
, Em
), QL_FP3
, F_SSIZE
, VERIFIER (elem_sd
)),
2926 SF16_INSN ("fmla", 0x5f001000, 0xffc0f400, asisdelem
, OP3 (Sd
, Sn
, Em16
), QL_FP3_H
, F_SSIZE
),
2927 _SIMD_INSN ("fmls", 0x5f805000, 0xff80f400, asisdelem
, 0, OP3 (Sd
, Sn
, Em
), QL_FP3
, F_SSIZE
, VERIFIER (elem_sd
)),
2928 SF16_INSN ("fmls", 0x5f005000, 0xffc0f400, asisdelem
, OP3 (Sd
, Sn
, Em16
), QL_FP3_H
, F_SSIZE
),
2929 _SIMD_INSN ("fmul", 0x5f809000, 0xff80f400, asisdelem
, 0, OP3 (Sd
, Sn
, Em
), QL_FP3
, F_SSIZE
, VERIFIER (elem_sd
)),
2930 SF16_INSN ("fmul", 0x5f009000, 0xffc0f400, asisdelem
, OP3 (Sd
, Sn
, Em16
), QL_FP3_H
, F_SSIZE
),
2931 _SIMD_INSN ("fmulx", 0x7f809000, 0xff80f400, asisdelem
, 0, OP3 (Sd
, Sn
, Em
), QL_FP3
, F_SSIZE
, VERIFIER (elem_sd
)),
2932 SF16_INSN ("fmulx", 0x7f009000, 0xffc0f400, asisdelem
, OP3 (Sd
, Sn
, Em16
), QL_FP3_H
, F_SSIZE
),
2933 RDMA_INSN ("sqrdmlah", 0x7f00d000, 0xff00f400, asisdelem
, OP3 (Sd
, Sn
, Em16
), QL_SISD_HS
, F_SSIZE
),
2934 RDMA_INSN ("sqrdmlsh", 0x7f00f000, 0xff00f400, asisdelem
, OP3 (Sd
, Sn
, Em16
), QL_SISD_HS
, F_SSIZE
),
2935 /* AdvSIMD load/store multiple structures. */
2936 SIMD_INSN ("st4", 0xc000000, 0xbfff0000, asisdlse
, 0, OP2 (LVt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDST
, F_SIZEQ
| F_OD(4)),
2937 SIMD_INSN ("st1", 0xc000000, 0xbfff0000, asisdlse
, 0, OP2 (LVt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDST_ANY
, F_SIZEQ
| F_OD(1)),
2938 SIMD_INSN ("st2", 0xc000000, 0xbfff0000, asisdlse
, 0, OP2 (LVt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDST
, F_SIZEQ
| F_OD(2)),
2939 SIMD_INSN ("st3", 0xc000000, 0xbfff0000, asisdlse
, 0, OP2 (LVt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDST
, F_SIZEQ
| F_OD(3)),
2940 SIMD_INSN ("ld4", 0xc400000, 0xbfff0000, asisdlse
, 0, OP2 (LVt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDST
, F_SIZEQ
| F_OD(4)),
2941 SIMD_INSN ("ld1", 0xc400000, 0xbfff0000, asisdlse
, 0, OP2 (LVt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDST_ANY
, F_SIZEQ
| F_OD(1)),
2942 SIMD_INSN ("ld2", 0xc400000, 0xbfff0000, asisdlse
, 0, OP2 (LVt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDST
, F_SIZEQ
| F_OD(2)),
2943 SIMD_INSN ("ld3", 0xc400000, 0xbfff0000, asisdlse
, 0, OP2 (LVt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDST
, F_SIZEQ
| F_OD(3)),
2944 /* AdvSIMD load/store multiple structures (post-indexed). */
2945 SIMD_INSN ("st4", 0xc800000, 0xbfe00000, asisdlsep
, 0, OP2 (LVt
, SIMD_ADDR_POST
), QL_SIMD_LDST
, F_SIZEQ
| F_OD(4)),
2946 SIMD_INSN ("st1", 0xc800000, 0xbfe00000, asisdlsep
, 0, OP2 (LVt
, SIMD_ADDR_POST
), QL_SIMD_LDST_ANY
, F_SIZEQ
| F_OD(1)),
2947 SIMD_INSN ("st2", 0xc800000, 0xbfe00000, asisdlsep
, 0, OP2 (LVt
, SIMD_ADDR_POST
), QL_SIMD_LDST
, F_SIZEQ
| F_OD(2)),
2948 SIMD_INSN ("st3", 0xc800000, 0xbfe00000, asisdlsep
, 0, OP2 (LVt
, SIMD_ADDR_POST
), QL_SIMD_LDST
, F_SIZEQ
| F_OD(3)),
2949 SIMD_INSN ("ld4", 0xcc00000, 0xbfe00000, asisdlsep
, 0, OP2 (LVt
, SIMD_ADDR_POST
), QL_SIMD_LDST
, F_SIZEQ
| F_OD(4)),
2950 SIMD_INSN ("ld1", 0xcc00000, 0xbfe00000, asisdlsep
, 0, OP2 (LVt
, SIMD_ADDR_POST
), QL_SIMD_LDST_ANY
, F_SIZEQ
| F_OD(1)),
2951 SIMD_INSN ("ld2", 0xcc00000, 0xbfe00000, asisdlsep
, 0, OP2 (LVt
, SIMD_ADDR_POST
), QL_SIMD_LDST
, F_SIZEQ
| F_OD(2)),
2952 SIMD_INSN ("ld3", 0xcc00000, 0xbfe00000, asisdlsep
, 0, OP2 (LVt
, SIMD_ADDR_POST
), QL_SIMD_LDST
, F_SIZEQ
| F_OD(3)),
2953 /* AdvSIMD load/store single structure. */
2954 SIMD_INSN ("st1", 0xd000000, 0xbfff2000, asisdlso
, 0, OP2 (LEt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDSTONE
, F_OD(1)),
2955 SIMD_INSN ("st3", 0xd002000, 0xbfff2000, asisdlso
, 0, OP2 (LEt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDSTONE
, F_OD(3)),
2956 SIMD_INSN ("st2", 0xd200000, 0xbfff2000, asisdlso
, 0, OP2 (LEt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDSTONE
, F_OD(2)),
2957 SIMD_INSN ("st4", 0xd202000, 0xbfff2000, asisdlso
, 0, OP2 (LEt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDSTONE
, F_OD(4)),
2958 SIMD_INSN ("ld1", 0xd400000, 0xbfff2000, asisdlso
, 0, OP2 (LEt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDSTONE
, F_OD(1)),
2959 SIMD_INSN ("ld3", 0xd402000, 0xbfff2000, asisdlso
, 0, OP2 (LEt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDSTONE
, F_OD(3)),
2960 SIMD_INSN ("ld1r", 0xd40c000, 0xbffff000, asisdlso
, 0, OP2 (LVt_AL
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDST_ANY
, F_SIZEQ
| F_OD(1)),
2961 SIMD_INSN ("ld3r", 0xd40e000, 0xbffff000, asisdlso
, 0, OP2 (LVt_AL
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDST_ANY
, F_SIZEQ
| F_OD(3)),
2962 SIMD_INSN ("ld2", 0xd600000, 0xbfff2000, asisdlso
, 0, OP2 (LEt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDSTONE
, F_OD(2)),
2963 SIMD_INSN ("ld4", 0xd602000, 0xbfff2000, asisdlso
, 0, OP2 (LEt
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDSTONE
, F_OD(4)),
2964 SIMD_INSN ("ld2r", 0xd60c000, 0xbffff000, asisdlso
, 0, OP2 (LVt_AL
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDST_ANY
, F_SIZEQ
| F_OD(2)),
2965 SIMD_INSN ("ld4r", 0xd60e000, 0xbffff000, asisdlso
, 0, OP2 (LVt_AL
, SIMD_ADDR_SIMPLE
), QL_SIMD_LDST_ANY
, F_SIZEQ
| F_OD(4)),
2966 /* AdvSIMD load/store single structure (post-indexed). */
2967 SIMD_INSN ("st1", 0xd800000, 0xbfe02000, asisdlsop
, 0, OP2 (LEt
, SIMD_ADDR_POST
), QL_SIMD_LDSTONE
, F_OD(1)),
2968 SIMD_INSN ("st3", 0xd802000, 0xbfe02000, asisdlsop
, 0, OP2 (LEt
, SIMD_ADDR_POST
), QL_SIMD_LDSTONE
, F_OD(3)),
2969 SIMD_INSN ("st2", 0xda00000, 0xbfe02000, asisdlsop
, 0, OP2 (LEt
, SIMD_ADDR_POST
), QL_SIMD_LDSTONE
, F_OD(2)),
2970 SIMD_INSN ("st4", 0xda02000, 0xbfe02000, asisdlsop
, 0, OP2 (LEt
, SIMD_ADDR_POST
), QL_SIMD_LDSTONE
, F_OD(4)),
2971 SIMD_INSN ("ld1", 0xdc00000, 0xbfe02000, asisdlsop
, 0, OP2 (LEt
, SIMD_ADDR_POST
), QL_SIMD_LDSTONE
, F_OD(1)),
2972 SIMD_INSN ("ld3", 0xdc02000, 0xbfe02000, asisdlsop
, 0, OP2 (LEt
, SIMD_ADDR_POST
), QL_SIMD_LDSTONE
, F_OD(3)),
2973 SIMD_INSN ("ld1r", 0xdc0c000, 0xbfe0f000, asisdlsop
, 0, OP2 (LVt_AL
, SIMD_ADDR_POST
), QL_SIMD_LDST_ANY
, F_SIZEQ
| F_OD(1)),
2974 SIMD_INSN ("ld3r", 0xdc0e000, 0xbfe0f000, asisdlsop
, 0, OP2 (LVt_AL
, SIMD_ADDR_POST
), QL_SIMD_LDST_ANY
, F_SIZEQ
| F_OD(3)),
2975 SIMD_INSN ("ld2", 0xde00000, 0xbfe02000, asisdlsop
, 0, OP2 (LEt
, SIMD_ADDR_POST
), QL_SIMD_LDSTONE
, F_OD(2)),
2976 SIMD_INSN ("ld4", 0xde02000, 0xbfe02000, asisdlsop
, 0, OP2 (LEt
, SIMD_ADDR_POST
), QL_SIMD_LDSTONE
, F_OD(4)),
2977 SIMD_INSN ("ld2r", 0xde0c000, 0xbfe0f000, asisdlsop
, 0, OP2 (LVt_AL
, SIMD_ADDR_POST
), QL_SIMD_LDST_ANY
, F_SIZEQ
| F_OD(2)),
2978 SIMD_INSN ("ld4r", 0xde0e000, 0xbfe0f000, asisdlsop
, 0, OP2 (LVt_AL
, SIMD_ADDR_POST
), QL_SIMD_LDST_ANY
, F_SIZEQ
| F_OD(4)),
2979 /* AdvSIMD scalar two-reg misc. */
2980 SIMD_INSN ("suqadd", 0x5e203800, 0xff3ffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAME
, F_SSIZE
),
2981 SIMD_INSN ("sqabs", 0x5e207800, 0xff3ffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAME
, F_SSIZE
),
2982 SIMD_INSN ("cmgt", 0x5e208800, 0xff3ffc00, asisdmisc
, 0, OP3 (Sd
, Sn
, IMM0
), QL_SISD_CMP_0
, F_SSIZE
),
2983 SIMD_INSN ("cmeq", 0x5e209800, 0xff3ffc00, asisdmisc
, 0, OP3 (Sd
, Sn
, IMM0
), QL_SISD_CMP_0
, F_SSIZE
),
2984 SIMD_INSN ("cmlt", 0x5e20a800, 0xff3ffc00, asisdmisc
, 0, OP3 (Sd
, Sn
, IMM0
), QL_SISD_CMP_0
, F_SSIZE
),
2985 SIMD_INSN ("abs", 0x5e20b800, 0xff3ffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_2SAMED
, F_SSIZE
),
2986 SIMD_INSN ("sqxtn", 0x5e214800, 0xff3ffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_SISD_NARROW
, F_SSIZE
),
2987 SIMD_INSN ("fcvtns", 0x5e21a800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
2988 SF16_INSN ("fcvtns", 0x5e79a800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
2989 SIMD_INSN ("fcvtms", 0x5e21b800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
2990 SF16_INSN ("fcvtms", 0x5e79b800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
2991 SIMD_INSN ("fcvtas", 0x5e21c800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
2992 SF16_INSN ("fcvtas", 0x5e79c800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
2993 SIMD_INSN ("scvtf", 0x5e21d800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
2994 SF16_INSN ("scvtf", 0x5e79d800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
2995 SIMD_INSN ("fcmgt", 0x5ea0c800, 0xffbffc00, asisdmisc
, 0, OP3 (Sd
, Sn
, FPIMM0
), QL_SISD_FCMP_0
, F_SSIZE
),
2996 SF16_INSN ("fcmgt", 0x5ef8c800, 0xfffffc00, asisdmisc
, OP3 (Sd
, Sn
, FPIMM0
), QL_SISD_FCMP_H_0
, F_SSIZE
),
2997 SIMD_INSN ("fcmeq", 0x5ea0d800, 0xffbffc00, asisdmisc
, 0, OP3 (Sd
, Sn
, FPIMM0
), QL_SISD_FCMP_0
, F_SSIZE
),
2998 SF16_INSN ("fcmeq", 0x5ef8d800, 0xfffffc00, asisdmisc
, OP3 (Sd
, Sn
, FPIMM0
), QL_SISD_FCMP_H_0
, F_SSIZE
),
2999 SIMD_INSN ("fcmlt", 0x5ea0e800, 0xffbffc00, asisdmisc
, 0, OP3 (Sd
, Sn
, FPIMM0
), QL_SISD_FCMP_0
, F_SSIZE
),
3000 SF16_INSN ("fcmlt", 0x5ef8e800, 0xfffffc00, asisdmisc
, OP3 (Sd
, Sn
, FPIMM0
), QL_SISD_FCMP_H_0
, F_SSIZE
),
3001 SIMD_INSN ("fcvtps", 0x5ea1a800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
3002 SF16_INSN ("fcvtps", 0x5ef9a800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
3003 SIMD_INSN ("fcvtzs", 0x5ea1b800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
3004 SF16_INSN ("fcvtzs", 0x5ef9b800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
3005 SIMD_INSN ("frecpe", 0x5ea1d800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
3006 SF16_INSN ("frecpe", 0x5ef9d800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
3007 SIMD_INSN ("frecpx", 0x5ea1f800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
3008 SF16_INSN ("frecpx", 0x5ef9f800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
3009 SIMD_INSN ("usqadd", 0x7e203800, 0xff3ffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAME
, F_SSIZE
),
3010 SIMD_INSN ("sqneg", 0x7e207800, 0xff3ffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAME
, F_SSIZE
),
3011 SIMD_INSN ("cmge", 0x7e208800, 0xff3ffc00, asisdmisc
, 0, OP3 (Sd
, Sn
, IMM0
), QL_SISD_CMP_0
, F_SSIZE
),
3012 SIMD_INSN ("cmle", 0x7e209800, 0xff3ffc00, asisdmisc
, 0, OP3 (Sd
, Sn
, IMM0
), QL_SISD_CMP_0
, F_SSIZE
),
3013 SIMD_INSN ("neg", 0x7e20b800, 0xff3ffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_2SAMED
, F_SSIZE
),
3014 SIMD_INSN ("sqxtun", 0x7e212800, 0xff3ffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_SISD_NARROW
, F_SSIZE
),
3015 SIMD_INSN ("uqxtn", 0x7e214800, 0xff3ffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_SISD_NARROW
, F_SSIZE
),
3016 SIMD_INSN ("fcvtxn", 0x7e216800, 0xffbffc00, asisdmisc
, OP_FCVTXN_S
, OP2 (Sd
, Sn
), QL_SISD_NARROW_S
, F_MISC
),
3017 SIMD_INSN ("fcvtnu", 0x7e21a800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
3018 SF16_INSN ("fcvtnu", 0x7e79a800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
3019 SIMD_INSN ("fcvtmu", 0x7e21b800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
3020 SF16_INSN ("fcvtmu", 0x7e79b800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
3021 SIMD_INSN ("fcvtau", 0x7e21c800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
3022 SF16_INSN ("fcvtau", 0x7e79c800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
3023 SIMD_INSN ("ucvtf", 0x7e21d800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
3024 SF16_INSN ("ucvtf", 0x7e79d800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
3025 SIMD_INSN ("fcmge", 0x7ea0c800, 0xffbffc00, asisdmisc
, 0, OP3 (Sd
, Sn
, FPIMM0
), QL_SISD_FCMP_0
, F_SSIZE
),
3026 SF16_INSN ("fcmge", 0x7ef8c800, 0xfffffc00, asisdmisc
, OP3 (Sd
, Sn
, FPIMM0
), QL_SISD_FCMP_H_0
, F_SSIZE
),
3027 SIMD_INSN ("fcmle", 0x7ea0d800, 0xffbffc00, asisdmisc
, 0, OP3 (Sd
, Sn
, FPIMM0
), QL_SISD_FCMP_0
, F_SSIZE
),
3028 SF16_INSN ("fcmle", 0x7ef8d800, 0xfffffc00, asisdmisc
, OP3 (Sd
, Sn
, FPIMM0
), QL_SISD_FCMP_H_0
, F_SSIZE
),
3029 SIMD_INSN ("fcvtpu", 0x7ea1a800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
3030 SF16_INSN ("fcvtpu", 0x7ef9a800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_SISD_FCMP_H_0
, F_SSIZE
),
3031 SIMD_INSN ("fcvtzu", 0x7ea1b800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
3032 SF16_INSN ("fcvtzu", 0x7ef9b800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
3033 SIMD_INSN ("frsqrte", 0x7ea1d800, 0xffbffc00, asisdmisc
, 0, OP2 (Sd
, Sn
), QL_S_2SAMESD
, F_SSIZE
),
3034 SF16_INSN ("frsqrte", 0x7ef9d800, 0xfffffc00, asisdmisc
, OP2 (Sd
, Sn
), QL_S_2SAMEH
, F_SSIZE
),
3035 /* AdvSIMD scalar copy. */
3036 SIMD_INSN ("dup", 0x5e000400, 0xffe0fc00, asisdone
, 0, OP2 (Sd
, En
), QL_S_2SAME
, F_HAS_ALIAS
),
3037 SIMD_INSN ("mov", 0x5e000400, 0xffe0fc00, asisdone
, 0, OP2 (Sd
, En
), QL_S_2SAME
, F_ALIAS
),
3038 /* AdvSIMD scalar pairwise. */
3039 SIMD_INSN ("addp", 0x5e31b800, 0xff3ffc00, asisdpair
, 0, OP2 (Sd
, Vn
), QL_SISD_PAIR_D
, F_SIZEQ
),
3040 SIMD_INSN ("fmaxnmp", 0x7e30c800, 0xffbffc00, asisdpair
, 0, OP2 (Sd
, Vn
), QL_SISD_PAIR
, F_SIZEQ
),
3041 SF16_INSN ("fmaxnmp", 0x5e30c800, 0xfffffc00, asisdpair
, OP2 (Sd
, Vn
), QL_SISD_PAIR_H
, F_SIZEQ
),
3042 SIMD_INSN ("faddp", 0x7e30d800, 0xffbffc00, asisdpair
, 0, OP2 (Sd
, Vn
), QL_SISD_PAIR
, F_SIZEQ
),
3043 SF16_INSN ("faddp", 0x5e30d800, 0xfffffc00, asisdpair
, OP2 (Sd
, Vn
), QL_SISD_PAIR_H
, F_SIZEQ
),
3044 SIMD_INSN ("fmaxp", 0x7e30f800, 0xffbffc00, asisdpair
, 0, OP2 (Sd
, Vn
), QL_SISD_PAIR
, F_SIZEQ
),
3045 SF16_INSN ("fmaxp", 0x5e30f800, 0xfffffc00, asisdpair
, OP2 (Sd
, Vn
), QL_SISD_PAIR_H
, F_SIZEQ
),
3046 SIMD_INSN ("fminnmp", 0x7eb0c800, 0xffbffc00, asisdpair
, 0, OP2 (Sd
, Vn
), QL_SISD_PAIR
, F_SIZEQ
),
3047 SF16_INSN ("fminnmp", 0x5eb0c800, 0xfffffc00, asisdpair
, OP2 (Sd
, Vn
), QL_SISD_PAIR_H
, F_SIZEQ
),
3048 SIMD_INSN ("fminp", 0x7eb0f800, 0xffbffc00, asisdpair
, 0, OP2 (Sd
, Vn
), QL_SISD_PAIR
, F_SIZEQ
),
3049 SF16_INSN ("fminp", 0x5eb0f800, 0xfffffc00, asisdpair
, OP2 (Sd
, Vn
), QL_SISD_PAIR_H
, F_SIZEQ
),
3050 /* AdvSIMD scalar three same. */
3051 SIMD_INSN ("sqadd", 0x5e200c00, 0xff20fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAME
, F_SSIZE
),
3052 SIMD_INSN ("sqsub", 0x5e202c00, 0xff20fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAME
, F_SSIZE
),
3053 SIMD_INSN ("sqshl", 0x5e204c00, 0xff20fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAME
, F_SSIZE
),
3054 SIMD_INSN ("sqrshl", 0x5e205c00, 0xff20fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAME
, F_SSIZE
),
3055 SIMD_INSN ("sqdmulh", 0x5e20b400, 0xff20fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_SISD_HS
, F_SSIZE
),
3056 SIMD_INSN ("fmulx", 0x5e20dc00, 0xffa0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_FP3
, F_SSIZE
),
3057 SF16_INSN ("fmulx", 0x5e401c00, 0xffe0fc00, asisdsame
, OP3 (Sd
, Sn
, Sm
), QL_FP3_H
, F_SSIZE
),
3058 SIMD_INSN ("fcmeq", 0x5e20e400, 0xffa0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_FP3
, F_SSIZE
),
3059 SF16_INSN ("fcmeq", 0x5e402400, 0xffe0fc00, asisdsame
, OP3 (Sd
, Sn
, Sm
), QL_FP3_H
, F_SSIZE
),
3060 SIMD_INSN ("frecps", 0x5e20fc00, 0xffa0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_FP3
, F_SSIZE
),
3061 SF16_INSN ("frecps", 0x5e403c00, 0xffe0fc00, asisdsame
, OP3 (Sd
, Sn
, Sm
), QL_FP3_H
, F_SSIZE
),
3062 SIMD_INSN ("frsqrts", 0x5ea0fc00, 0xffa0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_FP3
, F_SSIZE
),
3063 SF16_INSN ("frsqrts", 0x5ec03c00, 0xffe0fc00, asisdsame
, OP3 (Sd
, Sn
, Sm
), QL_FP3_H
, F_SSIZE
),
3064 SIMD_INSN ("cmgt", 0x5ee03400, 0xffe0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAMED
, F_SSIZE
),
3065 SIMD_INSN ("cmge", 0x5ee03c00, 0xffe0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAMED
, F_SSIZE
),
3066 SIMD_INSN ("sshl", 0x5ee04400, 0xffe0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAMED
, F_SSIZE
),
3067 SIMD_INSN ("srshl", 0x5ee05400, 0xffe0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAMED
, F_SSIZE
),
3068 SIMD_INSN ("add", 0x5ee08400, 0xffe0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAMED
, F_SSIZE
),
3069 SIMD_INSN ("cmtst", 0x5ee08c00, 0xffe0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAMED
, F_SSIZE
),
3070 SIMD_INSN ("uqadd", 0x7e200c00, 0xff20fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAME
, F_SSIZE
),
3071 SIMD_INSN ("uqsub", 0x7e202c00, 0xff20fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAME
, F_SSIZE
),
3072 SIMD_INSN ("uqshl", 0x7e204c00, 0xff20fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAME
, F_SSIZE
),
3073 SIMD_INSN ("uqrshl", 0x7e205c00, 0xff20fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAME
, F_SSIZE
),
3074 SIMD_INSN ("sqrdmulh", 0x7e20b400, 0xff20fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_SISD_HS
, F_SSIZE
),
3075 SIMD_INSN ("fcmge", 0x7e20e400, 0xffa0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_FP3
, F_SSIZE
),
3076 SF16_INSN ("fcmge", 0x7e402400, 0xffe0fc00, asisdsame
, OP3 (Sd
, Sn
, Sm
), QL_FP3_H
, F_SSIZE
),
3077 SIMD_INSN ("facge", 0x7e20ec00, 0xffa0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_FP3
, F_SSIZE
),
3078 SF16_INSN ("facge", 0x7e402c00, 0xffe0fc00, asisdsame
, OP3 (Sd
, Sn
, Sm
), QL_FP3_H
, F_SSIZE
),
3079 SIMD_INSN ("fabd", 0x7ea0d400, 0xffa0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_FP3
, F_SSIZE
),
3080 SF16_INSN ("fabd", 0x7ec01400, 0xffe0fc00, asisdsame
, OP3 (Sd
, Sn
, Sm
), QL_FP3_H
, F_SSIZE
),
3081 SIMD_INSN ("fcmgt", 0x7ea0e400, 0xffa0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_FP3
, F_SSIZE
),
3082 SF16_INSN ("fcmgt", 0x7ec02400, 0xffe0fc00, asisdsame
, OP3 (Sd
, Sn
, Sm
), QL_FP3_H
, F_SSIZE
),
3083 SIMD_INSN ("facgt", 0x7ea0ec00, 0xffa0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_FP3
, F_SSIZE
),
3084 SF16_INSN ("facgt", 0x7ec02c00, 0xffe0fc00, asisdsame
, OP3 (Sd
, Sn
, Sm
), QL_FP3_H
, F_SSIZE
),
3085 SIMD_INSN ("cmhi", 0x7ee03400, 0xffe0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAMED
, F_SSIZE
),
3086 SIMD_INSN ("cmhs", 0x7ee03c00, 0xffe0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAMED
, F_SSIZE
),
3087 SIMD_INSN ("ushl", 0x7ee04400, 0xffe0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAMED
, F_SSIZE
),
3088 SIMD_INSN ("urshl", 0x7ee05400, 0xffe0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAMED
, F_SSIZE
),
3089 SIMD_INSN ("sub", 0x7ee08400, 0xffe0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAMED
, F_SSIZE
),
3090 SIMD_INSN ("cmeq", 0x7ee08c00, 0xffe0fc00, asisdsame
, 0, OP3 (Sd
, Sn
, Sm
), QL_S_3SAMED
, F_SSIZE
),
3091 /* AdvSIMDs scalar three same extension. */
3092 RDMA_INSN ("sqrdmlah", 0x7e008400, 0xff20fc00, asimdsame
, OP3 (Sd
, Sn
, Sm
), QL_SISD_HS
, F_SSIZE
),
3093 RDMA_INSN ("sqrdmlsh", 0x7e008c00, 0xff20fc00, asimdsame
, OP3 (Sd
, Sn
, Sm
), QL_SISD_HS
, F_SSIZE
),
3094 /* AdvSIMD scalar shift by immediate. */
3095 SIMD_INSN ("sshr", 0x5f000400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_D
, 0),
3096 SIMD_INSN ("ssra", 0x5f001400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_D
, 0),
3097 SIMD_INSN ("srshr", 0x5f002400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_D
, 0),
3098 SIMD_INSN ("srsra", 0x5f003400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_D
, 0),
3099 SIMD_INSN ("shl", 0x5f005400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSL
), QL_SSHIFT_D
, 0),
3100 SIMD_INSN ("sqshl", 0x5f007400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSL
), QL_SSHIFT
, 0),
3101 SIMD_INSN ("sqshrn", 0x5f009400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFTN
, 0),
3102 SIMD_INSN ("sqrshrn", 0x5f009c00, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFTN
, 0),
3103 SIMD_INSN ("scvtf", 0x5f00e400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_SD
, 0),
3104 SF16_INSN ("scvtf", 0x5f10e400, 0xff80fc00, asisdshf
, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_H
, 0),
3105 SIMD_INSN ("fcvtzs", 0x5f00fc00, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_SD
, 0),
3106 SF16_INSN ("fcvtzs", 0x5f10fc00, 0xff80fc00, asisdshf
, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_H
, 0),
3107 SIMD_INSN ("ushr", 0x7f000400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_D
, 0),
3108 SIMD_INSN ("usra", 0x7f001400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_D
, 0),
3109 SIMD_INSN ("urshr", 0x7f002400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_D
, 0),
3110 SIMD_INSN ("ursra", 0x7f003400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_D
, 0),
3111 SIMD_INSN ("sri", 0x7f004400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_D
, 0),
3112 SIMD_INSN ("sli", 0x7f005400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSL
), QL_SSHIFT_D
, 0),
3113 SIMD_INSN ("sqshlu", 0x7f006400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSL
), QL_SSHIFT
, 0),
3114 SIMD_INSN ("uqshl", 0x7f007400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSL
), QL_SSHIFT
, 0),
3115 SIMD_INSN ("sqshrun", 0x7f008400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFTN
, 0),
3116 SIMD_INSN ("sqrshrun", 0x7f008c00, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFTN
, 0),
3117 SIMD_INSN ("uqshrn", 0x7f009400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFTN
, 0),
3118 SIMD_INSN ("uqrshrn", 0x7f009c00, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFTN
, 0),
3119 SIMD_INSN ("ucvtf", 0x7f00e400, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_SD
, 0),
3120 SF16_INSN ("ucvtf", 0x7f10e400, 0xff80fc00, asisdshf
, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_H
, 0),
3121 SIMD_INSN ("fcvtzu", 0x7f00fc00, 0xff80fc00, asisdshf
, 0, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_SD
, 0),
3122 SF16_INSN ("fcvtzu", 0x7f10fc00, 0xff80fc00, asisdshf
, OP3 (Sd
, Sn
, IMM_VLSR
), QL_SSHIFT_H
, 0),
3124 CORE_INSN ("sbfm", 0x13000000, 0x7f800000, bitfield
, 0, OP4 (Rd
, Rn
, IMMR
, IMMS
), QL_BF
, F_HAS_ALIAS
| F_SF
| F_N
),
3125 CORE_INSN ("sbfiz", 0x13000000, 0x7f800000, bitfield
, OP_SBFIZ
, OP4 (Rd
, Rn
, IMM
, WIDTH
), QL_BF2
, F_ALIAS
| F_P1
| F_CONV
),
3126 CORE_INSN ("sbfx", 0x13000000, 0x7f800000, bitfield
, OP_SBFX
, OP4 (Rd
, Rn
, IMM
, WIDTH
), QL_BF2
, F_ALIAS
| F_P1
| F_CONV
),
3127 CORE_INSN ("sxtb", 0x13001c00, 0x7fbffc00, bitfield
, 0, OP2 (Rd
, Rn
), QL_EXT
, F_ALIAS
| F_P3
| F_SF
| F_N
),
3128 CORE_INSN ("sxth", 0x13003c00, 0x7fbffc00, bitfield
, 0, OP2 (Rd
, Rn
), QL_EXT
, F_ALIAS
| F_P3
| F_SF
| F_N
),
3129 CORE_INSN ("sxtw", 0x93407c00, 0xfffffc00, bitfield
, 0, OP2 (Rd
, Rn
), QL_EXT_W
, F_ALIAS
| F_P3
),
3130 CORE_INSN ("asr", 0x13000000, 0x7f800000, bitfield
, OP_ASR_IMM
, OP3 (Rd
, Rn
, IMM
), QL_SHIFT
, F_ALIAS
| F_P2
| F_CONV
),
3131 CORE_INSN ("bfm", 0x33000000, 0x7f800000, bitfield
, 0, OP4 (Rd
, Rn
, IMMR
, IMMS
), QL_BF
, F_HAS_ALIAS
| F_SF
| F_N
),
3132 CORE_INSN ("bfi", 0x33000000, 0x7f800000, bitfield
, OP_BFI
, OP4 (Rd
, Rn
, IMM
, WIDTH
), QL_BF2
, F_ALIAS
| F_P1
| F_CONV
),
3133 V8_2_INSN ("bfc", 0x330003e0, 0x7f8003e0, bitfield
, OP_BFC
, OP3 (Rd
, IMM
, WIDTH
), QL_BF1
, F_ALIAS
| F_P2
| F_CONV
),
3134 CORE_INSN ("bfxil", 0x33000000, 0x7f800000, bitfield
, OP_BFXIL
, OP4 (Rd
, Rn
, IMM
, WIDTH
), QL_BF2
, F_ALIAS
| F_P1
| F_CONV
),
3135 CORE_INSN ("ubfm", 0x53000000, 0x7f800000, bitfield
, 0, OP4 (Rd
, Rn
, IMMR
, IMMS
), QL_BF
, F_HAS_ALIAS
| F_SF
| F_N
),
3136 CORE_INSN ("ubfiz", 0x53000000, 0x7f800000, bitfield
, OP_UBFIZ
, OP4 (Rd
, Rn
, IMM
, WIDTH
), QL_BF2
, F_ALIAS
| F_P1
| F_CONV
),
3137 CORE_INSN ("ubfx", 0x53000000, 0x7f800000, bitfield
, OP_UBFX
, OP4 (Rd
, Rn
, IMM
, WIDTH
), QL_BF2
, F_ALIAS
| F_P1
| F_CONV
),
3138 CORE_INSN ("uxtb", 0x53001c00, 0xfffffc00, bitfield
, OP_UXTB
, OP2 (Rd
, Rn
), QL_I2SAMEW
, F_ALIAS
| F_P3
),
3139 CORE_INSN ("uxth", 0x53003c00, 0xfffffc00, bitfield
, OP_UXTH
, OP2 (Rd
, Rn
), QL_I2SAMEW
, F_ALIAS
| F_P3
),
3140 CORE_INSN ("lsl", 0x53000000, 0x7f800000, bitfield
, OP_LSL_IMM
, OP3 (Rd
, Rn
, IMM
), QL_SHIFT
, F_ALIAS
| F_P2
| F_CONV
),
3141 CORE_INSN ("lsr", 0x53000000, 0x7f800000, bitfield
, OP_LSR_IMM
, OP3 (Rd
, Rn
, IMM
), QL_SHIFT
, F_ALIAS
| F_P2
| F_CONV
),
3142 /* Unconditional branch (immediate). */
3143 CORE_INSN ("b", 0x14000000, 0xfc000000, branch_imm
, OP_B
, OP1 (ADDR_PCREL26
), QL_PCREL_26
, 0),
3144 CORE_INSN ("bl", 0x94000000, 0xfc000000, branch_imm
, OP_BL
, OP1 (ADDR_PCREL26
), QL_PCREL_26
, 0),
3145 /* Unconditional branch (register). */
3146 CORE_INSN ("br", 0xd61f0000, 0xfffffc1f, branch_reg
, 0, OP1 (Rn
), QL_I1X
, 0),
3147 CORE_INSN ("blr", 0xd63f0000, 0xfffffc1f, branch_reg
, 0, OP1 (Rn
), QL_I1X
, 0),
3148 CORE_INSN ("ret", 0xd65f0000, 0xfffffc1f, branch_reg
, 0, OP1 (Rn
), QL_I1X
, F_OPD0_OPT
| F_DEFAULT (30)),
3149 CORE_INSN ("eret", 0xd69f03e0, 0xffffffff, branch_reg
, 0, OP0 (), {}, 0),
3150 CORE_INSN ("drps", 0xd6bf03e0, 0xffffffff, branch_reg
, 0, OP0 (), {}, 0),
3151 V8_3_INSN ("braa", 0xd71f0800, 0xfffffc00, branch_reg
, OP2 (Rn
, Rd_SP
), QL_I2SAMEX
, 0),
3152 V8_3_INSN ("brab", 0xd71f0c00, 0xfffffc00, branch_reg
, OP2 (Rn
, Rd_SP
), QL_I2SAMEX
, 0),
3153 V8_3_INSN ("blraa", 0xd73f0800, 0xfffffc00, branch_reg
, OP2 (Rn
, Rd_SP
), QL_I2SAMEX
, 0),
3154 V8_3_INSN ("blrab", 0xd73f0c00, 0xfffffc00, branch_reg
, OP2 (Rn
, Rd_SP
), QL_I2SAMEX
, 0),
3155 V8_3_INSN ("braaz", 0xd61f081f, 0xfffffc1f, branch_reg
, OP1 (Rn
), QL_I1X
, 0),
3156 V8_3_INSN ("brabz", 0xd61f0c1f, 0xfffffc1f, branch_reg
, OP1 (Rn
), QL_I1X
, 0),
3157 V8_3_INSN ("blraaz", 0xd63f081f, 0xfffffc1f, branch_reg
, OP1 (Rn
), QL_I1X
, 0),
3158 V8_3_INSN ("blrabz", 0xd63f0c1f, 0xfffffc1f, branch_reg
, OP1 (Rn
), QL_I1X
, 0),
3159 V8_3_INSN ("retaa", 0xd65f0bff, 0xffffffff, branch_reg
, OP0 (), {}, 0),
3160 V8_3_INSN ("retab", 0xd65f0fff, 0xffffffff, branch_reg
, OP0 (), {}, 0),
3161 V8_3_INSN ("eretaa", 0xd69f0bff, 0xffffffff, branch_reg
, OP0 (), {}, 0),
3162 V8_3_INSN ("eretab", 0xd69f0fff, 0xffffffff, branch_reg
, OP0 (), {}, 0),
3163 /* Compare & branch (immediate). */
3164 CORE_INSN ("cbz", 0x34000000, 0x7f000000, compbranch
, 0, OP2 (Rt
, ADDR_PCREL19
), QL_R_PCREL
, F_SF
),
3165 CORE_INSN ("cbnz", 0x35000000, 0x7f000000, compbranch
, 0, OP2 (Rt
, ADDR_PCREL19
), QL_R_PCREL
, F_SF
),
3166 /* Conditional branch (immediate). */
3167 CORE_INSN ("b.c", 0x54000000, 0xff000010, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_COND
),
3168 /* Conditional compare (immediate). */
3169 CORE_INSN ("ccmn", 0x3a400800, 0x7fe00c10, condcmp_imm
, 0, OP4 (Rn
, CCMP_IMM
, NZCV
, COND
), QL_CCMP_IMM
, F_SF
),
3170 CORE_INSN ("ccmp", 0x7a400800, 0x7fe00c10, condcmp_imm
, 0, OP4 (Rn
, CCMP_IMM
, NZCV
, COND
), QL_CCMP_IMM
, F_SF
),
3171 /* Conditional compare (register). */
3172 CORE_INSN ("ccmn", 0x3a400000, 0x7fe00c10, condcmp_reg
, 0, OP4 (Rn
, Rm
, NZCV
, COND
), QL_CCMP
, F_SF
),
3173 CORE_INSN ("ccmp", 0x7a400000, 0x7fe00c10, condcmp_reg
, 0, OP4 (Rn
, Rm
, NZCV
, COND
), QL_CCMP
, F_SF
),
3174 /* Conditional select. */
3175 CORE_INSN ("csel", 0x1a800000, 0x7fe00c00, condsel
, 0, OP4 (Rd
, Rn
, Rm
, COND
), QL_CSEL
, F_SF
),
3176 CORE_INSN ("csinc", 0x1a800400, 0x7fe00c00, condsel
, 0, OP4 (Rd
, Rn
, Rm
, COND
), QL_CSEL
, F_HAS_ALIAS
| F_SF
),
3177 CORE_INSN ("cinc", 0x1a800400, 0x7fe00c00, condsel
, OP_CINC
, OP3 (Rd
, Rn
, COND1
), QL_CSEL
, F_ALIAS
| F_SF
| F_CONV
),
3178 CORE_INSN ("cset", 0x1a9f07e0, 0x7fff0fe0, condsel
, OP_CSET
, OP2 (Rd
, COND1
), QL_DST_R
, F_ALIAS
| F_P1
| F_SF
| F_CONV
),
3179 CORE_INSN ("csinv", 0x5a800000, 0x7fe00c00, condsel
, 0, OP4 (Rd
, Rn
, Rm
, COND
), QL_CSEL
, F_HAS_ALIAS
| F_SF
),
3180 CORE_INSN ("cinv", 0x5a800000, 0x7fe00c00, condsel
, OP_CINV
, OP3 (Rd
, Rn
, COND1
), QL_CSEL
, F_ALIAS
| F_SF
| F_CONV
),
3181 CORE_INSN ("csetm", 0x5a9f03e0, 0x7fff0fe0, condsel
, OP_CSETM
, OP2 (Rd
, COND1
), QL_DST_R
, F_ALIAS
| F_P1
| F_SF
| F_CONV
),
3182 CORE_INSN ("csneg", 0x5a800400, 0x7fe00c00, condsel
, 0, OP4 (Rd
, Rn
, Rm
, COND
), QL_CSEL
, F_HAS_ALIAS
| F_SF
),
3183 CORE_INSN ("cneg", 0x5a800400, 0x7fe00c00, condsel
, OP_CNEG
, OP3 (Rd
, Rn
, COND1
), QL_CSEL
, F_ALIAS
| F_SF
| F_CONV
),
3185 AES_INSN ("aese", 0x4e284800, 0xfffffc00, cryptoaes
, OP2 (Vd
, Vn
), QL_V2SAME16B
, 0),
3186 AES_INSN ("aesd", 0x4e285800, 0xfffffc00, cryptoaes
, OP2 (Vd
, Vn
), QL_V2SAME16B
, 0),
3187 AES_INSN ("aesmc", 0x4e286800, 0xfffffc00, cryptoaes
, OP2 (Vd
, Vn
), QL_V2SAME16B
, 0),
3188 AES_INSN ("aesimc", 0x4e287800, 0xfffffc00, cryptoaes
, OP2 (Vd
, Vn
), QL_V2SAME16B
, 0),
3189 /* Crypto two-reg SHA. */
3190 SHA2_INSN ("sha1h", 0x5e280800, 0xfffffc00, cryptosha2
, OP2 (Fd
, Fn
), QL_2SAMES
, 0),
3191 SHA2_INSN ("sha1su1", 0x5e281800, 0xfffffc00, cryptosha2
, OP2 (Vd
, Vn
), QL_V2SAME4S
, 0),
3192 SHA2_INSN ("sha256su0",0x5e282800, 0xfffffc00, cryptosha2
, OP2 (Vd
, Vn
), QL_V2SAME4S
, 0),
3193 /* Crypto three-reg SHA. */
3194 SHA2_INSN ("sha1c", 0x5e000000, 0xffe0fc00, cryptosha3
, OP3 (Fd
, Fn
, Vm
), QL_SHAUPT
, 0),
3195 SHA2_INSN ("sha1p", 0x5e001000, 0xffe0fc00, cryptosha3
, OP3 (Fd
, Fn
, Vm
), QL_SHAUPT
, 0),
3196 SHA2_INSN ("sha1m", 0x5e002000, 0xffe0fc00, cryptosha3
, OP3 (Fd
, Fn
, Vm
), QL_SHAUPT
, 0),
3197 SHA2_INSN ("sha1su0", 0x5e003000, 0xffe0fc00, cryptosha3
, OP3 (Vd
, Vn
, Vm
), QL_V3SAME4S
, 0),
3198 SHA2_INSN ("sha256h", 0x5e004000, 0xffe0fc00, cryptosha3
, OP3 (Fd
, Fn
, Vm
), QL_SHA256UPT
, 0),
3199 SHA2_INSN ("sha256h2", 0x5e005000, 0xffe0fc00, cryptosha3
, OP3 (Fd
, Fn
, Vm
), QL_SHA256UPT
, 0),
3200 SHA2_INSN ("sha256su1",0x5e006000, 0xffe0fc00, cryptosha3
, OP3 (Vd
, Vn
, Vm
), QL_V3SAME4S
, 0),
3201 /* Data-processing (1 source). */
3202 CORE_INSN ("rbit", 0x5ac00000, 0x7ffffc00, dp_1src
, 0, OP2 (Rd
, Rn
), QL_I2SAME
, F_SF
),
3203 CORE_INSN ("rev16", 0x5ac00400, 0x7ffffc00, dp_1src
, 0, OP2 (Rd
, Rn
), QL_I2SAME
, F_SF
),
3204 CORE_INSN ("rev", 0x5ac00800, 0xfffffc00, dp_1src
, 0, OP2 (Rd
, Rn
), QL_I2SAMEW
, 0),
3205 CORE_INSN ("rev", 0xdac00c00, 0xfffffc00, dp_1src
, 0, OP2 (Rd
, Rn
), QL_I2SAMEX
, F_SF
| F_HAS_ALIAS
| F_P1
),
3206 V8_2_INSN ("rev64", 0xdac00c00, 0xfffffc00, dp_1src
, 0, OP2 (Rd
, Rn
), QL_I2SAMEX
, F_SF
| F_ALIAS
),
3207 CORE_INSN ("clz", 0x5ac01000, 0x7ffffc00, dp_1src
, 0, OP2 (Rd
, Rn
), QL_I2SAME
, F_SF
),
3208 CORE_INSN ("cls", 0x5ac01400, 0x7ffffc00, dp_1src
, 0, OP2 (Rd
, Rn
), QL_I2SAME
, F_SF
),
3209 CORE_INSN ("rev32", 0xdac00800, 0xfffffc00, dp_1src
, 0, OP2 (Rd
, Rn
), QL_I2SAMEX
, 0),
3210 V8_3_INSN ("pacia", 0xdac10000, 0xfffffc00, dp_1src
, OP2 (Rd
, Rn_SP
), QL_I2SAMEX
, 0),
3211 V8_3_INSN ("pacib", 0xdac10400, 0xfffffc00, dp_1src
, OP2 (Rd
, Rn_SP
), QL_I2SAMEX
, 0),
3212 V8_3_INSN ("pacda", 0xdac10800, 0xfffffc00, dp_1src
, OP2 (Rd
, Rn_SP
), QL_I2SAMEX
, 0),
3213 V8_3_INSN ("pacdb", 0xdac10c00, 0xfffffc00, dp_1src
, OP2 (Rd
, Rn_SP
), QL_I2SAMEX
, 0),
3214 V8_3_INSN ("autia", 0xdac11000, 0xfffffc00, dp_1src
, OP2 (Rd
, Rn_SP
), QL_I2SAMEX
, 0),
3215 V8_3_INSN ("autib", 0xdac11400, 0xfffffc00, dp_1src
, OP2 (Rd
, Rn_SP
), QL_I2SAMEX
, 0),
3216 V8_3_INSN ("autda", 0xdac11800, 0xfffffc00, dp_1src
, OP2 (Rd
, Rn_SP
), QL_I2SAMEX
, 0),
3217 V8_3_INSN ("autdb", 0xdac11c00, 0xfffffc00, dp_1src
, OP2 (Rd
, Rn_SP
), QL_I2SAMEX
, 0),
3218 V8_3_INSN ("paciza", 0xdac123e0, 0xffffffe0, dp_1src
, OP1 (Rd
), QL_I1X
, 0),
3219 V8_3_INSN ("pacizb", 0xdac127e0, 0xffffffe0, dp_1src
, OP1 (Rd
), QL_I1X
, 0),
3220 V8_3_INSN ("pacdza", 0xdac12be0, 0xffffffe0, dp_1src
, OP1 (Rd
), QL_I1X
, 0),
3221 V8_3_INSN ("pacdzb", 0xdac12fe0, 0xffffffe0, dp_1src
, OP1 (Rd
), QL_I1X
, 0),
3222 V8_3_INSN ("autiza", 0xdac133e0, 0xffffffe0, dp_1src
, OP1 (Rd
), QL_I1X
, 0),
3223 V8_3_INSN ("autizb", 0xdac137e0, 0xffffffe0, dp_1src
, OP1 (Rd
), QL_I1X
, 0),
3224 V8_3_INSN ("autdza", 0xdac13be0, 0xffffffe0, dp_1src
, OP1 (Rd
), QL_I1X
, 0),
3225 V8_3_INSN ("autdzb", 0xdac13fe0, 0xffffffe0, dp_1src
, OP1 (Rd
), QL_I1X
, 0),
3226 V8_3_INSN ("xpaci", 0xdac143e0, 0xffffffe0, dp_1src
, OP1 (Rd
), QL_I1X
, 0),
3227 V8_3_INSN ("xpacd", 0xdac147e0, 0xffffffe0, dp_1src
, OP1 (Rd
), QL_I1X
, 0),
3228 /* Data-processing (2 source). */
3229 CORE_INSN ("udiv", 0x1ac00800, 0x7fe0fc00, dp_2src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_SF
),
3230 CORE_INSN ("sdiv", 0x1ac00c00, 0x7fe0fc00, dp_2src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_SF
),
3231 CORE_INSN ("lslv", 0x1ac02000, 0x7fe0fc00, dp_2src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_SF
| F_HAS_ALIAS
),
3232 CORE_INSN ("lsl", 0x1ac02000, 0x7fe0fc00, dp_2src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_SF
| F_ALIAS
),
3233 CORE_INSN ("lsrv", 0x1ac02400, 0x7fe0fc00, dp_2src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_SF
| F_HAS_ALIAS
),
3234 CORE_INSN ("lsr", 0x1ac02400, 0x7fe0fc00, dp_2src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_SF
| F_ALIAS
),
3235 CORE_INSN ("asrv", 0x1ac02800, 0x7fe0fc00, dp_2src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_SF
| F_HAS_ALIAS
),
3236 CORE_INSN ("asr", 0x1ac02800, 0x7fe0fc00, dp_2src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_SF
| F_ALIAS
),
3237 CORE_INSN ("rorv", 0x1ac02c00, 0x7fe0fc00, dp_2src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_SF
| F_HAS_ALIAS
),
3238 CORE_INSN ("ror", 0x1ac02c00, 0x7fe0fc00, dp_2src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_SF
| F_ALIAS
),
3239 MEMTAG_INSN ("subp", 0x9ac00000, 0xffe0fc00, dp_2src
, OP3 (Rd
, Rn_SP
, Rm_SP
), QL_I3SAMEX
, 0),
3240 MEMTAG_INSN ("subps", 0xbac00000, 0xffe0fc00, dp_2src
, OP3 (Rd
, Rn_SP
, Rm_SP
), QL_I3SAMEX
, F_HAS_ALIAS
),
3241 MEMTAG_INSN ("cmpp", 0xbac0001f, 0xffe0fc1f, dp_2src
, OP2 (Rn_SP
, Rm_SP
), QL_I2SAMEX
, F_ALIAS
),
3242 MEMTAG_INSN ("irg", 0x9ac01000, 0xffe0fc00, dp_2src
, OP3 (Rd_SP
, Rn_SP
, Rm
), QL_I3SAMEX
, F_OPD2_OPT
| F_DEFAULT (0x1f)),
3243 MEMTAG_INSN ("gmi", 0x9ac01400, 0xffe0fc00, dp_2src
, OP3 (Rd
, Rn_SP
, Rm
), QL_I3SAMEX
, 0),
3244 V8_3_INSN ("pacga", 0x9ac03000, 0xffe0fc00, dp_2src
, OP3 (Rd
, Rn
, Rm_SP
), QL_I3SAMEX
, 0),
3245 /* CRC instructions. */
3246 _CRC_INSN ("crc32b", 0x1ac04000, 0xffe0fc00, dp_2src
, OP3 (Rd
, Rn
, Rm
), QL_I3SAMEW
, 0),
3247 _CRC_INSN ("crc32h", 0x1ac04400, 0xffe0fc00, dp_2src
, OP3 (Rd
, Rn
, Rm
), QL_I3SAMEW
, 0),
3248 _CRC_INSN ("crc32w", 0x1ac04800, 0xffe0fc00, dp_2src
, OP3 (Rd
, Rn
, Rm
), QL_I3SAMEW
, 0),
3249 _CRC_INSN ("crc32x", 0x9ac04c00, 0xffe0fc00, dp_2src
, OP3 (Rd
, Rn
, Rm
), QL_I3WWX
, 0),
3250 _CRC_INSN ("crc32cb",0x1ac05000, 0xffe0fc00, dp_2src
, OP3 (Rd
, Rn
, Rm
), QL_I3SAMEW
, 0),
3251 _CRC_INSN ("crc32ch",0x1ac05400, 0xffe0fc00, dp_2src
, OP3 (Rd
, Rn
, Rm
), QL_I3SAMEW
, 0),
3252 _CRC_INSN ("crc32cw",0x1ac05800, 0xffe0fc00, dp_2src
, OP3 (Rd
, Rn
, Rm
), QL_I3SAMEW
, 0),
3253 _CRC_INSN ("crc32cx",0x9ac05c00, 0xffe0fc00, dp_2src
, OP3 (Rd
, Rn
, Rm
), QL_I3WWX
, 0),
3254 /* Data-processing (3 source). */
3255 CORE_INSN ("madd", 0x1b000000, 0x7fe08000, dp_3src
, 0, OP4 (Rd
, Rn
, Rm
, Ra
), QL_I4SAMER
, F_HAS_ALIAS
| F_SF
),
3256 CORE_INSN ("mul", 0x1b007c00, 0x7fe0fc00, dp_3src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_ALIAS
| F_SF
),
3257 CORE_INSN ("msub", 0x1b008000, 0x7fe08000, dp_3src
, 0, OP4 (Rd
, Rn
, Rm
, Ra
), QL_I4SAMER
, F_HAS_ALIAS
| F_SF
),
3258 CORE_INSN ("mneg", 0x1b00fc00, 0x7fe0fc00, dp_3src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMER
, F_ALIAS
| F_SF
),
3259 CORE_INSN ("smaddl",0x9b200000, 0xffe08000, dp_3src
, 0, OP4 (Rd
, Rn
, Rm
, Ra
), QL_I4SAMEL
, F_HAS_ALIAS
),
3260 CORE_INSN ("smull", 0x9b207c00, 0xffe0fc00, dp_3src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMEL
, F_ALIAS
),
3261 CORE_INSN ("smsubl",0x9b208000, 0xffe08000, dp_3src
, 0, OP4 (Rd
, Rn
, Rm
, Ra
), QL_I4SAMEL
, F_HAS_ALIAS
),
3262 CORE_INSN ("smnegl",0x9b20fc00, 0xffe0fc00, dp_3src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMEL
, F_ALIAS
),
3263 CORE_INSN ("smulh", 0x9b407c00, 0xffe08000, dp_3src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMEX
, 0),
3264 CORE_INSN ("umaddl",0x9ba00000, 0xffe08000, dp_3src
, 0, OP4 (Rd
, Rn
, Rm
, Ra
), QL_I4SAMEL
, F_HAS_ALIAS
),
3265 CORE_INSN ("umull", 0x9ba07c00, 0xffe0fc00, dp_3src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMEL
, F_ALIAS
),
3266 CORE_INSN ("umsubl",0x9ba08000, 0xffe08000, dp_3src
, 0, OP4 (Rd
, Rn
, Rm
, Ra
), QL_I4SAMEL
, F_HAS_ALIAS
),
3267 CORE_INSN ("umnegl",0x9ba0fc00, 0xffe0fc00, dp_3src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMEL
, F_ALIAS
),
3268 CORE_INSN ("umulh", 0x9bc07c00, 0xffe08000, dp_3src
, 0, OP3 (Rd
, Rn
, Rm
), QL_I3SAMEX
, 0),
3269 /* Excep'n generation. */
3270 CORE_INSN ("svc", 0xd4000001, 0xffe0001f, exception
, 0, OP1 (EXCEPTION
), {}, 0),
3271 CORE_INSN ("hvc", 0xd4000002, 0xffe0001f, exception
, 0, OP1 (EXCEPTION
), {}, 0),
3272 CORE_INSN ("smc", 0xd4000003, 0xffe0001f, exception
, 0, OP1 (EXCEPTION
), {}, 0),
3273 CORE_INSN ("brk", 0xd4200000, 0xffe0001f, exception
, 0, OP1 (EXCEPTION
), {}, 0),
3274 CORE_INSN ("hlt", 0xd4400000, 0xffe0001f, exception
, 0, OP1 (EXCEPTION
), {}, 0),
3275 CORE_INSN ("dcps1", 0xd4a00001, 0xffe0001f, exception
, 0, OP1 (EXCEPTION
), {}, F_OPD0_OPT
| F_DEFAULT (0)),
3276 CORE_INSN ("dcps2", 0xd4a00002, 0xffe0001f, exception
, 0, OP1 (EXCEPTION
), {}, F_OPD0_OPT
| F_DEFAULT (0)),
3277 CORE_INSN ("dcps3", 0xd4a00003, 0xffe0001f, exception
, 0, OP1 (EXCEPTION
), {}, F_OPD0_OPT
| F_DEFAULT (0)),
3279 CORE_INSN ("extr", 0x13800000, 0x7fa00000, extract
, 0, OP4 (Rd
, Rn
, Rm
, IMMS
), QL_EXTR
, F_HAS_ALIAS
| F_SF
| F_N
),
3280 CORE_INSN ("ror", 0x13800000, 0x7fa00000, extract
, OP_ROR_IMM
, OP3 (Rd
, Rm
, IMMS
), QL_SHIFT
, F_ALIAS
| F_CONV
),
3281 /* Floating-point<->fixed-point conversions. */
3282 __FP_INSN ("scvtf", 0x1e020000, 0x7f3f0000, float2fix
, 0, OP3 (Fd
, Rn
, FBITS
), QL_FIX2FP
, F_FPTYPE
| F_SF
),
3283 FF16_INSN ("scvtf", 0x1ec20000, 0x7f3f0000, float2fix
, OP3 (Fd
, Rn
, FBITS
), QL_FIX2FP_H
, F_FPTYPE
| F_SF
),
3284 __FP_INSN ("ucvtf", 0x1e030000, 0x7f3f0000, float2fix
, 0, OP3 (Fd
, Rn
, FBITS
), QL_FIX2FP
, F_FPTYPE
| F_SF
),
3285 FF16_INSN ("ucvtf", 0x1ec30000, 0x7f3f0000, float2fix
, OP3 (Fd
, Rn
, FBITS
), QL_FIX2FP_H
, F_FPTYPE
| F_SF
),
3286 __FP_INSN ("fcvtzs",0x1e180000, 0x7f3f0000, float2fix
, 0, OP3 (Rd
, Fn
, FBITS
), QL_FP2FIX
, F_FPTYPE
| F_SF
),
3287 FF16_INSN ("fcvtzs",0x1ed80000, 0x7f3f0000, float2fix
, OP3 (Rd
, Fn
, FBITS
), QL_FP2FIX_H
, F_FPTYPE
| F_SF
),
3288 __FP_INSN ("fcvtzu",0x1e190000, 0x7f3f0000, float2fix
, 0, OP3 (Rd
, Fn
, FBITS
), QL_FP2FIX
, F_FPTYPE
| F_SF
),
3289 FF16_INSN ("fcvtzu",0x1ed90000, 0x7f3f0000, float2fix
, OP3 (Rd
, Fn
, FBITS
), QL_FP2FIX_H
, F_FPTYPE
| F_SF
),
3290 /* Floating-point<->integer conversions. */
3291 __FP_INSN ("fcvtns",0x1e200000, 0x7f3ffc00, float2int
, 0, OP2 (Rd
, Fn
), QL_FP2INT
, F_FPTYPE
| F_SF
),
3292 FF16_INSN ("fcvtns",0x1ee00000, 0x7f3ffc00, float2int
, OP2 (Rd
, Fn
), QL_FP2INT_H
, F_FPTYPE
| F_SF
),
3293 __FP_INSN ("fcvtnu",0x1e210000, 0x7f3ffc00, float2int
, 0, OP2 (Rd
, Fn
), QL_FP2INT
, F_FPTYPE
| F_SF
),
3294 FF16_INSN ("fcvtnu",0x1ee10000, 0x7f3ffc00, float2int
, OP2 (Rd
, Fn
), QL_FP2INT_H
, F_FPTYPE
| F_SF
),
3295 __FP_INSN ("scvtf", 0x1e220000, 0x7f3ffc00, float2int
, 0, OP2 (Fd
, Rn
), QL_INT2FP
, F_FPTYPE
| F_SF
),
3296 FF16_INSN ("scvtf", 0x1ee20000, 0x7f3ffc00, float2int
, OP2 (Fd
, Rn
), QL_INT2FP_H
, F_FPTYPE
| F_SF
),
3297 __FP_INSN ("ucvtf", 0x1e230000, 0x7f3ffc00, float2int
, 0, OP2 (Fd
, Rn
), QL_INT2FP
, F_FPTYPE
| F_SF
),
3298 FF16_INSN ("ucvtf", 0x1ee30000, 0x7f3ffc00, float2int
, OP2 (Fd
, Rn
), QL_INT2FP_H
, F_FPTYPE
| F_SF
),
3299 __FP_INSN ("fcvtas",0x1e240000, 0x7f3ffc00, float2int
, 0, OP2 (Rd
, Fn
), QL_FP2INT
, F_FPTYPE
| F_SF
),
3300 FF16_INSN ("fcvtas",0x1ee40000, 0x7f3ffc00, float2int
, OP2 (Rd
, Fn
), QL_FP2INT_H
, F_FPTYPE
| F_SF
),
3301 __FP_INSN ("fcvtau",0x1e250000, 0x7f3ffc00, float2int
, 0, OP2 (Rd
, Fn
), QL_FP2INT
, F_FPTYPE
| F_SF
),
3302 FF16_INSN ("fcvtau",0x1ee50000, 0x7f3ffc00, float2int
, OP2 (Rd
, Fn
), QL_FP2INT_H
, F_FPTYPE
| F_SF
),
3303 __FP_INSN ("fmov", 0x1e260000, 0x7f3ffc00, float2int
, 0, OP2 (Rd
, Fn
), QL_FP2INT_FMOV
, F_FPTYPE
| F_SF
),
3304 FF16_INSN ("fmov", 0x1ee60000, 0x7f3ffc00, float2int
, OP2 (Rd
, Fn
), QL_FP2INT_H
, F_FPTYPE
| F_SF
),
3305 __FP_INSN ("fmov", 0x1e270000, 0x7f3ffc00, float2int
, 0, OP2 (Fd
, Rn
), QL_INT2FP_FMOV
, F_FPTYPE
| F_SF
),
3306 FF16_INSN ("fmov", 0x1ee70000, 0x7f3ffc00, float2int
, OP2 (Fd
, Rn
), QL_INT2FP_H
, F_FPTYPE
| F_SF
),
3307 __FP_INSN ("fcvtps",0x1e280000, 0x7f3ffc00, float2int
, 0, OP2 (Rd
, Fn
), QL_FP2INT
, F_FPTYPE
| F_SF
),
3308 FF16_INSN ("fcvtps",0x1ee80000, 0x7f3ffc00, float2int
, OP2 (Rd
, Fn
), QL_FP2INT_H
, F_FPTYPE
| F_SF
),
3309 __FP_INSN ("fcvtpu",0x1e290000, 0x7f3ffc00, float2int
, 0, OP2 (Rd
, Fn
), QL_FP2INT
, F_FPTYPE
| F_SF
),
3310 FF16_INSN ("fcvtpu",0x1ee90000, 0x7f3ffc00, float2int
, OP2 (Rd
, Fn
), QL_FP2INT_H
, F_FPTYPE
| F_SF
),
3311 __FP_INSN ("fcvtms",0x1e300000, 0x7f3ffc00, float2int
, 0, OP2 (Rd
, Fn
), QL_FP2INT
, F_FPTYPE
| F_SF
),
3312 FF16_INSN ("fcvtms",0x1ef00000, 0x7f3ffc00, float2int
, OP2 (Rd
, Fn
), QL_FP2INT_H
, F_FPTYPE
| F_SF
),
3313 __FP_INSN ("fcvtmu",0x1e310000, 0x7f3ffc00, float2int
, 0, OP2 (Rd
, Fn
), QL_FP2INT
, F_FPTYPE
| F_SF
),
3314 FF16_INSN ("fcvtmu",0x1ef10000, 0x7f3ffc00, float2int
, OP2 (Rd
, Fn
), QL_FP2INT_H
, F_FPTYPE
| F_SF
),
3315 __FP_INSN ("fcvtzs",0x1e380000, 0x7f3ffc00, float2int
, 0, OP2 (Rd
, Fn
), QL_FP2INT
, F_FPTYPE
| F_SF
),
3316 FF16_INSN ("fcvtzs",0x1ef80000, 0x7f3ffc00, float2int
, OP2 (Rd
, Fn
), QL_FP2INT_H
, F_FPTYPE
| F_SF
),
3317 __FP_INSN ("fcvtzu",0x1e390000, 0x7f3ffc00, float2int
, 0, OP2 (Rd
, Fn
), QL_FP2INT
, F_FPTYPE
| F_SF
),
3318 FF16_INSN ("fcvtzu",0x1ef90000, 0x7f3ffc00, float2int
, OP2 (Rd
, Fn
), QL_FP2INT_H
, F_FPTYPE
| F_SF
),
3319 __FP_INSN ("fmov", 0x9eae0000, 0xfffffc00, float2int
, 0, OP2 (Rd
, VnD1
), QL_XVD1
, 0),
3320 __FP_INSN ("fmov", 0x9eaf0000, 0xfffffc00, float2int
, 0, OP2 (VdD1
, Rn
), QL_VD1X
, 0),
3321 {"fjcvtzs", 0x1e7e0000, 0xfffffc00, float2int
, 0, FP_V8_3
, OP2 (Rd
, Fn
), QL_FP2INT_W_D
, 0, 0, 0, NULL
},
3322 /* Floating-point conditional compare. */
3323 __FP_INSN ("fccmp", 0x1e200400, 0xff200c10, floatccmp
, 0, OP4 (Fn
, Fm
, NZCV
, COND
), QL_FCCMP
, F_FPTYPE
),
3324 FF16_INSN ("fccmp", 0x1ee00400, 0xff200c10, floatccmp
, OP4 (Fn
, Fm
, NZCV
, COND
), QL_FCCMP_H
, F_FPTYPE
),
3325 __FP_INSN ("fccmpe",0x1e200410, 0xff200c10, floatccmp
, 0, OP4 (Fn
, Fm
, NZCV
, COND
), QL_FCCMP
, F_FPTYPE
),
3326 FF16_INSN ("fccmpe",0x1ee00410, 0xff200c10, floatccmp
, OP4 (Fn
, Fm
, NZCV
, COND
), QL_FCCMP_H
, F_FPTYPE
),
3327 /* Floating-point compare. */
3328 __FP_INSN ("fcmp", 0x1e202000, 0xff20fc1f, floatcmp
, 0, OP2 (Fn
, Fm
), QL_FP2
, F_FPTYPE
),
3329 FF16_INSN ("fcmp", 0x1ee02000, 0xff20fc1f, floatcmp
, OP2 (Fn
, Fm
), QL_FP2_H
, F_FPTYPE
),
3330 __FP_INSN ("fcmpe", 0x1e202010, 0xff20fc1f, floatcmp
, 0, OP2 (Fn
, Fm
), QL_FP2
, F_FPTYPE
),
3331 FF16_INSN ("fcmpe", 0x1ee02010, 0xff20fc1f, floatcmp
, OP2 (Fn
, Fm
), QL_FP2_H
, F_FPTYPE
),
3332 __FP_INSN ("fcmp", 0x1e202008, 0xff20fc1f, floatcmp
, 0, OP2 (Fn
, FPIMM0
), QL_DST_SD
,F_FPTYPE
),
3333 FF16_INSN ("fcmp", 0x1ee02008, 0xff20fc1f, floatcmp
, OP2 (Fn
, FPIMM0
), QL_FP2_H
, F_FPTYPE
),
3334 __FP_INSN ("fcmpe", 0x1e202018, 0xff20fc1f, floatcmp
, 0, OP2 (Fn
, FPIMM0
), QL_DST_SD
,F_FPTYPE
),
3335 FF16_INSN ("fcmpe", 0x1ee02018, 0xff20fc1f, floatcmp
, OP2 (Fn
, FPIMM0
), QL_FP2_H
, F_FPTYPE
),
3336 /* Data processing instructions ARMv8.5-A. */
3337 FLAGMANIP_INSN ("xaflag", 0xd500403f, 0xffffffff, 0, OP0 (), {}, 0),
3338 FLAGMANIP_INSN ("axflag", 0xd500405f, 0xffffffff, 0, OP0 (), {}, 0),
3339 FRINTTS_INSN ("frint32z", 0x1e284000, 0xffbffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3340 FRINTTS_INSN ("frint32x", 0x1e28c000, 0xffbffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3341 FRINTTS_INSN ("frint64z", 0x1e294000, 0xffbffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3342 FRINTTS_INSN ("frint64x", 0x1e29c000, 0xffbffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3343 /* Floating-point data-processing (1 source). */
3344 __FP_INSN ("fmov", 0x1e204000, 0xff3ffc00, floatdp1
, 0, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3345 FF16_INSN ("fmov", 0x1ee04000, 0xff3ffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2_H
, F_FPTYPE
),
3346 __FP_INSN ("fabs", 0x1e20c000, 0xff3ffc00, floatdp1
, 0, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3347 FF16_INSN ("fabs", 0x1ee0c000, 0xff3ffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2_H
, F_FPTYPE
),
3348 __FP_INSN ("fneg", 0x1e214000, 0xff3ffc00, floatdp1
, 0, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3349 FF16_INSN ("fneg", 0x1ee14000, 0xff3ffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2_H
, F_FPTYPE
),
3350 __FP_INSN ("fsqrt", 0x1e21c000, 0xff3ffc00, floatdp1
, 0, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3351 FF16_INSN ("fsqrt", 0x1ee1c000, 0xff3ffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2_H
, F_FPTYPE
),
3352 __FP_INSN ("fcvt", 0x1e224000, 0xff3e7c00, floatdp1
, OP_FCVT
, OP2 (Fd
, Fn
), QL_FCVT
, F_FPTYPE
| F_MISC
),
3353 __FP_INSN ("frintn",0x1e244000, 0xff3ffc00, floatdp1
, 0, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3354 FF16_INSN ("frintn",0x1ee44000, 0xff3ffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2_H
, F_FPTYPE
),
3355 __FP_INSN ("frintp",0x1e24c000, 0xff3ffc00, floatdp1
, 0, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3356 FF16_INSN ("frintp",0x1ee4c000, 0xff3ffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2_H
, F_FPTYPE
),
3357 __FP_INSN ("frintm",0x1e254000, 0xff3ffc00, floatdp1
, 0, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3358 FF16_INSN ("frintm",0x1ee54000, 0xff3ffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2_H
, F_FPTYPE
),
3359 __FP_INSN ("frintz",0x1e25c000, 0xff3ffc00, floatdp1
, 0, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3360 FF16_INSN ("frintz",0x1ee5c000, 0xff3ffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2_H
, F_FPTYPE
),
3361 __FP_INSN ("frinta",0x1e264000, 0xff3ffc00, floatdp1
, 0, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3362 FF16_INSN ("frinta",0x1ee64000, 0xff3ffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2_H
, F_FPTYPE
),
3363 __FP_INSN ("frintx",0x1e274000, 0xff3ffc00, floatdp1
, 0, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3364 FF16_INSN ("frintx",0x1ee74000, 0xff3ffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2_H
, F_FPTYPE
),
3365 __FP_INSN ("frinti",0x1e27c000, 0xff3ffc00, floatdp1
, 0, OP2 (Fd
, Fn
), QL_FP2
, F_FPTYPE
),
3366 FF16_INSN ("frinti",0x1ee7c000, 0xff3ffc00, floatdp1
, OP2 (Fd
, Fn
), QL_FP2_H
, F_FPTYPE
),
3367 /* Floating-point data-processing (2 source). */
3368 __FP_INSN ("fmul", 0x1e200800, 0xff20fc00, floatdp2
, 0, OP3 (Fd
, Fn
, Fm
), QL_FP3
, F_FPTYPE
),
3369 FF16_INSN ("fmul", 0x1ee00800, 0xff20fc00, floatdp2
, OP3 (Fd
, Fn
, Fm
), QL_FP3_H
, F_FPTYPE
),
3370 __FP_INSN ("fdiv", 0x1e201800, 0xff20fc00, floatdp2
, 0, OP3 (Fd
, Fn
, Fm
), QL_FP3
, F_FPTYPE
),
3371 FF16_INSN ("fdiv", 0x1ee01800, 0xff20fc00, floatdp2
, OP3 (Fd
, Fn
, Fm
), QL_FP3_H
, F_FPTYPE
),
3372 __FP_INSN ("fadd", 0x1e202800, 0xff20fc00, floatdp2
, 0, OP3 (Fd
, Fn
, Fm
), QL_FP3
, F_FPTYPE
),
3373 FF16_INSN ("fadd", 0x1ee02800, 0xff20fc00, floatdp2
, OP3 (Fd
, Fn
, Fm
), QL_FP3_H
, F_FPTYPE
),
3374 __FP_INSN ("fsub", 0x1e203800, 0xff20fc00, floatdp2
, 0, OP3 (Fd
, Fn
, Fm
), QL_FP3
, F_FPTYPE
),
3375 FF16_INSN ("fsub", 0x1ee03800, 0xff20fc00, floatdp2
, OP3 (Fd
, Fn
, Fm
), QL_FP3_H
, F_FPTYPE
),
3376 __FP_INSN ("fmax", 0x1e204800, 0xff20fc00, floatdp2
, 0, OP3 (Fd
, Fn
, Fm
), QL_FP3
, F_FPTYPE
),
3377 FF16_INSN ("fmax", 0x1ee04800, 0xff20fc00, floatdp2
, OP3 (Fd
, Fn
, Fm
), QL_FP3_H
, F_FPTYPE
),
3378 __FP_INSN ("fmin", 0x1e205800, 0xff20fc00, floatdp2
, 0, OP3 (Fd
, Fn
, Fm
), QL_FP3
, F_FPTYPE
),
3379 FF16_INSN ("fmin", 0x1ee05800, 0xff20fc00, floatdp2
, OP3 (Fd
, Fn
, Fm
), QL_FP3_H
, F_FPTYPE
),
3380 __FP_INSN ("fmaxnm",0x1e206800, 0xff20fc00, floatdp2
, 0, OP3 (Fd
, Fn
, Fm
), QL_FP3
, F_FPTYPE
),
3381 FF16_INSN ("fmaxnm",0x1ee06800, 0xff20fc00, floatdp2
, OP3 (Fd
, Fn
, Fm
), QL_FP3_H
, F_FPTYPE
),
3382 __FP_INSN ("fminnm",0x1e207800, 0xff20fc00, floatdp2
, 0, OP3 (Fd
, Fn
, Fm
), QL_FP3
, F_FPTYPE
),
3383 FF16_INSN ("fminnm",0x1ee07800, 0xff20fc00, floatdp2
, OP3 (Fd
, Fn
, Fm
), QL_FP3_H
, F_FPTYPE
),
3384 __FP_INSN ("fnmul", 0x1e208800, 0xff20fc00, floatdp2
, 0, OP3 (Fd
, Fn
, Fm
), QL_FP3
, F_FPTYPE
),
3385 FF16_INSN ("fnmul", 0x1ee08800, 0xff20fc00, floatdp2
, OP3 (Fd
, Fn
, Fm
), QL_FP3_H
, F_FPTYPE
),
3386 /* Floating-point data-processing (3 source). */
3387 __FP_INSN ("fmadd", 0x1f000000, 0xff208000, floatdp3
, 0, OP4 (Fd
, Fn
, Fm
, Fa
), QL_FP4
, F_FPTYPE
),
3388 FF16_INSN ("fmadd", 0x1fc00000, 0xff208000, floatdp3
, OP4 (Fd
, Fn
, Fm
, Fa
), QL_FP4_H
, F_FPTYPE
),
3389 __FP_INSN ("fmsub", 0x1f008000, 0xff208000, floatdp3
, 0, OP4 (Fd
, Fn
, Fm
, Fa
), QL_FP4
, F_FPTYPE
),
3390 FF16_INSN ("fmsub", 0x1fc08000, 0xff208000, floatdp3
, OP4 (Fd
, Fn
, Fm
, Fa
), QL_FP4_H
, F_FPTYPE
),
3391 __FP_INSN ("fnmadd",0x1f200000, 0xff208000, floatdp3
, 0, OP4 (Fd
, Fn
, Fm
, Fa
), QL_FP4
, F_FPTYPE
),
3392 FF16_INSN ("fnmadd",0x1fe00000, 0xff208000, floatdp3
, OP4 (Fd
, Fn
, Fm
, Fa
), QL_FP4_H
, F_FPTYPE
),
3393 __FP_INSN ("fnmsub",0x1f208000, 0xff208000, floatdp3
, 0, OP4 (Fd
, Fn
, Fm
, Fa
), QL_FP4
, F_FPTYPE
),
3394 FF16_INSN ("fnmsub",0x1fe08000, 0xff208000, floatdp3
, OP4 (Fd
, Fn
, Fm
, Fa
), QL_FP4_H
, F_FPTYPE
),
3395 /* Floating-point immediate. */
3396 __FP_INSN ("fmov", 0x1e201000, 0xff201fe0, floatimm
, 0, OP2 (Fd
, FPIMM
), QL_DST_SD
, F_FPTYPE
),
3397 FF16_INSN ("fmov", 0x1ee01000, 0xff201fe0, floatimm
, OP2 (Fd
, FPIMM
), QL_DST_H
, F_FPTYPE
),
3398 /* Floating-point conditional select. */
3399 __FP_INSN ("fcsel", 0x1e200c00, 0xff200c00, floatsel
, 0, OP4 (Fd
, Fn
, Fm
, COND
), QL_FP_COND
, F_FPTYPE
),
3400 FF16_INSN ("fcsel", 0x1ee00c00, 0xff200c00, floatsel
, OP4 (Fd
, Fn
, Fm
, COND
), QL_FP_COND_H
, F_FPTYPE
),
3401 /* Load/store register (immediate indexed). */
3402 CORE_INSN ("strb", 0x38000400, 0xffe00400, ldst_imm9
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_W8
, 0),
3403 CORE_INSN ("ldrb", 0x38400400, 0xffe00400, ldst_imm9
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_W8
, 0),
3404 CORE_INSN ("ldrsb", 0x38800400, 0xffa00400, ldst_imm9
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_R8
, F_LDS_SIZE
),
3405 CORE_INSN ("str", 0x3c000400, 0x3f600400, ldst_imm9
, 0, OP2 (Ft
, ADDR_SIMM9
), QL_LDST_FP
, 0),
3406 CORE_INSN ("ldr", 0x3c400400, 0x3f600400, ldst_imm9
, 0, OP2 (Ft
, ADDR_SIMM9
), QL_LDST_FP
, 0),
3407 CORE_INSN ("strh", 0x78000400, 0xffe00400, ldst_imm9
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_W16
, 0),
3408 CORE_INSN ("ldrh", 0x78400400, 0xffe00400, ldst_imm9
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_W16
, 0),
3409 CORE_INSN ("ldrsh", 0x78800400, 0xffa00400, ldst_imm9
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_R16
, F_LDS_SIZE
),
3410 CORE_INSN ("str", 0xb8000400, 0xbfe00400, ldst_imm9
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_R
, F_GPRSIZE_IN_Q
),
3411 CORE_INSN ("ldr", 0xb8400400, 0xbfe00400, ldst_imm9
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_R
, F_GPRSIZE_IN_Q
),
3412 CORE_INSN ("ldrsw", 0xb8800400, 0xffe00400, ldst_imm9
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_X32
, 0),
3413 /* Load/store Allocation Tag instructions. */
3414 MEMTAG_INSN ("stg", 0xd9200800, 0xffe00c00, ldst_unscaled
, OP2 (Rt_SP
, ADDR_SIMM13
), QL_LDST_AT
, 0),
3415 MEMTAG_INSN ("stzg", 0xd9600800, 0xffe00c00, ldst_unscaled
, OP2 (Rt_SP
, ADDR_SIMM13
), QL_LDST_AT
, 0),
3416 MEMTAG_INSN ("st2g", 0xd9a00800, 0xffe00c00, ldst_unscaled
, OP2 (Rt_SP
, ADDR_SIMM13
), QL_LDST_AT
, 0),
3417 MEMTAG_INSN ("stz2g",0xd9e00800, 0xffe00c00, ldst_unscaled
, OP2 (Rt_SP
, ADDR_SIMM13
), QL_LDST_AT
, 0),
3418 MEMTAG_INSN ("stg", 0xd9200400, 0xffe00400, ldst_imm9
, OP2 (Rt_SP
, ADDR_SIMM13
), QL_LDST_AT
, 0),
3419 MEMTAG_INSN ("stzg", 0xd9600400, 0xffe00400, ldst_imm9
, OP2 (Rt_SP
, ADDR_SIMM13
), QL_LDST_AT
, 0),
3420 MEMTAG_INSN ("st2g", 0xd9a00400, 0xffe00400, ldst_imm9
, OP2 (Rt_SP
, ADDR_SIMM13
), QL_LDST_AT
, 0),
3421 MEMTAG_INSN ("stz2g",0xd9e00400, 0xffe00400, ldst_imm9
, OP2 (Rt_SP
, ADDR_SIMM13
), QL_LDST_AT
, 0),
3422 /* Load/store register (unsigned immediate). */
3423 CORE_INSN ("strb", 0x39000000, 0xffc00000, ldst_pos
, OP_STRB_POS
, OP2 (Rt
, ADDR_UIMM12
), QL_LDST_W8
, 0),
3424 CORE_INSN ("ldrb", 0x39400000, 0xffc00000, ldst_pos
, OP_LDRB_POS
, OP2 (Rt
, ADDR_UIMM12
), QL_LDST_W8
, 0),
3425 CORE_INSN ("ldrsb", 0x39800000, 0xff800000, ldst_pos
, OP_LDRSB_POS
, OP2 (Rt
, ADDR_UIMM12
), QL_LDST_R8
, F_LDS_SIZE
),
3426 CORE_INSN ("str", 0x3d000000, 0x3f400000, ldst_pos
, OP_STRF_POS
, OP2 (Ft
, ADDR_UIMM12
), QL_LDST_FP
, 0),
3427 CORE_INSN ("ldr", 0x3d400000, 0x3f400000, ldst_pos
, OP_LDRF_POS
, OP2 (Ft
, ADDR_UIMM12
), QL_LDST_FP
, 0),
3428 CORE_INSN ("strh", 0x79000000, 0xffc00000, ldst_pos
, OP_STRH_POS
, OP2 (Rt
, ADDR_UIMM12
), QL_LDST_W16
, 0),
3429 CORE_INSN ("ldrh", 0x79400000, 0xffc00000, ldst_pos
, OP_LDRH_POS
, OP2 (Rt
, ADDR_UIMM12
), QL_LDST_W16
, 0),
3430 CORE_INSN ("ldrsh", 0x79800000, 0xff800000, ldst_pos
, OP_LDRSH_POS
, OP2 (Rt
, ADDR_UIMM12
), QL_LDST_R16
, F_LDS_SIZE
),
3431 CORE_INSN ("str", 0xb9000000, 0xbfc00000, ldst_pos
, OP_STR_POS
, OP2 (Rt
, ADDR_UIMM12
), QL_LDST_R
, F_GPRSIZE_IN_Q
),
3432 CORE_INSN ("ldr", 0xb9400000, 0xbfc00000, ldst_pos
, OP_LDR_POS
, OP2 (Rt
, ADDR_UIMM12
), QL_LDST_R
, F_GPRSIZE_IN_Q
),
3433 CORE_INSN ("ldrsw", 0xb9800000, 0xffc00000, ldst_pos
, OP_LDRSW_POS
, OP2 (Rt
, ADDR_UIMM12
), QL_LDST_X32
, 0),
3434 CORE_INSN ("prfm", 0xf9800000, 0xffc00000, ldst_pos
, OP_PRFM_POS
, OP2 (PRFOP
, ADDR_UIMM12
), QL_LDST_PRFM
, 0),
3435 /* Load/store register (register offset). */
3436 CORE_INSN ("strb", 0x38200800, 0xffe00c00, ldst_regoff
, 0, OP2 (Rt
, ADDR_REGOFF
), QL_LDST_W8
, 0),
3437 CORE_INSN ("ldrb", 0x38600800, 0xffe00c00, ldst_regoff
, 0, OP2 (Rt
, ADDR_REGOFF
), QL_LDST_W8
, 0),
3438 CORE_INSN ("ldrsb", 0x38a00800, 0xffa00c00, ldst_regoff
, 0, OP2 (Rt
, ADDR_REGOFF
), QL_LDST_R8
, F_LDS_SIZE
),
3439 CORE_INSN ("str", 0x3c200800, 0x3f600c00, ldst_regoff
, 0, OP2 (Ft
, ADDR_REGOFF
), QL_LDST_FP
, 0),
3440 CORE_INSN ("ldr", 0x3c600800, 0x3f600c00, ldst_regoff
, 0, OP2 (Ft
, ADDR_REGOFF
), QL_LDST_FP
, 0),
3441 CORE_INSN ("strh", 0x78200800, 0xffe00c00, ldst_regoff
, 0, OP2 (Rt
, ADDR_REGOFF
), QL_LDST_W16
, 0),
3442 CORE_INSN ("ldrh", 0x78600800, 0xffe00c00, ldst_regoff
, 0, OP2 (Rt
, ADDR_REGOFF
), QL_LDST_W16
, 0),
3443 CORE_INSN ("ldrsh", 0x78a00800, 0xffa00c00, ldst_regoff
, 0, OP2 (Rt
, ADDR_REGOFF
), QL_LDST_R16
, F_LDS_SIZE
),
3444 CORE_INSN ("str", 0xb8200800, 0xbfe00c00, ldst_regoff
, 0, OP2 (Rt
, ADDR_REGOFF
), QL_LDST_R
, F_GPRSIZE_IN_Q
),
3445 CORE_INSN ("ldr", 0xb8600800, 0xbfe00c00, ldst_regoff
, 0, OP2 (Rt
, ADDR_REGOFF
), QL_LDST_R
, F_GPRSIZE_IN_Q
),
3446 CORE_INSN ("ldrsw", 0xb8a00800, 0xffe00c00, ldst_regoff
, 0, OP2 (Rt
, ADDR_REGOFF
), QL_LDST_X32
, 0),
3447 CORE_INSN ("prfm", 0xf8a00800, 0xffe00c00, ldst_regoff
, 0, OP2 (PRFOP
, ADDR_REGOFF
), QL_LDST_PRFM
, 0),
3448 /* Load/store register (unprivileged). */
3449 CORE_INSN ("sttrb", 0x38000800, 0xffe00c00, ldst_unpriv
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_W8
, 0),
3450 CORE_INSN ("ldtrb", 0x38400800, 0xffe00c00, ldst_unpriv
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_W8
, 0),
3451 CORE_INSN ("ldtrsb", 0x38800800, 0xffa00c00, ldst_unpriv
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_R8
, F_LDS_SIZE
),
3452 CORE_INSN ("sttrh", 0x78000800, 0xffe00c00, ldst_unpriv
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_W16
, 0),
3453 CORE_INSN ("ldtrh", 0x78400800, 0xffe00c00, ldst_unpriv
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_W16
, 0),
3454 CORE_INSN ("ldtrsh", 0x78800800, 0xffa00c00, ldst_unpriv
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_R16
, F_LDS_SIZE
),
3455 CORE_INSN ("sttr", 0xb8000800, 0xbfe00c00, ldst_unpriv
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_R
, F_GPRSIZE_IN_Q
),
3456 CORE_INSN ("ldtr", 0xb8400800, 0xbfe00c00, ldst_unpriv
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_R
, F_GPRSIZE_IN_Q
),
3457 CORE_INSN ("ldtrsw", 0xb8800800, 0xffe00c00, ldst_unpriv
, 0, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_X32
, 0),
3458 /* Load/store register (unscaled immediate). */
3459 CORE_INSN ("sturb", 0x38000000, 0xffe00c00, ldst_unscaled
, OP_STURB
, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_W8
, 0),
3460 CORE_INSN ("ldurb", 0x38400000, 0xffe00c00, ldst_unscaled
, OP_LDURB
, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_W8
, 0),
3461 CORE_INSN ("ldursb", 0x38800000, 0xffa00c00, ldst_unscaled
, OP_LDURSB
, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_R8
, F_LDS_SIZE
),
3462 CORE_INSN ("stur", 0x3c000000, 0x3f600c00, ldst_unscaled
, OP_STURV
, OP2 (Ft
, ADDR_SIMM9
), QL_LDST_FP
, 0),
3463 CORE_INSN ("ldur", 0x3c400000, 0x3f600c00, ldst_unscaled
, OP_LDURV
, OP2 (Ft
, ADDR_SIMM9
), QL_LDST_FP
, 0),
3464 CORE_INSN ("sturh", 0x78000000, 0xffe00c00, ldst_unscaled
, OP_STURH
, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_W16
, 0),
3465 CORE_INSN ("ldurh", 0x78400000, 0xffe00c00, ldst_unscaled
, OP_LDURH
, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_W16
, 0),
3466 CORE_INSN ("ldursh", 0x78800000, 0xffa00c00, ldst_unscaled
, OP_LDURSH
, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_R16
, F_LDS_SIZE
),
3467 CORE_INSN ("stur", 0xb8000000, 0xbfe00c00, ldst_unscaled
, OP_STUR
, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_R
, F_GPRSIZE_IN_Q
),
3468 CORE_INSN ("ldur", 0xb8400000, 0xbfe00c00, ldst_unscaled
, OP_LDUR
, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_R
, F_GPRSIZE_IN_Q
),
3469 CORE_INSN ("ldursw", 0xb8800000, 0xffe00c00, ldst_unscaled
, OP_LDURSW
, OP2 (Rt
, ADDR_SIMM9
), QL_LDST_X32
, 0),
3470 CORE_INSN ("prfum", 0xf8800000, 0xffe00c00, ldst_unscaled
, OP_PRFUM
, OP2 (PRFOP
, ADDR_SIMM9
), QL_LDST_PRFM
, 0),
3471 MEMTAG_INSN ("ldg", 0xd9600000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_SIMM13
), QL_LDG
, 0),
3472 /* Load/store register (scaled signed immediate). */
3473 V8_3_INSN ("ldraa", 0xf8200400, 0xffa00400, ldst_imm10
, OP2 (Rt
, ADDR_SIMM10
), QL_X1NIL
, 0),
3474 V8_3_INSN ("ldrab", 0xf8a00400, 0xffa00400, ldst_imm10
, OP2 (Rt
, ADDR_SIMM10
), QL_X1NIL
, 0),
3475 /* Load/store exclusive. */
3476 CORE_INSN ("stxrb", 0x8007c00, 0xffe08000, ldstexcl
, 0, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3477 CORE_INSN ("stlxrb", 0x800fc00, 0xffe08000, ldstexcl
, 0, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3478 CORE_INSN ("ldxrb", 0x85f7c00, 0xffe08000, ldstexcl
, 0, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3479 CORE_INSN ("ldaxrb", 0x85ffc00, 0xffe08000, ldstexcl
, 0, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3480 CORE_INSN ("stlrb", 0x89ffc00, 0xffe08000, ldstexcl
, 0, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3481 CORE_INSN ("ldarb", 0x8dffc00, 0xffeffc00, ldstexcl
, 0, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3482 CORE_INSN ("stxrh", 0x48007c00, 0xffe08000, ldstexcl
, 0, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3483 CORE_INSN ("stlxrh", 0x4800fc00, 0xffe08000, ldstexcl
, 0, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3484 CORE_INSN ("ldxrh", 0x485f7c00, 0xffe08000, ldstexcl
, 0, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3485 CORE_INSN ("ldaxrh", 0x485ffc00, 0xffe08000, ldstexcl
, 0, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3486 CORE_INSN ("stlrh", 0x489ffc00, 0xffe08000, ldstexcl
, 0, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3487 CORE_INSN ("ldarh", 0x48dffc00, 0xfffffc00, ldstexcl
, 0, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3488 CORE_INSN ("stxr", 0x88007c00, 0xbfe08000, ldstexcl
, 0, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2_LDST_EXC
, F_GPRSIZE_IN_Q
),
3489 CORE_INSN ("stlxr", 0x8800fc00, 0xbfe08000, ldstexcl
, 0, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2_LDST_EXC
, F_GPRSIZE_IN_Q
),
3490 CORE_INSN ("stxp", 0x88200000, 0xbfe08000, ldstexcl
, 0, OP4 (Rs
, Rt
, Rt2
, ADDR_SIMPLE
), QL_R3_LDST_EXC
, F_GPRSIZE_IN_Q
),
3491 CORE_INSN ("stlxp", 0x88208000, 0xbfe08000, ldstexcl
, 0, OP4 (Rs
, Rt
, Rt2
, ADDR_SIMPLE
), QL_R3_LDST_EXC
, F_GPRSIZE_IN_Q
),
3492 CORE_INSN ("ldxr", 0x885f7c00, 0xbfe08000, ldstexcl
, 0, OP2 (Rt
, ADDR_SIMPLE
), QL_R1NIL
, F_GPRSIZE_IN_Q
),
3493 CORE_INSN ("ldaxr", 0x885ffc00, 0xbfe08000, ldstexcl
, 0, OP2 (Rt
, ADDR_SIMPLE
), QL_R1NIL
, F_GPRSIZE_IN_Q
),
3494 CORE_INSN ("ldxp", 0x887f0000, 0xbfe08000, ldstexcl
, 0, OP3 (Rt
, Rt2
, ADDR_SIMPLE
), QL_R2NIL
, F_GPRSIZE_IN_Q
),
3495 CORE_INSN ("ldaxp", 0x887f8000, 0xbfe08000, ldstexcl
, 0, OP3 (Rt
, Rt2
, ADDR_SIMPLE
), QL_R2NIL
, F_GPRSIZE_IN_Q
),
3496 CORE_INSN ("stlr", 0x889ffc00, 0xbfe08000, ldstexcl
, 0, OP2 (Rt
, ADDR_SIMPLE
), QL_R1NIL
, F_GPRSIZE_IN_Q
),
3497 CORE_INSN ("ldar", 0x88dffc00, 0xbfeffc00, ldstexcl
, 0, OP2 (Rt
, ADDR_SIMPLE
), QL_R1NIL
, F_GPRSIZE_IN_Q
),
3498 RCPC_INSN ("ldaprb", 0x38bfc000, 0xfffffc00, ldstexcl
, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3499 RCPC_INSN ("ldaprh", 0x78bfc000, 0xfffffc00, ldstexcl
, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3500 RCPC_INSN ("ldapr", 0xb8bfc000, 0xbffffc00, ldstexcl
, OP2 (Rt
, ADDR_SIMPLE
), QL_R1NIL
, F_GPRSIZE_IN_Q
),
3501 MEMTAG_INSN ("ldgm", 0xd9e00000, 0xfffffc00, ldstexcl
, OP2 (Rt
, ADDR_SIMPLE
), QL_X1NIL
, 0),
3502 MEMTAG_INSN ("stgm", 0xd9a00000, 0xfffffc00, ldstexcl
, OP2 (Rt
, ADDR_SIMPLE
), QL_X1NIL
, 0),
3503 MEMTAG_INSN ("stzgm", 0xd9200000, 0xfffffc00, ldstexcl
, OP2 (Rt
, ADDR_SIMPLE
), QL_X1NIL
, 0),
3504 /* Limited Ordering Regions load/store instructions. */
3505 _LOR_INSN ("ldlar", 0x88df7c00, 0xbfe08000, ldstexcl
, OP2 (Rt
, ADDR_SIMPLE
), QL_R1NIL
, F_GPRSIZE_IN_Q
),
3506 _LOR_INSN ("ldlarb", 0x08df7c00, 0xffe08000, ldstexcl
, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3507 _LOR_INSN ("ldlarh", 0x48df7c00, 0xffe08000, ldstexcl
, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3508 _LOR_INSN ("stllr", 0x889f7c00, 0xbfe08000, ldstexcl
, OP2 (Rt
, ADDR_SIMPLE
), QL_R1NIL
, F_GPRSIZE_IN_Q
),
3509 _LOR_INSN ("stllrb", 0x089f7c00, 0xffe08000, ldstexcl
, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3510 _LOR_INSN ("stllrh", 0x489f7c00, 0xbfe08000, ldstexcl
, OP2 (Rt
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, 0),
3511 /* Load/store no-allocate pair (offset). */
3512 CORE_INSN ("stnp", 0x28000000, 0x7fc00000, ldstnapair_offs
, 0, OP3 (Rt
, Rt2
, ADDR_SIMM7
), QL_LDST_PAIR_R
, F_SF
),
3513 CORE_INSN ("ldnp", 0x28400000, 0x7fc00000, ldstnapair_offs
, 0, OP3 (Rt
, Rt2
, ADDR_SIMM7
), QL_LDST_PAIR_R
, F_SF
),
3514 CORE_INSN ("stnp", 0x2c000000, 0x3fc00000, ldstnapair_offs
, 0, OP3 (Ft
, Ft2
, ADDR_SIMM7
), QL_LDST_PAIR_FP
, 0),
3515 CORE_INSN ("ldnp", 0x2c400000, 0x3fc00000, ldstnapair_offs
, 0, OP3 (Ft
, Ft2
, ADDR_SIMM7
), QL_LDST_PAIR_FP
, 0),
3516 /* Load/store register pair (offset). */
3517 CORE_INSN ("stp", 0x29000000, 0x7ec00000, ldstpair_off
, 0, OP3 (Rt
, Rt2
, ADDR_SIMM7
), QL_LDST_PAIR_R
, F_SF
),
3518 CORE_INSN ("ldp", 0x29400000, 0x7ec00000, ldstpair_off
, 0, OP3 (Rt
, Rt2
, ADDR_SIMM7
), QL_LDST_PAIR_R
, F_SF
),
3519 CORE_INSN ("stp", 0x2d000000, 0x3fc00000, ldstpair_off
, 0, OP3 (Ft
, Ft2
, ADDR_SIMM7
), QL_LDST_PAIR_FP
, 0),
3520 CORE_INSN ("ldp", 0x2d400000, 0x3fc00000, ldstpair_off
, 0, OP3 (Ft
, Ft2
, ADDR_SIMM7
), QL_LDST_PAIR_FP
, 0),
3521 {"ldpsw", 0x69400000, 0xffc00000, ldstpair_off
, 0, CORE
, OP3 (Rt
, Rt2
, ADDR_SIMM7
), QL_LDST_PAIR_X32
, 0, 0, 0, VERIFIER (ldpsw
)},
3522 MEMTAG_INSN ("stgp", 0x69000000, 0xffc00000, ldstpair_off
, OP3 (Rt
, Rt2
, ADDR_SIMM11
), QL_STGP
, 0),
3523 /* Load/store register pair (indexed). */
3524 CORE_INSN ("stp", 0x28800000, 0x7ec00000, ldstpair_indexed
, 0, OP3 (Rt
, Rt2
, ADDR_SIMM7
), QL_LDST_PAIR_R
, F_SF
),
3525 CORE_INSN ("ldp", 0x28c00000, 0x7ec00000, ldstpair_indexed
, 0, OP3 (Rt
, Rt2
, ADDR_SIMM7
), QL_LDST_PAIR_R
, F_SF
),
3526 CORE_INSN ("stp", 0x2c800000, 0x3ec00000, ldstpair_indexed
, 0, OP3 (Ft
, Ft2
, ADDR_SIMM7
), QL_LDST_PAIR_FP
, 0),
3527 CORE_INSN ("ldp", 0x2cc00000, 0x3ec00000, ldstpair_indexed
, 0, OP3 (Ft
, Ft2
, ADDR_SIMM7
), QL_LDST_PAIR_FP
, 0),
3528 {"ldpsw", 0x68c00000, 0xfec00000, ldstpair_indexed
, 0, CORE
, OP3 (Rt
, Rt2
, ADDR_SIMM7
), QL_LDST_PAIR_X32
, 0, 0, 0, VERIFIER (ldpsw
)},
3529 MEMTAG_INSN ("stgp", 0x68800000, 0xfec00000, ldstpair_indexed
, OP3 (Rt
, Rt2
, ADDR_SIMM11
), QL_STGP
, 0),
3530 /* Load register (literal). */
3531 CORE_INSN ("ldr", 0x18000000, 0xbf000000, loadlit
, OP_LDR_LIT
, OP2 (Rt
, ADDR_PCREL19
), QL_R_PCREL
, F_GPRSIZE_IN_Q
),
3532 CORE_INSN ("ldr", 0x1c000000, 0x3f000000, loadlit
, OP_LDRV_LIT
, OP2 (Ft
, ADDR_PCREL19
), QL_FP_PCREL
, 0),
3533 CORE_INSN ("ldrsw", 0x98000000, 0xff000000, loadlit
, OP_LDRSW_LIT
, OP2 (Rt
, ADDR_PCREL19
), QL_X_PCREL
, 0),
3534 CORE_INSN ("prfm", 0xd8000000, 0xff000000, loadlit
, OP_PRFM_LIT
, OP2 (PRFOP
, ADDR_PCREL19
), QL_PRFM_PCREL
, 0),
3535 /* Logical (immediate). */
3536 CORE_INSN ("and", 0x12000000, 0x7f800000, log_imm
, 0, OP3 (Rd_SP
, Rn
, LIMM
), QL_R2NIL
, F_HAS_ALIAS
| F_SF
),
3537 CORE_INSN ("bic", 0x12000000, 0x7f800000, log_imm
, OP_BIC
, OP3 (Rd_SP
, Rn
, LIMM
), QL_R2NIL
, F_ALIAS
| F_PSEUDO
| F_SF
),
3538 CORE_INSN ("orr", 0x32000000, 0x7f800000, log_imm
, 0, OP3 (Rd_SP
, Rn
, LIMM
), QL_R2NIL
, F_HAS_ALIAS
| F_SF
),
3539 CORE_INSN ("mov", 0x320003e0, 0x7f8003e0, log_imm
, OP_MOV_IMM_LOG
, OP2 (Rd_SP
, IMM_MOV
), QL_R1NIL
, F_ALIAS
| F_P1
| F_SF
| F_CONV
),
3540 CORE_INSN ("eor", 0x52000000, 0x7f800000, log_imm
, 0, OP3 (Rd_SP
, Rn
, LIMM
), QL_R2NIL
, F_SF
),
3541 CORE_INSN ("ands", 0x72000000, 0x7f800000, log_imm
, 0, OP3 (Rd
, Rn
, LIMM
), QL_R2NIL
, F_HAS_ALIAS
| F_SF
),
3542 CORE_INSN ("tst", 0x7200001f, 0x7f80001f, log_imm
, 0, OP2 (Rn
, LIMM
), QL_R1NIL
, F_ALIAS
| F_SF
),
3543 /* Logical (shifted register). */
3544 CORE_INSN ("and", 0xa000000, 0x7f200000, log_shift
, 0, OP3 (Rd
, Rn
, Rm_SFT
), QL_I3SAMER
, F_SF
),
3545 CORE_INSN ("bic", 0xa200000, 0x7f200000, log_shift
, 0, OP3 (Rd
, Rn
, Rm_SFT
), QL_I3SAMER
, F_SF
),
3546 CORE_INSN ("orr", 0x2a000000, 0x7f200000, log_shift
, 0, OP3 (Rd
, Rn
, Rm_SFT
), QL_I3SAMER
, F_HAS_ALIAS
| F_SF
),
3547 CORE_INSN ("mov", 0x2a0003e0, 0x7fe0ffe0, log_shift
, 0, OP2 (Rd
, Rm_SFT
), QL_I2SAMER
, F_ALIAS
| F_SF
),
3548 CORE_INSN ("uxtw", 0x2a0003e0, 0x7f2003e0, log_shift
, OP_UXTW
, OP2 (Rd
, Rm
), QL_I2SAMEW
, F_ALIAS
| F_PSEUDO
),
3549 CORE_INSN ("orn", 0x2a200000, 0x7f200000, log_shift
, 0, OP3 (Rd
, Rn
, Rm_SFT
), QL_I3SAMER
, F_HAS_ALIAS
| F_SF
),
3550 CORE_INSN ("mvn", 0x2a2003e0, 0x7f2003e0, log_shift
, 0, OP2 (Rd
, Rm_SFT
), QL_I2SAMER
, F_ALIAS
| F_SF
),
3551 CORE_INSN ("eor", 0x4a000000, 0x7f200000, log_shift
, 0, OP3 (Rd
, Rn
, Rm_SFT
), QL_I3SAMER
, F_SF
),
3552 CORE_INSN ("eon", 0x4a200000, 0x7f200000, log_shift
, 0, OP3 (Rd
, Rn
, Rm_SFT
), QL_I3SAMER
, F_SF
),
3553 CORE_INSN ("ands", 0x6a000000, 0x7f200000, log_shift
, 0, OP3 (Rd
, Rn
, Rm_SFT
), QL_I3SAMER
, F_HAS_ALIAS
| F_SF
),
3554 CORE_INSN ("tst", 0x6a00001f, 0x7f20001f, log_shift
, 0, OP2 (Rn
, Rm_SFT
), QL_I2SAMER
, F_ALIAS
| F_SF
),
3555 CORE_INSN ("bics", 0x6a200000, 0x7f200000, log_shift
, 0, OP3 (Rd
, Rn
, Rm_SFT
), QL_I3SAMER
, F_SF
),
3556 /* LSE extension (atomic). */
3557 _LSE_INSN ("casb", 0x8a07c00, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3558 _LSE_INSN ("cash", 0x48a07c00, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3559 _LSE_INSN ("cas", 0x88a07c00, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3560 _LSE_INSN ("casab", 0x8e07c00, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3561 _LSE_INSN ("caslb", 0x8a0fc00, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3562 _LSE_INSN ("casalb", 0x8e0fc00, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3563 _LSE_INSN ("casah", 0x48e07c00, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3564 _LSE_INSN ("caslh", 0x48a0fc00, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3565 _LSE_INSN ("casalh", 0x48e0fc00, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3566 _LSE_INSN ("casa", 0x88e07c00, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3567 _LSE_INSN ("casl", 0x88a0fc00, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3568 _LSE_INSN ("casal", 0x88e0fc00, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3569 _LSE_INSN ("casp", 0x8207c00, 0xbfe0fc00, lse_atomic
, OP5 (Rs
, PAIRREG
, Rt
, PAIRREG
, ADDR_SIMPLE
), QL_R4NIL
, F_LSE_SZ
),
3570 _LSE_INSN ("caspa", 0x8607c00, 0xbfe0fc00, lse_atomic
, OP5 (Rs
, PAIRREG
, Rt
, PAIRREG
, ADDR_SIMPLE
), QL_R4NIL
, F_LSE_SZ
),
3571 _LSE_INSN ("caspl", 0x820fc00, 0xbfe0fc00, lse_atomic
, OP5 (Rs
, PAIRREG
, Rt
, PAIRREG
, ADDR_SIMPLE
), QL_R4NIL
, F_LSE_SZ
),
3572 _LSE_INSN ("caspal", 0x860fc00, 0xbfe0fc00, lse_atomic
, OP5 (Rs
, PAIRREG
, Rt
, PAIRREG
, ADDR_SIMPLE
), QL_R4NIL
, F_LSE_SZ
),
3573 _LSE_INSN ("swpb", 0x38208000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3574 _LSE_INSN ("swph", 0x78208000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3575 _LSE_INSN ("swp", 0xb8208000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3576 _LSE_INSN ("swpab", 0x38a08000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3577 _LSE_INSN ("swplb", 0x38608000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3578 _LSE_INSN ("swpalb", 0x38e08000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3579 _LSE_INSN ("swpah", 0x78a08000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3580 _LSE_INSN ("swplh", 0x78608000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3581 _LSE_INSN ("swpalh", 0x78e08000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3582 _LSE_INSN ("swpa", 0xb8a08000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3583 _LSE_INSN ("swpl", 0xb8608000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3584 _LSE_INSN ("swpal", 0xb8e08000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3585 _LSE_INSN ("ldaddb", 0x38200000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3586 _LSE_INSN ("ldaddh", 0x78200000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3587 _LSE_INSN ("ldadd", 0xb8200000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3588 _LSE_INSN ("ldaddab", 0x38a00000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3589 _LSE_INSN ("ldaddlb", 0x38600000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3590 _LSE_INSN ("ldaddalb", 0x38e00000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3591 _LSE_INSN ("ldaddah", 0x78a00000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3592 _LSE_INSN ("ldaddlh", 0x78600000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3593 _LSE_INSN ("ldaddalh", 0x78e00000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3594 _LSE_INSN ("ldadda", 0xb8a00000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3595 _LSE_INSN ("ldaddl", 0xb8600000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3596 _LSE_INSN ("ldaddal", 0xb8e00000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3597 _LSE_INSN ("ldclrb", 0x38201000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3598 _LSE_INSN ("ldclrh", 0x78201000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3599 _LSE_INSN ("ldclr", 0xb8201000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3600 _LSE_INSN ("ldclrab", 0x38a01000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3601 _LSE_INSN ("ldclrlb", 0x38601000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3602 _LSE_INSN ("ldclralb", 0x38e01000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3603 _LSE_INSN ("ldclrah", 0x78a01000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3604 _LSE_INSN ("ldclrlh", 0x78601000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3605 _LSE_INSN ("ldclralh", 0x78e01000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3606 _LSE_INSN ("ldclra", 0xb8a01000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3607 _LSE_INSN ("ldclrl", 0xb8601000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3608 _LSE_INSN ("ldclral", 0xb8e01000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3609 _LSE_INSN ("ldeorb", 0x38202000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3610 _LSE_INSN ("ldeorh", 0x78202000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3611 _LSE_INSN ("ldeor", 0xb8202000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3612 _LSE_INSN ("ldeorab", 0x38a02000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3613 _LSE_INSN ("ldeorlb", 0x38602000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3614 _LSE_INSN ("ldeoralb", 0x38e02000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3615 _LSE_INSN ("ldeorah", 0x78a02000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3616 _LSE_INSN ("ldeorlh", 0x78602000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3617 _LSE_INSN ("ldeoralh", 0x78e02000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3618 _LSE_INSN ("ldeora", 0xb8a02000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3619 _LSE_INSN ("ldeorl", 0xb8602000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3620 _LSE_INSN ("ldeoral", 0xb8e02000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3621 _LSE_INSN ("ldsetb", 0x38203000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3622 _LSE_INSN ("ldseth", 0x78203000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3623 _LSE_INSN ("ldset", 0xb8203000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3624 _LSE_INSN ("ldsetab", 0x38a03000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3625 _LSE_INSN ("ldsetlb", 0x38603000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3626 _LSE_INSN ("ldsetalb", 0x38e03000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3627 _LSE_INSN ("ldsetah", 0x78a03000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3628 _LSE_INSN ("ldsetlh", 0x78603000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3629 _LSE_INSN ("ldsetalh", 0x78e03000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3630 _LSE_INSN ("ldseta", 0xb8a03000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3631 _LSE_INSN ("ldsetl", 0xb8603000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3632 _LSE_INSN ("ldsetal", 0xb8e03000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3633 _LSE_INSN ("ldsmaxb", 0x38204000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3634 _LSE_INSN ("ldsmaxh", 0x78204000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3635 _LSE_INSN ("ldsmax", 0xb8204000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3636 _LSE_INSN ("ldsmaxab", 0x38a04000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3637 _LSE_INSN ("ldsmaxlb", 0x38604000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3638 _LSE_INSN ("ldsmaxalb", 0x38e04000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3639 _LSE_INSN ("ldsmaxah", 0x78a04000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3640 _LSE_INSN ("ldsmaxlh", 0x78604000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3641 _LSE_INSN ("ldsmaxalh", 0x78e04000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3642 _LSE_INSN ("ldsmaxa", 0xb8a04000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3643 _LSE_INSN ("ldsmaxl", 0xb8604000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3644 _LSE_INSN ("ldsmaxal", 0xb8e04000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3645 _LSE_INSN ("ldsminb", 0x38205000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3646 _LSE_INSN ("ldsminh", 0x78205000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3647 _LSE_INSN ("ldsmin", 0xb8205000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3648 _LSE_INSN ("ldsminab", 0x38a05000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3649 _LSE_INSN ("ldsminlb", 0x38605000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3650 _LSE_INSN ("ldsminalb", 0x38e05000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3651 _LSE_INSN ("ldsminah", 0x78a05000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3652 _LSE_INSN ("ldsminlh", 0x78605000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3653 _LSE_INSN ("ldsminalh", 0x78e05000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3654 _LSE_INSN ("ldsmina", 0xb8a05000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3655 _LSE_INSN ("ldsminl", 0xb8605000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3656 _LSE_INSN ("ldsminal", 0xb8e05000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3657 _LSE_INSN ("ldumaxb", 0x38206000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3658 _LSE_INSN ("ldumaxh", 0x78206000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3659 _LSE_INSN ("ldumax", 0xb8206000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3660 _LSE_INSN ("ldumaxab", 0x38a06000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3661 _LSE_INSN ("ldumaxlb", 0x38606000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3662 _LSE_INSN ("ldumaxalb", 0x38e06000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3663 _LSE_INSN ("ldumaxah", 0x78a06000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3664 _LSE_INSN ("ldumaxlh", 0x78606000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3665 _LSE_INSN ("ldumaxalh", 0x78e06000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3666 _LSE_INSN ("ldumaxa", 0xb8a06000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3667 _LSE_INSN ("ldumaxl", 0xb8606000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3668 _LSE_INSN ("ldumaxal", 0xb8e06000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3669 _LSE_INSN ("lduminb", 0x38207000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3670 _LSE_INSN ("lduminh", 0x78207000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3671 _LSE_INSN ("ldumin", 0xb8207000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3672 _LSE_INSN ("lduminab", 0x38a07000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3673 _LSE_INSN ("lduminlb", 0x38607000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3674 _LSE_INSN ("lduminalb", 0x38e07000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3675 _LSE_INSN ("lduminah", 0x78a07000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3676 _LSE_INSN ("lduminlh", 0x78607000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, F_HAS_ALIAS
),
3677 _LSE_INSN ("lduminalh", 0x78e07000, 0xffe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_W2_LDST_EXC
, 0),
3678 _LSE_INSN ("ldumina", 0xb8a07000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3679 _LSE_INSN ("lduminl", 0xb8607000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
| F_HAS_ALIAS
),
3680 _LSE_INSN ("lduminal", 0xb8e07000, 0xbfe0fc00, lse_atomic
, OP3 (Rs
, Rt
, ADDR_SIMPLE
), QL_R2NIL
, F_LSE_SZ
),
3681 _LSE_INSN ("staddb", 0x3820001f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3682 _LSE_INSN ("staddh", 0x7820001f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3683 _LSE_INSN ("stadd", 0xb820001f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3684 _LSE_INSN ("staddlb", 0x3860001f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3685 _LSE_INSN ("staddlh", 0x7860001f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3686 _LSE_INSN ("staddl", 0xb860001f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3687 _LSE_INSN ("stclrb", 0x3820101f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3688 _LSE_INSN ("stclrh", 0x7820101f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3689 _LSE_INSN ("stclr", 0xb820101f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3690 _LSE_INSN ("stclrlb", 0x3860101f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3691 _LSE_INSN ("stclrlh", 0x7860101f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3692 _LSE_INSN ("stclrl", 0xb860101f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3693 _LSE_INSN ("steorb", 0x3820201f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3694 _LSE_INSN ("steorh", 0x7820201f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3695 _LSE_INSN ("steor", 0xb820201f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3696 _LSE_INSN ("steorlb", 0x3860201f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3697 _LSE_INSN ("steorlh", 0x7860201f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3698 _LSE_INSN ("steorl", 0xb860201f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3699 _LSE_INSN ("stsetb", 0x3820301f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3700 _LSE_INSN ("stseth", 0x7820301f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3701 _LSE_INSN ("stset", 0xb820301f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3702 _LSE_INSN ("stsetlb", 0x3860301f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3703 _LSE_INSN ("stsetlh", 0x7860301f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3704 _LSE_INSN ("stsetl", 0xb860301f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3705 _LSE_INSN ("stsmaxb", 0x3820401f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3706 _LSE_INSN ("stsmaxh", 0x7820401f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3707 _LSE_INSN ("stsmax", 0xb820401f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3708 _LSE_INSN ("stsmaxlb", 0x3860401f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3709 _LSE_INSN ("stsmaxlh", 0x7860401f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3710 _LSE_INSN ("stsmaxl", 0xb860401f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3711 _LSE_INSN ("stsminb", 0x3820501f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3712 _LSE_INSN ("stsminh", 0x7820501f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3713 _LSE_INSN ("stsmin", 0xb820501f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3714 _LSE_INSN ("stsminlb", 0x3860501f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3715 _LSE_INSN ("stsminlh", 0x7860501f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3716 _LSE_INSN ("stsminl", 0xb860501f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3717 _LSE_INSN ("stumaxb", 0x3820601f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3718 _LSE_INSN ("stumaxh", 0x7820601f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3719 _LSE_INSN ("stumax", 0xb820601f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3720 _LSE_INSN ("stumaxlb", 0x3860601f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3721 _LSE_INSN ("stumaxlh", 0x7860601f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3722 _LSE_INSN ("stumaxl", 0xb860601f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3723 _LSE_INSN ("stuminb", 0x3820701f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3724 _LSE_INSN ("stuminh", 0x7820701f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3725 _LSE_INSN ("stumin", 0xb820701f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3726 _LSE_INSN ("stuminlb", 0x3860701f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3727 _LSE_INSN ("stuminlh", 0x7860701f, 0xffe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_W1_LDST_EXC
, F_ALIAS
),
3728 _LSE_INSN ("stuminl", 0xb860701f, 0xbfe0fc1f, lse_atomic
, OP2 (Rs
, ADDR_SIMPLE
), QL_R1NIL
, F_LSE_SZ
| F_ALIAS
),
3729 /* Move wide (immediate). */
3730 CORE_INSN ("movn", 0x12800000, 0x7f800000, movewide
, OP_MOVN
, OP2 (Rd
, HALF
), QL_DST_R
, F_SF
| F_HAS_ALIAS
),
3731 CORE_INSN ("mov", 0x12800000, 0x7f800000, movewide
, OP_MOV_IMM_WIDEN
, OP2 (Rd
, IMM_MOV
), QL_DST_R
, F_SF
| F_ALIAS
| F_CONV
),
3732 CORE_INSN ("movz", 0x52800000, 0x7f800000, movewide
, OP_MOVZ
, OP2 (Rd
, HALF
), QL_DST_R
, F_SF
| F_HAS_ALIAS
),
3733 CORE_INSN ("mov", 0x52800000, 0x7f800000, movewide
, OP_MOV_IMM_WIDE
, OP2 (Rd
, IMM_MOV
), QL_DST_R
, F_SF
| F_ALIAS
| F_CONV
),
3734 CORE_INSN ("movk", 0x72800000, 0x7f800000, movewide
, OP_MOVK
, OP2 (Rd
, HALF
), QL_DST_R
, F_SF
),
3735 /* PC-rel. addressing. */
3736 CORE_INSN ("adr", 0x10000000, 0x9f000000, pcreladdr
, 0, OP2 (Rd
, ADDR_PCREL21
), QL_ADRP
, 0),
3737 CORE_INSN ("adrp", 0x90000000, 0x9f000000, pcreladdr
, 0, OP2 (Rd
, ADDR_ADRP
), QL_ADRP
, 0),
3738 /* TME Instructions. */
3739 _TME_INSN ("tstart", 0xd5233060, 0xffffffe0, 0, 0, OP1 (Rd
), QL_I1X
, 0),
3740 _TME_INSN ("tcommit", 0xd503307f, 0xffffffff, 0, 0, OP0 (), {}, 0),
3741 _TME_INSN ("ttest", 0xd5233160, 0xffffffe0, 0, 0, OP1 (Rd
), QL_I1X
, 0),
3742 _TME_INSN ("tcancel", 0xd4600000, 0xffe0001f, 0, 0, OP1 (TME_UIMM16
), QL_IMM_NIL
, 0),
3744 CORE_INSN ("msr", 0xd500401f, 0xfff8f01f, ic_system
, 0, OP2 (PSTATEFIELD
, UIMM4
), {}, F_SYS_WRITE
),
3745 CORE_INSN ("hint",0xd503201f, 0xfffff01f, ic_system
, 0, OP1 (UIMM7
), {}, F_HAS_ALIAS
),
3746 CORE_INSN ("nop", 0xd503201f, 0xffffffff, ic_system
, 0, OP0 (), {}, F_ALIAS
),
3747 CORE_INSN ("csdb",0xd503229f, 0xffffffff, ic_system
, 0, OP0 (), {}, F_ALIAS
),
3748 BTI_INSN ("bti",0xd503241f, 0xffffff3f, ic_system
, OP1 (BTI_TARGET
), {}, F_ALIAS
| F_OPD0_OPT
| F_DEFAULT (0x0)),
3749 CORE_INSN ("yield", 0xd503203f, 0xffffffff, ic_system
, 0, OP0 (), {}, F_ALIAS
),
3750 CORE_INSN ("wfe", 0xd503205f, 0xffffffff, ic_system
, 0, OP0 (), {}, F_ALIAS
),
3751 CORE_INSN ("wfi", 0xd503207f, 0xffffffff, ic_system
, 0, OP0 (), {}, F_ALIAS
),
3752 CORE_INSN ("sev", 0xd503209f, 0xffffffff, ic_system
, 0, OP0 (), {}, F_ALIAS
),
3753 CORE_INSN ("sevl",0xd50320bf, 0xffffffff, ic_system
, 0, OP0 (), {}, F_ALIAS
),
3754 V8_3_INSN ("xpaclri", 0xd50320ff, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3755 V8_3_INSN ("pacia1716", 0xd503211f, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3756 V8_3_INSN ("pacib1716", 0xd503215f, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3757 V8_3_INSN ("autia1716", 0xd503219f, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3758 V8_3_INSN ("autib1716", 0xd50321df, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3759 {"esb", 0xd503221f, 0xffffffff, ic_system
, 0, RAS
, OP0 (), {}, F_ALIAS
, 0, 0, NULL
},
3760 {"psb", 0xd503223f, 0xffffffff, ic_system
, 0, STAT_PROFILE
, OP1 (BARRIER_PSB
), {}, F_ALIAS
, 0, 0, NULL
},
3761 CORE_INSN ("clrex", 0xd503305f, 0xfffff0ff, ic_system
, 0, OP1 (UIMM4
), {}, F_OPD0_OPT
| F_DEFAULT (0xF)),
3762 CORE_INSN ("dsb", 0xd503309f, 0xfffff0ff, ic_system
, 0, OP1 (BARRIER
), {}, F_HAS_ALIAS
),
3763 CORE_INSN ("ssbb", 0xd503309f, 0xffffffff, ic_system
, 0, OP0 (), {}, F_ALIAS
),
3764 CORE_INSN ("pssbb", 0xd503349f, 0xffffffff, ic_system
, 0, OP0 (), {}, F_ALIAS
),
3765 CORE_INSN ("dmb", 0xd50330bf, 0xfffff0ff, ic_system
, 0, OP1 (BARRIER
), {}, 0),
3766 CORE_INSN ("isb", 0xd50330df, 0xfffff0ff, ic_system
, 0, OP1 (BARRIER_ISB
), {}, F_OPD0_OPT
| F_DEFAULT (0xF)),
3767 SB_INSN ("sb", 0xd50330ff, 0xffffffff, ic_system
, OP0 (), {}, 0),
3768 CORE_INSN ("sys", 0xd5080000, 0xfff80000, ic_system
, 0, OP5 (UIMM3_OP1
, CRn
, CRm
, UIMM3_OP2
, Rt
), QL_SYS
, F_HAS_ALIAS
| F_OPD4_OPT
| F_DEFAULT (0x1F)),
3769 CORE_INSN ("at", 0xd5080000, 0xfff80000, ic_system
, 0, OP2 (SYSREG_AT
, Rt
), QL_SRC_X
, F_ALIAS
),
3770 CORE_INSN ("dc", 0xd5080000, 0xfff80000, ic_system
, 0, OP2 (SYSREG_DC
, Rt
), QL_SRC_X
, F_ALIAS
),
3771 CORE_INSN ("ic", 0xd5080000, 0xfff80000, ic_system
, 0, OP2 (SYSREG_IC
, Rt_SYS
), QL_SRC_X
, F_ALIAS
| F_OPD1_OPT
| F_DEFAULT (0x1F)),
3772 CORE_INSN ("tlbi",0xd5080000, 0xfff80000, ic_system
, 0, OP2 (SYSREG_TLBI
, Rt_SYS
), QL_SRC_X
, F_ALIAS
| F_OPD1_OPT
| F_DEFAULT (0x1F)),
3773 PREDRES_INSN ("cfp", 0xd50b7380, 0xffffffe0, ic_system
, OP2 (SYSREG_SR
, Rt
), QL_SRC_X
, F_ALIAS
),
3774 PREDRES_INSN ("dvp", 0xd50b73a0, 0xffffffe0, ic_system
, OP2 (SYSREG_SR
, Rt
), QL_SRC_X
, F_ALIAS
),
3775 PREDRES_INSN ("cpp", 0xd50b73e0, 0xffffffe0, ic_system
, OP2 (SYSREG_SR
, Rt
), QL_SRC_X
, F_ALIAS
),
3776 CORE_INSN ("msr", 0xd5000000, 0xffe00000, ic_system
, 0, OP2 (SYSREG
, Rt
), QL_SRC_X
, F_SYS_WRITE
),
3777 CORE_INSN ("sysl",0xd5280000, 0xfff80000, ic_system
, 0, OP5 (Rt
, UIMM3_OP1
, CRn
, CRm
, UIMM3_OP2
), QL_SYSL
, 0),
3778 CORE_INSN ("mrs", 0xd5200000, 0xffe00000, ic_system
, 0, OP2 (Rt
, SYSREG
), QL_DST_X
, F_SYS_READ
),
3779 V8_3_INSN ("paciaz", 0xd503231f, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3780 V8_3_INSN ("paciasp", 0xd503233f, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3781 V8_3_INSN ("pacibz", 0xd503235f, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3782 V8_3_INSN ("pacibsp", 0xd503237f, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3783 V8_3_INSN ("autiaz", 0xd503239f, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3784 V8_3_INSN ("autiasp", 0xd50323bf, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3785 V8_3_INSN ("autibz", 0xd50323df, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3786 V8_3_INSN ("autibsp", 0xd50323ff, 0xffffffff, ic_system
, OP0 (), {}, F_ALIAS
),
3787 /* Test & branch (immediate). */
3788 CORE_INSN ("tbz", 0x36000000, 0x7f000000, testbranch
, 0, OP3 (Rt
, BIT_NUM
, ADDR_PCREL14
), QL_PCREL_14
, 0),
3789 CORE_INSN ("tbnz",0x37000000, 0x7f000000, testbranch
, 0, OP3 (Rt
, BIT_NUM
, ADDR_PCREL14
), QL_PCREL_14
, 0),
3790 /* The old UAL conditional branch mnemonics (to aid portability). */
3791 CORE_INSN ("beq", 0x54000000, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3792 CORE_INSN ("bne", 0x54000001, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3793 CORE_INSN ("bcs", 0x54000002, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3794 CORE_INSN ("bhs", 0x54000002, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3795 CORE_INSN ("bcc", 0x54000003, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3796 CORE_INSN ("blo", 0x54000003, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3797 CORE_INSN ("bmi", 0x54000004, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3798 CORE_INSN ("bpl", 0x54000005, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3799 CORE_INSN ("bvs", 0x54000006, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3800 CORE_INSN ("bvc", 0x54000007, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3801 CORE_INSN ("bhi", 0x54000008, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3802 CORE_INSN ("bls", 0x54000009, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3803 CORE_INSN ("bge", 0x5400000a, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3804 CORE_INSN ("blt", 0x5400000b, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3805 CORE_INSN ("bgt", 0x5400000c, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3806 CORE_INSN ("ble", 0x5400000d, 0xff00001f, condbranch
, 0, OP1 (ADDR_PCREL19
), QL_PCREL_NIL
, F_ALIAS
| F_PSEUDO
),
3807 /* SVE instructions. */
3808 _SVE_INSN ("fmov", 0x2539c000, 0xff3fe000, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_FPIMM8
), OP_SVE_VU_HSD
, F_ALIAS
, 0),
3809 _SVE_INSN ("fmov", 0x0510c000, 0xff30e000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg4_16
, SVE_FPIMM8
), OP_SVE_VMU_HSD
, F_ALIAS
, 0),
3810 _SVE_INSN ("mov", 0x04603000, 0xffe0fc00, sve_misc
, OP_MOV_Z_Z
, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_DD
, F_ALIAS
| F_MISC
, 0),
3811 _SVE_INSN ("mov", 0x05202000, 0xff20fc00, sve_index
, OP_MOV_Z_V
, OP2 (SVE_Zd
, SVE_VZn
), OP_SVE_VV_BHSDQ
, F_ALIAS
| F_MISC
, 0),
3812 _SVE_INSN ("mov", 0x05203800, 0xff3ffc00, sve_size_bhsd
, 0, OP2 (SVE_Zd
, Rn_SP
), OP_SVE_VR_BHSD
, F_ALIAS
, 0),
3813 _SVE_INSN ("mov", 0x25804000, 0xfff0c210, sve_misc
, OP_MOV_P_P
, OP2 (SVE_Pd
, SVE_Pn
), OP_SVE_BB
, F_ALIAS
| F_MISC
, 0),
3814 _SVE_INSN ("mov", 0x05202000, 0xff20fc00, sve_index
, OP_MOV_Z_Zi
, OP2 (SVE_Zd
, SVE_Zn_INDEX
), OP_SVE_VV_BHSDQ
, F_ALIAS
| F_MISC
, 0),
3815 _SVE_INSN ("mov", 0x05c00000, 0xfffc0000, sve_limm
, 0, OP2 (SVE_Zd
, SVE_LIMM_MOV
), OP_SVE_VU_BHSD
, F_ALIAS
, 0),
3816 _SVE_INSN ("mov", 0x2538c000, 0xff3fc000, sve_size_bhsd
, 0, OP2 (SVE_Zd
, SVE_ASIMM
), OP_SVE_VU_BHSD
, F_ALIAS
, 0),
3817 _SVE_INSNC ("mov", 0x05208000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Vn
), OP_SVE_VMV_BHSD
, F_ALIAS
, C_SCAN_MOVPRFX
, 0),
3818 _SVE_INSN ("mov", 0x0520c000, 0xff20c000, sve_size_bhsd
, OP_MOV_Z_P_Z
, OP3 (SVE_Zd
, SVE_Pg4_10
, SVE_Zn
), OP_SVE_VMV_BHSD
, F_ALIAS
| F_MISC
, 0),
3819 _SVE_INSNC ("mov", 0x0528a000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, Rn_SP
), OP_SVE_VMR_BHSD
, F_ALIAS
, C_SCAN_MOVPRFX
, 0),
3820 _SVE_INSN ("mov", 0x25004000, 0xfff0c210, sve_misc
, OP_MOVZ_P_P_P
, OP3 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
), OP_SVE_BZB
, F_ALIAS
| F_MISC
, 0),
3821 _SVE_INSN ("mov", 0x25004210, 0xfff0c210, sve_misc
, OP_MOVM_P_P_P
, OP3 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
), OP_SVE_BMB
, F_ALIAS
| F_MISC
, 0),
3822 _SVE_INSNC ("mov", 0x05100000, 0xff308000, sve_cpy
, 0, OP3 (SVE_Zd
, SVE_Pg4_16
, SVE_ASIMM
), OP_SVE_VPU_BHSD
, F_ALIAS
, C_SCAN_MOVPRFX
, 0),
3823 _SVE_INSN ("movs", 0x25c04000, 0xfff0c210, sve_misc
, OP_MOVS_P_P
, OP2 (SVE_Pd
, SVE_Pn
), OP_SVE_BB
, F_ALIAS
| F_MISC
, 0),
3824 _SVE_INSN ("movs", 0x25404000, 0xfff0c210, sve_misc
, OP_MOVZS_P_P_P
, OP3 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
), OP_SVE_BZB
, F_ALIAS
| F_MISC
, 0),
3825 _SVE_INSN ("not", 0x25004200, 0xfff0c210, sve_misc
, OP_NOT_P_P_P_Z
, OP3 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
), OP_SVE_BZB
, F_ALIAS
| F_MISC
, 0),
3826 _SVE_INSN ("nots", 0x25404200, 0xfff0c210, sve_misc
, OP_NOTS_P_P_P_Z
, OP3 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
), OP_SVE_BZB
, F_ALIAS
| F_MISC
, 0),
3827 _SVE_INSNC ("abs", 0x0416a000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
3828 _SVE_INSN ("add", 0x04200000, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
3829 _SVE_INSNC ("add", 0x2520c000, 0xff3fc000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_AIMM
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
3830 _SVE_INSNC ("add", 0x04000000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
3831 _SVE_INSN ("addpl", 0x04605000, 0xffe0f800, sve_misc
, 0, OP3 (Rd_SP
, SVE_Rn_SP
, SVE_SIMM6
), OP_SVE_XXU
, 0, 0),
3832 _SVE_INSN ("addvl", 0x04205000, 0xffe0f800, sve_misc
, 0, OP3 (Rd_SP
, SVE_Rn_SP
, SVE_SIMM6
), OP_SVE_XXU
, 0, 0),
3833 _SVE_INSN ("adr", 0x0420a000, 0xffe0f000, sve_misc
, 0, OP2 (SVE_Zd
, SVE_ADDR_ZZ_SXTW
), OP_SVE_DD
, 0, 0),
3834 _SVE_INSN ("adr", 0x0460a000, 0xffe0f000, sve_misc
, 0, OP2 (SVE_Zd
, SVE_ADDR_ZZ_UXTW
), OP_SVE_DD
, 0, 0),
3835 _SVE_INSN ("adr", 0x04a0a000, 0xffa0f000, sve_size_sd
, 0, OP2 (SVE_Zd
, SVE_ADDR_ZZ_LSL
), OP_SVE_VV_SD
, 0, 0),
3836 _SVE_INSN ("and", 0x04203000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_DDD
, 0, 0),
3837 _SVE_INSNC ("and", 0x05800000, 0xfffc0000, sve_limm
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_LIMM
), OP_SVE_VVU_BHSD
, F_HAS_ALIAS
, C_SCAN_MOVPRFX
, 1),
3838 _SVE_INSNC ("and", 0x041a0000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
3839 _SVE_INSN ("and", 0x25004000, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, F_HAS_ALIAS
, 0),
3840 _SVE_INSN ("ands", 0x25404000, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, F_HAS_ALIAS
, 0),
3841 _SVE_INSN ("andv", 0x041a2000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_BHSD
, 0, 0),
3842 _SVE_INSN ("asr", 0x04208000, 0xff20fc00, sve_size_bhs
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVD_BHS
, 0, 0),
3843 _SVE_INSN ("asr", 0x04209000, 0xff20fc00, sve_shift_unpred
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED
), OP_SVE_VVU_BHSD
, 0, 0),
3844 _SVE_INSNC ("asr", 0x04108000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
3845 _SVE_INSNC ("asr", 0x04188000, 0xff3fe000, sve_size_bhs
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVD_BHS
, 0, C_SCAN_MOVPRFX
, 2),
3846 _SVE_INSNC ("asr", 0x04008000, 0xff3fe000, sve_shift_pred
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_SHRIMM_PRED
), OP_SVE_VMVU_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
3847 _SVE_INSNC ("asrd", 0x04048000, 0xff3fe000, sve_shift_pred
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_SHRIMM_PRED
), OP_SVE_VMVU_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
3848 _SVE_INSNC ("asrr", 0x04148000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
3849 _SVE_INSN ("bic", 0x04e03000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_DDD
, 0, 0),
3850 _SVE_INSNC ("bic", 0x041b0000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
3851 _SVE_INSN ("bic", 0x25004010, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, 0, 0),
3852 _SVE_INSN ("bics", 0x25404010, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, 0, 0),
3853 _SVE_INSN ("brka", 0x25104000, 0xffffc200, sve_pred_zm
, 0, OP3 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
), OP_SVE_BPB
, 0, 0),
3854 _SVE_INSN ("brkas", 0x25504000, 0xffffc210, sve_misc
, 0, OP3 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
), OP_SVE_BZB
, 0, 0),
3855 _SVE_INSN ("brkb", 0x25904000, 0xffffc200, sve_pred_zm
, 0, OP3 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
), OP_SVE_BPB
, 0, 0),
3856 _SVE_INSN ("brkbs", 0x25d04000, 0xffffc210, sve_misc
, 0, OP3 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
), OP_SVE_BZB
, 0, 0),
3857 _SVE_INSN ("brkn", 0x25184000, 0xffffc210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pd
), OP_SVE_BZBB
, 0, 3),
3858 _SVE_INSN ("brkns", 0x25584000, 0xffffc210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pd
), OP_SVE_BZBB
, 0, 3),
3859 _SVE_INSN ("brkpa", 0x2500c000, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, 0, 0),
3860 _SVE_INSN ("brkpas", 0x2540c000, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, 0, 0),
3861 _SVE_INSN ("brkpb", 0x2500c010, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, 0, 0),
3862 _SVE_INSN ("brkpbs", 0x2540c010, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, 0, 0),
3863 _SVE_INSNC ("clasta", 0x05288000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VUVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
3864 _SVE_INSN ("clasta", 0x052a8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Vd
, SVE_Pg3
, SVE_Vd
, SVE_Zm_5
), OP_SVE_VUVV_BHSD
, 0, 2),
3865 _SVE_INSN ("clasta", 0x0530a000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (Rd
, SVE_Pg3
, Rd
, SVE_Zm_5
), OP_SVE_RURV_BHSD
, 0, 2),
3866 _SVE_INSNC ("clastb", 0x05298000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VUVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
3867 _SVE_INSN ("clastb", 0x052b8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Vd
, SVE_Pg3
, SVE_Vd
, SVE_Zm_5
), OP_SVE_VUVV_BHSD
, 0, 2),
3868 _SVE_INSN ("clastb", 0x0531a000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (Rd
, SVE_Pg3
, Rd
, SVE_Zm_5
), OP_SVE_RURV_BHSD
, 0, 2),
3869 _SVE_INSNC ("cls", 0x0418a000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
3870 _SVE_INSNC ("clz", 0x0419a000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
3871 _SVE_INSN ("cmpeq", 0x24002000, 0xff20e010, sve_size_bhs
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVD_BHS
, 0, 0),
3872 _SVE_INSN ("cmpeq", 0x2400a000, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_BHSD
, 0, 0),
3873 _SVE_INSN ("cmpeq", 0x25008000, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SIMM5
), OP_SVE_VZVU_BHSD
, 0, 0),
3874 _SVE_INSN ("cmpge", 0x24004000, 0xff20e010, sve_size_bhs
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVD_BHS
, 0, 0),
3875 _SVE_INSN ("cmpge", 0x24008000, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_BHSD
, F_HAS_ALIAS
, 0),
3876 _SVE_INSN ("cmpge", 0x25000000, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SIMM5
), OP_SVE_VZVU_BHSD
, 0, 0),
3877 _SVE_INSN ("cmpgt", 0x24004010, 0xff20e010, sve_size_bhs
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVD_BHS
, 0, 0),
3878 _SVE_INSN ("cmpgt", 0x24008010, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_BHSD
, F_HAS_ALIAS
, 0),
3879 _SVE_INSN ("cmpgt", 0x25000010, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SIMM5
), OP_SVE_VZVU_BHSD
, 0, 0),
3880 _SVE_INSN ("cmphi", 0x24000010, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_BHSD
, F_HAS_ALIAS
, 0),
3881 _SVE_INSN ("cmphi", 0x2400c010, 0xff20e010, sve_size_bhs
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVD_BHS
, 0, 0),
3882 _SVE_INSN ("cmphi", 0x24200010, 0xff202010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_UIMM7
), OP_SVE_VZVU_BHSD
, 0, 0),
3883 _SVE_INSN ("cmphs", 0x24000000, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_BHSD
, F_HAS_ALIAS
, 0),
3884 _SVE_INSN ("cmphs", 0x2400c000, 0xff20e010, sve_size_bhs
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVD_BHS
, 0, 0),
3885 _SVE_INSN ("cmphs", 0x24200000, 0xff202010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_UIMM7
), OP_SVE_VZVU_BHSD
, 0, 0),
3886 _SVE_INSN ("cmple", 0x24006010, 0xff20e010, sve_size_bhs
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVD_BHS
, 0, 0),
3887 _SVE_INSN ("cmple", 0x25002010, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SIMM5
), OP_SVE_VZVU_BHSD
, 0, 0),
3888 _SVE_INSN ("cmplo", 0x2400e000, 0xff20e010, sve_size_bhs
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVD_BHS
, 0, 0),
3889 _SVE_INSN ("cmplo", 0x24202000, 0xff202010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_UIMM7
), OP_SVE_VZVU_BHSD
, 0, 0),
3890 _SVE_INSN ("cmpls", 0x2400e010, 0xff20e010, sve_size_bhs
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVD_BHS
, 0, 0),
3891 _SVE_INSN ("cmpls", 0x24202010, 0xff202010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_UIMM7
), OP_SVE_VZVU_BHSD
, 0, 0),
3892 _SVE_INSN ("cmplt", 0x24006000, 0xff20e010, sve_size_bhs
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVD_BHS
, 0, 0),
3893 _SVE_INSN ("cmplt", 0x25002000, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SIMM5
), OP_SVE_VZVU_BHSD
, 0, 0),
3894 _SVE_INSN ("cmpne", 0x24002010, 0xff20e010, sve_size_bhs
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVD_BHS
, 0, 0),
3895 _SVE_INSN ("cmpne", 0x2400a010, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_BHSD
, 0, 0),
3896 _SVE_INSN ("cmpne", 0x25008010, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SIMM5
), OP_SVE_VZVU_BHSD
, 0, 0),
3897 _SVE_INSNC ("cnot", 0x041ba000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
3898 _SVE_INSNC ("cnt", 0x041aa000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
3899 _SVE_INSN ("cntb", 0x0420e000, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
3900 _SVE_INSN ("cntd", 0x04e0e000, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
3901 _SVE_INSN ("cnth", 0x0460e000, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
3902 _SVE_INSN ("cntp", 0x25208000, 0xff3fc200, sve_size_bhsd
, 0, OP3 (Rd
, SVE_Pg4_10
, SVE_Pn
), OP_SVE_XUV_BHSD
, 0, 0),
3903 _SVE_INSN ("cntw", 0x04a0e000, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
3904 _SVE_INSN ("compact", 0x05a18000, 0xffbfe000, sve_size_sd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_SD
, 0, 0),
3905 _SVE_INSNC ("cpy", 0x05208000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Vn
), OP_SVE_VMV_BHSD
, F_HAS_ALIAS
, C_SCAN_MOVPRFX
, 0),
3906 _SVE_INSNC ("cpy", 0x0528a000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, Rn_SP
), OP_SVE_VMR_BHSD
, F_HAS_ALIAS
, C_SCAN_MOVPRFX
, 0),
3907 _SVE_INSNC ("cpy", 0x05100000, 0xff308000, sve_cpy
, 0, OP3 (SVE_Zd
, SVE_Pg4_16
, SVE_ASIMM
), OP_SVE_VPU_BHSD
, F_HAS_ALIAS
, C_SCAN_MOVPRFX
, 0),
3908 _SVE_INSN ("ctermeq", 0x25a02000, 0xffa0fc1f, sve_size_sd
, 0, OP2 (Rn
, Rm
), OP_SVE_RR
, 0, 0),
3909 _SVE_INSN ("ctermne", 0x25a02010, 0xffa0fc1f, sve_size_sd
, 0, OP2 (Rn
, Rm
), OP_SVE_RR
, 0, 0),
3910 _SVE_INSN ("decb", 0x0430e400, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
3911 _SVE_INSNC ("decd", 0x04f0c400, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_DU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
3912 _SVE_INSN ("decd", 0x04f0e400, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
3913 _SVE_INSNC ("dech", 0x0470c400, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_HU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
3914 _SVE_INSN ("dech", 0x0470e400, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
3915 _SVE_INSNC ("decp", 0x252d8000, 0xff3ffe00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Pg4_5
), OP_SVE_VU_HSD
, 0, C_SCAN_MOVPRFX
, 0),
3916 _SVE_INSN ("decp", 0x252d8800, 0xff3ffe00, sve_size_bhsd
, 0, OP2 (Rd
, SVE_Pg4_5
), OP_SVE_XV_BHSD
, 0, 0),
3917 _SVE_INSNC ("decw", 0x04b0c400, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_SU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
3918 _SVE_INSN ("decw", 0x04b0e400, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
3919 _SVE_INSN ("dup", 0x05203800, 0xff3ffc00, sve_size_bhsd
, 0, OP2 (SVE_Zd
, Rn_SP
), OP_SVE_VR_BHSD
, F_HAS_ALIAS
, 0),
3920 _SVE_INSN ("dup", 0x05202000, 0xff20fc00, sve_index
, 0, OP2 (SVE_Zd
, SVE_Zn_INDEX
), OP_SVE_VV_BHSDQ
, F_HAS_ALIAS
, 0),
3921 _SVE_INSN ("dup", 0x2538c000, 0xff3fc000, sve_size_bhsd
, 0, OP2 (SVE_Zd
, SVE_ASIMM
), OP_SVE_VU_BHSD
, F_HAS_ALIAS
, 0),
3922 _SVE_INSN ("dupm", 0x05c00000, 0xfffc0000, sve_limm
, 0, OP2 (SVE_Zd
, SVE_LIMM
), OP_SVE_VU_BHSD
, F_HAS_ALIAS
, 0),
3923 _SVE_INSN ("eor", 0x04a03000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_DDD
, 0, 0),
3924 _SVE_INSNC ("eor", 0x05400000, 0xfffc0000, sve_limm
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_LIMM
), OP_SVE_VVU_BHSD
, F_HAS_ALIAS
, C_SCAN_MOVPRFX
, 1),
3925 _SVE_INSNC ("eor", 0x04190000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
3926 _SVE_INSN ("eor", 0x25004200, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, F_HAS_ALIAS
, 0),
3927 _SVE_INSN ("eors", 0x25404200, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, F_HAS_ALIAS
, 0),
3928 _SVE_INSN ("eorv", 0x04192000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_BHSD
, 0, 0),
3929 _SVE_INSNC ("ext", 0x05200000, 0xffe0e000, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zd
, SVE_Zm_5
, SVE_UIMM8_53
), OP_SVE_BBBU
, 0, C_SCAN_MOVPRFX
, 1),
3930 _SVE_INSNC ("fabd", 0x65088000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3931 _SVE_INSNC ("fabs", 0x041ca000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
3932 _SVE_INSN ("facge", 0x6500c010, 0xff20e010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_HSD
, F_HAS_ALIAS
, 0),
3933 _SVE_INSN ("facgt", 0x6500e010, 0xff20e010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_HSD
, F_HAS_ALIAS
, 0),
3934 _SVE_INSN ("fadd", 0x65000000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD
, 0, 0),
3935 _SVE_INSNC ("fadd", 0x65008000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3936 _SVE_INSNC ("fadd", 0x65188000, 0xff3fe3c0, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_I1_HALF_ONE
), OP_SVE_VMVU_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3937 _SVE_INSN ("fadda", 0x65182000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Vd
, SVE_Pg3
, SVE_Vd
, SVE_Zm_5
), OP_SVE_VUVV_HSD
, 0, 2),
3938 _SVE_INSN ("faddv", 0x65002000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_HSD
, 0, 0),
3939 _SVE_INSNC ("fcadd", 0x64008000, 0xff3ee000, sve_size_hsd
, 0, OP5 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
, SVE_IMM_ROT1
), OP_SVE_VMVVU_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3940 _SVE_INSNC ("fcmla", 0x64000000, 0xff208000, sve_size_hsd
, 0, OP5 (SVE_Zd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
, IMM_ROT2
), OP_SVE_VMVVU_HSD
, 0, C_SCAN_MOVPRFX
, 0),
3941 _SVE_INSNC ("fcmla", 0x64a01000, 0xffe0f000, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
, SVE_IMM_ROT2
), OP_SVE_VVVU_H
, 0, C_SCAN_MOVPRFX
, 0),
3942 _SVE_INSNC ("fcmla", 0x64e01000, 0xffe0f000, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
, SVE_IMM_ROT2
), OP_SVE_VVVU_S
, 0, C_SCAN_MOVPRFX
, 0),
3943 _SVE_INSN ("fcmeq", 0x65122000, 0xff3fe010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, FPIMM0
), OP_SVE_VZV_HSD
, 0, 0),
3944 _SVE_INSN ("fcmeq", 0x65006000, 0xff20e010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_HSD
, 0, 0),
3945 _SVE_INSN ("fcmge", 0x65102000, 0xff3fe010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, FPIMM0
), OP_SVE_VZV_HSD
, 0, 0),
3946 _SVE_INSN ("fcmge", 0x65004000, 0xff20e010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_HSD
, F_HAS_ALIAS
, 0),
3947 _SVE_INSN ("fcmgt", 0x65102010, 0xff3fe010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, FPIMM0
), OP_SVE_VZV_HSD
, 0, 0),
3948 _SVE_INSN ("fcmgt", 0x65004010, 0xff20e010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_HSD
, F_HAS_ALIAS
, 0),
3949 _SVE_INSN ("fcmle", 0x65112010, 0xff3fe010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, FPIMM0
), OP_SVE_VZV_HSD
, 0, 0),
3950 _SVE_INSN ("fcmlt", 0x65112000, 0xff3fe010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, FPIMM0
), OP_SVE_VZV_HSD
, 0, 0),
3951 _SVE_INSN ("fcmne", 0x65132000, 0xff3fe010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, FPIMM0
), OP_SVE_VZV_HSD
, 0, 0),
3952 _SVE_INSN ("fcmne", 0x65006010, 0xff20e010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_HSD
, 0, 0),
3953 _SVE_INSN ("fcmuo", 0x6500c000, 0xff20e010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_HSD
, 0, 0),
3954 _SVE_INSNC ("fcpy", 0x0510c000, 0xff30e000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg4_16
, SVE_FPIMM8
), OP_SVE_VMU_HSD
, F_HAS_ALIAS
, C_SCAN_MOVPRFX
, 0),
3955 _SVE_INSNC ("fcvt", 0x6588a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_HMS
, 0, C_SCAN_MOVPRFX
| C_MAX_ELEM
, 0),
3956 _SVE_INSNC ("fcvt", 0x6589a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMH
, 0, C_SCAN_MOVPRFX
| C_MAX_ELEM
, 0),
3957 _SVE_INSNC ("fcvt", 0x65c8a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_HMD
, 0, C_SCAN_MOVPRFX
| C_MAX_ELEM
, 0),
3958 _SVE_INSNC ("fcvt", 0x65c9a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMH
, 0, C_SCAN_MOVPRFX
| C_MAX_ELEM
, 0),
3959 _SVE_INSNC ("fcvt", 0x65caa000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMD
, 0, C_SCAN_MOVPRFX
| C_MAX_ELEM
, 0),
3960 _SVE_INSNC ("fcvt", 0x65cba000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMS
, 0, C_SCAN_MOVPRFX
| C_MAX_ELEM
, 0),
3961 _SVE_INSNC ("fcvtzs", 0x655aa000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_HMH
, 0, C_SCAN_MOVPRFX
, 0),
3962 _SVE_INSNC ("fcvtzs", 0x655ca000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMH
, 0, C_SCAN_MOVPRFX
, 0),
3963 _SVE_INSNC ("fcvtzs", 0x655ea000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMH
, 0, C_SCAN_MOVPRFX
, 0),
3964 _SVE_INSNC ("fcvtzs", 0x659ca000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMS
, 0, C_SCAN_MOVPRFX
, 0),
3965 _SVE_INSNC ("fcvtzs", 0x65d8a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMD
, 0, C_SCAN_MOVPRFX
, 0),
3966 _SVE_INSNC ("fcvtzs", 0x65dca000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMS
, 0, C_SCAN_MOVPRFX
, 0),
3967 _SVE_INSNC ("fcvtzs", 0x65dea000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMD
, 0, C_SCAN_MOVPRFX
, 0),
3968 _SVE_INSNC ("fcvtzu", 0x655ba000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_HMH
, 0, C_SCAN_MOVPRFX
, 0),
3969 _SVE_INSNC ("fcvtzu", 0x655da000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMH
, 0, C_SCAN_MOVPRFX
, 0),
3970 _SVE_INSNC ("fcvtzu", 0x655fa000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMH
, 0, C_SCAN_MOVPRFX
, 0),
3971 _SVE_INSNC ("fcvtzu", 0x659da000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMS
, 0, C_SCAN_MOVPRFX
, 0),
3972 _SVE_INSNC ("fcvtzu", 0x65d9a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMD
, 0, C_SCAN_MOVPRFX
, 0),
3973 _SVE_INSNC ("fcvtzu", 0x65dda000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMS
, 0, C_SCAN_MOVPRFX
, 0),
3974 _SVE_INSNC ("fcvtzu", 0x65dfa000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMD
, 0, C_SCAN_MOVPRFX
, 0),
3975 _SVE_INSNC ("fdiv", 0x650d8000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3976 _SVE_INSNC ("fdivr", 0x650c8000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3977 _SVE_INSN ("fdup", 0x2539c000, 0xff3fe000, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_FPIMM8
), OP_SVE_VU_HSD
, F_HAS_ALIAS
, 0),
3978 _SVE_INSN ("fexpa", 0x0420b800, 0xff3ffc00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_HSD
, 0, 0),
3979 _SVE_INSNC ("fmad", 0x65208000, 0xff20e000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zm_5
, SVE_Za_16
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
3980 _SVE_INSNC ("fmax", 0x65068000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3981 _SVE_INSNC ("fmax", 0x651e8000, 0xff3fe3c0, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_I1_ZERO_ONE
), OP_SVE_VMVU_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3982 _SVE_INSNC ("fmaxnm", 0x65048000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3983 _SVE_INSNC ("fmaxnm", 0x651c8000, 0xff3fe3c0, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_I1_ZERO_ONE
), OP_SVE_VMVU_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3984 _SVE_INSN ("fmaxnmv", 0x65042000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_HSD
, 0, 0),
3985 _SVE_INSN ("fmaxv", 0x65062000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_HSD
, 0, 0),
3986 _SVE_INSNC ("fmin", 0x65078000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3987 _SVE_INSNC ("fmin", 0x651f8000, 0xff3fe3c0, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_I1_ZERO_ONE
), OP_SVE_VMVU_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3988 _SVE_INSNC ("fminnm", 0x65058000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3989 _SVE_INSNC ("fminnm", 0x651d8000, 0xff3fe3c0, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_I1_ZERO_ONE
), OP_SVE_VMVU_HSD
, 0, C_SCAN_MOVPRFX
, 2),
3990 _SVE_INSN ("fminnmv", 0x65052000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_HSD
, 0, 0),
3991 _SVE_INSN ("fminv", 0x65072000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_HSD
, 0, 0),
3992 _SVE_INSNC ("fmla", 0x65200000, 0xff20e000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
3993 _SVE_INSNC ("fmla", 0x64200000, 0xffa0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_22_INDEX
), OP_SVE_VVV_H
, 0, C_SCAN_MOVPRFX
, 0),
3994 _SVE_INSNC ("fmla", 0x64a00000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
), OP_SVE_VVV_S
, 0, C_SCAN_MOVPRFX
, 0),
3995 _SVE_INSNC ("fmla", 0x64e00000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
), OP_SVE_VVV_D
, 0, C_SCAN_MOVPRFX
, 0),
3996 _SVE_INSNC ("fmls", 0x65202000, 0xff20e000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
3997 _SVE_INSNC ("fmls", 0x64200400, 0xffa0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_22_INDEX
), OP_SVE_VVV_H
, 0, C_SCAN_MOVPRFX
, 0),
3998 _SVE_INSNC ("fmls", 0x64a00400, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
), OP_SVE_VVV_S
, 0, C_SCAN_MOVPRFX
, 0),
3999 _SVE_INSNC ("fmls", 0x64e00400, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
), OP_SVE_VVV_D
, 0, C_SCAN_MOVPRFX
, 0),
4000 _SVE_INSNC ("fmsb", 0x6520a000, 0xff20e000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zm_5
, SVE_Za_16
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4001 _SVE_INSN ("fmul", 0x65000800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD
, 0, 0),
4002 _SVE_INSNC ("fmul", 0x65028000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4003 _SVE_INSNC ("fmul", 0x651a8000, 0xff3fe3c0, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_I1_HALF_TWO
), OP_SVE_VMVU_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4004 _SVE_INSN ("fmul", 0x64202000, 0xffa0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_22_INDEX
), OP_SVE_VVV_H
, 0, 0),
4005 _SVE_INSN ("fmul", 0x64a02000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
), OP_SVE_VVV_S
, 0, 0),
4006 _SVE_INSN ("fmul", 0x64e02000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
), OP_SVE_VVV_D
, 0, 0),
4007 _SVE_INSNC ("fmulx", 0x650a8000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4008 _SVE_INSNC ("fneg", 0x041da000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4009 _SVE_INSNC ("fnmad", 0x6520c000, 0xff20e000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zm_5
, SVE_Za_16
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4010 _SVE_INSNC ("fnmla", 0x65204000, 0xff20e000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4011 _SVE_INSNC ("fnmls", 0x65206000, 0xff20e000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4012 _SVE_INSNC ("fnmsb", 0x6520e000, 0xff20e000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zm_5
, SVE_Za_16
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4013 _SVE_INSN ("frecpe", 0x650e3000, 0xff3ffc00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_HSD
, 0, 0),
4014 _SVE_INSN ("frecps", 0x65001800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD
, 0, 0),
4015 _SVE_INSNC ("frecpx", 0x650ca000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4016 _SVE_INSNC ("frinta", 0x6504a000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4017 _SVE_INSNC ("frinti", 0x6507a000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4018 _SVE_INSNC ("frintm", 0x6502a000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4019 _SVE_INSNC ("frintn", 0x6500a000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4020 _SVE_INSNC ("frintp", 0x6501a000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4021 _SVE_INSNC ("frintx", 0x6506a000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4022 _SVE_INSNC ("frintz", 0x6503a000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4023 _SVE_INSN ("frsqrte", 0x650f3000, 0xff3ffc00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_HSD
, 0, 0),
4024 _SVE_INSN ("frsqrts", 0x65001c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD
, 0, 0),
4025 _SVE_INSNC ("fscale", 0x65098000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4026 _SVE_INSNC ("fsqrt", 0x650da000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4027 _SVE_INSN ("fsub", 0x65000400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD
, 0, 0),
4028 _SVE_INSNC ("fsub", 0x65018000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4029 _SVE_INSNC ("fsub", 0x65198000, 0xff3fe3c0, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_I1_HALF_ONE
), OP_SVE_VMVU_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4030 _SVE_INSNC ("fsubr", 0x65038000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4031 _SVE_INSNC ("fsubr", 0x651b8000, 0xff3fe3c0, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_I1_HALF_ONE
), OP_SVE_VMVU_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4032 _SVE_INSNC ("ftmad", 0x65108000, 0xff38fc00, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Zd
, SVE_Zm_5
, SVE_UIMM3
), OP_SVE_VVVU_HSD
, 0, C_SCAN_MOVPRFX
, 1),
4033 _SVE_INSN ("ftsmul", 0x65000c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD
, 0, 0),
4034 _SVE_INSN ("ftssel", 0x0420b000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD
, 0, 0),
4035 _SVE_INSN ("incb", 0x0430e000, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4036 _SVE_INSNC ("incd", 0x04f0c000, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_DU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4037 _SVE_INSN ("incd", 0x04f0e000, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4038 _SVE_INSNC ("inch", 0x0470c000, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_HU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4039 _SVE_INSN ("inch", 0x0470e000, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4040 _SVE_INSNC ("incp", 0x252c8000, 0xff3ffe00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Pg4_5
), OP_SVE_VU_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4041 _SVE_INSN ("incp", 0x252c8800, 0xff3ffe00, sve_size_bhsd
, 0, OP2 (Rd
, SVE_Pg4_5
), OP_SVE_XV_BHSD
, 0, 0),
4042 _SVE_INSNC ("incw", 0x04b0c000, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_SU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4043 _SVE_INSN ("incw", 0x04b0e000, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4044 _SVE_INSN ("index", 0x04204c00, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, Rn
, Rm
), OP_SVE_VRR_BHSD
, 0, 0),
4045 _SVE_INSN ("index", 0x04204000, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_SIMM5
, SVE_SIMM5B
), OP_SVE_VUU_BHSD
, 0, 0),
4046 _SVE_INSN ("index", 0x04204400, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, Rn
, SIMM5
), OP_SVE_VRU_BHSD
, 0, 0),
4047 _SVE_INSN ("index", 0x04204800, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_SIMM5
, Rm
), OP_SVE_VUR_BHSD
, 0, 0),
4048 _SVE_INSNC ("insr", 0x05243800, 0xff3ffc00, sve_size_bhsd
, 0, OP2 (SVE_Zd
, SVE_Rm
), OP_SVE_VR_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4049 _SVE_INSNC ("insr", 0x05343800, 0xff3ffc00, sve_size_bhsd
, 0, OP2 (SVE_Zd
, SVE_Vm
), OP_SVE_VV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4050 _SVE_INSN ("lasta", 0x0520a000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (Rd
, SVE_Pg3
, SVE_Zn
), OP_SVE_RUV_BHSD
, 0, 0),
4051 _SVE_INSN ("lasta", 0x05228000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_BHSD
, 0, 0),
4052 _SVE_INSN ("lastb", 0x0521a000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (Rd
, SVE_Pg3
, SVE_Zn
), OP_SVE_RUV_BHSD
, 0, 0),
4053 _SVE_INSN ("lastb", 0x05238000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_BHSD
, 0, 0),
4054 _SVE_INSN ("ld1b", 0x84004000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_SZS
, F_OD(1), 0),
4055 _SVE_INSN ("ld1b", 0xa4004000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_BZU
, F_OD(1), 0),
4056 _SVE_INSN ("ld1b", 0xa4204000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_HZU
, F_OD(1), 0),
4057 _SVE_INSN ("ld1b", 0xa4404000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_SZU
, F_OD(1), 0),
4058 _SVE_INSN ("ld1b", 0xa4604000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_DZU
, F_OD(1), 0),
4059 _SVE_INSN ("ld1b", 0xc4004000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4060 _SVE_INSN ("ld1b", 0xc440c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4061 _SVE_INSN ("ld1b", 0x8420c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5
), OP_SVE_SZS
, F_OD(1), 0),
4062 _SVE_INSN ("ld1b", 0xa400a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_BZU
, F_OD(1), 0),
4063 _SVE_INSN ("ld1b", 0xa420a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_HZU
, F_OD(1), 0),
4064 _SVE_INSN ("ld1b", 0xa440a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SZU
, F_OD(1), 0),
4065 _SVE_INSN ("ld1b", 0xa460a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4066 _SVE_INSN ("ld1b", 0xc420c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5
), OP_SVE_DZD
, F_OD(1), 0),
4067 _SVE_INSN ("ld1d", 0xa5e04000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL3
), OP_SVE_DZU
, F_OD(1), 0),
4068 _SVE_INSN ("ld1d", 0xc5804000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4069 _SVE_INSN ("ld1d", 0xc5a04000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW3_22
), OP_SVE_DZD
, F_OD(1), 0),
4070 _SVE_INSN ("ld1d", 0xc5c0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4071 _SVE_INSN ("ld1d", 0xc5e0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL3
), OP_SVE_DZD
, F_OD(1), 0),
4072 _SVE_INSN ("ld1d", 0xa5e0a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4073 _SVE_INSN ("ld1d", 0xc5a0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x8
), OP_SVE_DZD
, F_OD(1), 0),
4074 _SVE_INSN ("ld1h", 0x84804000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_SZS
, F_OD(1), 0),
4075 _SVE_INSN ("ld1h", 0x84a04000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW1_22
), OP_SVE_SZS
, F_OD(1), 0),
4076 _SVE_INSN ("ld1h", 0xa4a04000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_HZU
, F_OD(1), 0),
4077 _SVE_INSN ("ld1h", 0xa4c04000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_SZU
, F_OD(1), 0),
4078 _SVE_INSN ("ld1h", 0xa4e04000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_DZU
, F_OD(1), 0),
4079 _SVE_INSN ("ld1h", 0xc4804000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4080 _SVE_INSN ("ld1h", 0xc4a04000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW1_22
), OP_SVE_DZD
, F_OD(1), 0),
4081 _SVE_INSN ("ld1h", 0xc4c0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4082 _SVE_INSN ("ld1h", 0xc4e0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL1
), OP_SVE_DZD
, F_OD(1), 0),
4083 _SVE_INSN ("ld1h", 0x84a0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x2
), OP_SVE_SZS
, F_OD(1), 0),
4084 _SVE_INSN ("ld1h", 0xa4a0a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_HZU
, F_OD(1), 0),
4085 _SVE_INSN ("ld1h", 0xa4c0a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SZU
, F_OD(1), 0),
4086 _SVE_INSN ("ld1h", 0xa4e0a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4087 _SVE_INSN ("ld1h", 0xc4a0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x2
), OP_SVE_DZD
, F_OD(1), 0),
4088 _SVE_INSN ("ld1rb", 0x84408000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6
), OP_SVE_BZU
, F_OD(1), 0),
4089 _SVE_INSN ("ld1rb", 0x8440a000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6
), OP_SVE_HZU
, F_OD(1), 0),
4090 _SVE_INSN ("ld1rb", 0x8440c000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6
), OP_SVE_SZU
, F_OD(1), 0),
4091 _SVE_INSN ("ld1rb", 0x8440e000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6
), OP_SVE_DZU
, F_OD(1), 0),
4092 _SVE_INSN ("ld1rd", 0x85c0e000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6x8
), OP_SVE_DZU
, F_OD(1), 0),
4093 _SVE_INSN ("ld1rh", 0x84c0a000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6x2
), OP_SVE_HZU
, F_OD(1), 0),
4094 _SVE_INSN ("ld1rh", 0x84c0c000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6x2
), OP_SVE_SZU
, F_OD(1), 0),
4095 _SVE_INSN ("ld1rh", 0x84c0e000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6x2
), OP_SVE_DZU
, F_OD(1), 0),
4096 _SVE_INSN ("ld1rqb", 0xa4002000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x16
), OP_SVE_BZU
, F_OD(1), 0),
4097 _SVE_INSN ("ld1rqb", 0xa4000000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_BZU
, F_OD(1), 0),
4098 _SVE_INSN ("ld1rqd", 0xa5802000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x16
), OP_SVE_DZU
, F_OD(1), 0),
4099 _SVE_INSN ("ld1rqd", 0xa5800000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL3
), OP_SVE_DZU
, F_OD(1), 0),
4100 _SVE_INSN ("ld1rqh", 0xa4802000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x16
), OP_SVE_HZU
, F_OD(1), 0),
4101 _SVE_INSN ("ld1rqh", 0xa4800000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_HZU
, F_OD(1), 0),
4102 _SVE_INSN ("ld1rqw", 0xa5002000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x16
), OP_SVE_SZU
, F_OD(1), 0),
4103 _SVE_INSN ("ld1rqw", 0xa5000000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_SZU
, F_OD(1), 0),
4104 _SVE_INSN ("ld1rsb", 0x85c08000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6
), OP_SVE_DZU
, F_OD(1), 0),
4105 _SVE_INSN ("ld1rsb", 0x85c0a000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6
), OP_SVE_SZU
, F_OD(1), 0),
4106 _SVE_INSN ("ld1rsb", 0x85c0c000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6
), OP_SVE_HZU
, F_OD(1), 0),
4107 _SVE_INSN ("ld1rsh", 0x85408000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6x2
), OP_SVE_DZU
, F_OD(1), 0),
4108 _SVE_INSN ("ld1rsh", 0x8540a000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6x2
), OP_SVE_SZU
, F_OD(1), 0),
4109 _SVE_INSN ("ld1rsw", 0x84c08000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6x4
), OP_SVE_DZU
, F_OD(1), 0),
4110 _SVE_INSN ("ld1rw", 0x8540c000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6x4
), OP_SVE_SZU
, F_OD(1), 0),
4111 _SVE_INSN ("ld1rw", 0x8540e000, 0xffc0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_U6x4
), OP_SVE_DZU
, F_OD(1), 0),
4112 _SVE_INSN ("ld1sb", 0x84000000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_SZS
, F_OD(1), 0),
4113 _SVE_INSN ("ld1sb", 0xa5804000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_DZU
, F_OD(1), 0),
4114 _SVE_INSN ("ld1sb", 0xa5a04000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_SZU
, F_OD(1), 0),
4115 _SVE_INSN ("ld1sb", 0xa5c04000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_HZU
, F_OD(1), 0),
4116 _SVE_INSN ("ld1sb", 0xc4000000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4117 _SVE_INSN ("ld1sb", 0xc4408000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4118 _SVE_INSN ("ld1sb", 0x84208000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5
), OP_SVE_SZS
, F_OD(1), 0),
4119 _SVE_INSN ("ld1sb", 0xa580a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4120 _SVE_INSN ("ld1sb", 0xa5a0a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SZU
, F_OD(1), 0),
4121 _SVE_INSN ("ld1sb", 0xa5c0a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_HZU
, F_OD(1), 0),
4122 _SVE_INSN ("ld1sb", 0xc4208000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5
), OP_SVE_DZD
, F_OD(1), 0),
4123 _SVE_INSN ("ld1sh", 0x84800000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_SZS
, F_OD(1), 0),
4124 _SVE_INSN ("ld1sh", 0x84a00000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW1_22
), OP_SVE_SZS
, F_OD(1), 0),
4125 _SVE_INSN ("ld1sh", 0xa5004000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_DZU
, F_OD(1), 0),
4126 _SVE_INSN ("ld1sh", 0xa5204000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_SZU
, F_OD(1), 0),
4127 _SVE_INSN ("ld1sh", 0xc4800000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4128 _SVE_INSN ("ld1sh", 0xc4a00000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW1_22
), OP_SVE_DZD
, F_OD(1), 0),
4129 _SVE_INSN ("ld1sh", 0xc4c08000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4130 _SVE_INSN ("ld1sh", 0xc4e08000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL1
), OP_SVE_DZD
, F_OD(1), 0),
4131 _SVE_INSN ("ld1sh", 0x84a08000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x2
), OP_SVE_SZS
, F_OD(1), 0),
4132 _SVE_INSN ("ld1sh", 0xa500a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4133 _SVE_INSN ("ld1sh", 0xa520a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SZU
, F_OD(1), 0),
4134 _SVE_INSN ("ld1sh", 0xc4a08000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x2
), OP_SVE_DZD
, F_OD(1), 0),
4135 _SVE_INSN ("ld1sw", 0xa4804000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_DZU
, F_OD(1), 0),
4136 _SVE_INSN ("ld1sw", 0xc5000000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4137 _SVE_INSN ("ld1sw", 0xc5200000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW2_22
), OP_SVE_DZD
, F_OD(1), 0),
4138 _SVE_INSN ("ld1sw", 0xc5408000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4139 _SVE_INSN ("ld1sw", 0xc5608000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL2
), OP_SVE_DZD
, F_OD(1), 0),
4140 _SVE_INSN ("ld1sw", 0xa480a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4141 _SVE_INSN ("ld1sw", 0xc5208000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x4
), OP_SVE_DZD
, F_OD(1), 0),
4142 _SVE_INSN ("ld1w", 0x85004000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_SZS
, F_OD(1), 0),
4143 _SVE_INSN ("ld1w", 0x85204000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW2_22
), OP_SVE_SZS
, F_OD(1), 0),
4144 _SVE_INSN ("ld1w", 0xa5404000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_SZU
, F_OD(1), 0),
4145 _SVE_INSN ("ld1w", 0xa5604000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_DZU
, F_OD(1), 0),
4146 _SVE_INSN ("ld1w", 0xc5004000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4147 _SVE_INSN ("ld1w", 0xc5204000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW2_22
), OP_SVE_DZD
, F_OD(1), 0),
4148 _SVE_INSN ("ld1w", 0xc540c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4149 _SVE_INSN ("ld1w", 0xc560c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL2
), OP_SVE_DZD
, F_OD(1), 0),
4150 _SVE_INSN ("ld1w", 0x8520c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x4
), OP_SVE_SZS
, F_OD(1), 0),
4151 _SVE_INSN ("ld1w", 0xa540a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SZU
, F_OD(1), 0),
4152 _SVE_INSN ("ld1w", 0xa560a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4153 _SVE_INSN ("ld1w", 0xc520c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x4
), OP_SVE_DZD
, F_OD(1), 0),
4154 _SVE_INSN ("ld2b", 0xa420c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_BZU
, F_OD(2), 0),
4155 _SVE_INSN ("ld2b", 0xa420e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x2xVL
), OP_SVE_BZU
, F_OD(2), 0),
4156 _SVE_INSN ("ld2d", 0xa5a0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL3
), OP_SVE_DZU
, F_OD(2), 0),
4157 _SVE_INSN ("ld2d", 0xa5a0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x2xVL
), OP_SVE_DZU
, F_OD(2), 0),
4158 _SVE_INSN ("ld2h", 0xa4a0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_HZU
, F_OD(2), 0),
4159 _SVE_INSN ("ld2h", 0xa4a0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x2xVL
), OP_SVE_HZU
, F_OD(2), 0),
4160 _SVE_INSN ("ld2w", 0xa520c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_SZU
, F_OD(2), 0),
4161 _SVE_INSN ("ld2w", 0xa520e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x2xVL
), OP_SVE_SZU
, F_OD(2), 0),
4162 _SVE_INSN ("ld3b", 0xa440c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_BZU
, F_OD(3), 0),
4163 _SVE_INSN ("ld3b", 0xa440e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x3xVL
), OP_SVE_BZU
, F_OD(3), 0),
4164 _SVE_INSN ("ld3d", 0xa5c0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL3
), OP_SVE_DZU
, F_OD(3), 0),
4165 _SVE_INSN ("ld3d", 0xa5c0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x3xVL
), OP_SVE_DZU
, F_OD(3), 0),
4166 _SVE_INSN ("ld3h", 0xa4c0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_HZU
, F_OD(3), 0),
4167 _SVE_INSN ("ld3h", 0xa4c0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x3xVL
), OP_SVE_HZU
, F_OD(3), 0),
4168 _SVE_INSN ("ld3w", 0xa540c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_SZU
, F_OD(3), 0),
4169 _SVE_INSN ("ld3w", 0xa540e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x3xVL
), OP_SVE_SZU
, F_OD(3), 0),
4170 _SVE_INSN ("ld4b", 0xa460c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_BZU
, F_OD(4), 0),
4171 _SVE_INSN ("ld4b", 0xa460e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x4xVL
), OP_SVE_BZU
, F_OD(4), 0),
4172 _SVE_INSN ("ld4d", 0xa5e0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL3
), OP_SVE_DZU
, F_OD(4), 0),
4173 _SVE_INSN ("ld4d", 0xa5e0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x4xVL
), OP_SVE_DZU
, F_OD(4), 0),
4174 _SVE_INSN ("ld4h", 0xa4e0c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_HZU
, F_OD(4), 0),
4175 _SVE_INSN ("ld4h", 0xa4e0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x4xVL
), OP_SVE_HZU
, F_OD(4), 0),
4176 _SVE_INSN ("ld4w", 0xa560c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_SZU
, F_OD(4), 0),
4177 _SVE_INSN ("ld4w", 0xa560e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x4xVL
), OP_SVE_SZU
, F_OD(4), 0),
4179 _SVE_INSN ("ldff1b", 0x84006000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_SZS
, F_OD(1), 0),
4180 _SVE_INSN ("ldff1b", 0xa4006000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR
), OP_SVE_BZU
, F_OD(1), 0),
4181 _SVE_INSN ("ldff1b", 0xa4006000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_BZU
, F_OD(1), 0),
4182 _SVE_INSN ("ldff1b", 0xa4206000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR
), OP_SVE_HZU
, F_OD(1), 0),
4183 _SVE_INSN ("ldff1b", 0xa4206000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_HZU
, F_OD(1), 0),
4184 _SVE_INSN ("ldff1b", 0xa4406000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR
), OP_SVE_SZU
, F_OD(1), 0),
4185 _SVE_INSN ("ldff1b", 0xa4406000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_SZU
, F_OD(1), 0),
4186 _SVE_INSN ("ldff1b", 0xa4606000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR
), OP_SVE_DZU
, F_OD(1), 0),
4187 _SVE_INSN ("ldff1b", 0xa4606000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_DZU
, F_OD(1), 0),
4188 _SVE_INSN ("ldff1b", 0xc4006000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4189 _SVE_INSN ("ldff1b", 0xc440e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4190 _SVE_INSN ("ldff1b", 0x8420e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5
), OP_SVE_SZS
, F_OD(1), 0),
4191 _SVE_INSN ("ldff1b", 0xc420e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5
), OP_SVE_DZD
, F_OD(1), 0),
4193 _SVE_INSN ("ldff1d", 0xa5e06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR_LSL3
), OP_SVE_DZU
, F_OD(1), 0),
4194 _SVE_INSN ("ldff1d", 0xa5e06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_DZU
, F_OD(1), 0),
4195 _SVE_INSN ("ldff1d", 0xc5806000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4196 _SVE_INSN ("ldff1d", 0xc5a06000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW3_22
), OP_SVE_DZD
, F_OD(1), 0),
4197 _SVE_INSN ("ldff1d", 0xc5c0e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4198 _SVE_INSN ("ldff1d", 0xc5e0e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL3
), OP_SVE_DZD
, F_OD(1), 0),
4199 _SVE_INSN ("ldff1d", 0xc5a0e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x8
), OP_SVE_DZD
, F_OD(1), 0),
4201 _SVE_INSN ("ldff1h", 0x84806000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_SZS
, F_OD(1), 0),
4202 _SVE_INSN ("ldff1h", 0x84a06000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW1_22
), OP_SVE_SZS
, F_OD(1), 0),
4203 _SVE_INSN ("ldff1h", 0xa4a06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR_LSL1
), OP_SVE_HZU
, F_OD(1), 0),
4204 _SVE_INSN ("ldff1h", 0xa4a06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_HZU
, F_OD(1), 0),
4205 _SVE_INSN ("ldff1h", 0xa4c06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR_LSL1
), OP_SVE_SZU
, F_OD(1), 0),
4206 _SVE_INSN ("ldff1h", 0xa4c06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_SZU
, F_OD(1), 0),
4207 _SVE_INSN ("ldff1h", 0xa4e06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR_LSL1
), OP_SVE_DZU
, F_OD(1), 0),
4208 _SVE_INSN ("ldff1h", 0xa4e06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_DZU
, F_OD(1), 0),
4209 _SVE_INSN ("ldff1h", 0xc4806000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4210 _SVE_INSN ("ldff1h", 0xc4a06000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW1_22
), OP_SVE_DZD
, F_OD(1), 0),
4211 _SVE_INSN ("ldff1h", 0xc4c0e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4212 _SVE_INSN ("ldff1h", 0xc4e0e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL1
), OP_SVE_DZD
, F_OD(1), 0),
4213 _SVE_INSN ("ldff1h", 0x84a0e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x2
), OP_SVE_SZS
, F_OD(1), 0),
4214 _SVE_INSN ("ldff1h", 0xc4a0e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x2
), OP_SVE_DZD
, F_OD(1), 0),
4216 _SVE_INSN ("ldff1sb", 0x84002000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_SZS
, F_OD(1), 0),
4217 _SVE_INSN ("ldff1sb", 0xa5806000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR
), OP_SVE_DZU
, F_OD(1), 0),
4218 _SVE_INSN ("ldff1sb", 0xa5806000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_DZU
, F_OD(1), 0),
4219 _SVE_INSN ("ldff1sb", 0xa5a06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR
), OP_SVE_SZU
, F_OD(1), 0),
4220 _SVE_INSN ("ldff1sb", 0xa5a06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_SZU
, F_OD(1), 0),
4221 _SVE_INSN ("ldff1sb", 0xa5c06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR
), OP_SVE_HZU
, F_OD(1), 0),
4222 _SVE_INSN ("ldff1sb", 0xa5c06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_HZU
, F_OD(1), 0),
4223 _SVE_INSN ("ldff1sb", 0xc4002000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4224 _SVE_INSN ("ldff1sb", 0xc440a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4225 _SVE_INSN ("ldff1sb", 0x8420a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5
), OP_SVE_SZS
, F_OD(1), 0),
4226 _SVE_INSN ("ldff1sb", 0xc420a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5
), OP_SVE_DZD
, F_OD(1), 0),
4228 _SVE_INSN ("ldff1sh", 0x84802000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_SZS
, F_OD(1), 0),
4229 _SVE_INSN ("ldff1sh", 0x84a02000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW1_22
), OP_SVE_SZS
, F_OD(1), 0),
4230 _SVE_INSN ("ldff1sh", 0xa5006000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR_LSL1
), OP_SVE_DZU
, F_OD(1), 0),
4231 _SVE_INSN ("ldff1sh", 0xa5006000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_DZU
, F_OD(1), 0),
4232 _SVE_INSN ("ldff1sh", 0xa5206000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR_LSL1
), OP_SVE_SZU
, F_OD(1), 0),
4233 _SVE_INSN ("ldff1sh", 0xa5206000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_SZU
, F_OD(1), 0),
4234 _SVE_INSN ("ldff1sh", 0xc4802000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4235 _SVE_INSN ("ldff1sh", 0xc4a02000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW1_22
), OP_SVE_DZD
, F_OD(1), 0),
4236 _SVE_INSN ("ldff1sh", 0xc4c0a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4237 _SVE_INSN ("ldff1sh", 0xc4e0a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL1
), OP_SVE_DZD
, F_OD(1), 0),
4238 _SVE_INSN ("ldff1sh", 0x84a0a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x2
), OP_SVE_SZS
, F_OD(1), 0),
4239 _SVE_INSN ("ldff1sh", 0xc4a0a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x2
), OP_SVE_DZD
, F_OD(1), 0),
4241 _SVE_INSN ("ldff1sw", 0xa4806000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR_LSL2
), OP_SVE_DZU
, F_OD(1), 0),
4242 _SVE_INSN ("ldff1sw", 0xa4806000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_DZU
, F_OD(1), 0),
4243 _SVE_INSN ("ldff1sw", 0xc5002000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4244 _SVE_INSN ("ldff1sw", 0xc5202000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW2_22
), OP_SVE_DZD
, F_OD(1), 0),
4245 _SVE_INSN ("ldff1sw", 0xc540a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4246 _SVE_INSN ("ldff1sw", 0xc560a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL2
), OP_SVE_DZD
, F_OD(1), 0),
4247 _SVE_INSN ("ldff1sw", 0xc520a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x4
), OP_SVE_DZD
, F_OD(1), 0),
4249 _SVE_INSN ("ldff1w", 0x85006000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_SZS
, F_OD(1), 0),
4250 _SVE_INSN ("ldff1w", 0x85206000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW2_22
), OP_SVE_SZS
, F_OD(1), 0),
4251 _SVE_INSN ("ldff1w", 0xa5406000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR_LSL2
), OP_SVE_SZU
, F_OD(1), 0),
4252 _SVE_INSN ("ldff1w", 0xa5406000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_SZU
, F_OD(1), 0),
4253 _SVE_INSN ("ldff1w", 0xa5606000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RR_LSL2
), OP_SVE_DZU
, F_OD(1), 0),
4254 _SVE_INSN ("ldff1w", 0xa5606000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_R
), OP_SVE_DZU
, F_OD(1), 0),
4255 _SVE_INSN ("ldff1w", 0xc5006000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_DZD
, F_OD(1), 0),
4256 _SVE_INSN ("ldff1w", 0xc5206000, 0xffa0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW2_22
), OP_SVE_DZD
, F_OD(1), 0),
4257 _SVE_INSN ("ldff1w", 0xc540e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DZD
, F_OD(1), 0),
4258 _SVE_INSN ("ldff1w", 0xc560e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL2
), OP_SVE_DZD
, F_OD(1), 0),
4259 _SVE_INSN ("ldff1w", 0x8520e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x4
), OP_SVE_SZS
, F_OD(1), 0),
4260 _SVE_INSN ("ldff1w", 0xc520e000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x4
), OP_SVE_DZD
, F_OD(1), 0),
4262 _SVE_INSN ("ldnf1b", 0xa410a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_BZU
, F_OD(1), 0),
4263 _SVE_INSN ("ldnf1b", 0xa430a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_HZU
, F_OD(1), 0),
4264 _SVE_INSN ("ldnf1b", 0xa450a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SZU
, F_OD(1), 0),
4265 _SVE_INSN ("ldnf1b", 0xa470a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4266 _SVE_INSN ("ldnf1d", 0xa5f0a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4267 _SVE_INSN ("ldnf1h", 0xa4b0a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_HZU
, F_OD(1), 0),
4268 _SVE_INSN ("ldnf1h", 0xa4d0a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SZU
, F_OD(1), 0),
4269 _SVE_INSN ("ldnf1h", 0xa4f0a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4270 _SVE_INSN ("ldnf1sb", 0xa590a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4271 _SVE_INSN ("ldnf1sb", 0xa5b0a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SZU
, F_OD(1), 0),
4272 _SVE_INSN ("ldnf1sb", 0xa5d0a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_HZU
, F_OD(1), 0),
4273 _SVE_INSN ("ldnf1sh", 0xa510a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4274 _SVE_INSN ("ldnf1sh", 0xa530a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SZU
, F_OD(1), 0),
4275 _SVE_INSN ("ldnf1sw", 0xa490a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4276 _SVE_INSN ("ldnf1w", 0xa550a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SZU
, F_OD(1), 0),
4277 _SVE_INSN ("ldnf1w", 0xa570a000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4278 _SVE_INSN ("ldnt1b", 0xa400c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_BZU
, F_OD(1), 0),
4279 _SVE_INSN ("ldnt1b", 0xa400e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_BZU
, F_OD(1), 0),
4280 _SVE_INSN ("ldnt1d", 0xa580c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL3
), OP_SVE_DZU
, F_OD(1), 0),
4281 _SVE_INSN ("ldnt1d", 0xa580e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DZU
, F_OD(1), 0),
4282 _SVE_INSN ("ldnt1h", 0xa480c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_HZU
, F_OD(1), 0),
4283 _SVE_INSN ("ldnt1h", 0xa480e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_HZU
, F_OD(1), 0),
4284 _SVE_INSN ("ldnt1w", 0xa500c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_SZU
, F_OD(1), 0),
4285 _SVE_INSN ("ldnt1w", 0xa500e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SZU
, F_OD(1), 0),
4286 _SVE_INSN ("ldr", 0x85800000, 0xffc0e010, sve_misc
, 0, OP2 (SVE_Pt
, SVE_ADDR_RI_S9xVL
), {}, 0, 0),
4287 _SVE_INSN ("ldr", 0x85804000, 0xffc0e000, sve_misc
, 0, OP2 (SVE_Zt
, SVE_ADDR_RI_S9xVL
), {}, 0, 0),
4288 _SVE_INSN ("lsl", 0x04208c00, 0xff20fc00, sve_size_bhs
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVD_BHS
, 0, 0),
4289 _SVE_INSN ("lsl", 0x04209c00, 0xff20fc00, sve_shift_unpred
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHLIMM_UNPRED
), OP_SVE_VVU_BHSD
, 0, 0),
4290 _SVE_INSNC ("lsl", 0x04138000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4291 _SVE_INSNC ("lsl", 0x041b8000, 0xff3fe000, sve_size_bhs
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVD_BHS
, 0, C_SCAN_MOVPRFX
, 2),
4292 _SVE_INSNC ("lsl", 0x04038000, 0xff3fe000, sve_shift_pred
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_SHLIMM_PRED
), OP_SVE_VMVU_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4293 _SVE_INSNC ("lslr", 0x04178000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4294 _SVE_INSN ("lsr", 0x04208400, 0xff20fc00, sve_size_bhs
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVD_BHS
, 0, 0),
4295 _SVE_INSN ("lsr", 0x04209400, 0xff20fc00, sve_shift_unpred
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED
), OP_SVE_VVU_BHSD
, 0, 0),
4296 _SVE_INSNC ("lsr", 0x04118000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4297 _SVE_INSNC ("lsr", 0x04198000, 0xff3fe000, sve_size_bhs
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVD_BHS
, 0, C_SCAN_MOVPRFX
, 2),
4298 _SVE_INSNC ("lsr", 0x04018000, 0xff3fe000, sve_shift_pred
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_SHRIMM_PRED
), OP_SVE_VMVU_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4299 _SVE_INSNC ("lsrr", 0x04158000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4300 _SVE_INSNC ("mad", 0x0400c000, 0xff20e000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zm_16
, SVE_Za_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4301 _SVE_INSNC ("mla", 0x04004000, 0xff20e000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4302 _SVE_INSNC ("mls", 0x04006000, 0xff20e000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4303 _SVE_INSNC ("movprfx", 0x0420bc00, 0xfffffc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_Zn
), {}, F_SCAN
, C_SCAN_MOVPRFX
, 0),
4304 _SVE_INSNC ("movprfx", 0x04102000, 0xff3ee000, sve_movprfx
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VPV_BHSD
, F_SCAN
, C_SCAN_MOVPRFX
, 0),
4305 _SVE_INSNC ("msb", 0x0400e000, 0xff20e000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zm_16
, SVE_Za_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4306 _SVE_INSNC ("mul", 0x2530c000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_SIMM8
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4307 _SVE_INSNC ("mul", 0x04100000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4308 _SVE_INSN ("nand", 0x25804210, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, 0, 0),
4309 _SVE_INSN ("nands", 0x25c04210, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, 0, 0),
4310 _SVE_INSNC ("neg", 0x0417a000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4311 _SVE_INSN ("nor", 0x25804200, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, 0, 0),
4312 _SVE_INSN ("nors", 0x25c04200, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, 0, 0),
4313 _SVE_INSNC ("not", 0x041ea000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4314 _SVE_INSN ("orn", 0x25804010, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, 0, 0),
4315 _SVE_INSN ("orns", 0x25c04010, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, 0, 0),
4316 _SVE_INSN ("orr", 0x04603000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_DDD
, F_HAS_ALIAS
, 0),
4317 _SVE_INSNC ("orr", 0x05000000, 0xfffc0000, sve_limm
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_LIMM
), OP_SVE_VVU_BHSD
, F_HAS_ALIAS
, C_SCAN_MOVPRFX
, 1),
4318 _SVE_INSNC ("orr", 0x04180000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4319 _SVE_INSN ("orr", 0x25804000, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, F_HAS_ALIAS
, 0),
4320 _SVE_INSN ("orrs", 0x25c04000, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BZBB
, F_HAS_ALIAS
, 0),
4321 _SVE_INSN ("orv", 0x04182000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_BHSD
, 0, 0),
4322 _SVE_INSN ("pfalse", 0x2518e400, 0xfffffff0, sve_misc
, 0, OP1 (SVE_Pd
), OP_SVE_B
, 0, 0),
4323 _SVE_INSN ("pfirst", 0x2558c000, 0xfffffe10, sve_misc
, 0, OP3 (SVE_Pd
, SVE_Pg4_5
, SVE_Pd
), OP_SVE_BUB
, 0, 2),
4324 _SVE_INSN ("pnext", 0x2519c400, 0xff3ffe10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, SVE_Pg4_5
, SVE_Pd
), OP_SVE_VUV_BHSD
, 0, 2),
4325 _SVE_INSN ("prfb", 0x8400c000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RX
), {}, 0, 0),
4326 _SVE_INSN ("prfb", 0x84200000, 0xffa0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_UUS
, 0, 0),
4327 _SVE_INSN ("prfb", 0xc4200000, 0xffa0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RZ_XTW_22
), OP_SVE_UUD
, 0, 0),
4328 _SVE_INSN ("prfb", 0xc4608000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_UUD
, 0, 0),
4329 _SVE_INSN ("prfb", 0x8400e000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_ZI_U5
), OP_SVE_UUS
, 0, 0),
4330 _SVE_INSN ("prfb", 0x85c00000, 0xffc0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RI_S6xVL
), {}, 0, 0),
4331 _SVE_INSN ("prfb", 0xc400e000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_ZI_U5
), OP_SVE_UUD
, 0, 0),
4332 _SVE_INSN ("prfd", 0x84206000, 0xffa0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RZ_XTW3_22
), OP_SVE_UUS
, 0, 0),
4333 _SVE_INSN ("prfd", 0x8580c000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RX_LSL3
), {}, 0, 0),
4334 _SVE_INSN ("prfd", 0xc4206000, 0xffa0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RZ_XTW3_22
), OP_SVE_UUD
, 0, 0),
4335 _SVE_INSN ("prfd", 0xc460e000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RZ_LSL3
), OP_SVE_UUD
, 0, 0),
4336 _SVE_INSN ("prfd", 0x8580e000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_ZI_U5x8
), OP_SVE_UUS
, 0, 0),
4337 _SVE_INSN ("prfd", 0x85c06000, 0xffc0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RI_S6xVL
), {}, 0, 0),
4338 _SVE_INSN ("prfd", 0xc580e000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_ZI_U5x8
), OP_SVE_UUD
, 0, 0),
4339 _SVE_INSN ("prfh", 0x84202000, 0xffa0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RZ_XTW1_22
), OP_SVE_UUS
, 0, 0),
4340 _SVE_INSN ("prfh", 0x8480c000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), {}, 0, 0),
4341 _SVE_INSN ("prfh", 0xc4202000, 0xffa0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RZ_XTW1_22
), OP_SVE_UUD
, 0, 0),
4342 _SVE_INSN ("prfh", 0xc460a000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RZ_LSL1
), OP_SVE_UUD
, 0, 0),
4343 _SVE_INSN ("prfh", 0x8480e000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_ZI_U5x2
), OP_SVE_UUS
, 0, 0),
4344 _SVE_INSN ("prfh", 0x85c02000, 0xffc0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RI_S6xVL
), {}, 0, 0),
4345 _SVE_INSN ("prfh", 0xc480e000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_ZI_U5x2
), OP_SVE_UUD
, 0, 0),
4346 _SVE_INSN ("prfw", 0x84204000, 0xffa0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RZ_XTW2_22
), OP_SVE_UUS
, 0, 0),
4347 _SVE_INSN ("prfw", 0x8500c000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), {}, 0, 0),
4348 _SVE_INSN ("prfw", 0xc4204000, 0xffa0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RZ_XTW2_22
), OP_SVE_UUD
, 0, 0),
4349 _SVE_INSN ("prfw", 0xc460c000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RZ_LSL2
), OP_SVE_UUD
, 0, 0),
4350 _SVE_INSN ("prfw", 0x8500e000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_ZI_U5x4
), OP_SVE_UUS
, 0, 0),
4351 _SVE_INSN ("prfw", 0x85c04000, 0xffc0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_RI_S6xVL
), {}, 0, 0),
4352 _SVE_INSN ("prfw", 0xc500e000, 0xffe0e010, sve_misc
, 0, OP3 (SVE_PRFOP
, SVE_Pg3
, SVE_ADDR_ZI_U5x4
), OP_SVE_UUD
, 0, 0),
4353 _SVE_INSN ("ptest", 0x2550c000, 0xffffc21f, sve_misc
, 0, OP2 (SVE_Pg4_10
, SVE_Pn
), OP_SVE_UB
, 0, 0),
4354 _SVE_INSN ("ptrue", 0x2518e000, 0xff3ffc10, sve_size_bhsd
, 0, OP2 (SVE_Pd
, SVE_PATTERN
), OP_SVE_VU_BHSD
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4355 _SVE_INSN ("ptrues", 0x2519e000, 0xff3ffc10, sve_size_bhsd
, 0, OP2 (SVE_Pd
, SVE_PATTERN
), OP_SVE_VU_BHSD
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4356 _SVE_INSN ("punpkhi", 0x05314000, 0xfffffe10, sve_misc
, 0, OP2 (SVE_Pd
, SVE_Pn
), OP_SVE_HB
, 0, 0),
4357 _SVE_INSN ("punpklo", 0x05304000, 0xfffffe10, sve_misc
, 0, OP2 (SVE_Pd
, SVE_Pn
), OP_SVE_HB
, 0, 0),
4358 _SVE_INSNC ("rbit", 0x05278000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4359 _SVE_INSN ("rdffr", 0x2519f000, 0xfffffff0, sve_misc
, 0, OP1 (SVE_Pd
), OP_SVE_B
, 0, 0),
4360 _SVE_INSN ("rdffr", 0x2518f000, 0xfffffe10, sve_misc
, 0, OP2 (SVE_Pd
, SVE_Pg4_5
), OP_SVE_BZ
, 0, 0),
4361 _SVE_INSN ("rdffrs", 0x2558f000, 0xfffffe10, sve_misc
, 0, OP2 (SVE_Pd
, SVE_Pg4_5
), OP_SVE_BZ
, 0, 0),
4362 _SVE_INSN ("rdvl", 0x04bf5000, 0xfffff800, sve_misc
, 0, OP2 (Rd
, SVE_SIMM6
), OP_SVE_XU
, 0, 0),
4363 _SVE_INSN ("rev", 0x05344000, 0xff3ffe10, sve_size_bhsd
, 0, OP2 (SVE_Pd
, SVE_Pn
), OP_SVE_VV_BHSD
, 0, 0),
4364 _SVE_INSN ("rev", 0x05383800, 0xff3ffc00, sve_size_bhsd
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_BHSD
, 0, 0),
4365 _SVE_INSNC ("revb", 0x05248000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4366 _SVE_INSNC ("revh", 0x05a58000, 0xffbfe000, sve_size_sd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_SD
, 0, C_SCAN_MOVPRFX
, 0),
4367 _SVE_INSNC ("revw", 0x05e68000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMD
, 0, C_SCAN_MOVPRFX
, 0),
4368 _SVE_INSNC ("sabd", 0x040c0000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4369 _SVE_INSN ("saddv", 0x04002000, 0xff3fe000, sve_size_bhs
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DUV_BHS
, 0, 0),
4370 _SVE_INSNC ("scvtf", 0x6552a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_HMH
, 0, C_SCAN_MOVPRFX
, 0),
4371 _SVE_INSNC ("scvtf", 0x6554a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_HMS
, 0, C_SCAN_MOVPRFX
, 0),
4372 _SVE_INSNC ("scvtf", 0x6594a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMS
, 0, C_SCAN_MOVPRFX
, 0),
4373 _SVE_INSNC ("scvtf", 0x65d0a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMS
, 0, C_SCAN_MOVPRFX
, 0),
4374 _SVE_INSNC ("scvtf", 0x6556a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_HMD
, 0, C_SCAN_MOVPRFX
, 0),
4375 _SVE_INSNC ("scvtf", 0x65d4a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMD
, 0, C_SCAN_MOVPRFX
, 0),
4376 _SVE_INSNC ("scvtf", 0x65d6a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMD
, 0, C_SCAN_MOVPRFX
, 0),
4377 _SVE_INSNC ("sdiv", 0x04940000, 0xffbfe000, sve_size_sd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_SD
, 0, C_SCAN_MOVPRFX
, 2),
4378 _SVE_INSNC ("sdivr", 0x04960000, 0xffbfe000, sve_size_sd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_SD
, 0, C_SCAN_MOVPRFX
, 2),
4379 _SVE_INSNC ("sdot", 0x44800000, 0xffa0fc00, sve_size_sd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_SD_BH
, 0, C_SCAN_MOVPRFX
, 0),
4380 _SVE_INSNC ("sdot", 0x44a00000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
), OP_SVE_VVV_S_B
, 0, C_SCAN_MOVPRFX
, 0),
4381 _SVE_INSNC ("sdot", 0x44e00000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
), OP_SVE_VVV_D_H
, 0, C_SCAN_MOVPRFX
, 0),
4382 _SVE_INSN ("sel", 0x0520c000, 0xff20c000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg4_10
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VUVV_BHSD
, F_HAS_ALIAS
, 0),
4383 _SVE_INSN ("sel", 0x25004210, 0xfff0c210, sve_misc
, 0, OP4 (SVE_Pd
, SVE_Pg4_10
, SVE_Pn
, SVE_Pm
), OP_SVE_BUBB
, F_HAS_ALIAS
, 0),
4384 _SVE_INSN ("setffr", 0x252c9000, 0xffffffff, sve_misc
, 0, OP0 (), {}, 0, 0),
4385 _SVE_INSNC ("smax", 0x2528c000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_SIMM8
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4386 _SVE_INSNC ("smax", 0x04080000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4387 _SVE_INSN ("smaxv", 0x04082000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_BHSD
, 0, 0),
4388 _SVE_INSNC ("smin", 0x252ac000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_SIMM8
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4389 _SVE_INSNC ("smin", 0x040a0000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4390 _SVE_INSN ("sminv", 0x040a2000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_BHSD
, 0, 0),
4391 _SVE_INSNC ("smulh", 0x04120000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4392 _SVE_INSNC ("splice", 0x052c8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VUVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4393 _SVE_INSN ("sqadd", 0x04201000, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4394 _SVE_INSNC ("sqadd", 0x2524c000, 0xff3fc000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_AIMM
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4395 _SVE_INSN ("sqdecb", 0x0430f800, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4396 _SVE_INSN ("sqdecb", 0x0420f800, 0xfff0fc00, sve_misc
, 0, OP3 (Rd
, Rd
, SVE_PATTERN_SCALED
), OP_SVE_XWU
, F_OPD2_OPT
| F_DEFAULT(31), 1),
4397 _SVE_INSNC ("sqdecd", 0x04e0c800, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_DU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4398 _SVE_INSN ("sqdecd", 0x04f0f800, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4399 _SVE_INSN ("sqdecd", 0x04e0f800, 0xfff0fc00, sve_misc
, 0, OP3 (Rd
, Rd
, SVE_PATTERN_SCALED
), OP_SVE_XWU
, F_OPD2_OPT
| F_DEFAULT(31), 1),
4400 _SVE_INSNC ("sqdech", 0x0460c800, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_HU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4401 _SVE_INSN ("sqdech", 0x0470f800, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4402 _SVE_INSN ("sqdech", 0x0460f800, 0xfff0fc00, sve_misc
, 0, OP3 (Rd
, Rd
, SVE_PATTERN_SCALED
), OP_SVE_XWU
, F_OPD2_OPT
| F_DEFAULT(31), 1),
4403 _SVE_INSNC ("sqdecp", 0x252a8000, 0xff3ffe00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Pg4_5
), OP_SVE_VU_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4404 _SVE_INSN ("sqdecp", 0x252a8c00, 0xff3ffe00, sve_size_bhsd
, 0, OP2 (Rd
, SVE_Pg4_5
), OP_SVE_XV_BHSD
, 0, 0),
4405 _SVE_INSN ("sqdecp", 0x252a8800, 0xff3ffe00, sve_size_bhsd
, 0, OP3 (Rd
, SVE_Pg4_5
, Rd
), OP_SVE_XVW_BHSD
, 0, 2),
4406 _SVE_INSNC ("sqdecw", 0x04a0c800, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_SU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4407 _SVE_INSN ("sqdecw", 0x04b0f800, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4408 _SVE_INSN ("sqdecw", 0x04a0f800, 0xfff0fc00, sve_misc
, 0, OP3 (Rd
, Rd
, SVE_PATTERN_SCALED
), OP_SVE_XWU
, F_OPD2_OPT
| F_DEFAULT(31), 1),
4409 _SVE_INSN ("sqincb", 0x0430f000, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4410 _SVE_INSN ("sqincb", 0x0420f000, 0xfff0fc00, sve_misc
, 0, OP3 (Rd
, Rd
, SVE_PATTERN_SCALED
), OP_SVE_XWU
, F_OPD2_OPT
| F_DEFAULT(31), 1),
4411 _SVE_INSNC ("sqincd", 0x04e0c000, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_DU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4412 _SVE_INSN ("sqincd", 0x04f0f000, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4413 _SVE_INSN ("sqincd", 0x04e0f000, 0xfff0fc00, sve_misc
, 0, OP3 (Rd
, Rd
, SVE_PATTERN_SCALED
), OP_SVE_XWU
, F_OPD2_OPT
| F_DEFAULT(31), 1),
4414 _SVE_INSNC ("sqinch", 0x0460c000, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_HU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4415 _SVE_INSN ("sqinch", 0x0470f000, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4416 _SVE_INSN ("sqinch", 0x0460f000, 0xfff0fc00, sve_misc
, 0, OP3 (Rd
, Rd
, SVE_PATTERN_SCALED
), OP_SVE_XWU
, F_OPD2_OPT
| F_DEFAULT(31), 1),
4417 _SVE_INSNC ("sqincp", 0x25288000, 0xff3ffe00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Pg4_5
), OP_SVE_VU_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4418 _SVE_INSN ("sqincp", 0x25288c00, 0xff3ffe00, sve_size_bhsd
, 0, OP2 (Rd
, SVE_Pg4_5
), OP_SVE_XV_BHSD
, 0, 0),
4419 _SVE_INSN ("sqincp", 0x25288800, 0xff3ffe00, sve_size_bhsd
, 0, OP3 (Rd
, SVE_Pg4_5
, Rd
), OP_SVE_XVW_BHSD
, 0, 2),
4420 _SVE_INSNC ("sqincw", 0x04a0c000, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_SU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4421 _SVE_INSN ("sqincw", 0x04b0f000, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4422 _SVE_INSN ("sqincw", 0x04a0f000, 0xfff0fc00, sve_misc
, 0, OP3 (Rd
, Rd
, SVE_PATTERN_SCALED
), OP_SVE_XWU
, F_OPD2_OPT
| F_DEFAULT(31), 1),
4423 _SVE_INSN ("sqsub", 0x04201800, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4424 _SVE_INSNC ("sqsub", 0x2526c000, 0xff3fc000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_AIMM
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4425 _SVE_INSN ("st1b", 0xe4004000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_BUU
, F_OD(1), 0),
4426 _SVE_INSN ("st1b", 0xe4008000, 0xffe0a000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_14
), OP_SVE_DUD
, F_OD(1), 0),
4427 _SVE_INSN ("st1b", 0xe400a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DUD
, F_OD(1), 0),
4428 _SVE_INSN ("st1b", 0xe4204000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_HUU
, F_OD(1), 0),
4429 _SVE_INSN ("st1b", 0xe4404000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_SUU
, F_OD(1), 0),
4430 _SVE_INSN ("st1b", 0xe4408000, 0xffe0a000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_14
), OP_SVE_SUS
, F_OD(1), 0),
4431 _SVE_INSN ("st1b", 0xe4604000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_DUU
, F_OD(1), 0),
4432 _SVE_INSN ("st1b", 0xe400e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_BUU
, F_OD(1), 0),
4433 _SVE_INSN ("st1b", 0xe420e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_HUU
, F_OD(1), 0),
4434 _SVE_INSN ("st1b", 0xe440a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5
), OP_SVE_DUD
, F_OD(1), 0),
4435 _SVE_INSN ("st1b", 0xe440e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SUU
, F_OD(1), 0),
4436 _SVE_INSN ("st1b", 0xe460a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5
), OP_SVE_SUS
, F_OD(1), 0),
4437 _SVE_INSN ("st1b", 0xe460e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DUU
, F_OD(1), 0),
4438 _SVE_INSN ("st1d", 0xe5808000, 0xffe0a000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_14
), OP_SVE_DUD
, F_OD(1), 0),
4439 _SVE_INSN ("st1d", 0xe580a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DUD
, F_OD(1), 0),
4440 _SVE_INSN ("st1d", 0xe5a08000, 0xffe0a000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW3_14
), OP_SVE_DUD
, F_OD(1), 0),
4441 _SVE_INSN ("st1d", 0xe5a0a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL3
), OP_SVE_DUD
, F_OD(1), 0),
4442 _SVE_INSN ("st1d", 0xe5e04000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL3
), OP_SVE_DUU
, F_OD(1), 0),
4443 _SVE_INSN ("st1d", 0xe5c0a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x8
), OP_SVE_DUD
, F_OD(1), 0),
4444 _SVE_INSN ("st1d", 0xe5e0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DUU
, F_OD(1), 0),
4445 _SVE_INSN ("st1h", 0xe4808000, 0xffe0a000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_14
), OP_SVE_DUD
, F_OD(1), 0),
4446 _SVE_INSN ("st1h", 0xe480a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DUD
, F_OD(1), 0),
4447 _SVE_INSN ("st1h", 0xe4a04000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_HUU
, F_OD(1), 0),
4448 _SVE_INSN ("st1h", 0xe4a08000, 0xffe0a000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW1_14
), OP_SVE_DUD
, F_OD(1), 0),
4449 _SVE_INSN ("st1h", 0xe4a0a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL1
), OP_SVE_DUD
, F_OD(1), 0),
4450 _SVE_INSN ("st1h", 0xe4c04000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_SUU
, F_OD(1), 0),
4451 _SVE_INSN ("st1h", 0xe4c08000, 0xffe0a000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_14
), OP_SVE_SUS
, F_OD(1), 0),
4452 _SVE_INSN ("st1h", 0xe4e04000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_DUU
, F_OD(1), 0),
4453 _SVE_INSN ("st1h", 0xe4e08000, 0xffe0a000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW1_14
), OP_SVE_SUS
, F_OD(1), 0),
4454 _SVE_INSN ("st1h", 0xe4a0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_HUU
, F_OD(1), 0),
4455 _SVE_INSN ("st1h", 0xe4c0a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x2
), OP_SVE_DUD
, F_OD(1), 0),
4456 _SVE_INSN ("st1h", 0xe4c0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SUU
, F_OD(1), 0),
4457 _SVE_INSN ("st1h", 0xe4e0a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x2
), OP_SVE_SUS
, F_OD(1), 0),
4458 _SVE_INSN ("st1h", 0xe4e0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DUU
, F_OD(1), 0),
4459 _SVE_INSN ("st1w", 0xe5008000, 0xffe0a000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_14
), OP_SVE_DUD
, F_OD(1), 0),
4460 _SVE_INSN ("st1w", 0xe500a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ
), OP_SVE_DUD
, F_OD(1), 0),
4461 _SVE_INSN ("st1w", 0xe5208000, 0xffe0a000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW2_14
), OP_SVE_DUD
, F_OD(1), 0),
4462 _SVE_INSN ("st1w", 0xe520a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_LSL2
), OP_SVE_DUD
, F_OD(1), 0),
4463 _SVE_INSN ("st1w", 0xe5404000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_SUU
, F_OD(1), 0),
4464 _SVE_INSN ("st1w", 0xe5408000, 0xffe0a000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW_14
), OP_SVE_SUS
, F_OD(1), 0),
4465 _SVE_INSN ("st1w", 0xe5604000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_DUU
, F_OD(1), 0),
4466 _SVE_INSN ("st1w", 0xe5608000, 0xffe0a000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RZ_XTW2_14
), OP_SVE_SUS
, F_OD(1), 0),
4467 _SVE_INSN ("st1w", 0xe540a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x4
), OP_SVE_DUD
, F_OD(1), 0),
4468 _SVE_INSN ("st1w", 0xe540e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SUU
, F_OD(1), 0),
4469 _SVE_INSN ("st1w", 0xe560a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZI_U5x4
), OP_SVE_SUS
, F_OD(1), 0),
4470 _SVE_INSN ("st1w", 0xe560e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DUU
, F_OD(1), 0),
4471 _SVE_INSN ("st2b", 0xe4206000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_BUU
, F_OD(2), 0),
4472 _SVE_INSN ("st2b", 0xe430e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x2xVL
), OP_SVE_BUU
, F_OD(2), 0),
4473 _SVE_INSN ("st2d", 0xe5a06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL3
), OP_SVE_DUU
, F_OD(2), 0),
4474 _SVE_INSN ("st2d", 0xe5b0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x2xVL
), OP_SVE_DUU
, F_OD(2), 0),
4475 _SVE_INSN ("st2h", 0xe4a06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_HUU
, F_OD(2), 0),
4476 _SVE_INSN ("st2h", 0xe4b0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x2xVL
), OP_SVE_HUU
, F_OD(2), 0),
4477 _SVE_INSN ("st2w", 0xe5206000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_SUU
, F_OD(2), 0),
4478 _SVE_INSN ("st2w", 0xe530e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x2xVL
), OP_SVE_SUU
, F_OD(2), 0),
4479 _SVE_INSN ("st3b", 0xe4406000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_BUU
, F_OD(3), 0),
4480 _SVE_INSN ("st3b", 0xe450e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x3xVL
), OP_SVE_BUU
, F_OD(3), 0),
4481 _SVE_INSN ("st3d", 0xe5c06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL3
), OP_SVE_DUU
, F_OD(3), 0),
4482 _SVE_INSN ("st3d", 0xe5d0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x3xVL
), OP_SVE_DUU
, F_OD(3), 0),
4483 _SVE_INSN ("st3h", 0xe4c06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_HUU
, F_OD(3), 0),
4484 _SVE_INSN ("st3h", 0xe4d0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x3xVL
), OP_SVE_HUU
, F_OD(3), 0),
4485 _SVE_INSN ("st3w", 0xe5406000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_SUU
, F_OD(3), 0),
4486 _SVE_INSN ("st3w", 0xe550e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x3xVL
), OP_SVE_SUU
, F_OD(3), 0),
4487 _SVE_INSN ("st4b", 0xe4606000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_BUU
, F_OD(4), 0),
4488 _SVE_INSN ("st4b", 0xe470e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x4xVL
), OP_SVE_BUU
, F_OD(4), 0),
4489 _SVE_INSN ("st4d", 0xe5e06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL3
), OP_SVE_DUU
, F_OD(4), 0),
4490 _SVE_INSN ("st4d", 0xe5f0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x4xVL
), OP_SVE_DUU
, F_OD(4), 0),
4491 _SVE_INSN ("st4h", 0xe4e06000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_HUU
, F_OD(4), 0),
4492 _SVE_INSN ("st4h", 0xe4f0e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x4xVL
), OP_SVE_HUU
, F_OD(4), 0),
4493 _SVE_INSN ("st4w", 0xe5606000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_SUU
, F_OD(4), 0),
4494 _SVE_INSN ("st4w", 0xe570e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4x4xVL
), OP_SVE_SUU
, F_OD(4), 0),
4495 _SVE_INSN ("stnt1b", 0xe4006000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX
), OP_SVE_BUU
, F_OD(1), 0),
4496 _SVE_INSN ("stnt1b", 0xe410e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_BUU
, F_OD(1), 0),
4497 _SVE_INSN ("stnt1d", 0xe5806000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL3
), OP_SVE_DUU
, F_OD(1), 0),
4498 _SVE_INSN ("stnt1d", 0xe590e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_DUU
, F_OD(1), 0),
4499 _SVE_INSN ("stnt1h", 0xe4806000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL1
), OP_SVE_HUU
, F_OD(1), 0),
4500 _SVE_INSN ("stnt1h", 0xe490e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_HUU
, F_OD(1), 0),
4501 _SVE_INSN ("stnt1w", 0xe5006000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RX_LSL2
), OP_SVE_SUU
, F_OD(1), 0),
4502 _SVE_INSN ("stnt1w", 0xe510e000, 0xfff0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_RI_S4xVL
), OP_SVE_SUU
, F_OD(1), 0),
4503 _SVE_INSN ("str", 0xe5800000, 0xffc0e010, sve_misc
, 0, OP2 (SVE_Pt
, SVE_ADDR_RI_S9xVL
), {}, 0, 0),
4504 _SVE_INSN ("str", 0xe5804000, 0xffc0e000, sve_misc
, 0, OP2 (SVE_Zt
, SVE_ADDR_RI_S9xVL
), {}, 0, 0),
4505 _SVE_INSN ("sub", 0x04200400, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4506 _SVE_INSNC ("sub", 0x2521c000, 0xff3fc000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_AIMM
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4507 _SVE_INSNC ("sub", 0x04010000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4508 _SVE_INSNC ("subr", 0x2523c000, 0xff3fc000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_AIMM
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4509 _SVE_INSNC ("subr", 0x04030000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4510 _SVE_INSN ("sunpkhi", 0x05313800, 0xff3ffc00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_HSD_BHS
, 0, 0),
4511 _SVE_INSN ("sunpklo", 0x05303800, 0xff3ffc00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_HSD_BHS
, 0, 0),
4512 _SVE_INSNC ("sxtb", 0x0410a000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4513 _SVE_INSNC ("sxth", 0x0492a000, 0xffbfe000, sve_size_sd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_SD
, 0, C_SCAN_MOVPRFX
, 0),
4514 _SVE_INSNC ("sxtw", 0x04d4a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMD
, 0, C_SCAN_MOVPRFX
, 0),
4515 _SVE_INSN ("tbl", 0x05203000, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_ZnxN
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, F_OD(1), 0),
4516 _SVE_INSN ("trn1", 0x05205000, 0xff30fe10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, SVE_Pn
, SVE_Pm
), OP_SVE_VVV_BHSD
, 0, 0),
4517 _SVE_INSN ("trn1", 0x05207000, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4518 _SVE_INSN ("trn2", 0x05205400, 0xff30fe10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, SVE_Pn
, SVE_Pm
), OP_SVE_VVV_BHSD
, 0, 0),
4519 _SVE_INSN ("trn2", 0x05207400, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4520 _SVE_INSNC ("uabd", 0x040d0000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4521 _SVE_INSN ("uaddv", 0x04012000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DUV_BHSD
, 0, 0),
4522 _SVE_INSNC ("ucvtf", 0x6553a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_HMH
, 0, C_SCAN_MOVPRFX
, 0),
4523 _SVE_INSNC ("ucvtf", 0x6555a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_HMS
, 0, C_SCAN_MOVPRFX
, 0),
4524 _SVE_INSNC ("ucvtf", 0x6595a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMS
, 0, C_SCAN_MOVPRFX
, 0),
4525 _SVE_INSNC ("ucvtf", 0x65d1a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMS
, 0, C_SCAN_MOVPRFX
, 0),
4526 _SVE_INSNC ("ucvtf", 0x6557a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_HMD
, 0, C_SCAN_MOVPRFX
, 0),
4527 _SVE_INSNC ("ucvtf", 0x65d5a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMD
, 0, C_SCAN_MOVPRFX
, 0),
4528 _SVE_INSNC ("ucvtf", 0x65d7a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMD
, 0, C_SCAN_MOVPRFX
, 0),
4529 _SVE_INSNC ("udiv", 0x04950000, 0xffbfe000, sve_size_sd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_SD
, 0, C_SCAN_MOVPRFX
, 2),
4530 _SVE_INSNC ("udivr", 0x04970000, 0xffbfe000, sve_size_sd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_SD
, 0, C_SCAN_MOVPRFX
, 2),
4531 _SVE_INSNC ("udot", 0x44800400, 0xffa0fc00, sve_size_sd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_SD_BH
, 0, C_SCAN_MOVPRFX
, 0),
4532 _SVE_INSNC ("udot", 0x44a00400, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
), OP_SVE_VVV_S_B
, 0, C_SCAN_MOVPRFX
, 0),
4533 _SVE_INSNC ("udot", 0x44e00400, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
), OP_SVE_VVV_D_H
, 0, C_SCAN_MOVPRFX
, 0),
4534 _SVE_INSNC ("umax", 0x2529c000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_UIMM8
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4535 _SVE_INSNC ("umax", 0x04090000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4536 _SVE_INSN ("umaxv", 0x04092000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_BHSD
, 0, 0),
4537 _SVE_INSNC ("umin", 0x252bc000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_UIMM8
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4538 _SVE_INSNC ("umin", 0x040b0000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4539 _SVE_INSN ("uminv", 0x040b2000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Vd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VUV_BHSD
, 0, 0),
4540 _SVE_INSNC ("umulh", 0x04130000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zm_5
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4541 _SVE_INSN ("uqadd", 0x04201400, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4542 _SVE_INSNC ("uqadd", 0x2525c000, 0xff3fc000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_AIMM
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4543 _SVE_INSN ("uqdecb", 0x0420fc00, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_WU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4544 _SVE_INSN ("uqdecb", 0x0430fc00, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4545 _SVE_INSNC ("uqdecd", 0x04e0cc00, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_DU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4546 _SVE_INSN ("uqdecd", 0x04e0fc00, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_WU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4547 _SVE_INSN ("uqdecd", 0x04f0fc00, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4548 _SVE_INSNC ("uqdech", 0x0460cc00, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_HU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4549 _SVE_INSN ("uqdech", 0x0460fc00, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_WU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4550 _SVE_INSN ("uqdech", 0x0470fc00, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4551 _SVE_INSNC ("uqdecp", 0x252b8000, 0xff3ffe00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Pg4_5
), OP_SVE_VU_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4552 _SVE_INSN ("uqdecp", 0x252b8800, 0xff3ffe00, sve_size_bhsd
, 0, OP2 (Rd
, SVE_Pg4_5
), OP_SVE_WV_BHSD
, 0, 0),
4553 _SVE_INSN ("uqdecp", 0x252b8c00, 0xff3ffe00, sve_size_bhsd
, 0, OP2 (Rd
, SVE_Pg4_5
), OP_SVE_XV_BHSD
, 0, 0),
4554 _SVE_INSNC ("uqdecw", 0x04a0cc00, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_SU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4555 _SVE_INSN ("uqdecw", 0x04a0fc00, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_WU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4556 _SVE_INSN ("uqdecw", 0x04b0fc00, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4557 _SVE_INSN ("uqincb", 0x0420f400, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_WU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4558 _SVE_INSN ("uqincb", 0x0430f400, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4559 _SVE_INSNC ("uqincd", 0x04e0c400, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_DU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4560 _SVE_INSN ("uqincd", 0x04e0f400, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_WU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4561 _SVE_INSN ("uqincd", 0x04f0f400, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4562 _SVE_INSNC ("uqinch", 0x0460c400, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_HU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4563 _SVE_INSN ("uqinch", 0x0460f400, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_WU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4564 _SVE_INSN ("uqinch", 0x0470f400, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4565 _SVE_INSNC ("uqincp", 0x25298000, 0xff3ffe00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Pg4_5
), OP_SVE_VU_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4566 _SVE_INSN ("uqincp", 0x25298800, 0xff3ffe00, sve_size_bhsd
, 0, OP2 (Rd
, SVE_Pg4_5
), OP_SVE_WV_BHSD
, 0, 0),
4567 _SVE_INSN ("uqincp", 0x25298c00, 0xff3ffe00, sve_size_bhsd
, 0, OP2 (Rd
, SVE_Pg4_5
), OP_SVE_XV_BHSD
, 0, 0),
4568 _SVE_INSNC ("uqincw", 0x04a0c400, 0xfff0fc00, sve_misc
, 0, OP2 (SVE_Zd
, SVE_PATTERN_SCALED
), OP_SVE_SU
, F_OPD1_OPT
| F_DEFAULT(31), C_SCAN_MOVPRFX
, 0),
4569 _SVE_INSN ("uqincw", 0x04a0f400, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_WU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4570 _SVE_INSN ("uqincw", 0x04b0f400, 0xfff0fc00, sve_misc
, 0, OP2 (Rd
, SVE_PATTERN_SCALED
), OP_SVE_XU
, F_OPD1_OPT
| F_DEFAULT(31), 0),
4571 _SVE_INSN ("uqsub", 0x04201c00, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4572 _SVE_INSNC ("uqsub", 0x2527c000, 0xff3fc000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_AIMM
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4573 _SVE_INSN ("uunpkhi", 0x05333800, 0xff3ffc00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_HSD_BHS
, 0, 0),
4574 _SVE_INSN ("uunpklo", 0x05323800, 0xff3ffc00, sve_size_hsd
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_HSD_BHS
, 0, 0),
4575 _SVE_INSNC ("uxtb", 0x0411a000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4576 _SVE_INSNC ("uxth", 0x0493a000, 0xffbfe000, sve_size_sd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_SD
, 0, C_SCAN_MOVPRFX
, 0),
4577 _SVE_INSNC ("uxtw", 0x04d5a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMD
, 0, C_SCAN_MOVPRFX
, 0),
4578 _SVE_INSN ("uzp1", 0x05204800, 0xff30fe10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, SVE_Pn
, SVE_Pm
), OP_SVE_VVV_BHSD
, 0, 0),
4579 _SVE_INSN ("uzp1", 0x05206800, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4580 _SVE_INSN ("uzp2", 0x05204c00, 0xff30fe10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, SVE_Pn
, SVE_Pm
), OP_SVE_VVV_BHSD
, 0, 0),
4581 _SVE_INSN ("uzp2", 0x05206c00, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4582 _SVE_INSN ("whilele", 0x25200410, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VWW_BHSD
, 0, 0),
4583 _SVE_INSN ("whilele", 0x25201410, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VXX_BHSD
, 0, 0),
4584 _SVE_INSN ("whilelo", 0x25200c00, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VWW_BHSD
, 0, 0),
4585 _SVE_INSN ("whilelo", 0x25201c00, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VXX_BHSD
, 0, 0),
4586 _SVE_INSN ("whilels", 0x25200c10, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VWW_BHSD
, 0, 0),
4587 _SVE_INSN ("whilels", 0x25201c10, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VXX_BHSD
, 0, 0),
4588 _SVE_INSN ("whilelt", 0x25200400, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VWW_BHSD
, 0, 0),
4589 _SVE_INSN ("whilelt", 0x25201400, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VXX_BHSD
, 0, 0),
4590 _SVE_INSN ("wrffr", 0x25289000, 0xfffffe1f, sve_misc
, 0, OP1 (SVE_Pn
), OP_SVE_B
, 0, 0),
4591 _SVE_INSN ("zip1", 0x05204000, 0xff30fe10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, SVE_Pn
, SVE_Pm
), OP_SVE_VVV_BHSD
, 0, 0),
4592 _SVE_INSN ("zip1", 0x05206000, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4593 _SVE_INSN ("zip2", 0x05204400, 0xff30fe10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, SVE_Pn
, SVE_Pm
), OP_SVE_VVV_BHSD
, 0, 0),
4594 _SVE_INSN ("zip2", 0x05206400, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4595 _SVE_INSNC ("bic", 0x05800000, 0xfffc0000, sve_limm
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_INV_LIMM
), OP_SVE_VVU_BHSD
, F_ALIAS
| F_PSEUDO
, C_SCAN_MOVPRFX
, 1),
4596 _SVE_INSN ("cmple", 0x24008000, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zm_16
, SVE_Zn
), OP_SVE_VZVV_BHSD
, F_ALIAS
| F_PSEUDO
, 0),
4597 _SVE_INSN ("cmplo", 0x24000010, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zm_16
, SVE_Zn
), OP_SVE_VZVV_BHSD
, F_ALIAS
| F_PSEUDO
, 0),
4598 _SVE_INSN ("cmpls", 0x24000000, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zm_16
, SVE_Zn
), OP_SVE_VZVV_BHSD
, F_ALIAS
| F_PSEUDO
, 0),
4599 _SVE_INSN ("cmplt", 0x24008010, 0xff20e010, sve_size_bhsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zm_16
, SVE_Zn
), OP_SVE_VZVV_BHSD
, F_ALIAS
| F_PSEUDO
, 0),
4600 _SVE_INSNC ("eon", 0x05400000, 0xfffc0000, sve_limm
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_INV_LIMM
), OP_SVE_VVU_BHSD
, F_ALIAS
| F_PSEUDO
, C_SCAN_MOVPRFX
, 1),
4601 _SVE_INSN ("facle", 0x6500c010, 0xff20e010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zm_16
, SVE_Zn
), OP_SVE_VZVV_HSD
, F_ALIAS
| F_PSEUDO
, 0),
4602 _SVE_INSN ("faclt", 0x6500e010, 0xff20e010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zm_16
, SVE_Zn
), OP_SVE_VZVV_HSD
, F_ALIAS
| F_PSEUDO
, 0),
4603 _SVE_INSN ("fcmle", 0x65004000, 0xff20e010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zm_16
, SVE_Zn
), OP_SVE_VZVV_HSD
, F_ALIAS
| F_PSEUDO
, 0),
4604 _SVE_INSN ("fcmlt", 0x65004010, 0xff20e010, sve_size_hsd
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zm_16
, SVE_Zn
), OP_SVE_VZVV_HSD
, F_ALIAS
| F_PSEUDO
, 0),
4605 _SVE_INSN ("fmov", 0x2538c000, 0xff3fffe0, sve_size_hsd
, 0, OP2 (SVE_Zd
, FPIMM0
), OP_SVE_V_HSD
, F_ALIAS
| F_PSEUDO
, 0),
4606 _SVE_INSNC ("fmov", 0x05104000, 0xff30ffe0, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg4_16
, FPIMM0
), OP_SVE_VM_HSD
, F_ALIAS
| F_PSEUDO
, C_SCAN_MOVPRFX
, 0),
4607 _SVE_INSNC ("orn", 0x05000000, 0xfffc0000, sve_limm
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_INV_LIMM
), OP_SVE_VVU_BHSD
, F_ALIAS
| F_PSEUDO
, C_SCAN_MOVPRFX
, 1),
4609 /* SVE2 instructions. */
4610 SVE2_INSNC ("adclb", 0x4500d000, 0xffa0fc00, sve_size_sd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_SD
, 0, C_SCAN_MOVPRFX
, 0),
4611 SVE2_INSNC ("adclt", 0x4500d400, 0xffa0fc00, sve_size_sd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_SD
, 0, C_SCAN_MOVPRFX
, 0),
4612 SVE2_INSN ("addhnb", 0x45206000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHS_HSD
, 0, 0),
4613 SVE2_INSN ("addhnt", 0x45206400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHS_HSD
, 0, 0),
4614 SVE2_INSNC ("addp", 0x4411a000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4615 SVE2_INSNC ("bcax", 0x04603800, 0xffe0fc00, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zd
, SVE_Zm_16
, SVE_Zn
), OP_SVE_DDDD
, 0, C_SCAN_MOVPRFX
, 1),
4616 SVE2_INSNC ("bsl", 0x04203c00, 0xffe0fc00, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zd
, SVE_Zm_16
, SVE_Zn
), OP_SVE_DDDD
, 0, C_SCAN_MOVPRFX
, 1),
4617 SVE2_INSNC ("bsl1n", 0x04603c00, 0xffe0fc00, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zd
, SVE_Zm_16
, SVE_Zn
), OP_SVE_DDDD
, 0, C_SCAN_MOVPRFX
, 1),
4618 SVE2_INSNC ("bsl2n", 0x04a03c00, 0xffe0fc00, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zd
, SVE_Zm_16
, SVE_Zn
), OP_SVE_DDDD
, 0, C_SCAN_MOVPRFX
, 1),
4619 SVE2_INSNC ("cadd", 0x4500d800, 0xff3ff800, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Zd
, SVE_Zn
, SVE_IMM_ROT3
), OP_SVE_VVVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4620 SVE2_INSNC ("cdot", 0x44801000, 0xffa0f000, sve_size_sd
, 0, OP4 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
, SVE_IMM_ROT2
), OP_SVE_VVVU_SD_BH
, 0, C_SCAN_MOVPRFX
, 0),
4621 SVE2_INSNC ("cdot", 0x44e04000, 0xffe0f000, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
, SVE_IMM_ROT2
), OP_SVE_DHHU
, 0, C_SCAN_MOVPRFX
, 0),
4622 SVE2_INSNC ("cdot", 0x44a04000, 0xffe0f000, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
, SVE_IMM_ROT2
), OP_SVE_SBBU
, 0, C_SCAN_MOVPRFX
, 0),
4623 SVE2_INSNC ("cmla", 0x44002000, 0xff20f000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
, SVE_IMM_ROT2
), OP_SVE_VVVU_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4624 SVE2_INSNC ("cmla", 0x44a06000, 0xffe0f000, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
, SVE_IMM_ROT2
), OP_SVE_VVVU_H
, 0, C_SCAN_MOVPRFX
, 0),
4625 SVE2_INSNC ("cmla", 0x44e06000, 0xffe0f000, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
, SVE_IMM_ROT2
), OP_SVE_VVVU_S
, 0, C_SCAN_MOVPRFX
, 0),
4626 SVE2_INSNC ("eor3", 0x04203800, 0xffe0fc00, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zd
, SVE_Zm_16
, SVE_Zn
), OP_SVE_DDDD
, 0, C_SCAN_MOVPRFX
, 1),
4627 SVE2_INSNC ("eorbt", 0x45009000, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4628 SVE2_INSNC ("eortb", 0x45009400, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4629 SVE2_INSN ("ext", 0x05600000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_ZnxN
, SVE_UIMM8_53
), OP_SVE_BBU
, F_OD(2), 0),
4630 SVE2_INSNC ("faddp", 0x64108000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4631 SVE2_INSN ("fcvtlt", 0x6489a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMH
, 0, 0),
4632 SVE2_INSN ("fcvtlt", 0x64cba000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_DMS
, 0, 0),
4633 SVE2_INSN ("fcvtnt", 0x6488a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_HMS
, 0, 0),
4634 SVE2_INSN ("fcvtnt", 0x64caa000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMD
, 0, 0),
4635 SVE2_INSNC ("fcvtx", 0x650aa000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMD
, 0, C_SCAN_MOVPRFX
| C_MAX_ELEM
, 0),
4636 SVE2_INSN ("fcvtxnt", 0x640aa000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMD
, 0, 0),
4637 SVE2_INSNC ("flogb", 0x6518a000, 0xfff9e000, sve_size_hsd2
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD
, 0, C_SCAN_MOVPRFX
, 0),
4638 SVE2_INSNC ("fmaxnmp", 0x64148000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4639 SVE2_INSNC ("fmaxp", 0x64168000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4640 SVE2_INSNC ("fminnmp", 0x64158000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4641 SVE2_INSNC ("fminp", 0x64178000, 0xff3fe000, sve_size_hsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_HSD
, 0, C_SCAN_MOVPRFX
, 2),
4642 SVE2_INSNC ("fmlalb", 0x64a04000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4643 SVE2_INSNC ("fmlalb", 0x64a08000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4644 SVE2_INSNC ("fmlalt", 0x64a04400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4645 SVE2_INSNC ("fmlalt", 0x64a08400, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4646 SVE2_INSNC ("fmlslb", 0x64a06000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4647 SVE2_INSNC ("fmlslb", 0x64a0a000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4648 SVE2_INSNC ("fmlslt", 0x64a06400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4649 SVE2_INSNC ("fmlslt", 0x64a0a400, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4650 SVE2_INSN ("histcnt", 0x45a0c000, 0xffa0e000, sve_size_sd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_SD
, 0, 0),
4651 SVE2_INSN ("histseg", 0x4520a000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_BBB
, 0, 0),
4652 SVE2_INSN ("ldnt1b", 0x8400a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_SZS
, F_OD(1), 0),
4653 SVE2_INSN ("ldnt1b", 0xc400c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_DZD
, F_OD(1), 0),
4654 SVE2_INSN ("ldnt1d", 0xc580c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_DZD
, F_OD(1), 0),
4655 SVE2_INSN ("ldnt1h", 0x8480a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_SZS
, F_OD(1), 0),
4656 SVE2_INSN ("ldnt1h", 0xc480c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_DZD
, F_OD(1), 0),
4657 SVE2_INSN ("ldnt1sb", 0x84008000, 0xbfe0e000, sve_size_sd2
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_VZV_SD
, F_OD(1), 0),
4658 SVE2_INSN ("ldnt1sh", 0x84808000, 0xbfe0e000, sve_size_sd2
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_VZV_SD
, F_OD(1), 0),
4659 SVE2_INSN ("ldnt1sw", 0xc5008000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_DZD
, F_OD(1), 0),
4660 SVE2_INSN ("ldnt1w", 0x8500a000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_SZS
, F_OD(1), 0),
4661 SVE2_INSN ("ldnt1w", 0xc500c000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_DZD
, F_OD(1), 0),
4662 SVE2_INSN ("match", 0x45208000, 0xffa0e010, sve_size_bh
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_BH
, 0, 0),
4663 SVE2_INSNC ("mla", 0x44200800, 0xffa0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_22_INDEX
), OP_SVE_HHH
, 0, C_SCAN_MOVPRFX
, 0),
4664 SVE2_INSNC ("mla", 0x44a00800, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
), OP_SVE_SSS
, 0, C_SCAN_MOVPRFX
, 0),
4665 SVE2_INSNC ("mla", 0x44e00800, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
), OP_SVE_DDD
, 0, C_SCAN_MOVPRFX
, 0),
4666 SVE2_INSNC ("mls", 0x44200c00, 0xffa0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_22_INDEX
), OP_SVE_HHH
, 0, C_SCAN_MOVPRFX
, 0),
4667 SVE2_INSNC ("mls", 0x44a00c00, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
), OP_SVE_SSS
, 0, C_SCAN_MOVPRFX
, 0),
4668 SVE2_INSNC ("mls", 0x44e00c00, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
), OP_SVE_DDD
, 0, C_SCAN_MOVPRFX
, 0),
4669 SVE2_INSN ("mul", 0x4420f800, 0xffa0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_22_INDEX
), OP_SVE_HHH
, 0, 0),
4670 SVE2_INSN ("mul", 0x44a0f800, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
), OP_SVE_SSS
, 0, 0),
4671 SVE2_INSN ("mul", 0x44e0f800, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
), OP_SVE_DDD
, 0, 0),
4672 SVE2_INSN ("mul", 0x04206000, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4673 SVE2_INSNC ("nbsl", 0x04e03c00, 0xffe0fc00, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zd
, SVE_Zm_16
, SVE_Zn
), OP_SVE_DDDD
, 0, C_SCAN_MOVPRFX
, 1),
4674 SVE2_INSN ("nmatch", 0x45208010, 0xffa0e010, sve_size_bh
, 0, OP4 (SVE_Pd
, SVE_Pg3
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VZVV_BH
, 0, 0),
4675 SVE2_INSN ("pmul", 0x04206400, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_BBB
, 0, 0),
4676 SVE2_INSN ("raddhnb", 0x45206800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHS_HSD
, 0, 0),
4677 SVE2_INSN ("raddhnt", 0x45206c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHS_HSD
, 0, 0),
4678 SVE2_INSN ("rshrnb", 0x45201800, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4679 SVE2_INSN ("rshrnt", 0x45201c00, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4680 SVE2_INSN ("rsubhnb", 0x45207800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHS_HSD
, 0, 0),
4681 SVE2_INSN ("rsubhnt", 0x45207c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHS_HSD
, 0, 0),
4682 SVE2_INSNC ("saba", 0x4500f800, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4683 SVE2_INSNC ("sabalb", 0x4500c000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4684 SVE2_INSNC ("sabalt", 0x4500c400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4685 SVE2_INSN ("sabdlb", 0x45003000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4686 SVE2_INSN ("sabdlt", 0x45003400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4687 SVE2_INSNC ("sadalp", 0x4404a000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4688 SVE2_INSN ("saddlb", 0x45000000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4689 SVE2_INSN ("saddlbt", 0x45008000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4690 SVE2_INSN ("saddlt", 0x45000400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4691 SVE2_INSN ("saddwb", 0x45004000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS2
, 0, 0),
4692 SVE2_INSN ("saddwt", 0x45004400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS2
, 0, 0),
4693 SVE2_INSNC ("sbclb", 0x4580d000, 0xffa0fc00, sve_size_sd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_SD
, 0, C_SCAN_MOVPRFX
, 0),
4694 SVE2_INSNC ("sbclt", 0x4580d400, 0xffa0fc00, sve_size_sd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_SD
, 0, C_SCAN_MOVPRFX
, 0),
4695 SVE2_INSNC ("shadd", 0x44108000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4696 SVE2_INSN ("shrnb", 0x45201000, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4697 SVE2_INSN ("shrnt", 0x45201400, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4698 SVE2_INSNC ("shsub", 0x44128000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4699 SVE2_INSNC ("shsubr", 0x44168000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4700 SVE2_INSN ("sli", 0x4500f400, 0xff20fc00, sve_shift_tsz_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHLIMM_UNPRED
), OP_SVE_VVU_BHSD
, 0, 0),
4701 SVE2_INSNC ("smaxp", 0x4414a000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4702 SVE2_INSNC ("sminp", 0x4416a000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4703 SVE2_INSNC ("smlalb", 0x44a08000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4704 SVE2_INSNC ("smlalb", 0x44e08000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, C_SCAN_MOVPRFX
, 0),
4705 SVE2_INSNC ("smlalb", 0x44004000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4706 SVE2_INSNC ("smlalt", 0x44a08400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4707 SVE2_INSNC ("smlalt", 0x44e08400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, C_SCAN_MOVPRFX
, 0),
4708 SVE2_INSNC ("smlalt", 0x44004400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4709 SVE2_INSNC ("smlslb", 0x44a0a000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4710 SVE2_INSNC ("smlslb", 0x44e0a000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, C_SCAN_MOVPRFX
, 0),
4711 SVE2_INSNC ("smlslb", 0x44005000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4712 SVE2_INSNC ("smlslt", 0x44a0a400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4713 SVE2_INSNC ("smlslt", 0x44e0a400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, C_SCAN_MOVPRFX
, 0),
4714 SVE2_INSNC ("smlslt", 0x44005400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4715 SVE2_INSN ("smulh", 0x04206800, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4716 SVE2_INSN ("smullb", 0x44a0c000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, 0),
4717 SVE2_INSN ("smullb", 0x44e0c000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, 0),
4718 SVE2_INSN ("smullb", 0x45007000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4719 SVE2_INSN ("smullt", 0x44a0c400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, 0),
4720 SVE2_INSN ("smullt", 0x44e0c400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, 0),
4721 SVE2_INSN ("smullt", 0x45007400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4722 SVE2_INSN ("splice", 0x052d8000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_ZnxN
), OP_SVE_VUV_BHSD
, F_OD(2), 0),
4723 SVE2_INSNC ("sqabs", 0x4408a000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4724 SVE2_INSNC ("sqadd", 0x44188000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4725 SVE2_INSNC ("sqcadd", 0x4501d800, 0xff3ff800, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Zd
, SVE_Zn
, SVE_IMM_ROT3
), OP_SVE_VVVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4726 SVE2_INSNC ("sqdmlalb", 0x44a02000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4727 SVE2_INSNC ("sqdmlalb", 0x44e02000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, C_SCAN_MOVPRFX
, 0),
4728 SVE2_INSNC ("sqdmlalb", 0x44006000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4729 SVE2_INSNC ("sqdmlalbt", 0x44000800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4730 SVE2_INSNC ("sqdmlalt", 0x44a02400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4731 SVE2_INSNC ("sqdmlalt", 0x44e02400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, C_SCAN_MOVPRFX
, 0),
4732 SVE2_INSNC ("sqdmlalt", 0x44006400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4733 SVE2_INSNC ("sqdmlslb", 0x44a03000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4734 SVE2_INSNC ("sqdmlslb", 0x44e03000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, C_SCAN_MOVPRFX
, 0),
4735 SVE2_INSNC ("sqdmlslb", 0x44006800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4736 SVE2_INSNC ("sqdmlslbt", 0x44000c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4737 SVE2_INSNC ("sqdmlslt", 0x44a03400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4738 SVE2_INSNC ("sqdmlslt", 0x44e03400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, C_SCAN_MOVPRFX
, 0),
4739 SVE2_INSNC ("sqdmlslt", 0x44006c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4740 SVE2_INSN ("sqdmulh", 0x4420f000, 0xffa0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_22_INDEX
), OP_SVE_HHH
, 0, 0),
4741 SVE2_INSN ("sqdmulh", 0x44a0f000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
), OP_SVE_SSS
, 0, 0),
4742 SVE2_INSN ("sqdmulh", 0x44e0f000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
), OP_SVE_DDD
, 0, 0),
4743 SVE2_INSN ("sqdmulh", 0x04207000, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4744 SVE2_INSN ("sqdmullb", 0x44a0e000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, 0),
4745 SVE2_INSN ("sqdmullb", 0x44e0e000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, 0),
4746 SVE2_INSN ("sqdmullb", 0x45006000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4747 SVE2_INSN ("sqdmullt", 0x44a0e400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, 0),
4748 SVE2_INSN ("sqdmullt", 0x44e0e400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, 0),
4749 SVE2_INSN ("sqdmullt", 0x45006400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4750 SVE2_INSNC ("sqneg", 0x4409a000, 0xff3fe000, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4751 SVE2_INSNC ("sqrdcmlah", 0x44a07000, 0xffe0f000, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
, SVE_IMM_ROT2
), OP_SVE_HHHU
, 0, C_SCAN_MOVPRFX
, 0),
4752 SVE2_INSNC ("sqrdcmlah", 0x44e07000, 0xffe0f000, sve_misc
, 0, OP4 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
, SVE_IMM_ROT2
), OP_SVE_SSSU
, 0, C_SCAN_MOVPRFX
, 0),
4753 SVE2_INSNC ("sqrdcmlah", 0x44003000, 0xff20f000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
, SVE_IMM_ROT2
), OP_SVE_VVVU_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4754 SVE2_INSNC ("sqrdmlah", 0x44201000, 0xffa0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_22_INDEX
), OP_SVE_HHH
, 0, C_SCAN_MOVPRFX
, 0),
4755 SVE2_INSNC ("sqrdmlah", 0x44a01000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
), OP_SVE_SSS
, 0, C_SCAN_MOVPRFX
, 0),
4756 SVE2_INSNC ("sqrdmlah", 0x44e01000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
), OP_SVE_DDD
, 0, C_SCAN_MOVPRFX
, 0),
4757 SVE2_INSNC ("sqrdmlah", 0x44007000, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4758 SVE2_INSNC ("sqrdmlsh", 0x44201400, 0xffa0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_22_INDEX
), OP_SVE_HHH
, 0, C_SCAN_MOVPRFX
, 0),
4759 SVE2_INSNC ("sqrdmlsh", 0x44a01400, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
), OP_SVE_SSS
, 0, C_SCAN_MOVPRFX
, 0),
4760 SVE2_INSNC ("sqrdmlsh", 0x44e01400, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
), OP_SVE_DDD
, 0, C_SCAN_MOVPRFX
, 0),
4761 SVE2_INSNC ("sqrdmlsh", 0x44007400, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4762 SVE2_INSN ("sqrdmulh", 0x4420f400, 0xffa0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_22_INDEX
), OP_SVE_HHH
, 0, 0),
4763 SVE2_INSN ("sqrdmulh", 0x44a0f400, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_INDEX
), OP_SVE_SSS
, 0, 0),
4764 SVE2_INSN ("sqrdmulh", 0x44e0f400, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_INDEX
), OP_SVE_DDD
, 0, 0),
4765 SVE2_INSN ("sqrdmulh", 0x04207400, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4766 SVE2_INSNC ("sqrshl", 0x440a8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4767 SVE2_INSNC ("sqrshlr", 0x440e8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4768 SVE2_INSN ("sqrshrnb", 0x45202800, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4769 SVE2_INSN ("sqrshrnt", 0x45202c00, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4770 SVE2_INSN ("sqrshrunb", 0x45200800, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4771 SVE2_INSN ("sqrshrunt", 0x45200c00, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4772 SVE2_INSNC ("sqshl", 0x04068000, 0xff3fe000, sve_shift_pred
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_SHLIMM_PRED
), OP_SVE_VMVU_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4773 SVE2_INSNC ("sqshl", 0x44088000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4774 SVE2_INSNC ("sqshlr", 0x440c8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4775 SVE2_INSNC ("sqshlu", 0x040f8000, 0xff3fe000, sve_shift_pred
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_SHLIMM_PRED
), OP_SVE_VMVU_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4776 SVE2_INSN ("sqshrnb", 0x45202000, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4777 SVE2_INSN ("sqshrnt", 0x45202400, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4778 SVE2_INSN ("sqshrunb", 0x45200000, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4779 SVE2_INSN ("sqshrunt", 0x45200400, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4780 SVE2_INSNC ("sqsub", 0x441a8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4781 SVE2_INSNC ("sqsubr", 0x441e8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4782 SVE2_INSN ("sqxtnb", 0x45204000, 0xffa7fc00, sve_size_tsz_bhs
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_BHS_HSD
, 0, 0),
4783 SVE2_INSN ("sqxtnt", 0x45204400, 0xffa7fc00, sve_size_tsz_bhs
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_BHS_HSD
, 0, 0),
4784 SVE2_INSN ("sqxtunb", 0x45205000, 0xffa7fc00, sve_size_tsz_bhs
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_BHS_HSD
, 0, 0),
4785 SVE2_INSN ("sqxtunt", 0x45205400, 0xffa7fc00, sve_size_tsz_bhs
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_BHS_HSD
, 0, 0),
4786 SVE2_INSNC ("srhadd", 0x44148000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4787 SVE2_INSN ("sri", 0x4500f000, 0xff20fc00, sve_shift_tsz_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED
), OP_SVE_VVU_BHSD
, 0, 0),
4788 SVE2_INSNC ("srshl", 0x44028000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4789 SVE2_INSNC ("srshlr", 0x44068000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4790 SVE2_INSNC ("srshr", 0x040c8000, 0xff3fe000, sve_shift_pred
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_SHRIMM_PRED
), OP_SVE_VMVU_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4791 SVE2_INSNC ("srsra", 0x4500e800, 0xff20fc00, sve_shift_tsz_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4792 SVE2_INSN ("sshllb", 0x4500a000, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHLIMM_UNPRED_22
), OP_SVE_VVU_HSD_BHS
, 0, 0),
4793 SVE2_INSN ("sshllt", 0x4500a400, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHLIMM_UNPRED_22
), OP_SVE_VVU_HSD_BHS
, 0, 0),
4794 SVE2_INSNC ("ssra", 0x4500e000, 0xff20fc00, sve_shift_tsz_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4795 SVE2_INSN ("ssublb", 0x45001000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4796 SVE2_INSN ("ssublbt", 0x45008800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4797 SVE2_INSN ("ssublt", 0x45001400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4798 SVE2_INSN ("ssubltb", 0x45008c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4799 SVE2_INSN ("ssubwb", 0x45005000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS2
, 0, 0),
4800 SVE2_INSN ("ssubwt", 0x45005400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS2
, 0, 0),
4801 SVE2_INSN ("stnt1b", 0xe4402000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_SUS
, F_OD(1), 0),
4802 SVE2_INSN ("stnt1b", 0xe4002000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_DUD
, F_OD(1), 0),
4803 SVE2_INSN ("stnt1d", 0xe5802000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_DUD
, F_OD(1), 0),
4804 SVE2_INSN ("stnt1h", 0xe4c02000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_SUS
, F_OD(1), 0),
4805 SVE2_INSN ("stnt1h", 0xe4802000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_DUD
, F_OD(1), 0),
4806 SVE2_INSN ("stnt1w", 0xe5402000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_SUS
, F_OD(1), 0),
4807 SVE2_INSN ("stnt1w", 0xe5002000, 0xffe0e000, sve_misc
, 0, OP3 (SVE_ZtxN
, SVE_Pg3
, SVE_ADDR_ZX
), OP_SVE_DUD
, F_OD(1), 0),
4808 SVE2_INSN ("subhnb", 0x45207000, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHS_HSD
, 0, 0),
4809 SVE2_INSN ("subhnt", 0x45207400, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHS_HSD
, 0, 0),
4810 SVE2_INSNC ("suqadd", 0x441c8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4811 SVE2_INSN ("tbl", 0x05202800, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_ZnxN
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, F_OD(2), 0),
4812 SVE2_INSN ("tbx", 0x05202c00, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4813 SVE2_INSNC ("uaba", 0x4500fc00, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4814 SVE2_INSNC ("uabalb", 0x4500c800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4815 SVE2_INSNC ("uabalt", 0x4500cc00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4816 SVE2_INSN ("uabdlb", 0x45003800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4817 SVE2_INSN ("uabdlt", 0x45003c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4818 SVE2_INSNC ("uadalp", 0x4405a000, 0xff3fe000, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_VMV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4819 SVE2_INSN ("uaddlb", 0x45000800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4820 SVE2_INSN ("uaddlt", 0x45000c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4821 SVE2_INSN ("uaddwb", 0x45004800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS2
, 0, 0),
4822 SVE2_INSN ("uaddwt", 0x45004c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS2
, 0, 0),
4823 SVE2_INSNC ("uhadd", 0x44118000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4824 SVE2_INSNC ("uhsub", 0x44138000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4825 SVE2_INSNC ("uhsubr", 0x44178000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4826 SVE2_INSNC ("umaxp", 0x4415a000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4827 SVE2_INSNC ("uminp", 0x4417a000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4828 SVE2_INSNC ("umlalb", 0x44a09000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4829 SVE2_INSNC ("umlalb", 0x44e09000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, C_SCAN_MOVPRFX
, 0),
4830 SVE2_INSNC ("umlalb", 0x44004800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4831 SVE2_INSNC ("umlalt", 0x44a09400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4832 SVE2_INSNC ("umlalt", 0x44e09400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, C_SCAN_MOVPRFX
, 0),
4833 SVE2_INSNC ("umlalt", 0x44004c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4834 SVE2_INSNC ("umlslb", 0x44a0b000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4835 SVE2_INSNC ("umlslb", 0x44e0b000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, C_SCAN_MOVPRFX
, 0),
4836 SVE2_INSNC ("umlslb", 0x44005800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4837 SVE2_INSNC ("umlslt", 0x44a0b400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, C_SCAN_MOVPRFX
, 0),
4838 SVE2_INSNC ("umlslt", 0x44e0b400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, C_SCAN_MOVPRFX
, 0),
4839 SVE2_INSNC ("umlslt", 0x44005c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, C_SCAN_MOVPRFX
, 0),
4840 SVE2_INSN ("umulh", 0x04206c00, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4841 SVE2_INSN ("umullb", 0x44a0d000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, 0),
4842 SVE2_INSN ("umullb", 0x44e0d000, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, 0),
4843 SVE2_INSN ("umullb", 0x45007800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4844 SVE2_INSN ("umullt", 0x44a0d400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm3_11_INDEX
), OP_SVE_SHH
, 0, 0),
4845 SVE2_INSN ("umullt", 0x44e0d400, 0xffe0f400, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm4_11_INDEX
), OP_SVE_DSS
, 0, 0),
4846 SVE2_INSN ("umullt", 0x45007c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4847 SVE2_INSNC ("uqadd", 0x44198000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4848 SVE2_INSNC ("uqrshl", 0x440b8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4849 SVE2_INSNC ("uqrshlr", 0x440f8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4850 SVE2_INSN ("uqrshrnb", 0x45203800, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4851 SVE2_INSN ("uqrshrnt", 0x45203c00, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4852 SVE2_INSNC ("uqshl", 0x04078000, 0xff3fe000, sve_shift_pred
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_SHLIMM_PRED
), OP_SVE_VMVU_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4853 SVE2_INSNC ("uqshl", 0x44098000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4854 SVE2_INSNC ("uqshlr", 0x440d8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4855 SVE2_INSN ("uqshrnb", 0x45203000, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4856 SVE2_INSN ("uqshrnt", 0x45203400, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED_22
), OP_SVE_VVU_BHS_HSD
, 0, 0),
4857 SVE2_INSNC ("uqsub", 0x441b8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4858 SVE2_INSNC ("uqsubr", 0x441f8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4859 SVE2_INSN ("uqxtnb", 0x45204800, 0xffa7fc00, sve_size_tsz_bhs
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_BHS_HSD
, 0, 0),
4860 SVE2_INSN ("uqxtnt", 0x45204c00, 0xffa7fc00, sve_size_tsz_bhs
, 0, OP2 (SVE_Zd
, SVE_Zn
), OP_SVE_VV_BHS_HSD
, 0, 0),
4861 SVE2_INSNC ("urecpe", 0x4480a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMS
, 0, C_SCAN_MOVPRFX
, 0),
4862 SVE2_INSNC ("urhadd", 0x44158000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4863 SVE2_INSNC ("urshl", 0x44038000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4864 SVE2_INSNC ("urshlr", 0x44078000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4865 SVE2_INSNC ("urshr", 0x040d8000, 0xff3fe000, sve_shift_pred
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_SHRIMM_PRED
), OP_SVE_VMVU_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4866 SVE2_INSNC ("ursqrte", 0x4481a000, 0xffffe000, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Pg3
, SVE_Zn
), OP_SVE_SMS
, 0, C_SCAN_MOVPRFX
, 0),
4867 SVE2_INSNC ("ursra", 0x4500ec00, 0xff20fc00, sve_shift_tsz_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4868 SVE2_INSN ("ushllb", 0x4500a800, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHLIMM_UNPRED_22
), OP_SVE_VVU_HSD_BHS
, 0, 0),
4869 SVE2_INSN ("ushllt", 0x4500ac00, 0xffa0fc00, sve_shift_tsz_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHLIMM_UNPRED_22
), OP_SVE_VVU_HSD_BHS
, 0, 0),
4870 SVE2_INSNC ("usqadd", 0x441d8000, 0xff3fe000, sve_size_bhsd
, 0, OP4 (SVE_Zd
, SVE_Pg3
, SVE_Zd
, SVE_Zn
), OP_SVE_VMVV_BHSD
, 0, C_SCAN_MOVPRFX
, 2),
4871 SVE2_INSNC ("usra", 0x4500e400, 0xff20fc00, sve_shift_tsz_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED
), OP_SVE_VVU_BHSD
, 0, C_SCAN_MOVPRFX
, 0),
4872 SVE2_INSN ("usublb", 0x45001800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4873 SVE2_INSN ("usublt", 0x45001c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS
, 0, 0),
4874 SVE2_INSN ("usubwb", 0x45005800, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS2
, 0, 0),
4875 SVE2_INSN ("usubwt", 0x45005c00, 0xff20fc00, sve_size_hsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_HSD_BHS2
, 0, 0),
4876 SVE2_INSN ("whilege", 0x25200000, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VWW_BHSD
, 0, 0),
4877 SVE2_INSN ("whilege", 0x25201000, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VXX_BHSD
, 0, 0),
4878 SVE2_INSN ("whilegt", 0x25200010, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VWW_BHSD
, 0, 0),
4879 SVE2_INSN ("whilegt", 0x25201010, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VXX_BHSD
, 0, 0),
4880 SVE2_INSN ("whilehi", 0x25200810, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VWW_BHSD
, 0, 0),
4881 SVE2_INSN ("whilehi", 0x25201810, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VXX_BHSD
, 0, 0),
4882 SVE2_INSN ("whilehs", 0x25200800, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VWW_BHSD
, 0, 0),
4883 SVE2_INSN ("whilehs", 0x25201800, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VXX_BHSD
, 0, 0),
4884 SVE2_INSN ("whilerw", 0x25203010, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VXX_BHSD
, 0, 0),
4885 SVE2_INSN ("whilewr", 0x25203000, 0xff20fc10, sve_size_bhsd
, 0, OP3 (SVE_Pd
, Rn
, Rm
), OP_SVE_VXX_BHSD
, 0, 0),
4886 SVE2_INSNC ("xar", 0x04203400, 0xff20fc00, sve_shift_tsz_bhsd
, 0, OP4 (SVE_Zd
, SVE_Zd
, SVE_Zn
, SVE_SHRIMM_UNPRED
), OP_SVE_VVVU_BHSD
, 0, C_SCAN_MOVPRFX
, 1),
4887 /* SVE2_SM4 instructions. */
4888 SVE2SM4_INSN ("sm4e", 0x4523e000, 0xfffffc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_Zn
), OP_SVE_SSS
, 0, 1),
4889 SVE2SM4_INSN ("sm4ekey", 0x4520f000, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_SSS
, 0, 0),
4890 /* SVE2_AES instructions. */
4891 SVE2AES_INSN ("aesd", 0x4522e400, 0xfffffc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_Zn
), OP_SVE_BBB
, 0, 1),
4892 SVE2AES_INSN ("aese", 0x4522e000, 0xfffffc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zd
, SVE_Zn
), OP_SVE_BBB
, 0, 1),
4893 SVE2AES_INSN ("aesimc", 0x4520e400, 0xffffffe0, sve_misc
, 0, OP2 (SVE_Zd
, SVE_Zd
), OP_SVE_BB
, 0, 1),
4894 SVE2AES_INSN ("aesmc", 0x4520e000, 0xffffffe0, sve_misc
, 0, OP2 (SVE_Zd
, SVE_Zd
), OP_SVE_BB
, 0, 1),
4895 SVE2AES_INSN ("pmullb", 0x45006800, 0xff20fc00, sve_size_013
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_QHD_DBS
, 0, 0),
4896 SVE2AES_INSN ("pmullt", 0x45006c00, 0xff20fc00, sve_size_013
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_QHD_DBS
, 0, 0),
4897 /* SVE2_SHA3 instructions. */
4898 SVE2SHA3_INSN ("rax1", 0x4520f400, 0xffe0fc00, sve_misc
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_DDD
, 0, 0),
4899 /* SVE2_BITPERM instructions. */
4900 SVE2BITPERM_INSN ("bdep", 0x4500b400, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4901 SVE2BITPERM_INSN ("bext", 0x4500b000, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4902 SVE2BITPERM_INSN ("bgrp", 0x4500b800, 0xff20fc00, sve_size_bhsd
, 0, OP3 (SVE_Zd
, SVE_Zn
, SVE_Zm_16
), OP_SVE_VVV_BHSD
, 0, 0),
4904 /* SIMD Dot Product (optional in v8.2-A). */
4905 DOT_INSN ("udot", 0x2e009400, 0xbf20fc00, dotproduct
, OP3 (Vd
, Vn
, Vm
), QL_V3DOT
, F_SIZEQ
),
4906 DOT_INSN ("sdot", 0xe009400, 0xbf20fc00, dotproduct
, OP3 (Vd
, Vn
, Vm
), QL_V3DOT
, F_SIZEQ
),
4907 DOT_INSN ("udot", 0x2f00e000, 0xbf00f400, dotproduct
, OP3 (Vd
, Vn
, Em
), QL_V2DOT
, F_SIZEQ
),
4908 DOT_INSN ("sdot", 0xf00e000, 0xbf00f400, dotproduct
, OP3 (Vd
, Vn
, Em
), QL_V2DOT
, F_SIZEQ
),
4909 /* Crypto SHA2 (optional in ARMv8.2-a). */
4910 SHA2_INSN ("sha512h", 0xce608000, 0xffe0fc00, cryptosha2
, OP3 (Fd
, Fn
, Vm
), QL_SHA512UPT
, 0),
4911 SHA2_INSN ("sha512h2", 0xce608400, 0xffe0fc00, cryptosha2
, OP3 (Fd
, Fn
, Vm
), QL_SHA512UPT
, 0),
4912 SHA2_INSN ("sha512su0", 0xcec08000, 0xfffffc00, cryptosha2
, OP2 (Vd
, Vn
), QL_V2SAME2D
, 0),
4913 SHA2_INSN ("sha512su1", 0xce608800, 0xffe0fc00, cryptosha2
, OP3 (Vd
, Vn
, Vm
), QL_V3SAME2D
, 0),
4914 /* Crypto SHA3 (optional in ARMv8.2-a). */
4915 SHA3_INSN ("eor3", 0xce000000, 0xffe08000, cryptosha3
, OP4 (Vd
, Vn
, Vm
, Va
), QL_V4SAME16B
, 0),
4916 SHA3_INSN ("rax1", 0xce608c00, 0xffe0fc00, cryptosha3
, OP3 (Vd
, Vn
, Vm
), QL_V3SAME2D
, 0),
4917 SHA3_INSN ("xar", 0xce800000, 0xffe00000, cryptosha3
, OP4 (Vd
, Vn
, Vm
, IMM
), QL_XAR
, 0),
4918 SHA3_INSN ("bcax", 0xce200000, 0xffe08000, cryptosha3
, OP4 (Vd
, Vn
, Vm
, Va
), QL_V4SAME16B
, 0),
4919 /* Crypto SM3 (optional in ARMv8.2-a). */
4920 SM4_INSN ("sm3ss1", 0xce400000, 0xffe08000, cryptosm3
, OP4 (Vd
, Vn
, Vm
, Va
), QL_V4SAME4S
, 0),
4921 SM4_INSN ("sm3tt1a", 0xce408000, 0xffe0cc00, cryptosm3
, OP3 (Vd
, Vn
, Em
), QL_SM3TT
, 0),
4922 SM4_INSN ("sm3tt1b", 0xce408400, 0xffe0cc00, cryptosm3
, OP3 (Vd
, Vn
, Em
), QL_SM3TT
, 0),
4923 SM4_INSN ("sm3tt2a", 0xce408800, 0xffe0cc00, cryptosm3
, OP3 (Vd
, Vn
, Em
), QL_SM3TT
, 0),
4924 SM4_INSN ("sm3tt2b", 0xce408c00, 0xffe0cc00, cryptosm3
, OP3 (Vd
, Vn
, Em
), QL_SM3TT
, 0),
4925 SM4_INSN ("sm3partw1", 0xce60c000, 0xffe0fc00, cryptosm3
, OP3 (Vd
, Vn
, Vm
), QL_V3SAME4S
, 0),
4926 SM4_INSN ("sm3partw2", 0xce60c400, 0xffe0fc00, cryptosm3
, OP3 (Vd
, Vn
, Vm
), QL_V3SAME4S
, 0),
4927 /* Crypto SM4 (optional in ARMv8.2-a). */
4928 SM4_INSN ("sm4e", 0xcec08400, 0xfffffc00, cryptosm4
, OP2 (Vd
, Vn
), QL_V2SAME4S
, 0),
4929 SM4_INSN ("sm4ekey", 0xce60c800, 0xffe0fc00, cryptosm4
, OP3 (Vd
, Vn
, Vm
), QL_V3SAME4S
, 0),
4930 /* Crypto FP16 (optional in ARMv8.2-a). */
4931 FP16_V8_2_INSN ("fmlal", 0xe20ec00, 0xffa0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3FML2S
, 0),
4932 FP16_V8_2_INSN ("fmlsl", 0xea0ec00, 0xffa0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3FML2S
, 0),
4933 FP16_V8_2_INSN ("fmlal2", 0x2e20cc00, 0xffa0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3FML2S
, 0),
4934 FP16_V8_2_INSN ("fmlsl2", 0x2ea0cc00, 0xffa0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3FML2S
, 0),
4936 FP16_V8_2_INSN ("fmlal", 0x4e20ec00, 0xffa0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3FML4S
, 0),
4937 FP16_V8_2_INSN ("fmlsl", 0x4ea0ec00, 0xffa0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3FML4S
, 0),
4938 FP16_V8_2_INSN ("fmlal2", 0x6e20cc00, 0xffa0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3FML4S
, 0),
4939 FP16_V8_2_INSN ("fmlsl2", 0x6ea0cc00, 0xffa0fc00, asimdsame
, OP3 (Vd
, Vn
, Vm
), QL_V3FML4S
, 0),
4941 FP16_V8_2_INSN ("fmlal", 0xf800000, 0xffc0f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_V2FML2S
, 0),
4942 FP16_V8_2_INSN ("fmlsl", 0xf804000, 0xffc0f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_V2FML2S
, 0),
4943 FP16_V8_2_INSN ("fmlal2", 0x2f808000, 0xffc0f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_V2FML2S
, 0),
4944 FP16_V8_2_INSN ("fmlsl2", 0x2f80c000, 0xffc0f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_V2FML2S
, 0),
4946 FP16_V8_2_INSN ("fmlal", 0x4f800000, 0xffc0f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_V2FML4S
, 0),
4947 FP16_V8_2_INSN ("fmlsl", 0x4f804000, 0xffc0f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_V2FML4S
, 0),
4948 FP16_V8_2_INSN ("fmlal2", 0x6f808000, 0xffc0f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_V2FML4S
, 0),
4949 FP16_V8_2_INSN ("fmlsl2", 0x6f80c000, 0xffc0f400, asimdelem
, OP3 (Vd
, Vn
, Em16
), QL_V2FML4S
, 0),
4950 /* System extensions ARMv8.4-a. */
4951 V8_4_INSN ("cfinv", 0xd500401f, 0xffffffff, ic_system
, OP0 (), {}, 0),
4952 V8_4_INSN ("rmif", 0xba000400, 0xffe07c10, ic_system
, OP3 (Rn
, IMM_2
, MASK
), QL_RMIF
, 0),
4953 V8_4_INSN ("setf8", 0x3a00080d, 0xfffffc1f, ic_system
, OP1 (Rn
), QL_SETF
, 0),
4954 V8_4_INSN ("setf16", 0x3a00480d, 0xfffffc1f, ic_system
, OP1 (Rn
), QL_SETF
, 0),
4955 /* Memory access instructions ARMv8.4-a. */
4956 V8_4_INSN ("stlurb" , 0x19000000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLW
, 0),
4957 V8_4_INSN ("ldapurb", 0x19400000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLW
, 0),
4958 V8_4_INSN ("ldapursb", 0x19c00000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLW
, 0),
4959 V8_4_INSN ("ldapursb", 0x19800000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLX
, 0),
4960 V8_4_INSN ("stlurh", 0x59000000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLW
, 0),
4961 V8_4_INSN ("ldapurh", 0x59400000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLW
, 0),
4962 V8_4_INSN ("ldapursh", 0x59c00000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLW
, 0),
4963 V8_4_INSN ("ldapursh", 0x59800000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLX
, 0),
4964 V8_4_INSN ("stlur", 0x99000000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLW
, 0),
4965 V8_4_INSN ("ldapur", 0x99400000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLW
, 0),
4966 V8_4_INSN ("ldapursw", 0x99800000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLX
, 0),
4967 V8_4_INSN ("stlur", 0xd9000000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLX
, 0),
4968 V8_4_INSN ("ldapur", 0xd9400000, 0xffe00c00, ldst_unscaled
, OP2 (Rt
, ADDR_OFFSET
), QL_STLX
, 0),
4969 {0, 0, 0, 0, 0, 0, {}, {}, 0, 0, 0, NULL
},
4972 #ifdef AARCH64_OPERANDS
4973 #undef AARCH64_OPERANDS
4976 /* Macro-based operand decription; this will be fed into aarch64-gen for it
4977 to generate the structure aarch64_operands and the function
4978 aarch64_insert_operand and aarch64_extract_operand.
4980 These inserters and extracters in the description execute the conversion
4981 between the aarch64_opnd_info and value in the operand-related instruction
4984 /* Y expects arguments (left to right) to be operand class, inserter/extractor
4985 name suffix, operand name, flags, related bitfield(s) and description.
4986 X only differs from Y by having the operand inserter and extractor names
4987 listed separately. */
4989 #define AARCH64_OPERANDS \
4990 Y(INT_REG, regno, "Rd", 0, F(FLD_Rd), "an integer register") \
4991 Y(INT_REG, regno, "Rn", 0, F(FLD_Rn), "an integer register") \
4992 Y(INT_REG, regno, "Rm", 0, F(FLD_Rm), "an integer register") \
4993 Y(INT_REG, regno, "Rt", 0, F(FLD_Rt), "an integer register") \
4994 Y(INT_REG, regno, "Rt2", 0, F(FLD_Rt2), "an integer register") \
4995 Y(INT_REG, regno, "Rt_SP", OPD_F_MAYBE_SP, F(FLD_Rt), \
4996 "an integer or stack pointer register") \
4997 Y(INT_REG, regno, "Rs", 0, F(FLD_Rs), "an integer register") \
4998 Y(INT_REG, regno, "Ra", 0, F(FLD_Ra), "an integer register") \
4999 X(INT_REG, ins_regno, ext_regrt_sysins, "Rt_SYS", 0, F(FLD_Rt), \
5000 "an integer register") \
5001 Y(INT_REG, regno, "Rd_SP", OPD_F_MAYBE_SP, F(FLD_Rd), \
5002 "an integer or stack pointer register") \
5003 Y(INT_REG, regno, "Rn_SP", OPD_F_MAYBE_SP, F(FLD_Rn), \
5004 "an integer or stack pointer register") \
5005 Y(INT_REG, regno, "Rm_SP", OPD_F_MAYBE_SP, F(FLD_Rm), \
5006 "an integer or stack pointer register") \
5007 X(INT_REG, 0, ext_regno_pair, "PAIRREG", 0, F(), \
5008 "the second reg of a pair") \
5009 Y(MODIFIED_REG, reg_extended, "Rm_EXT", 0, F(), \
5010 "an integer register with optional extension") \
5011 Y(MODIFIED_REG, reg_shifted, "Rm_SFT", 0, F(), \
5012 "an integer register with optional shift") \
5013 Y(FP_REG, regno, "Fd", 0, F(FLD_Rd), "a floating-point register") \
5014 Y(FP_REG, regno, "Fn", 0, F(FLD_Rn), "a floating-point register") \
5015 Y(FP_REG, regno, "Fm", 0, F(FLD_Rm), "a floating-point register") \
5016 Y(FP_REG, regno, "Fa", 0, F(FLD_Ra), "a floating-point register") \
5017 Y(FP_REG, ft, "Ft", 0, F(FLD_Rt), "a floating-point register") \
5018 Y(FP_REG, regno, "Ft2", 0, F(FLD_Rt2), "a floating-point register") \
5019 Y(SISD_REG, regno, "Sd", 0, F(FLD_Rd), "a SIMD scalar register") \
5020 Y(SISD_REG, regno, "Sn", 0, F(FLD_Rn), "a SIMD scalar register") \
5021 Y(SISD_REG, regno, "Sm", 0, F(FLD_Rm), "a SIMD scalar register") \
5022 Y(SIMD_REG, regno, "Va", 0, F(FLD_Ra), "a SIMD vector register") \
5023 Y(SIMD_REG, regno, "Vd", 0, F(FLD_Rd), "a SIMD vector register") \
5024 Y(SIMD_REG, regno, "Vn", 0, F(FLD_Rn), "a SIMD vector register") \
5025 Y(SIMD_REG, regno, "Vm", 0, F(FLD_Rm), "a SIMD vector register") \
5026 Y(FP_REG, regno, "VdD1", 0, F(FLD_Rd), \
5027 "the top half of a 128-bit FP/SIMD register") \
5028 Y(FP_REG, regno, "VnD1", 0, F(FLD_Rn), \
5029 "the top half of a 128-bit FP/SIMD register") \
5030 Y(SIMD_ELEMENT, reglane, "Ed", 0, F(FLD_Rd), \
5031 "a SIMD vector element") \
5032 Y(SIMD_ELEMENT, reglane, "En", 0, F(FLD_Rn), \
5033 "a SIMD vector element") \
5034 Y(SIMD_ELEMENT, reglane, "Em", 0, F(FLD_Rm), \
5035 "a SIMD vector element") \
5036 Y(SIMD_ELEMENT, reglane, "Em16", 0, F(FLD_Rm), \
5037 "a SIMD vector element limited to V0-V15") \
5038 Y(SIMD_REGLIST, reglist, "LVn", 0, F(FLD_Rn), \
5039 "a SIMD vector register list") \
5040 Y(SIMD_REGLIST, ldst_reglist, "LVt", 0, F(), \
5041 "a SIMD vector register list") \
5042 Y(SIMD_REGLIST, ldst_reglist_r, "LVt_AL", 0, F(), \
5043 "a SIMD vector register list") \
5044 Y(SIMD_REGLIST, ldst_elemlist, "LEt", 0, F(), \
5045 "a SIMD vector element list") \
5046 Y(IMMEDIATE, imm, "CRn", 0, F(FLD_CRn), \
5047 "a 4-bit opcode field named for historical reasons C0 - C15") \
5048 Y(IMMEDIATE, imm, "CRm", 0, F(FLD_CRm), \
5049 "a 4-bit opcode field named for historical reasons C0 - C15") \
5050 Y(IMMEDIATE, imm, "IDX", 0, F(FLD_imm4), \
5051 "an immediate as the index of the least significant byte") \
5052 Y(IMMEDIATE, imm, "MASK", 0, F(FLD_imm4_2), \
5053 "an immediate as the index of the least significant byte") \
5054 Y(IMMEDIATE, advsimd_imm_shift, "IMM_VLSL", 0, F(), \
5055 "a left shift amount for an AdvSIMD register") \
5056 Y(IMMEDIATE, advsimd_imm_shift, "IMM_VLSR", 0, F(), \
5057 "a right shift amount for an AdvSIMD register") \
5058 Y(IMMEDIATE, advsimd_imm_modified, "SIMD_IMM", 0, F(), \
5060 Y(IMMEDIATE, advsimd_imm_modified, "SIMD_IMM_SFT", 0, F(), \
5061 "an 8-bit unsigned immediate with optional shift") \
5062 Y(IMMEDIATE, advsimd_imm_modified, "SIMD_FPIMM", 0, F(), \
5063 "an 8-bit floating-point constant") \
5064 X(IMMEDIATE, 0, ext_shll_imm, "SHLL_IMM", 0, F(), \
5065 "an immediate shift amount of 8, 16 or 32") \
5066 X(IMMEDIATE, 0, 0, "IMM0", 0, F(), "0") \
5067 X(IMMEDIATE, 0, 0, "FPIMM0", 0, F(), "0.0") \
5068 Y(IMMEDIATE, fpimm, "FPIMM", 0, F(FLD_imm8), \
5069 "an 8-bit floating-point constant") \
5070 Y(IMMEDIATE, imm, "IMMR", 0, F(FLD_immr), \
5071 "the right rotate amount") \
5072 Y(IMMEDIATE, imm, "IMMS", 0, F(FLD_imm6), \
5073 "the leftmost bit number to be moved from the source") \
5074 Y(IMMEDIATE, imm, "WIDTH", 0, F(FLD_imm6), \
5075 "the width of the bit-field") \
5076 Y(IMMEDIATE, imm, "IMM", 0, F(FLD_imm6), "an immediate") \
5077 Y(IMMEDIATE, imm, "IMM_2", 0, F(FLD_imm6_2), "an immediate") \
5078 Y(IMMEDIATE, imm, "UIMM3_OP1", 0, F(FLD_op1), \
5079 "a 3-bit unsigned immediate") \
5080 Y(IMMEDIATE, imm, "UIMM3_OP2", 0, F(FLD_op2), \
5081 "a 3-bit unsigned immediate") \
5082 Y(IMMEDIATE, imm, "UIMM4", 0, F(FLD_CRm), \
5083 "a 4-bit unsigned immediate") \
5084 Y(IMMEDIATE, imm, "UIMM4_ADDG", 0, F(FLD_imm4_3), \
5085 "a 4-bit unsigned Logical Address Tag modifier") \
5086 Y(IMMEDIATE, imm, "UIMM7", 0, F(FLD_CRm, FLD_op2), \
5087 "a 7-bit unsigned immediate") \
5088 Y(IMMEDIATE, imm, "UIMM10", OPD_F_SHIFT_BY_4, F(FLD_immr), \
5089 "a 10-bit unsigned multiple of 16") \
5090 Y(IMMEDIATE, imm, "BIT_NUM", 0, F(FLD_b5, FLD_b40), \
5091 "the bit number to be tested") \
5092 Y(IMMEDIATE, imm, "EXCEPTION", 0, F(FLD_imm16), \
5093 "a 16-bit unsigned immediate") \
5094 Y(IMMEDIATE, imm, "CCMP_IMM", 0, F(FLD_imm5), \
5095 "a 5-bit unsigned immediate") \
5096 Y(IMMEDIATE, imm, "SIMM5", OPD_F_SEXT, F(FLD_imm5), \
5097 "a 5-bit signed immediate") \
5098 Y(IMMEDIATE, imm, "NZCV", 0, F(FLD_nzcv), \
5099 "a flag bit specifier giving an alternative value for each flag") \
5100 Y(IMMEDIATE, limm, "LIMM", 0, F(FLD_N,FLD_immr,FLD_imms), \
5101 "Logical immediate") \
5102 Y(IMMEDIATE, aimm, "AIMM", 0, F(FLD_shift,FLD_imm12), \
5103 "a 12-bit unsigned immediate with optional left shift of 12 bits")\
5104 Y(IMMEDIATE, imm_half, "HALF", 0, F(FLD_imm16), \
5105 "a 16-bit immediate with optional left shift") \
5106 Y(IMMEDIATE, fbits, "FBITS", 0, F(FLD_scale), \
5107 "the number of bits after the binary point in the fixed-point value")\
5108 X(IMMEDIATE, 0, 0, "IMM_MOV", 0, F(), "an immediate") \
5109 Y(IMMEDIATE, imm_rotate2, "IMM_ROT1", 0, F(FLD_rotate1), \
5110 "a 2-bit rotation specifier for complex arithmetic operations") \
5111 Y(IMMEDIATE, imm_rotate2, "IMM_ROT2", 0, F(FLD_rotate2), \
5112 "a 2-bit rotation specifier for complex arithmetic operations") \
5113 Y(IMMEDIATE, imm_rotate1, "IMM_ROT3", 0, F(FLD_rotate3), \
5114 "a 1-bit rotation specifier for complex arithmetic operations") \
5115 Y(COND, cond, "COND", 0, F(), "a condition") \
5116 Y(COND, cond, "COND1", 0, F(), \
5117 "one of the standard conditions, excluding AL and NV.") \
5118 X(ADDRESS, 0, ext_imm, "ADDR_ADRP", OPD_F_SEXT, F(FLD_immhi, FLD_immlo),\
5119 "21-bit PC-relative address of a 4KB page") \
5120 Y(ADDRESS, imm, "ADDR_PCREL14", OPD_F_SEXT | OPD_F_SHIFT_BY_2, \
5121 F(FLD_imm14), "14-bit PC-relative address") \
5122 Y(ADDRESS, imm, "ADDR_PCREL19", OPD_F_SEXT | OPD_F_SHIFT_BY_2, \
5123 F(FLD_imm19), "19-bit PC-relative address") \
5124 Y(ADDRESS, imm, "ADDR_PCREL21", OPD_F_SEXT, F(FLD_immhi,FLD_immlo), \
5125 "21-bit PC-relative address") \
5126 Y(ADDRESS, imm, "ADDR_PCREL26", OPD_F_SEXT | OPD_F_SHIFT_BY_2, \
5127 F(FLD_imm26), "26-bit PC-relative address") \
5128 Y(ADDRESS, addr_simple, "ADDR_SIMPLE", 0, F(), \
5129 "an address with base register (no offset)") \
5130 Y(ADDRESS, addr_regoff, "ADDR_REGOFF", 0, F(), \
5131 "an address with register offset") \
5132 Y(ADDRESS, addr_simm, "ADDR_SIMM7", 0, F(FLD_imm7,FLD_index2), \
5133 "an address with 7-bit signed immediate offset") \
5134 Y(ADDRESS, addr_simm, "ADDR_SIMM9", 0, F(FLD_imm9,FLD_index), \
5135 "an address with 9-bit signed immediate offset") \
5136 Y(ADDRESS, addr_simm, "ADDR_SIMM9_2", 0, F(FLD_imm9,FLD_index), \
5137 "an address with 9-bit negative or unaligned immediate offset") \
5138 Y(ADDRESS, addr_simm10, "ADDR_SIMM10", 0, F(FLD_Rn,FLD_S_imm10,FLD_imm9,FLD_index),\
5139 "an address with 10-bit scaled, signed immediate offset") \
5140 Y(ADDRESS, addr_simm, "ADDR_SIMM11", 0, F(FLD_imm7,FLD_index2),\
5141 "an address with 11-bit signed immediate (multiple of 16) offset")\
5142 Y(ADDRESS, addr_uimm12, "ADDR_UIMM12", 0, F(FLD_Rn,FLD_imm12), \
5143 "an address with scaled, unsigned immediate offset") \
5144 Y(ADDRESS, addr_simm, "ADDR_SIMM13", 0, F(FLD_imm9,FLD_index),\
5145 "an address with 13-bit signed immediate (multiple of 16) offset")\
5146 Y(ADDRESS, addr_simple, "SIMD_ADDR_SIMPLE", 0, F(), \
5147 "an address with base register (no offset)") \
5148 Y(ADDRESS, addr_offset, "ADDR_OFFSET", 0, F(FLD_Rn,FLD_imm9,FLD_index),\
5149 "an address with an optional 8-bit signed immediate offset") \
5150 Y(ADDRESS, simd_addr_post, "SIMD_ADDR_POST", 0, F(), \
5151 "a post-indexed address with immediate or register increment") \
5152 Y(SYSTEM, sysreg, "SYSREG", 0, F(), "a system register") \
5153 Y(SYSTEM, pstatefield, "PSTATEFIELD", 0, F(), \
5154 "a PSTATE field name") \
5155 Y(SYSTEM, sysins_op, "SYSREG_AT", 0, F(), \
5156 "an address translation operation specifier") \
5157 Y(SYSTEM, sysins_op, "SYSREG_DC", 0, F(), \
5158 "a data cache maintenance operation specifier") \
5159 Y(SYSTEM, sysins_op, "SYSREG_IC", 0, F(), \
5160 "an instruction cache maintenance operation specifier") \
5161 Y(SYSTEM, sysins_op, "SYSREG_TLBI", 0, F(), \
5162 "a TBL invalidation operation specifier") \
5163 Y(SYSTEM, sysins_op, "SYSREG_SR", 0, F(), \
5164 "a Speculation Restriction option name (RCTX)") \
5165 Y(SYSTEM, barrier, "BARRIER", 0, F(), \
5166 "a barrier option name") \
5167 Y(SYSTEM, barrier, "BARRIER_ISB", 0, F(), \
5168 "the ISB option name SY or an optional 4-bit unsigned immediate") \
5169 Y(SYSTEM, prfop, "PRFOP", 0, F(), \
5170 "a prefetch operation specifier") \
5171 Y(SYSTEM, hint, "BARRIER_PSB", 0, F (), \
5172 "the PSB option name CSYNC") \
5173 Y(SYSTEM, hint, "BTI", 0, F (), \
5174 "BTI targets j/c/jc") \
5175 Y(ADDRESS, sve_addr_ri_s4, "SVE_ADDR_RI_S4x16", \
5176 4 << OPD_F_OD_LSB, F(FLD_Rn), \
5177 "an address with a 4-bit signed offset, multiplied by 16") \
5178 Y(ADDRESS, sve_addr_ri_s4xvl, "SVE_ADDR_RI_S4xVL", \
5179 0 << OPD_F_OD_LSB, F(FLD_Rn), \
5180 "an address with a 4-bit signed offset, multiplied by VL") \
5181 Y(ADDRESS, sve_addr_ri_s4xvl, "SVE_ADDR_RI_S4x2xVL", \
5182 1 << OPD_F_OD_LSB, F(FLD_Rn), \
5183 "an address with a 4-bit signed offset, multiplied by 2*VL") \
5184 Y(ADDRESS, sve_addr_ri_s4xvl, "SVE_ADDR_RI_S4x3xVL", \
5185 2 << OPD_F_OD_LSB, F(FLD_Rn), \
5186 "an address with a 4-bit signed offset, multiplied by 3*VL") \
5187 Y(ADDRESS, sve_addr_ri_s4xvl, "SVE_ADDR_RI_S4x4xVL", \
5188 3 << OPD_F_OD_LSB, F(FLD_Rn), \
5189 "an address with a 4-bit signed offset, multiplied by 4*VL") \
5190 Y(ADDRESS, sve_addr_ri_s6xvl, "SVE_ADDR_RI_S6xVL", \
5191 0 << OPD_F_OD_LSB, F(FLD_Rn), \
5192 "an address with a 6-bit signed offset, multiplied by VL") \
5193 Y(ADDRESS, sve_addr_ri_s9xvl, "SVE_ADDR_RI_S9xVL", \
5194 0 << OPD_F_OD_LSB, F(FLD_Rn), \
5195 "an address with a 9-bit signed offset, multiplied by VL") \
5196 Y(ADDRESS, sve_addr_ri_u6, "SVE_ADDR_RI_U6", 0 << OPD_F_OD_LSB, \
5197 F(FLD_Rn), "an address with a 6-bit unsigned offset") \
5198 Y(ADDRESS, sve_addr_ri_u6, "SVE_ADDR_RI_U6x2", 1 << OPD_F_OD_LSB, \
5200 "an address with a 6-bit unsigned offset, multiplied by 2") \
5201 Y(ADDRESS, sve_addr_ri_u6, "SVE_ADDR_RI_U6x4", 2 << OPD_F_OD_LSB, \
5203 "an address with a 6-bit unsigned offset, multiplied by 4") \
5204 Y(ADDRESS, sve_addr_ri_u6, "SVE_ADDR_RI_U6x8", 3 << OPD_F_OD_LSB, \
5206 "an address with a 6-bit unsigned offset, multiplied by 8") \
5207 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_R", 0 << OPD_F_OD_LSB, \
5208 F(FLD_Rn,FLD_Rm), "an address with an optional scalar register offset") \
5209 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_RR", 0 << OPD_F_OD_LSB, \
5210 F(FLD_Rn,FLD_Rm), "an address with a scalar register offset") \
5211 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_RR_LSL1", 1 << OPD_F_OD_LSB, \
5212 F(FLD_Rn,FLD_Rm), "an address with a scalar register offset") \
5213 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_RR_LSL2", 2 << OPD_F_OD_LSB, \
5214 F(FLD_Rn,FLD_Rm), "an address with a scalar register offset") \
5215 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_RR_LSL3", 3 << OPD_F_OD_LSB, \
5216 F(FLD_Rn,FLD_Rm), "an address with a scalar register offset") \
5217 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_RX", \
5218 (0 << OPD_F_OD_LSB) | OPD_F_NO_ZR, F(FLD_Rn,FLD_Rm), \
5219 "an address with a scalar register offset") \
5220 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_RX_LSL1", \
5221 (1 << OPD_F_OD_LSB) | OPD_F_NO_ZR, F(FLD_Rn,FLD_Rm), \
5222 "an address with a scalar register offset") \
5223 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_RX_LSL2", \
5224 (2 << OPD_F_OD_LSB) | OPD_F_NO_ZR, F(FLD_Rn,FLD_Rm), \
5225 "an address with a scalar register offset") \
5226 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_RX_LSL3", \
5227 (3 << OPD_F_OD_LSB) | OPD_F_NO_ZR, F(FLD_Rn,FLD_Rm), \
5228 "an address with a scalar register offset") \
5229 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_ZX", \
5230 0 << OPD_F_OD_LSB , F(FLD_SVE_Zn,FLD_Rm), \
5231 "vector of address with a scalar register offset") \
5232 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_RZ", 0 << OPD_F_OD_LSB, \
5233 F(FLD_Rn,FLD_SVE_Zm_16), \
5234 "an address with a vector register offset") \
5235 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_RZ_LSL1", 1 << OPD_F_OD_LSB, \
5236 F(FLD_Rn,FLD_SVE_Zm_16), \
5237 "an address with a vector register offset") \
5238 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_RZ_LSL2", 2 << OPD_F_OD_LSB, \
5239 F(FLD_Rn,FLD_SVE_Zm_16), \
5240 "an address with a vector register offset") \
5241 Y(ADDRESS, sve_addr_rr_lsl, "SVE_ADDR_RZ_LSL3", 3 << OPD_F_OD_LSB, \
5242 F(FLD_Rn,FLD_SVE_Zm_16), \
5243 "an address with a vector register offset") \
5244 Y(ADDRESS, sve_addr_rz_xtw, "SVE_ADDR_RZ_XTW_14", \
5245 0 << OPD_F_OD_LSB, F(FLD_Rn,FLD_SVE_Zm_16,FLD_SVE_xs_14), \
5246 "an address with a vector register offset") \
5247 Y(ADDRESS, sve_addr_rz_xtw, "SVE_ADDR_RZ_XTW_22", \
5248 0 << OPD_F_OD_LSB, F(FLD_Rn,FLD_SVE_Zm_16,FLD_SVE_xs_22), \
5249 "an address with a vector register offset") \
5250 Y(ADDRESS, sve_addr_rz_xtw, "SVE_ADDR_RZ_XTW1_14", \
5251 1 << OPD_F_OD_LSB, F(FLD_Rn,FLD_SVE_Zm_16,FLD_SVE_xs_14), \
5252 "an address with a vector register offset") \
5253 Y(ADDRESS, sve_addr_rz_xtw, "SVE_ADDR_RZ_XTW1_22", \
5254 1 << OPD_F_OD_LSB, F(FLD_Rn,FLD_SVE_Zm_16,FLD_SVE_xs_22), \
5255 "an address with a vector register offset") \
5256 Y(ADDRESS, sve_addr_rz_xtw, "SVE_ADDR_RZ_XTW2_14", \
5257 2 << OPD_F_OD_LSB, F(FLD_Rn,FLD_SVE_Zm_16,FLD_SVE_xs_14), \
5258 "an address with a vector register offset") \
5259 Y(ADDRESS, sve_addr_rz_xtw, "SVE_ADDR_RZ_XTW2_22", \
5260 2 << OPD_F_OD_LSB, F(FLD_Rn,FLD_SVE_Zm_16,FLD_SVE_xs_22), \
5261 "an address with a vector register offset") \
5262 Y(ADDRESS, sve_addr_rz_xtw, "SVE_ADDR_RZ_XTW3_14", \
5263 3 << OPD_F_OD_LSB, F(FLD_Rn,FLD_SVE_Zm_16,FLD_SVE_xs_14), \
5264 "an address with a vector register offset") \
5265 Y(ADDRESS, sve_addr_rz_xtw, "SVE_ADDR_RZ_XTW3_22", \
5266 3 << OPD_F_OD_LSB, F(FLD_Rn,FLD_SVE_Zm_16,FLD_SVE_xs_22), \
5267 "an address with a vector register offset") \
5268 Y(ADDRESS, sve_addr_zi_u5, "SVE_ADDR_ZI_U5", 0 << OPD_F_OD_LSB, \
5269 F(FLD_SVE_Zn), "an address with a 5-bit unsigned offset") \
5270 Y(ADDRESS, sve_addr_zi_u5, "SVE_ADDR_ZI_U5x2", 1 << OPD_F_OD_LSB, \
5272 "an address with a 5-bit unsigned offset, multiplied by 2") \
5273 Y(ADDRESS, sve_addr_zi_u5, "SVE_ADDR_ZI_U5x4", 2 << OPD_F_OD_LSB, \
5275 "an address with a 5-bit unsigned offset, multiplied by 4") \
5276 Y(ADDRESS, sve_addr_zi_u5, "SVE_ADDR_ZI_U5x8", 3 << OPD_F_OD_LSB, \
5278 "an address with a 5-bit unsigned offset, multiplied by 8") \
5279 Y(ADDRESS, sve_addr_zz_lsl, "SVE_ADDR_ZZ_LSL", 0, \
5280 F(FLD_SVE_Zn,FLD_SVE_Zm_16), \
5281 "an address with a vector register offset") \
5282 Y(ADDRESS, sve_addr_zz_sxtw, "SVE_ADDR_ZZ_SXTW", 0, \
5283 F(FLD_SVE_Zn,FLD_SVE_Zm_16), \
5284 "an address with a vector register offset") \
5285 Y(ADDRESS, sve_addr_zz_uxtw, "SVE_ADDR_ZZ_UXTW", 0, \
5286 F(FLD_SVE_Zn,FLD_SVE_Zm_16), \
5287 "an address with a vector register offset") \
5288 Y(IMMEDIATE, sve_aimm, "SVE_AIMM", 0, F(FLD_SVE_imm9), \
5289 "a 9-bit unsigned arithmetic operand") \
5290 Y(IMMEDIATE, sve_asimm, "SVE_ASIMM", 0, F(FLD_SVE_imm9), \
5291 "a 9-bit signed arithmetic operand") \
5292 Y(IMMEDIATE, fpimm, "SVE_FPIMM8", 0, F(FLD_SVE_imm8), \
5293 "an 8-bit floating-point immediate") \
5294 Y(IMMEDIATE, sve_float_half_one, "SVE_I1_HALF_ONE", 0, \
5295 F(FLD_SVE_i1), "either 0.5 or 1.0") \
5296 Y(IMMEDIATE, sve_float_half_two, "SVE_I1_HALF_TWO", 0, \
5297 F(FLD_SVE_i1), "either 0.5 or 2.0") \
5298 Y(IMMEDIATE, sve_float_zero_one, "SVE_I1_ZERO_ONE", 0, \
5299 F(FLD_SVE_i1), "either 0.0 or 1.0") \
5300 Y(IMMEDIATE, imm_rotate1, "SVE_IMM_ROT1", 0, F(FLD_SVE_rot1), \
5301 "a 1-bit rotation specifier for complex arithmetic operations") \
5302 Y(IMMEDIATE, imm_rotate2, "SVE_IMM_ROT2", 0, F(FLD_SVE_rot2), \
5303 "a 2-bit rotation specifier for complex arithmetic operations") \
5304 Y(IMMEDIATE, imm_rotate1, "SVE_IMM_ROT3", 0, F(FLD_SVE_rot3), \
5305 "a 1-bit rotation specifier for complex arithmetic operations") \
5306 Y(IMMEDIATE, inv_limm, "SVE_INV_LIMM", 0, \
5307 F(FLD_SVE_N,FLD_SVE_immr,FLD_SVE_imms), \
5308 "an inverted 13-bit logical immediate") \
5309 Y(IMMEDIATE, limm, "SVE_LIMM", 0, \
5310 F(FLD_SVE_N,FLD_SVE_immr,FLD_SVE_imms), \
5311 "a 13-bit logical immediate") \
5312 Y(IMMEDIATE, sve_limm_mov, "SVE_LIMM_MOV", 0, \
5313 F(FLD_SVE_N,FLD_SVE_immr,FLD_SVE_imms), \
5314 "a 13-bit logical move immediate") \
5315 Y(IMMEDIATE, imm, "SVE_PATTERN", 0, F(FLD_SVE_pattern), \
5316 "an enumeration value such as POW2") \
5317 Y(IMMEDIATE, sve_scale, "SVE_PATTERN_SCALED", 0, \
5318 F(FLD_SVE_pattern), "an enumeration value such as POW2") \
5319 Y(IMMEDIATE, imm, "SVE_PRFOP", 0, F(FLD_SVE_prfop), \
5320 "an enumeration value such as PLDL1KEEP") \
5321 Y(PRED_REG, regno, "SVE_Pd", 0, F(FLD_SVE_Pd), \
5322 "an SVE predicate register") \
5323 Y(PRED_REG, regno, "SVE_Pg3", 0, F(FLD_SVE_Pg3), \
5324 "an SVE predicate register") \
5325 Y(PRED_REG, regno, "SVE_Pg4_5", 0, F(FLD_SVE_Pg4_5), \
5326 "an SVE predicate register") \
5327 Y(PRED_REG, regno, "SVE_Pg4_10", 0, F(FLD_SVE_Pg4_10), \
5328 "an SVE predicate register") \
5329 Y(PRED_REG, regno, "SVE_Pg4_16", 0, F(FLD_SVE_Pg4_16), \
5330 "an SVE predicate register") \
5331 Y(PRED_REG, regno, "SVE_Pm", 0, F(FLD_SVE_Pm), \
5332 "an SVE predicate register") \
5333 Y(PRED_REG, regno, "SVE_Pn", 0, F(FLD_SVE_Pn), \
5334 "an SVE predicate register") \
5335 Y(PRED_REG, regno, "SVE_Pt", 0, F(FLD_SVE_Pt), \
5336 "an SVE predicate register") \
5337 Y(INT_REG, regno, "SVE_Rm", 0, F(FLD_SVE_Rm), \
5338 "an integer register or zero") \
5339 Y(INT_REG, regno, "SVE_Rn_SP", OPD_F_MAYBE_SP, F(FLD_SVE_Rn), \
5340 "an integer register or SP") \
5341 Y(IMMEDIATE, sve_shlimm, "SVE_SHLIMM_PRED", 0, \
5342 F(FLD_SVE_tszh,FLD_SVE_imm5), "a shift-left immediate operand") \
5343 Y(IMMEDIATE, sve_shlimm, "SVE_SHLIMM_UNPRED", 0, \
5344 F(FLD_SVE_tszh,FLD_imm5), "a shift-left immediate operand") \
5345 Y(IMMEDIATE, sve_shlimm, "SVE_SHLIMM_UNPRED_22", 0, \
5346 F(FLD_SVE_sz, FLD_SVE_tszl_19, FLD_SVE_imm3), \
5347 "a shift-left immediate operand") \
5348 Y(IMMEDIATE, sve_shrimm, "SVE_SHRIMM_PRED", 1 << OPD_F_OD_LSB, \
5349 F(FLD_SVE_tszh,FLD_SVE_imm5), "a shift-right immediate operand") \
5350 Y(IMMEDIATE, sve_shrimm, "SVE_SHRIMM_UNPRED", 1 << OPD_F_OD_LSB, \
5351 F(FLD_SVE_tszh,FLD_imm5), "a shift-right immediate operand") \
5352 Y(IMMEDIATE, sve_shrimm, "SVE_SHRIMM_UNPRED_22", 2 << OPD_F_OD_LSB, \
5353 F(FLD_SVE_sz, FLD_SVE_tszl_19, FLD_SVE_imm3), \
5354 "a shift-right immediate operand") \
5355 Y(IMMEDIATE, imm, "SVE_SIMM5", OPD_F_SEXT, F(FLD_SVE_imm5), \
5356 "a 5-bit signed immediate") \
5357 Y(IMMEDIATE, imm, "SVE_SIMM5B", OPD_F_SEXT, F(FLD_SVE_imm5b), \
5358 "a 5-bit signed immediate") \
5359 Y(IMMEDIATE, imm, "SVE_SIMM6", OPD_F_SEXT, F(FLD_SVE_imms), \
5360 "a 6-bit signed immediate") \
5361 Y(IMMEDIATE, imm, "SVE_SIMM8", OPD_F_SEXT, F(FLD_SVE_imm8), \
5362 "an 8-bit signed immediate") \
5363 Y(IMMEDIATE, imm, "SVE_UIMM3", 0, F(FLD_SVE_imm3), \
5364 "a 3-bit unsigned immediate") \
5365 Y(IMMEDIATE, imm, "SVE_UIMM7", 0, F(FLD_SVE_imm7), \
5366 "a 7-bit unsigned immediate") \
5367 Y(IMMEDIATE, imm, "SVE_UIMM8", 0, F(FLD_SVE_imm8), \
5368 "an 8-bit unsigned immediate") \
5369 Y(IMMEDIATE, imm, "SVE_UIMM8_53", 0, F(FLD_imm5,FLD_imm3), \
5370 "an 8-bit unsigned immediate") \
5371 Y(SIMD_REG, regno, "SVE_VZn", 0, F(FLD_SVE_Zn), "a SIMD register") \
5372 Y(SIMD_REG, regno, "SVE_Vd", 0, F(FLD_SVE_Vd), "a SIMD register") \
5373 Y(SIMD_REG, regno, "SVE_Vm", 0, F(FLD_SVE_Vm), "a SIMD register") \
5374 Y(SIMD_REG, regno, "SVE_Vn", 0, F(FLD_SVE_Vn), "a SIMD register") \
5375 Y(SVE_REG, regno, "SVE_Za_5", 0, F(FLD_SVE_Za_5), \
5376 "an SVE vector register") \
5377 Y(SVE_REG, regno, "SVE_Za_16", 0, F(FLD_SVE_Za_16), \
5378 "an SVE vector register") \
5379 Y(SVE_REG, regno, "SVE_Zd", 0, F(FLD_SVE_Zd), \
5380 "an SVE vector register") \
5381 Y(SVE_REG, regno, "SVE_Zm_5", 0, F(FLD_SVE_Zm_5), \
5382 "an SVE vector register") \
5383 Y(SVE_REG, regno, "SVE_Zm_16", 0, F(FLD_SVE_Zm_16), \
5384 "an SVE vector register") \
5385 Y(SVE_REG, sve_quad_index, "SVE_Zm3_INDEX", \
5386 3 << OPD_F_OD_LSB, F(FLD_SVE_Zm_16), \
5387 "an indexed SVE vector register") \
5388 Y(SVE_REG, sve_quad_index, "SVE_Zm3_22_INDEX", \
5389 3 << OPD_F_OD_LSB, F(FLD_SVE_i3h, FLD_SVE_Zm_16), \
5390 "an indexed SVE vector register") \
5391 Y(SVE_REG, sve_quad_index, "SVE_Zm3_11_INDEX", \
5392 3 << OPD_F_OD_LSB, F(FLD_SVE_i3h2, FLD_SVE_i3l, FLD_SVE_imm3), \
5393 "an indexed SVE vector register") \
5394 Y(SVE_REG, sve_quad_index, "SVE_Zm4_11_INDEX", \
5395 4 << OPD_F_OD_LSB, F(FLD_SVE_i2h, FLD_SVE_i3l, FLD_SVE_imm4), \
5396 "an indexed SVE vector register") \
5397 Y(SVE_REG, sve_quad_index, "SVE_Zm4_INDEX", \
5398 4 << OPD_F_OD_LSB, F(FLD_SVE_Zm_16), \
5399 "an indexed SVE vector register") \
5400 Y(SVE_REG, regno, "SVE_Zn", 0, F(FLD_SVE_Zn), \
5401 "an SVE vector register") \
5402 Y(SVE_REG, sve_index, "SVE_Zn_INDEX", 0, F(FLD_SVE_Zn), \
5403 "an indexed SVE vector register") \
5404 Y(SVE_REG, sve_reglist, "SVE_ZnxN", 0, F(FLD_SVE_Zn), \
5405 "a list of SVE vector registers") \
5406 Y(SVE_REG, regno, "SVE_Zt", 0, F(FLD_SVE_Zt), \
5407 "an SVE vector register") \
5408 Y(SVE_REG, sve_reglist, "SVE_ZtxN", 0, F(FLD_SVE_Zt), \
5409 "a list of SVE vector registers") \
5410 Y(IMMEDIATE, imm, "TME_UIMM16", 0, F(FLD_imm16), \
5411 "a 16-bit unsigned immediate for TME tcancel") \
5412 Y(SIMD_ELEMENT, reglane, "SM3_IMM2", 0, F(FLD_SM3_imm2), \
5413 "an indexed SM3 vector immediate")