xref: /qemu/target/hexagon/imported/encode_pp.def (revision 59958d89)
17cf9345cSTaylor Simpson/*
2406c74f2STaylor Simpson *  Copyright(c) 2019-2023 Qualcomm Innovation Center, Inc. All Rights Reserved.
37cf9345cSTaylor Simpson *
47cf9345cSTaylor Simpson *  This program is free software; you can redistribute it and/or modify
57cf9345cSTaylor Simpson *  it under the terms of the GNU General Public License as published by
67cf9345cSTaylor Simpson *  the Free Software Foundation; either version 2 of the License, or
77cf9345cSTaylor Simpson *  (at your option) any later version.
87cf9345cSTaylor Simpson *
97cf9345cSTaylor Simpson *  This program is distributed in the hope that it will be useful,
107cf9345cSTaylor Simpson *  but WITHOUT ANY WARRANTY; without even the implied warranty of
117cf9345cSTaylor Simpson *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
127cf9345cSTaylor Simpson *  GNU General Public License for more details.
137cf9345cSTaylor Simpson *
147cf9345cSTaylor Simpson *  You should have received a copy of the GNU General Public License
157cf9345cSTaylor Simpson *  along with this program; if not, see <http://www.gnu.org/licenses/>.
167cf9345cSTaylor Simpson */
177cf9345cSTaylor Simpson
187cf9345cSTaylor Simpson/*
197cf9345cSTaylor Simpson * Encodings for 32 bit instructions
207cf9345cSTaylor Simpson *
217cf9345cSTaylor Simpson */
227cf9345cSTaylor Simpson
237cf9345cSTaylor Simpson
247cf9345cSTaylor Simpson
257cf9345cSTaylor Simpson
267cf9345cSTaylor SimpsonDEF_CLASS32("---- ---- -------- PP------ --------",ALL_PP)
277cf9345cSTaylor SimpsonDEF_FIELD32("---- ---- -------- !!------ --------",Parse,"Packet/Loop parse bits")
287cf9345cSTaylor SimpsonDEF_FIELD32("!!!! ---- -------- PP------ --------",ICLASS,"Instruction Class")
297cf9345cSTaylor Simpson
307cf9345cSTaylor Simpson#define ICLASS_EXTENDER   "0000"
317cf9345cSTaylor Simpson#define ICLASS_CJ         "0001"
327cf9345cSTaylor Simpson#define ICLASS_NCJ        "0010"
337cf9345cSTaylor Simpson#define ICLASS_V4LDST     "0011"
347cf9345cSTaylor Simpson#define ICLASS_V2LDST     "0100"
357cf9345cSTaylor Simpson#define ICLASS_J          "0101"
367cf9345cSTaylor Simpson#define ICLASS_CR         "0110"
377cf9345cSTaylor Simpson#define ICLASS_ALU2op     "0111"
387cf9345cSTaylor Simpson#define ICLASS_S2op       "1000"
397cf9345cSTaylor Simpson#define ICLASS_LD         "1001"
407cf9345cSTaylor Simpson#define ICLASS_ST         "1010"
417cf9345cSTaylor Simpson#define ICLASS_ADDI       "1011"
427cf9345cSTaylor Simpson#define ICLASS_S3op       "1100"
437cf9345cSTaylor Simpson#define ICLASS_ALU64      "1101"
447cf9345cSTaylor Simpson#define ICLASS_M          "1110"
457cf9345cSTaylor Simpson#define ICLASS_ALU3op     "1111"
467cf9345cSTaylor Simpson
477cf9345cSTaylor Simpson
487cf9345cSTaylor Simpson
497cf9345cSTaylor Simpson/*******************************/
507cf9345cSTaylor Simpson/*                             */
517cf9345cSTaylor Simpson/*                             */
527cf9345cSTaylor Simpson/*     V4 Immediate Payload    */
537cf9345cSTaylor Simpson/*                             */
547cf9345cSTaylor Simpson/*                             */
557cf9345cSTaylor Simpson/*******************************/
567cf9345cSTaylor Simpson
577cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_EXTENDER" ---- -------- PP------ --------",EXTENDER)
587cf9345cSTaylor SimpsonDEF_ENC32(A4_ext, ICLASS_EXTENDER "iiii iiiiiiii PPiiiiii iiiiiiii")
597cf9345cSTaylor Simpson
607cf9345cSTaylor Simpson
617cf9345cSTaylor Simpson
627cf9345cSTaylor Simpson/*******************************/
637cf9345cSTaylor Simpson/*                             */
647cf9345cSTaylor Simpson/*                             */
657cf9345cSTaylor Simpson/*     V2 PREDICATED LD/ST     */
667cf9345cSTaylor Simpson/*                             */
677cf9345cSTaylor Simpson/*                             */
687cf9345cSTaylor Simpson/*******************************/
697cf9345cSTaylor Simpson
707cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V2LDST" ---- -------- PP------ --------",V2LDST)
717cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V2LDST" ---1 -------- PP------ --------",V2LD)
727cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V2LDST" ---0 -------- PP------ --------",V2ST)
737cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V2LDST" 0--1 -------- PP------ --------",PLD)
747cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V2LDST" 0--0 -------- PP------ --------",PST)
757cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V2LDST" 1--1 -------- PP------ --------",GPLD)
767cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V2LDST" 1--0 -------- PP------ --------",GPST)
777cf9345cSTaylor Simpson
787cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_V2LDST" 0!-- -------- PP------ --------",PMEM_Sense,"Sense")
797cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_V2LDST" 0-!- -------- PP------ --------",PMEM_PredNew,"PredNew")
807cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_V2LDST" ---1 !!------ PP------ --------",PMEML_Type,"Type")
817cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_V2LDST" ---1 --!----- PP------ --------",PMEML_UN,"Unsigned")
827cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_V2LDST" ---0 !!!----- PP------ --------",PMEMS_Type,"Type")
837cf9345cSTaylor Simpson
847cf9345cSTaylor Simpson#define STD_PLD_IOENC(TAG,OPC) \
857cf9345cSTaylor SimpsonDEF_ENC32(L2_pload##TAG##t_io,   ICLASS_V2LDST" 0001 "OPC"  sssss  PP0ttiii  iiiddddd")\
867cf9345cSTaylor SimpsonDEF_ENC32(L2_pload##TAG##f_io,   ICLASS_V2LDST" 0101 "OPC"  sssss  PP0ttiii  iiiddddd")\
877cf9345cSTaylor SimpsonDEF_ENC32(L2_pload##TAG##tnew_io,ICLASS_V2LDST" 0011 "OPC"  sssss  PP0ttiii  iiiddddd")\
887cf9345cSTaylor SimpsonDEF_ENC32(L2_pload##TAG##fnew_io,ICLASS_V2LDST" 0111 "OPC"  sssss  PP0ttiii  iiiddddd")
897cf9345cSTaylor Simpson
907cf9345cSTaylor SimpsonSTD_PLD_IOENC(rb,  "000")
917cf9345cSTaylor SimpsonSTD_PLD_IOENC(rub, "001")
927cf9345cSTaylor SimpsonSTD_PLD_IOENC(rh,  "010")
937cf9345cSTaylor SimpsonSTD_PLD_IOENC(ruh, "011")
947cf9345cSTaylor SimpsonSTD_PLD_IOENC(ri,  "100")
957cf9345cSTaylor SimpsonSTD_PLD_IOENC(rd,  "110") /* note dest reg field LSB=0, 1 is reserved */
967cf9345cSTaylor Simpson
977cf9345cSTaylor Simpson
987cf9345cSTaylor Simpson
997cf9345cSTaylor Simpson#define STD_PST_IOENC(TAG,OPC,SRC) \
1007cf9345cSTaylor SimpsonDEF_ENC32(S2_pstore##TAG##t_io,   ICLASS_V2LDST" 0000 "OPC"  sssss  PPi"SRC"  iiiii0vv")\
1017cf9345cSTaylor SimpsonDEF_ENC32(S2_pstore##TAG##f_io,   ICLASS_V2LDST" 0100 "OPC"  sssss  PPi"SRC"  iiiii0vv")\
1027cf9345cSTaylor SimpsonDEF_ENC32(S4_pstore##TAG##tnew_io,ICLASS_V2LDST" 0010 "OPC"  sssss  PPi"SRC"  iiiii0vv")\
1037cf9345cSTaylor SimpsonDEF_ENC32(S4_pstore##TAG##fnew_io,ICLASS_V2LDST" 0110 "OPC"  sssss  PPi"SRC"  iiiii0vv")
1047cf9345cSTaylor Simpson
1057cf9345cSTaylor SimpsonSTD_PST_IOENC(rb,    "000","ttttt")
1067cf9345cSTaylor SimpsonSTD_PST_IOENC(rh,    "010","ttttt")
1077cf9345cSTaylor SimpsonSTD_PST_IOENC(rf,    "011","ttttt")
1087cf9345cSTaylor SimpsonSTD_PST_IOENC(ri,    "100","ttttt")
1097cf9345cSTaylor SimpsonSTD_PST_IOENC(rd,    "110","ttttt")
1107cf9345cSTaylor SimpsonSTD_PST_IOENC(rbnew, "101","00ttt")
1117cf9345cSTaylor SimpsonSTD_PST_IOENC(rhnew, "101","01ttt")
1127cf9345cSTaylor SimpsonSTD_PST_IOENC(rinew, "101","10ttt")
1137cf9345cSTaylor Simpson
1147cf9345cSTaylor Simpson
1157cf9345cSTaylor Simpson
1167cf9345cSTaylor Simpson
1177cf9345cSTaylor Simpson
1187cf9345cSTaylor Simpson/*******************************/
1197cf9345cSTaylor Simpson/*                             */
1207cf9345cSTaylor Simpson/*                             */
1217cf9345cSTaylor Simpson/*     V2 GP-RELATIVE LD/ST    */
1227cf9345cSTaylor Simpson/*                             */
1237cf9345cSTaylor Simpson/*                             */
1247cf9345cSTaylor Simpson/*******************************/
1257cf9345cSTaylor Simpson#define STD_LD_GP(TAG,OPC) \
1267cf9345cSTaylor SimpsonDEF_ENC32(L2_load##TAG##gp,   ICLASS_V2LDST" 1ii1 "OPC"  iiiii  PPiiiiii  iiiddddd")
1277cf9345cSTaylor Simpson
1287cf9345cSTaylor SimpsonSTD_LD_GP(rb,  "000")
1297cf9345cSTaylor SimpsonSTD_LD_GP(rub, "001")
1307cf9345cSTaylor SimpsonSTD_LD_GP(rh,  "010")
1317cf9345cSTaylor SimpsonSTD_LD_GP(ruh, "011")
1327cf9345cSTaylor SimpsonSTD_LD_GP(ri,  "100")
1337cf9345cSTaylor SimpsonSTD_LD_GP(rd,  "110") /* note dest reg field LSB=0, 1 is reserved */
1347cf9345cSTaylor Simpson
1357cf9345cSTaylor Simpson#define STD_ST_GP(TAG,OPC,SRC) \
1367cf9345cSTaylor SimpsonDEF_ENC32(S2_store##TAG##gp,  ICLASS_V2LDST" 1ii0 "OPC"  iiiii  PPi"SRC"  iiiiiiii")
1377cf9345cSTaylor Simpson
1387cf9345cSTaylor SimpsonSTD_ST_GP(rb,   "000","ttttt")
1397cf9345cSTaylor SimpsonSTD_ST_GP(rh,   "010","ttttt")
1407cf9345cSTaylor SimpsonSTD_ST_GP(rf,   "011","ttttt")
1417cf9345cSTaylor SimpsonSTD_ST_GP(ri,   "100","ttttt")
1427cf9345cSTaylor SimpsonSTD_ST_GP(rd,   "110","ttttt")
1437cf9345cSTaylor SimpsonSTD_ST_GP(rbnew,"101","00ttt")
1447cf9345cSTaylor SimpsonSTD_ST_GP(rhnew,"101","01ttt")
1457cf9345cSTaylor SimpsonSTD_ST_GP(rinew,"101","10ttt")
1467cf9345cSTaylor Simpson
1477cf9345cSTaylor Simpson
1487cf9345cSTaylor Simpson
1497cf9345cSTaylor Simpson
1507cf9345cSTaylor Simpson
1517cf9345cSTaylor Simpson/*******************************/
1527cf9345cSTaylor Simpson/*                             */
1537cf9345cSTaylor Simpson/*                             */
1547cf9345cSTaylor Simpson/*     V4LDST                  */
1557cf9345cSTaylor Simpson/*                             */
1567cf9345cSTaylor Simpson/*                             */
1577cf9345cSTaylor Simpson/*******************************/
1587cf9345cSTaylor Simpson
1597cf9345cSTaylor Simpson
1607cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V4LDST" ---- -------- PP------ --------",V4LDST)
1617cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V4LDST" 0--- -------- PP------ --------",Pred_RplusR)
1627cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V4LDST" 100- -------- PP------ --------",Pred_StoreImmed)
1637cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V4LDST" 101- -------- PP------ --------",RplusR)
1647cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V4LDST" 110- -------- PP------ --------",StoreImmed)
1657cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_V4LDST" 111- -------- PP------ --------",MemOp)
1667cf9345cSTaylor Simpson
1677cf9345cSTaylor Simpson
1687cf9345cSTaylor Simpson
1697cf9345cSTaylor Simpson
1707cf9345cSTaylor Simpson/*******************************/
1717cf9345cSTaylor Simpson/*    Pred (R+R)               */
1727cf9345cSTaylor Simpson/*******************************/
1737cf9345cSTaylor Simpson
1747cf9345cSTaylor Simpson#define STD_PLD_RRENC(TAG,OPC) \
1757cf9345cSTaylor SimpsonDEF_ENC32(L4_pload##TAG##t_rr,   ICLASS_V4LDST" 00 00 "OPC"  sssss  PPittttt  ivvddddd")\
1767cf9345cSTaylor SimpsonDEF_ENC32(L4_pload##TAG##f_rr,   ICLASS_V4LDST" 00 01 "OPC"  sssss  PPittttt  ivvddddd")\
1777cf9345cSTaylor SimpsonDEF_ENC32(L4_pload##TAG##tnew_rr,ICLASS_V4LDST" 00 10 "OPC"  sssss  PPittttt  ivvddddd")\
1787cf9345cSTaylor SimpsonDEF_ENC32(L4_pload##TAG##fnew_rr,ICLASS_V4LDST" 00 11 "OPC"  sssss  PPittttt  ivvddddd")
1797cf9345cSTaylor Simpson
1807cf9345cSTaylor SimpsonSTD_PLD_RRENC(rb,  "000")
1817cf9345cSTaylor SimpsonSTD_PLD_RRENC(rub, "001")
1827cf9345cSTaylor SimpsonSTD_PLD_RRENC(rh,  "010")
1837cf9345cSTaylor SimpsonSTD_PLD_RRENC(ruh, "011")
1847cf9345cSTaylor SimpsonSTD_PLD_RRENC(ri,  "100")
1857cf9345cSTaylor SimpsonSTD_PLD_RRENC(rd,  "110")
1867cf9345cSTaylor Simpson
1877cf9345cSTaylor Simpson#define STD_PST_RRENC(TAG,OPC,SRC) \
1887cf9345cSTaylor SimpsonDEF_ENC32(S4_pstore##TAG##t_rr,   ICLASS_V4LDST" 01 00 "OPC"  sssss  PPiuuuuu  ivv"SRC)\
1897cf9345cSTaylor SimpsonDEF_ENC32(S4_pstore##TAG##f_rr,   ICLASS_V4LDST" 01 01 "OPC"  sssss  PPiuuuuu  ivv"SRC)\
1907cf9345cSTaylor SimpsonDEF_ENC32(S4_pstore##TAG##tnew_rr,ICLASS_V4LDST" 01 10 "OPC"  sssss  PPiuuuuu  ivv"SRC)\
1917cf9345cSTaylor SimpsonDEF_ENC32(S4_pstore##TAG##fnew_rr,ICLASS_V4LDST" 01 11 "OPC"  sssss  PPiuuuuu  ivv"SRC)
1927cf9345cSTaylor Simpson
1937cf9345cSTaylor SimpsonSTD_PST_RRENC(rb,    "000","ttttt")
1947cf9345cSTaylor SimpsonSTD_PST_RRENC(rh,    "010","ttttt")
1957cf9345cSTaylor SimpsonSTD_PST_RRENC(rf,    "011","ttttt")
1967cf9345cSTaylor SimpsonSTD_PST_RRENC(ri,    "100","ttttt")
1977cf9345cSTaylor SimpsonSTD_PST_RRENC(rd,    "110","ttttt")
1987cf9345cSTaylor SimpsonSTD_PST_RRENC(rbnew, "101","00ttt")
1997cf9345cSTaylor SimpsonSTD_PST_RRENC(rhnew, "101","01ttt")
2007cf9345cSTaylor SimpsonSTD_PST_RRENC(rinew, "101","10ttt")
2017cf9345cSTaylor Simpson
2027cf9345cSTaylor Simpson
2037cf9345cSTaylor Simpson
2047cf9345cSTaylor Simpson/*******************************/
2057cf9345cSTaylor Simpson/*     Pred Store immediates   */
2067cf9345cSTaylor Simpson/*******************************/
2077cf9345cSTaylor Simpson
2087cf9345cSTaylor Simpson#define V4_PSTI(TAG,OPC) \
2097cf9345cSTaylor SimpsonDEF_ENC32(S4_storei##TAG##t_io,    ICLASS_V4LDST" 100 00  "OPC"  sssss  PPIiiiii  ivvIIIII")\
2107cf9345cSTaylor SimpsonDEF_ENC32(S4_storei##TAG##f_io,    ICLASS_V4LDST" 100 01  "OPC"  sssss  PPIiiiii  ivvIIIII")\
2117cf9345cSTaylor SimpsonDEF_ENC32(S4_storei##TAG##tnew_io, ICLASS_V4LDST" 100 10  "OPC"  sssss  PPIiiiii  ivvIIIII")\
2127cf9345cSTaylor SimpsonDEF_ENC32(S4_storei##TAG##fnew_io, ICLASS_V4LDST" 100 11  "OPC"  sssss  PPIiiiii  ivvIIIII")
2137cf9345cSTaylor Simpson
2147cf9345cSTaylor SimpsonV4_PSTI(rb, "00")
2157cf9345cSTaylor SimpsonV4_PSTI(rh, "01")
2167cf9345cSTaylor SimpsonV4_PSTI(ri, "10")
2177cf9345cSTaylor Simpson
2187cf9345cSTaylor Simpson
2197cf9345cSTaylor Simpson
2207cf9345cSTaylor Simpson/*******************************/
2217cf9345cSTaylor Simpson/*    (R+R)                    */
2227cf9345cSTaylor Simpson/*******************************/
2237cf9345cSTaylor Simpson
2247cf9345cSTaylor Simpson#define STD_LD_RRENC(TAG,OPC) \
2257cf9345cSTaylor SimpsonDEF_ENC32(L4_load##TAG##_rr,     ICLASS_V4LDST" 1010 "OPC"  sssss  PPittttt  i--ddddd")
2267cf9345cSTaylor Simpson
2277cf9345cSTaylor SimpsonSTD_LD_RRENC(rb,  "000")
2287cf9345cSTaylor SimpsonSTD_LD_RRENC(rub, "001")
2297cf9345cSTaylor SimpsonSTD_LD_RRENC(rh,  "010")
2307cf9345cSTaylor SimpsonSTD_LD_RRENC(ruh, "011")
2317cf9345cSTaylor SimpsonSTD_LD_RRENC(ri,  "100")
2327cf9345cSTaylor SimpsonSTD_LD_RRENC(rd,  "110")
2337cf9345cSTaylor Simpson
2347cf9345cSTaylor Simpson#define STD_ST_RRENC(TAG,OPC,SRC) \
2357cf9345cSTaylor SimpsonDEF_ENC32(S4_store##TAG##_rr,     ICLASS_V4LDST" 1011 "OPC"  sssss  PPiuuuuu  i--"SRC)
2367cf9345cSTaylor Simpson
2377cf9345cSTaylor SimpsonSTD_ST_RRENC(rb,    "000","ttttt")
2387cf9345cSTaylor SimpsonSTD_ST_RRENC(rh,    "010","ttttt")
2397cf9345cSTaylor SimpsonSTD_ST_RRENC(rf,    "011","ttttt")
2407cf9345cSTaylor SimpsonSTD_ST_RRENC(ri,    "100","ttttt")
2417cf9345cSTaylor SimpsonSTD_ST_RRENC(rd,    "110","ttttt")
2427cf9345cSTaylor SimpsonSTD_ST_RRENC(rbnew, "101","00ttt")
2437cf9345cSTaylor SimpsonSTD_ST_RRENC(rhnew, "101","01ttt")
2447cf9345cSTaylor SimpsonSTD_ST_RRENC(rinew, "101","10ttt")
2457cf9345cSTaylor Simpson
2467cf9345cSTaylor Simpson
2477cf9345cSTaylor Simpson
2487cf9345cSTaylor Simpson
2497cf9345cSTaylor Simpson/*******************************/
2507cf9345cSTaylor Simpson/*     Store immediates        */
2517cf9345cSTaylor Simpson/*******************************/
2527cf9345cSTaylor Simpson
2537cf9345cSTaylor Simpson#define V4_STI(TAG,OPC) \
2547cf9345cSTaylor SimpsonDEF_ENC32(S4_storei##TAG##_io,     ICLASS_V4LDST" 110 -- "OPC"  sssss  PPIiiiii  iIIIIIII")
2557cf9345cSTaylor Simpson
2567cf9345cSTaylor Simpson
2577cf9345cSTaylor SimpsonV4_STI(rb, "00")
2587cf9345cSTaylor SimpsonV4_STI(rh, "01")
2597cf9345cSTaylor SimpsonV4_STI(ri, "10")
2607cf9345cSTaylor Simpson
2617cf9345cSTaylor Simpson
2627cf9345cSTaylor Simpson/*******************************/
2637cf9345cSTaylor Simpson/*     Memops                 */
2647cf9345cSTaylor Simpson/*******************************/
2657cf9345cSTaylor Simpson
2667cf9345cSTaylor Simpson#define MEMOPENC(TAG,OPC) \
2677cf9345cSTaylor SimpsonDEF_ENC32(L4_add_##TAG##_io,         ICLASS_V4LDST" 111 0- " OPC "sssss  PP0iiiii  i00ttttt")\
2687cf9345cSTaylor SimpsonDEF_ENC32(L4_sub_##TAG##_io,         ICLASS_V4LDST" 111 0- " OPC "sssss  PP0iiiii  i01ttttt")\
2697cf9345cSTaylor SimpsonDEF_ENC32(L4_and_##TAG##_io,         ICLASS_V4LDST" 111 0- " OPC "sssss  PP0iiiii  i10ttttt")\
2707cf9345cSTaylor SimpsonDEF_ENC32(L4_or_##TAG##_io,          ICLASS_V4LDST" 111 0- " OPC "sssss  PP0iiiii  i11ttttt")\
2717cf9345cSTaylor Simpson\
2727cf9345cSTaylor SimpsonDEF_ENC32(L4_iadd_##TAG##_io,        ICLASS_V4LDST" 111 1- " OPC "sssss  PP0iiiii  i00IIIII")\
2737cf9345cSTaylor SimpsonDEF_ENC32(L4_isub_##TAG##_io,        ICLASS_V4LDST" 111 1- " OPC "sssss  PP0iiiii  i01IIIII")\
2747cf9345cSTaylor SimpsonDEF_ENC32(L4_iand_##TAG##_io,        ICLASS_V4LDST" 111 1- " OPC "sssss  PP0iiiii  i10IIIII")\
2757cf9345cSTaylor SimpsonDEF_ENC32(L4_ior_##TAG##_io,         ICLASS_V4LDST" 111 1- " OPC "sssss  PP0iiiii  i11IIIII")
2767cf9345cSTaylor Simpson
2777cf9345cSTaylor Simpson
2787cf9345cSTaylor Simpson
2797cf9345cSTaylor SimpsonMEMOPENC(memopw,"10")
2807cf9345cSTaylor SimpsonMEMOPENC(memoph,"01")
2817cf9345cSTaylor SimpsonMEMOPENC(memopb,"00")
2827cf9345cSTaylor Simpson
2837cf9345cSTaylor Simpson
2847cf9345cSTaylor Simpson
2857cf9345cSTaylor Simpson
2867cf9345cSTaylor Simpson/*******************************/
2877cf9345cSTaylor Simpson/*                             */
2887cf9345cSTaylor Simpson/*                             */
2897cf9345cSTaylor Simpson/*           LOAD              */
2907cf9345cSTaylor Simpson/*                             */
2917cf9345cSTaylor Simpson/*                             */
2927cf9345cSTaylor Simpson/*******************************/
2937cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_LD" ---- -------- PP------ --------",LD)
2947cf9345cSTaylor Simpson
2957cf9345cSTaylor Simpson
2967cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_LD" 0--- -------- PP------ --------",LD_ADDR_ROFFSET)
29746ef47e2STaylor SimpsonDEF_CLASS32(ICLASS_LD" 100- -------- PP----0- --------",LD_ADDR_POST_CIRC_IMMED)
2987cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_LD" 101- -------- PP00---- --------",LD_ADDR_POST_IMMED)
2997cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_LD" 101- -------- PP01---- --------",LD_ADDR_ABS_UPDATE_V4)
3007cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_LD" 101- -------- PP1----- --------",LD_ADDR_POST_IMMED_PRED_V2)
3017cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_LD" 110- -------- PP-0---- 0-------",LD_ADDR_POST_REG)
3027cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_LD" 110- -------- PP-1---- --------",LD_ADDR_ABS_PLUS_REG_V4)
3037cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_LD" 100- -------- PP----1- --------",LD_ADDR_POST_CREG_V2)
304af7f1821STaylor SimpsonDEF_CLASS32(ICLASS_LD" 111- -------- PP------ 0-------",LD_ADDR_POST_BREV_REG)
3057cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_LD" 111- -------- PP------ 1-------",LD_ADDR_PRED_ABS_V4)
3067cf9345cSTaylor Simpson
3077cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_LD" !!!- -------- PP------ --------",LD_Amode,"Amode")
3087cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_LD" ---! !!------ PP------ --------",LD_Type,"Type")
3097cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_LD" ---- --!----- PP------ --------",LD_UN,"Unsigned")
3107cf9345cSTaylor Simpson
3117cf9345cSTaylor Simpson#define STD_LD_ENC(TAG,OPC) \
3127cf9345cSTaylor SimpsonDEF_ENC32(L2_load##TAG##_io,   ICLASS_LD" 0 ii "OPC"  sssss  PPiiiiii  iiiddddd")\
31346ef47e2STaylor SimpsonDEF_ENC32(L2_load##TAG##_pci,  ICLASS_LD" 1 00 "OPC"  xxxxx  PPu0--0i  iiiddddd")\
3147cf9345cSTaylor SimpsonDEF_ENC32(L2_load##TAG##_pi,   ICLASS_LD" 1 01 "OPC"  xxxxx  PP00---i  iiiddddd")\
3157cf9345cSTaylor SimpsonDEF_ENC32(L4_load##TAG##_ap,   ICLASS_LD" 1 01 "OPC"  eeeee  PP01IIII  -IIddddd")\
3167cf9345cSTaylor SimpsonDEF_ENC32(L2_load##TAG##_pr,   ICLASS_LD" 1 10 "OPC"  xxxxx  PPu0----  0--ddddd")\
3177cf9345cSTaylor SimpsonDEF_ENC32(L4_load##TAG##_ur,   ICLASS_LD" 1 10 "OPC"  ttttt  PPi1IIII  iIIddddd")\
31846ef47e2STaylor SimpsonDEF_ENC32(L2_load##TAG##_pcr,  ICLASS_LD" 1 00 "OPC"  xxxxx  PPu0--1-  0--ddddd")\
319af7f1821STaylor SimpsonDEF_ENC32(L2_load##TAG##_pbr,  ICLASS_LD" 1 11 "OPC"  xxxxx  PPu0----  0--ddddd")
3207cf9345cSTaylor Simpson
3217cf9345cSTaylor Simpson
3227cf9345cSTaylor Simpson#define STD_LDX_ENC(TAG,OPC) \
3237cf9345cSTaylor SimpsonDEF_ENC32(L2_load##TAG##_io,   ICLASS_LD" 0 ii "OPC"  sssss  PPiiiiii  iiiyyyyy")\
32446ef47e2STaylor SimpsonDEF_ENC32(L2_load##TAG##_pci,  ICLASS_LD" 1 00 "OPC"  xxxxx  PPu0--0i  iiiyyyyy")\
3257cf9345cSTaylor SimpsonDEF_ENC32(L2_load##TAG##_pi,   ICLASS_LD" 1 01 "OPC"  xxxxx  PP00---i  iiiyyyyy")\
3267cf9345cSTaylor SimpsonDEF_ENC32(L4_load##TAG##_ap,   ICLASS_LD" 1 01 "OPC"  eeeee  PP01IIII  -IIyyyyy")\
3277cf9345cSTaylor SimpsonDEF_ENC32(L2_load##TAG##_pr,   ICLASS_LD" 1 10 "OPC"  xxxxx  PPu0----  0--yyyyy")\
3287cf9345cSTaylor SimpsonDEF_ENC32(L4_load##TAG##_ur,   ICLASS_LD" 1 10 "OPC"  ttttt  PPi1IIII  iIIyyyyy")\
32946ef47e2STaylor SimpsonDEF_ENC32(L2_load##TAG##_pcr,  ICLASS_LD" 1 00 "OPC"  xxxxx  PPu0--1-  0--yyyyy")\
33046ef47e2STaylor SimpsonDEF_ENC32(L2_load##TAG##_pbr,  ICLASS_LD" 1 11 "OPC"  xxxxx  PPu0----  0--yyyyy")
3317cf9345cSTaylor Simpson
3327cf9345cSTaylor Simpson
3337cf9345cSTaylor Simpson#define STD_PLD_ENC(TAG,OPC) \
3347cf9345cSTaylor SimpsonDEF_ENC32(L2_pload##TAG##t_pi,    ICLASS_LD" 1 01 "OPC"  xxxxx  PP100tti  iiiddddd")\
3357cf9345cSTaylor SimpsonDEF_ENC32(L2_pload##TAG##f_pi,    ICLASS_LD" 1 01 "OPC"  xxxxx  PP101tti  iiiddddd")\
3367cf9345cSTaylor SimpsonDEF_ENC32(L2_pload##TAG##tnew_pi, ICLASS_LD" 1 01 "OPC"  xxxxx  PP110tti  iiiddddd")\
3377cf9345cSTaylor SimpsonDEF_ENC32(L2_pload##TAG##fnew_pi, ICLASS_LD" 1 01 "OPC"  xxxxx  PP111tti  iiiddddd")\
3387cf9345cSTaylor SimpsonDEF_ENC32(L4_pload##TAG##t_abs,   ICLASS_LD" 1 11 "OPC"  iiiii  PP100tti  1--ddddd")\
3397cf9345cSTaylor SimpsonDEF_ENC32(L4_pload##TAG##f_abs,   ICLASS_LD" 1 11 "OPC"  iiiii  PP101tti  1--ddddd")\
3407cf9345cSTaylor SimpsonDEF_ENC32(L4_pload##TAG##tnew_abs,ICLASS_LD" 1 11 "OPC"  iiiii  PP110tti  1--ddddd")\
3417cf9345cSTaylor SimpsonDEF_ENC32(L4_pload##TAG##fnew_abs,ICLASS_LD" 1 11 "OPC"  iiiii  PP111tti  1--ddddd")
3427cf9345cSTaylor Simpson
3437cf9345cSTaylor Simpson
3447cf9345cSTaylor Simpson/*               0 000  misc: dealloc,loadw_locked,dcfetch      */
3450d0b91a8STaylor SimpsonSTD_LD_ENC(bzw4,"0 101")
3460d0b91a8STaylor SimpsonSTD_LD_ENC(bzw2,"0 011")
3470d0b91a8STaylor Simpson
3480d0b91a8STaylor SimpsonSTD_LD_ENC(bsw4,"0 111")
3490d0b91a8STaylor SimpsonSTD_LD_ENC(bsw2,"0 001")
3500d0b91a8STaylor Simpson
3517aa9ffabSTaylor SimpsonSTD_LDX_ENC(alignh,"0 010")
3527aa9ffabSTaylor SimpsonSTD_LDX_ENC(alignb,"0 100")
3537aa9ffabSTaylor Simpson
3547cf9345cSTaylor SimpsonSTD_LD_ENC(rb,  "1 000")
3557cf9345cSTaylor SimpsonSTD_LD_ENC(rub, "1 001")
3567cf9345cSTaylor SimpsonSTD_LD_ENC(rh,  "1 010")
3577cf9345cSTaylor SimpsonSTD_LD_ENC(ruh, "1 011")
3587cf9345cSTaylor SimpsonSTD_LD_ENC(ri,  "1 100")
3597cf9345cSTaylor SimpsonSTD_LD_ENC(rd,  "1 110") /* note dest reg field LSB=0, 1 is reserved */
3607cf9345cSTaylor Simpson
3617cf9345cSTaylor SimpsonSTD_PLD_ENC(rb,  "1 000")
3627cf9345cSTaylor SimpsonSTD_PLD_ENC(rub, "1 001")
3637cf9345cSTaylor SimpsonSTD_PLD_ENC(rh,  "1 010")
3647cf9345cSTaylor SimpsonSTD_PLD_ENC(ruh, "1 011")
3657cf9345cSTaylor SimpsonSTD_PLD_ENC(ri,  "1 100")
3667cf9345cSTaylor SimpsonSTD_PLD_ENC(rd,  "1 110") /* note dest reg field LSB=0, 1 is reserved */
3677cf9345cSTaylor Simpson
3687cf9345cSTaylor Simpson
3697cf9345cSTaylor SimpsonDEF_CLASS32(    ICLASS_LD" 0--0 000----- PP------ --------",LD_MISC)
3707cf9345cSTaylor SimpsonDEF_ANTICLASS32(ICLASS_LD" 0--0 000----- PP------ --------",LD_ADDR_ROFFSET)
37146ef47e2STaylor SimpsonDEF_ANTICLASS32(ICLASS_LD" 1000 000----- PP------ --------",LD_ADDR_POST_CIRC_IMMED)
3727cf9345cSTaylor SimpsonDEF_ANTICLASS32(ICLASS_LD" 1010 000----- PP------ --------",LD_ADDR_POST_IMMED)
3737cf9345cSTaylor SimpsonDEF_ANTICLASS32(ICLASS_LD" 1100 000----- PP------ --------",LD_ADDR_POST_REG)
3747cf9345cSTaylor SimpsonDEF_ANTICLASS32(ICLASS_LD" 1110 000----- PP------ --------",LD_ADDR_POST_REG)
3757cf9345cSTaylor Simpson
3767cf9345cSTaylor SimpsonDEF_ENC32(L2_deallocframe,    ICLASS_LD" 000 0 000 sssss PP0----- ---ddddd")
3777cf9345cSTaylor SimpsonDEF_ENC32(L4_return,          ICLASS_LD" 011 0 000 sssss PP0000-- ---ddddd")
3787cf9345cSTaylor SimpsonDEF_ENC32(L4_return_t,        ICLASS_LD" 011 0 000 sssss PP0100vv ---ddddd")
3797cf9345cSTaylor SimpsonDEF_ENC32(L4_return_f,        ICLASS_LD" 011 0 000 sssss PP1100vv ---ddddd")
3807cf9345cSTaylor SimpsonDEF_ENC32(L4_return_tnew_pt,  ICLASS_LD" 011 0 000 sssss PP0110vv ---ddddd")
3817cf9345cSTaylor SimpsonDEF_ENC32(L4_return_fnew_pt,  ICLASS_LD" 011 0 000 sssss PP1110vv ---ddddd")
3827cf9345cSTaylor SimpsonDEF_ENC32(L4_return_tnew_pnt, ICLASS_LD" 011 0 000 sssss PP0010vv ---ddddd")
3837cf9345cSTaylor SimpsonDEF_ENC32(L4_return_fnew_pnt, ICLASS_LD" 011 0 000 sssss PP1010vv ---ddddd")
3847cf9345cSTaylor Simpson
385406c74f2STaylor SimpsonDEF_ENC32(L2_loadw_locked,ICLASS_LD" 001 0 000 sssss PP000--- 000ddddd")
3867cf9345cSTaylor Simpson
3877cf9345cSTaylor Simpson
3887cf9345cSTaylor Simpson
389406c74f2STaylor SimpsonDEF_ENC32(L2_loadw_aq,        ICLASS_LD" 001 0 000 sssss PP001--- 000ddddd")
390406c74f2STaylor SimpsonDEF_ENC32(L4_loadd_aq,        ICLASS_LD" 001 0 000 sssss PP011--- 000ddddd")
3917cf9345cSTaylor Simpson
392406c74f2STaylor SimpsonDEF_ENC32(R6_release_at_vi,    ICLASS_ST" 000 01 11sssss PP0ttttt --0011dd")
393406c74f2STaylor SimpsonDEF_ENC32(R6_release_st_vi,   ICLASS_ST" 000 01 11sssss PP0ttttt --1011dd")
3947cf9345cSTaylor Simpson
395406c74f2STaylor SimpsonDEF_ENC32(S2_storew_rl_at_vi,  ICLASS_ST" 000 01 01sssss PP-ttttt --0010dd")
396406c74f2STaylor SimpsonDEF_ENC32(S2_storew_rl_st_vi, ICLASS_ST" 000 01 01sssss PP-ttttt --1010dd")
3977cf9345cSTaylor Simpson
398406c74f2STaylor SimpsonDEF_ENC32(S4_stored_rl_at_vi,  ICLASS_ST" 000 01 11sssss PP0ttttt --0010dd")
399406c74f2STaylor SimpsonDEF_ENC32(S4_stored_rl_st_vi, ICLASS_ST" 000 01 11sssss PP0ttttt --1010dd")
400406c74f2STaylor Simpson
401406c74f2STaylor SimpsonDEF_ENC32(L4_loadd_locked,ICLASS_LD" 001 0 000 sssss PP010--- 000ddddd")
4027cf9345cSTaylor SimpsonDEF_EXT_SPACE(EXTRACTW,   ICLASS_LD" 001 0 000 iiiii PP0iiiii -01iiiii")
4037cf9345cSTaylor SimpsonDEF_ENC32(Y2_dcfetchbo,   ICLASS_LD" 010 0 000 sssss PP0--iii iiiiiiii")
4047cf9345cSTaylor Simpson
4057cf9345cSTaylor Simpson
4067cf9345cSTaylor Simpson
4077cf9345cSTaylor Simpson
4087cf9345cSTaylor Simpson
4097cf9345cSTaylor Simpson
4107cf9345cSTaylor Simpson
4117cf9345cSTaylor Simpson
4127cf9345cSTaylor Simpson/*******************************/
4137cf9345cSTaylor Simpson/*                             */
4147cf9345cSTaylor Simpson/*                             */
4157cf9345cSTaylor Simpson/*           STORE             */
4167cf9345cSTaylor Simpson/*                             */
4177cf9345cSTaylor Simpson/*                             */
4187cf9345cSTaylor Simpson/*******************************/
4197cf9345cSTaylor Simpson
4207cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ST" ---- -------- PP------ --------",ST)
4217cf9345cSTaylor Simpson
4227cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ST" !!!- -------- PP------ --------",ST_Amode,"Amode")
4237cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ST" ---! !!------ PP------ --------",ST_Type,"Type")
4247cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ST" ---- --!----- PP------ --------",ST_UN,"Unsigned")
4257cf9345cSTaylor Simpson
4267cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ST" 0--1 -------- PP------ --------",ST_ADDR_ROFFSET)
42746ef47e2STaylor SimpsonDEF_CLASS32(ICLASS_ST" 1001 -------- PP------ ------0-",ST_ADDR_POST_CIRC_IMMED)
4287cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ST" 1011 -------- PP0----- 0-----0-",ST_ADDR_POST_IMMED)
4297cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ST" 1011 -------- PP0----- 1-------",ST_ADDR_ABS_UPDATE_V4)
4307cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ST" 1011 -------- PP1----- --------",ST_ADDR_POST_IMMED_PRED_V2)
4317cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ST" 1111 -------- PP------ 1-------",ST_ADDR_PRED_ABS_V4)
4327cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ST" 1101 -------- PP------ 0-------",ST_ADDR_POST_REG)
4337cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ST" 1101 -------- PP------ 1-------",ST_ADDR_ABS_PLUS_REG_V4)
4347cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ST" 1001 -------- PP------ ------1-",ST_ADDR_POST_CREG_V2)
435af7f1821STaylor SimpsonDEF_CLASS32(ICLASS_ST" 1111 -------- PP------ 0-------",ST_ADDR_POST_BREV_REG)
4367cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ST" 0--0 1------- PP------ --------",ST_MISC_STORELIKE)
4377cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ST" 1--0 0------- PP------ --------",ST_MISC_BUSOP)
4387cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ST" 0--0 0------- PP------ --------",ST_MISC_CACHEOP)
4397cf9345cSTaylor Simpson
4407cf9345cSTaylor Simpson
4417cf9345cSTaylor Simpson#define STD_ST_ENC(TAG,OPC,SRC) \
4427cf9345cSTaylor SimpsonDEF_ENC32(S2_store##TAG##_io,   ICLASS_ST" 0 ii "OPC"  sssss  PPi"SRC"  iiiiiiii")\
44346ef47e2STaylor SimpsonDEF_ENC32(S2_store##TAG##_pci,  ICLASS_ST" 1 00 "OPC"  xxxxx  PPu"SRC"  0iiii-0-")\
4447cf9345cSTaylor SimpsonDEF_ENC32(S2_store##TAG##_pi,   ICLASS_ST" 1 01 "OPC"  xxxxx  PP0"SRC"  0iiii-0-")\
4457cf9345cSTaylor SimpsonDEF_ENC32(S4_store##TAG##_ap,   ICLASS_ST" 1 01 "OPC"  eeeee  PP0"SRC"  1-IIIIII")\
4467cf9345cSTaylor SimpsonDEF_ENC32(S2_store##TAG##_pr,   ICLASS_ST" 1 10 "OPC"  xxxxx  PPu"SRC"  0-------")\
4477cf9345cSTaylor SimpsonDEF_ENC32(S4_store##TAG##_ur,   ICLASS_ST" 1 10 "OPC"  uuuuu  PPi"SRC"  1iIIIIII")\
44846ef47e2STaylor SimpsonDEF_ENC32(S2_store##TAG##_pcr,  ICLASS_ST" 1 00 "OPC"  xxxxx  PPu"SRC"  0-----1-")\
449af7f1821STaylor SimpsonDEF_ENC32(S2_store##TAG##_pbr,  ICLASS_ST" 1 11 "OPC"  xxxxx  PPu"SRC"  0-------")
4507cf9345cSTaylor Simpson
4517cf9345cSTaylor Simpson
4527cf9345cSTaylor Simpson#define STD_PST_ENC(TAG,OPC,SRC) \
4537cf9345cSTaylor SimpsonDEF_ENC32(S2_pstore##TAG##t_pi,    ICLASS_ST" 1 01 "OPC"  xxxxx  PP1"SRC"  0iiii0vv")\
4547cf9345cSTaylor SimpsonDEF_ENC32(S2_pstore##TAG##f_pi,    ICLASS_ST" 1 01 "OPC"  xxxxx  PP1"SRC"  0iiii1vv")\
4557cf9345cSTaylor SimpsonDEF_ENC32(S2_pstore##TAG##tnew_pi, ICLASS_ST" 1 01 "OPC"  xxxxx  PP1"SRC"  1iiii0vv")\
4567cf9345cSTaylor SimpsonDEF_ENC32(S2_pstore##TAG##fnew_pi, ICLASS_ST" 1 01 "OPC"  xxxxx  PP1"SRC"  1iiii1vv")\
4577cf9345cSTaylor SimpsonDEF_ENC32(S4_pstore##TAG##t_abs,   ICLASS_ST" 1 11 "OPC"  ---ii  PP0"SRC"  1iiii0vv")\
4587cf9345cSTaylor SimpsonDEF_ENC32(S4_pstore##TAG##f_abs,   ICLASS_ST" 1 11 "OPC"  ---ii  PP0"SRC"  1iiii1vv")\
4597cf9345cSTaylor SimpsonDEF_ENC32(S4_pstore##TAG##tnew_abs,ICLASS_ST" 1 11 "OPC"  ---ii  PP1"SRC"  1iiii0vv")\
4607cf9345cSTaylor SimpsonDEF_ENC32(S4_pstore##TAG##fnew_abs,ICLASS_ST" 1 11 "OPC"  ---ii  PP1"SRC"  1iiii1vv")
4617cf9345cSTaylor Simpson
4627cf9345cSTaylor Simpson
4637cf9345cSTaylor Simpson/*                 0 0--  Store Misc */
4647cf9345cSTaylor Simpson/*                 0 1xx  Available */
4657cf9345cSTaylor SimpsonSTD_ST_ENC(rb,    "1 000","ttttt")
4667cf9345cSTaylor SimpsonSTD_ST_ENC(rh,    "1 010","ttttt")
4677cf9345cSTaylor SimpsonSTD_ST_ENC(rf,    "1 011","ttttt")
4687cf9345cSTaylor SimpsonSTD_ST_ENC(ri,    "1 100","ttttt")
4697cf9345cSTaylor SimpsonSTD_ST_ENC(rd,    "1 110","ttttt")
4707cf9345cSTaylor SimpsonSTD_ST_ENC(rbnew, "1 101","00ttt")
4717cf9345cSTaylor SimpsonSTD_ST_ENC(rhnew, "1 101","01ttt")
4727cf9345cSTaylor SimpsonSTD_ST_ENC(rinew, "1 101","10ttt")
4737cf9345cSTaylor Simpson
4747cf9345cSTaylor SimpsonSTD_PST_ENC(rb,    "1 000","ttttt")
4757cf9345cSTaylor SimpsonSTD_PST_ENC(rh,    "1 010","ttttt")
4767cf9345cSTaylor SimpsonSTD_PST_ENC(rf,    "1 011","ttttt")
4777cf9345cSTaylor SimpsonSTD_PST_ENC(ri,    "1 100","ttttt")
4787cf9345cSTaylor SimpsonSTD_PST_ENC(rd,    "1 110","ttttt")
4797cf9345cSTaylor SimpsonSTD_PST_ENC(rbnew, "1 101","00ttt")
4807cf9345cSTaylor SimpsonSTD_PST_ENC(rhnew, "1 101","01ttt")
4817cf9345cSTaylor SimpsonSTD_PST_ENC(rinew, "1 101","10ttt")
4827cf9345cSTaylor Simpson
4837cf9345cSTaylor Simpson
4847cf9345cSTaylor Simpson
4857cf9345cSTaylor Simpson/* User */
4867cf9345cSTaylor Simpson/*                                   xx - st_misc */
4877cf9345cSTaylor Simpson/*                                                */
4887cf9345cSTaylor Simpson/*                               x bus/cache     */
4897cf9345cSTaylor Simpson/*                                    x store/cache     */
4907cf9345cSTaylor SimpsonDEF_ENC32(S2_allocframe,   ICLASS_ST" 000 01 00xxxxx PP000iii iiiiiiii")
491406c74f2STaylor SimpsonDEF_ENC32(S2_storew_locked,ICLASS_ST" 000 01 01sssss PP-ttttt ----00dd")
492406c74f2STaylor SimpsonDEF_ENC32(S4_stored_locked,ICLASS_ST" 000 01 11sssss PP0ttttt ----00dd")
4937cf9345cSTaylor SimpsonDEF_ENC32(Y2_dczeroa,      ICLASS_ST" 000 01 10sssss PP0----- --------")
4947cf9345cSTaylor Simpson
4957cf9345cSTaylor Simpson
4967cf9345cSTaylor SimpsonDEF_ENC32(Y2_barrier,      ICLASS_ST" 100 00 00----- PP------ 000-----")
4977cf9345cSTaylor SimpsonDEF_ENC32(Y2_syncht,       ICLASS_ST" 100 00 10----- PP------ --------")
4987cf9345cSTaylor Simpson
4997cf9345cSTaylor Simpson
5007cf9345cSTaylor Simpson
5017cf9345cSTaylor SimpsonDEF_ENC32(Y2_dccleana,     ICLASS_ST" 000 00 00sssss PP------ --------")
5027cf9345cSTaylor SimpsonDEF_ENC32(Y2_dcinva,       ICLASS_ST" 000 00 01sssss PP------ --------")
5037cf9345cSTaylor SimpsonDEF_ENC32(Y2_dccleaninva,  ICLASS_ST" 000 00 10sssss PP------ --------")
5047cf9345cSTaylor Simpson
505a5a8d98cSTaylor SimpsonDEF_ENC32(Y4_l2fetch,      ICLASS_ST" 011 00 00sssss PP-ttttt 000-----")
506a5a8d98cSTaylor SimpsonDEF_ENC32(Y5_l2fetch,      ICLASS_ST" 011 01 00sssss PP-ttttt --------")
507a5a8d98cSTaylor Simpson
5087cf9345cSTaylor Simpson/*******************************/
5097cf9345cSTaylor Simpson/*                             */
5107cf9345cSTaylor Simpson/*                             */
5117cf9345cSTaylor Simpson/*           JUMP              */
5127cf9345cSTaylor Simpson/*                             */
5137cf9345cSTaylor Simpson/*                             */
5147cf9345cSTaylor Simpson/*******************************/
5157cf9345cSTaylor Simpson
5167cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_J" ---- -------- PP------ --------",J)
5177cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_J" 0--- -------- PP------ --------",JUMPR_MISC)
5187cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_J" 10-- -------- PP------ --------",UCJUMP)
5197cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_J" 110- -------- PP------ --------",CJUMP)
5207cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_J" 110- -------- PP--!--- --------",J_DN,"Dot-new")
5217cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_J" 110- -------- PP-!---- --------",J_PT,"Predict-taken")
5227cf9345cSTaylor Simpson
5237cf9345cSTaylor Simpson
5247cf9345cSTaylor Simpson
5257cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_J" 0000 -------- PP------ --------","[#0] PC=(Rs), R31=return")
5267cf9345cSTaylor SimpsonDEF_ENC32(J2_callr,     ICLASS_J" 0000  101sssss  PP------  --------")
52759958d89STaylor SimpsonDEF_ENC32(J2_callrh,    ICLASS_J" 0000  110sssss  PP------  --------")
5287cf9345cSTaylor Simpson
5297cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_J" 0001 -------- PP------ --------","[#1] if (Pu) PC=(Rs), R31=return")
5307cf9345cSTaylor SimpsonDEF_ENC32(J2_callrt,    ICLASS_J" 0001  000sssss  PP----uu  --------")
5317cf9345cSTaylor SimpsonDEF_ENC32(J2_callrf,    ICLASS_J" 0001  001sssss  PP----uu  --------")
5327cf9345cSTaylor Simpson
5337cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_J" 0010 -------- PP------ --------","[#2] PC=(Rs); ")
5347cf9345cSTaylor SimpsonDEF_ENC32(J2_jumpr,      ICLASS_J" 0010  100sssss  PP------  --------")
53559958d89STaylor SimpsonDEF_ENC32(J2_jumprh,     ICLASS_J" 0010  110sssss  PP------  --------")
5367cf9345cSTaylor SimpsonDEF_ENC32(J4_hintjumpr,  ICLASS_J" 0010  101sssss  PP------  --------")
5377cf9345cSTaylor Simpson
5387cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_J" 0011 -------- PP------ --------","[#3] if (Pu) PC=(Rs) ")
5397cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprt,   ICLASS_J" 0011  010sssss  PP-00-uu  --------")
5407cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprf,   ICLASS_J" 0011  011sssss  PP-00-uu  --------")
5417cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprtpt,    ICLASS_J" 0011  010sssss  PP-10-uu  --------")
5427cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprfpt,    ICLASS_J" 0011  011sssss  PP-10-uu  --------")
5437cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprtnew,   ICLASS_J" 0011  010sssss  PP-01-uu  --------")
5447cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprfnew,   ICLASS_J" 0011  011sssss  PP-01-uu  --------")
5457cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprtnewpt, ICLASS_J" 0011  010sssss  PP-11-uu  --------")
5467cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprfnewpt, ICLASS_J" 0011  011sssss  PP-11-uu  --------")
5477cf9345cSTaylor Simpson
5487cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_J" 0100 -------- PP------ --------","[#4] (#u8) ")
5497cf9345cSTaylor SimpsonDEF_ENC32(J2_trap0,     ICLASS_J" 0100  00------  PP-iiiii  ---iii--")
5507cf9345cSTaylor SimpsonDEF_ENC32(J2_pause,     ICLASS_J" 0100  01------  PP-iiiii  ---iii--")
5517cf9345cSTaylor Simpson
5527cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_J" 0110 -------- PP------ --------","[#6] icop(Rs) ")
5537cf9345cSTaylor SimpsonDEF_ENC32(Y2_icinva,    ICLASS_J" 0110  110sssss  PP000---  --------")
5547cf9345cSTaylor Simpson
5557cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_J" 0111 -------- PP------ --------","[#7] () ")
5567cf9345cSTaylor SimpsonDEF_ENC32(Y2_isync,     ICLASS_J" 0111  11000000  PP0---00  00000010")
5577cf9345cSTaylor Simpson
5587cf9345cSTaylor Simpson/* JUMP */
5597cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_J" 100- -------- PP------ --------","[#8,9] PC=(#r22)")
5607cf9345cSTaylor SimpsonDEF_ENC32(J2_jump,      ICLASS_J" 100i  iiiiiiii  PPiiiiii  iiiiiii-")
5617cf9345cSTaylor Simpson
5627cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_J" 101- -------- PP------ --------","[#10,11] PC=(#r22), R31=return")
5637cf9345cSTaylor SimpsonDEF_ENC32(J2_call,      ICLASS_J" 101i  iiiiiiii  PPiiiiii  iiiiiii0")
5647cf9345cSTaylor Simpson
5657cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_J" 1100 -------- PP------ --------","[#12] if (Pu) PC=(#r15)")
5667cf9345cSTaylor SimpsonDEF_ENC32(J2_jumpt,  ICLASS_J" 1100  ii0iiiii  PPi00-uu  iiiiiii-")
5677cf9345cSTaylor SimpsonDEF_ENC32(J2_jumpf,  ICLASS_J" 1100  ii1iiiii  PPi00-uu  iiiiiii-")
5687cf9345cSTaylor SimpsonDEF_ENC32(J2_jumptpt,   ICLASS_J" 1100  ii0iiiii  PPi10-uu  iiiiiii-")
5697cf9345cSTaylor SimpsonDEF_ENC32(J2_jumpfpt,   ICLASS_J" 1100  ii1iiiii  PPi10-uu  iiiiiii-")
5707cf9345cSTaylor SimpsonDEF_ENC32(J2_jumptnew,  ICLASS_J" 1100  ii0iiiii  PPi01-uu  iiiiiii-")
5717cf9345cSTaylor SimpsonDEF_ENC32(J2_jumpfnew,  ICLASS_J" 1100  ii1iiiii  PPi01-uu  iiiiiii-")
5727cf9345cSTaylor SimpsonDEF_ENC32(J2_jumptnewpt,ICLASS_J" 1100  ii0iiiii  PPi11-uu  iiiiiii-")
5737cf9345cSTaylor SimpsonDEF_ENC32(J2_jumpfnewpt,ICLASS_J" 1100  ii1iiiii  PPi11-uu  iiiiiii-")
5747cf9345cSTaylor Simpson
5757cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_J" 1101 -------- PP------ --------","[#13] if (Pu) PC=(#r15), R31=return")
5767cf9345cSTaylor SimpsonDEF_ENC32(J2_callt,     ICLASS_J" 1101  ii0iiiii  PPi-0-uu  iiiiiii-")
5777cf9345cSTaylor SimpsonDEF_ENC32(J2_callf,     ICLASS_J" 1101  ii1iiiii  PPi-0-uu  iiiiiii-")
5787cf9345cSTaylor Simpson
5797cf9345cSTaylor Simpson
5807cf9345cSTaylor Simpson
5817cf9345cSTaylor Simpson
5827cf9345cSTaylor Simpson
5837cf9345cSTaylor Simpson
5847cf9345cSTaylor Simpson
5857cf9345cSTaylor Simpson/*******************************/
5867cf9345cSTaylor Simpson/*                             */
5877cf9345cSTaylor Simpson/*        V4                   */
5887cf9345cSTaylor Simpson/*   COMPOUND COMPARE-JUMPS    */
5897cf9345cSTaylor Simpson/*                             */
5907cf9345cSTaylor Simpson/*                             */
5917cf9345cSTaylor Simpson/*******************************/
5927cf9345cSTaylor Simpson
5937cf9345cSTaylor Simpson
5947cf9345cSTaylor Simpson/* EJP: this has to match what we have in htmldocs.py... so I will call it CJ, we can change it */
5957cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_CJ" 0--- -------- PP------ --------",CJ)
5967cf9345cSTaylor Simpson
5977cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_CJ" 00-- -------- -------- --------","[#0-3]  pd=cmp.xx(R,#u5) ; if ([!]p0.new) jump:[h] #s9:2 ")
5987cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_CJ" 010- -------- -------- --------","[#4,5]  pd=cmp.eq(R,R) ; if ([!]p0.new) jump:[h] #s9:2 ")
5997cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_CJ" 0110 -------- -------- --------","[#6]    Rd=#u6 ; jump #s9:2 ")
6007cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_CJ" 0111 -------- -------- --------","[#7]    Rd=Rs ; jump #s9:2 ")
6017cf9345cSTaylor Simpson
6027cf9345cSTaylor Simpson
6037cf9345cSTaylor Simpson#define CMPJMPI_ENC(TAG,OPC) \
6047cf9345cSTaylor SimpsonDEF_ENC32(TAG##i_tp0_jump_t,      ICLASS_CJ" 00 0 "OPC"  0iissss  PP1IIIII  iiiiiii-") \
6057cf9345cSTaylor SimpsonDEF_ENC32(TAG##i_fp0_jump_t,      ICLASS_CJ" 00 0 "OPC"  1iissss  PP1IIIII  iiiiiii-") \
6067cf9345cSTaylor SimpsonDEF_ENC32(TAG##i_tp0_jump_nt,     ICLASS_CJ" 00 0 "OPC"  0iissss  PP0IIIII  iiiiiii-") \
6077cf9345cSTaylor SimpsonDEF_ENC32(TAG##i_fp0_jump_nt,     ICLASS_CJ" 00 0 "OPC"  1iissss  PP0IIIII  iiiiiii-") \
6087cf9345cSTaylor Simpson\
6097cf9345cSTaylor SimpsonDEF_ENC32(TAG##i_tp1_jump_t,      ICLASS_CJ" 00 1 "OPC"  0iissss  PP1IIIII  iiiiiii-") \
6107cf9345cSTaylor SimpsonDEF_ENC32(TAG##i_fp1_jump_t,      ICLASS_CJ" 00 1 "OPC"  1iissss  PP1IIIII  iiiiiii-") \
6117cf9345cSTaylor SimpsonDEF_ENC32(TAG##i_tp1_jump_nt,     ICLASS_CJ" 00 1 "OPC"  0iissss  PP0IIIII  iiiiiii-") \
6127cf9345cSTaylor SimpsonDEF_ENC32(TAG##i_fp1_jump_nt,     ICLASS_CJ" 00 1 "OPC"  1iissss  PP0IIIII  iiiiiii-")
6137cf9345cSTaylor Simpson
6147cf9345cSTaylor SimpsonCMPJMPI_ENC(J4_cmpeq,"00")
6157cf9345cSTaylor SimpsonCMPJMPI_ENC(J4_cmpgt,"01")
6167cf9345cSTaylor SimpsonCMPJMPI_ENC(J4_cmpgtu,"10")
6177cf9345cSTaylor Simpson
6187cf9345cSTaylor Simpson
6197cf9345cSTaylor Simpson#define CMPJMP1I_ENC(TAG,OPC) \
6207cf9345cSTaylor SimpsonDEF_ENC32(TAG##_tp0_jump_t,      ICLASS_CJ" 00 0  11  0iissss  PP1---"OPC"  iiiiiii-") \
6217cf9345cSTaylor SimpsonDEF_ENC32(TAG##_fp0_jump_t,      ICLASS_CJ" 00 0  11  1iissss  PP1---"OPC"  iiiiiii-") \
6227cf9345cSTaylor SimpsonDEF_ENC32(TAG##_tp0_jump_nt,     ICLASS_CJ" 00 0  11  0iissss  PP0---"OPC"  iiiiiii-") \
6237cf9345cSTaylor SimpsonDEF_ENC32(TAG##_fp0_jump_nt,     ICLASS_CJ" 00 0  11  1iissss  PP0---"OPC"  iiiiiii-") \
6247cf9345cSTaylor Simpson\
6257cf9345cSTaylor SimpsonDEF_ENC32(TAG##_tp1_jump_t,      ICLASS_CJ" 00 1  11  0iissss  PP1---"OPC"  iiiiiii-") \
6267cf9345cSTaylor SimpsonDEF_ENC32(TAG##_fp1_jump_t,      ICLASS_CJ" 00 1  11  1iissss  PP1---"OPC"  iiiiiii-") \
6277cf9345cSTaylor SimpsonDEF_ENC32(TAG##_tp1_jump_nt,     ICLASS_CJ" 00 1  11  0iissss  PP0---"OPC"  iiiiiii-") \
6287cf9345cSTaylor SimpsonDEF_ENC32(TAG##_fp1_jump_nt,     ICLASS_CJ" 00 1  11  1iissss  PP0---"OPC"  iiiiiii-")
6297cf9345cSTaylor Simpson
6307cf9345cSTaylor SimpsonCMPJMP1I_ENC(J4_cmpeqn1,"00")
6317cf9345cSTaylor SimpsonCMPJMP1I_ENC(J4_cmpgtn1,"01")
6327cf9345cSTaylor SimpsonCMPJMP1I_ENC(J4_tstbit0,"11")
6337cf9345cSTaylor Simpson
6347cf9345cSTaylor Simpson
6357cf9345cSTaylor Simpson
6367cf9345cSTaylor Simpson#define CMPJMPR_ENC(TAG,OPC) \
6377cf9345cSTaylor SimpsonDEF_ENC32(TAG##_tp0_jump_t,       ICLASS_CJ" 01 0 "OPC"  0iissss  PP10tttt  iiiiiii-") \
6387cf9345cSTaylor SimpsonDEF_ENC32(TAG##_fp0_jump_t,       ICLASS_CJ" 01 0 "OPC"  1iissss  PP10tttt  iiiiiii-") \
6397cf9345cSTaylor SimpsonDEF_ENC32(TAG##_tp0_jump_nt,      ICLASS_CJ" 01 0 "OPC"  0iissss  PP00tttt  iiiiiii-") \
6407cf9345cSTaylor SimpsonDEF_ENC32(TAG##_fp0_jump_nt,      ICLASS_CJ" 01 0 "OPC"  1iissss  PP00tttt  iiiiiii-") \
6417cf9345cSTaylor Simpson\
6427cf9345cSTaylor SimpsonDEF_ENC32(TAG##_tp1_jump_t,       ICLASS_CJ" 01 0 "OPC"  0iissss  PP11tttt  iiiiiii-") \
6437cf9345cSTaylor SimpsonDEF_ENC32(TAG##_fp1_jump_t,       ICLASS_CJ" 01 0 "OPC"  1iissss  PP11tttt  iiiiiii-") \
6447cf9345cSTaylor SimpsonDEF_ENC32(TAG##_tp1_jump_nt,      ICLASS_CJ" 01 0 "OPC"  0iissss  PP01tttt  iiiiiii-") \
6457cf9345cSTaylor SimpsonDEF_ENC32(TAG##_fp1_jump_nt,      ICLASS_CJ" 01 0 "OPC"  1iissss  PP01tttt  iiiiiii-")
6467cf9345cSTaylor Simpson
6477cf9345cSTaylor SimpsonCMPJMPR_ENC(J4_cmpeq,"00")
6487cf9345cSTaylor SimpsonCMPJMPR_ENC(J4_cmpgt,"01")
6497cf9345cSTaylor SimpsonCMPJMPR_ENC(J4_cmpgtu,"10")
6507cf9345cSTaylor Simpson
6517cf9345cSTaylor Simpson
6527cf9345cSTaylor SimpsonDEF_ENC32(J4_jumpseti,            ICLASS_CJ" 0110  --iidddd  PPIIIIII  iiiiiii-")
6537cf9345cSTaylor SimpsonDEF_ENC32(J4_jumpsetr,            ICLASS_CJ" 0111  --iissss  PP--dddd  iiiiiii-")
6547cf9345cSTaylor Simpson
6557cf9345cSTaylor Simpson
6567cf9345cSTaylor SimpsonDEF_EXT_SPACE(EXT_CJ,             ICLASS_CJ"1 iii  iiiiiiii  PPiiiiii  iiiiiiii")
6577cf9345cSTaylor Simpson
6587cf9345cSTaylor Simpson
6597cf9345cSTaylor Simpson
6607cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_NCJ" 0--- -------- PP------ --------",NCJ)
6617cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_NCJ" 00-- -------- -------- --------","[#0-3] if (cmp.xx(R.new,R)) jump:[h] #s9:2 ")
6627cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_NCJ" 01-- -------- -------- --------","[#4-7] if (cmp.xx(R.new,#U5)) jump:[h] #s9:2 ")
6637cf9345cSTaylor Simpson
6647cf9345cSTaylor Simpson#define OPRJMP_ENC(TAG,OPC) \
6657cf9345cSTaylor SimpsonDEF_ENC32(TAG##_t_jumpnv_t,       ICLASS_NCJ" 00 "OPC"  0ii-sss  PP1ttttt  iiiiiii-") \
6667cf9345cSTaylor SimpsonDEF_ENC32(TAG##_f_jumpnv_t,       ICLASS_NCJ" 00 "OPC"  1ii-sss  PP1ttttt  iiiiiii-") \
6677cf9345cSTaylor SimpsonDEF_ENC32(TAG##_t_jumpnv_nt,      ICLASS_NCJ" 00 "OPC"  0ii-sss  PP0ttttt  iiiiiii-") \
6687cf9345cSTaylor SimpsonDEF_ENC32(TAG##_f_jumpnv_nt,      ICLASS_NCJ" 00 "OPC"  1ii-sss  PP0ttttt  iiiiiii-")
6697cf9345cSTaylor Simpson
6707cf9345cSTaylor SimpsonOPRJMP_ENC(J4_cmpeq,   "000")
6717cf9345cSTaylor SimpsonOPRJMP_ENC(J4_cmpgt,   "001")
6727cf9345cSTaylor SimpsonOPRJMP_ENC(J4_cmpgtu,  "010")
6737cf9345cSTaylor SimpsonOPRJMP_ENC(J4_cmplt,   "011")
6747cf9345cSTaylor SimpsonOPRJMP_ENC(J4_cmpltu,  "100")
6757cf9345cSTaylor Simpson
6767cf9345cSTaylor Simpson
6777cf9345cSTaylor Simpson#define OPIJMP_ENC(TAG,OPC) \
6787cf9345cSTaylor SimpsonDEF_ENC32(TAG##_t_jumpnv_t,       ICLASS_NCJ" 01 "OPC"  0ii-sss  PP1IIIII  iiiiiii-") \
6797cf9345cSTaylor SimpsonDEF_ENC32(TAG##_f_jumpnv_t,       ICLASS_NCJ" 01 "OPC"  1ii-sss  PP1IIIII  iiiiiii-") \
6807cf9345cSTaylor SimpsonDEF_ENC32(TAG##_t_jumpnv_nt,      ICLASS_NCJ" 01 "OPC"  0ii-sss  PP0IIIII  iiiiiii-") \
6817cf9345cSTaylor SimpsonDEF_ENC32(TAG##_f_jumpnv_nt,      ICLASS_NCJ" 01 "OPC"  1ii-sss  PP0IIIII  iiiiiii-")
6827cf9345cSTaylor Simpson
6837cf9345cSTaylor SimpsonOPIJMP_ENC(J4_cmpeqi,  "000")
6847cf9345cSTaylor SimpsonOPIJMP_ENC(J4_cmpgti,  "001")
6857cf9345cSTaylor SimpsonOPIJMP_ENC(J4_cmpgtui, "010")
6867cf9345cSTaylor Simpson
6877cf9345cSTaylor Simpson
6887cf9345cSTaylor Simpson#define OPI1JMP_ENC(TAG,OPC) \
6897cf9345cSTaylor SimpsonDEF_ENC32(TAG##_t_jumpnv_t,       ICLASS_NCJ" 01 "OPC"  0ii-sss  PP1-----  iiiiiii-") \
6907cf9345cSTaylor SimpsonDEF_ENC32(TAG##_f_jumpnv_t,       ICLASS_NCJ" 01 "OPC"  1ii-sss  PP1-----  iiiiiii-") \
6917cf9345cSTaylor SimpsonDEF_ENC32(TAG##_t_jumpnv_nt,      ICLASS_NCJ" 01 "OPC"  0ii-sss  PP0-----  iiiiiii-") \
6927cf9345cSTaylor SimpsonDEF_ENC32(TAG##_f_jumpnv_nt,      ICLASS_NCJ" 01 "OPC"  1ii-sss  PP0-----  iiiiiii-")
6937cf9345cSTaylor Simpson
6947cf9345cSTaylor SimpsonOPI1JMP_ENC(J4_cmpeqn1,  "100")
6957cf9345cSTaylor SimpsonOPI1JMP_ENC(J4_cmpgtn1,  "101")
6967cf9345cSTaylor SimpsonOPI1JMP_ENC(J4_tstbit0,  "011")
6977cf9345cSTaylor Simpson
6987cf9345cSTaylor Simpson
6997cf9345cSTaylor SimpsonDEF_EXT_SPACE(EXT_NCJ,             ICLASS_NCJ"1 iii  iiiiiiii  PPiiiiii  iiiiiiii")
7007cf9345cSTaylor Simpson
7017cf9345cSTaylor Simpson
7027cf9345cSTaylor Simpson
7037cf9345cSTaylor Simpson/*******************************/
7047cf9345cSTaylor Simpson/*                             */
7057cf9345cSTaylor Simpson/*                             */
7067cf9345cSTaylor Simpson/*           CR                */
7077cf9345cSTaylor Simpson/*                             */
7087cf9345cSTaylor Simpson/*                             */
7097cf9345cSTaylor Simpson/*******************************/
7107cf9345cSTaylor Simpson
7117cf9345cSTaylor Simpson
7127cf9345cSTaylor Simpson
7137cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_CR" ---- -------- PP------ --------",CR)
7147cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_CR" -0-- -------- PP------ --------",CRUSER)
7157cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_CR" -1-- -------- PP------ --------",CRSUPER)
7167cf9345cSTaylor Simpson
7177cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_CR" -!-- -------- PP------ --------",CR_sm,"Supervisor mode only")
7187cf9345cSTaylor Simpson
7197cf9345cSTaylor Simpson/* User CR ops */
7207cf9345cSTaylor Simpson
7217cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_CR" 0000  --------  PP------  --------","[#0] (Rs,#r8)")
7227cf9345cSTaylor SimpsonDEF_ENC32(J2_loop0r,    ICLASS_CR" 0000  000sssss  PP-iiiii  ---ii---")
7237cf9345cSTaylor SimpsonDEF_ENC32(J2_loop1r,    ICLASS_CR" 0000  001sssss  PP-iiiii  ---ii---")
7247cf9345cSTaylor SimpsonDEF_ENC32(J2_ploop1sr,  ICLASS_CR" 0000  101sssss  PP-iiiii  ---ii---")
7257cf9345cSTaylor SimpsonDEF_ENC32(J2_ploop2sr,  ICLASS_CR" 0000  110sssss  PP-iiiii  ---ii---")
7267cf9345cSTaylor SimpsonDEF_ENC32(J2_ploop3sr,  ICLASS_CR" 0000  111sssss  PP-iiiii  ---ii---")
7277cf9345cSTaylor Simpson
7287cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(     ICLASS_CR" 0001  --------  PP------  --------","[#1] (Rs,#r13)")
7297cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprz,     ICLASS_CR" 0001  00isssss  PPi0iiii  iiiiiii-")
7307cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprzpt,   ICLASS_CR" 0001  00isssss  PPi1iiii  iiiiiii-")
7317cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprnz,    ICLASS_CR" 0001  10isssss  PPi0iiii  iiiiiii-")
7327cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprnzpt,  ICLASS_CR" 0001  10isssss  PPi1iiii  iiiiiii-")
7337cf9345cSTaylor Simpson
7347cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprgtez,  ICLASS_CR" 0001  01isssss  PPi0iiii  iiiiiii-")
7357cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprgtezpt,ICLASS_CR" 0001  01isssss  PPi1iiii  iiiiiii-")
7367cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprltez,  ICLASS_CR" 0001  11isssss  PPi0iiii  iiiiiii-")
7377cf9345cSTaylor SimpsonDEF_ENC32(J2_jumprltezpt,ICLASS_CR" 0001  11isssss  PPi1iiii  iiiiiii-")
7387cf9345cSTaylor Simpson
7397cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_CR" 0010  --------  PP------  --------","[#2] Cd=Rs ")
7407cf9345cSTaylor SimpsonDEF_ENC32(A2_tfrrcr,    ICLASS_CR" 0010  001sssss  PP------  ---ddddd")
7417cf9345cSTaylor Simpson
7427cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_CR" 0011  --------  PP------  --------","[#3] Cdd=Rss ")
7437cf9345cSTaylor SimpsonDEF_ENC32(A4_tfrpcp,    ICLASS_CR" 0011  001sssss  PP------  ---ddddd")
7447cf9345cSTaylor Simpson
7457cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_CR" 1000  --------  PP------  --------","[#8] Rdd=Css ")
7467cf9345cSTaylor SimpsonDEF_ENC32(A4_tfrcpp,    ICLASS_CR" 1000  000sssss  PP------  ---ddddd")
7477cf9345cSTaylor Simpson
7487cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_CR" 1001  --------  PP------  --------","[#9] (#r8,#U10)")
7497cf9345cSTaylor SimpsonDEF_ENC32(J2_ploop1si,  ICLASS_CR" 1001  101IIIII  PP-iiiii  IIIii-II")
7507cf9345cSTaylor SimpsonDEF_ENC32(J2_ploop2si,  ICLASS_CR" 1001  110IIIII  PP-iiiii  IIIii-II")
7517cf9345cSTaylor SimpsonDEF_ENC32(J2_ploop3si,  ICLASS_CR" 1001  111IIIII  PP-iiiii  IIIii-II")
7527cf9345cSTaylor SimpsonDEF_ENC32(J2_loop0i,    ICLASS_CR" 1001  000IIIII  PP-iiiii  IIIii-II")
7537cf9345cSTaylor SimpsonDEF_ENC32(J2_loop1i,    ICLASS_CR" 1001  001IIIII  PP-iiiii  IIIii-II")
7547cf9345cSTaylor Simpson
7557cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_CR" 1010  --------  PP------  --------","[#10] Rd=Cs ")
7567cf9345cSTaylor SimpsonDEF_ENC32(A2_tfrcrr,    ICLASS_CR" 1010  000sssss  PP------  ---ddddd")
7577cf9345cSTaylor SimpsonDEF_ENC32(C4_addipc,    ICLASS_CR" 1010  01001001  PP-iiiii  i--ddddd")
7587cf9345cSTaylor Simpson
7597cf9345cSTaylor Simpson
7607cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_CR" 1011  --------  PP0-----  --------","[#11] Pd=(Ps,Pt,Pu)")
7617cf9345cSTaylor SimpsonDEF_ENC32(C2_and,       ICLASS_CR" 1011  0000--ss  PP0---tt  ------dd")
7627cf9345cSTaylor SimpsonDEF_ENC32(C2_or,        ICLASS_CR" 1011  0010--ss  PP0---tt  ------dd")
7637cf9345cSTaylor SimpsonDEF_ENC32(C2_xor,       ICLASS_CR" 1011  0100--ss  PP0---tt  ------dd")
7647cf9345cSTaylor SimpsonDEF_ENC32(C2_andn,      ICLASS_CR" 1011  0110--ss  PP0---tt  ------dd")
7657cf9345cSTaylor SimpsonDEF_ENC32(C2_any8,      ICLASS_CR" 1011  1000--ss  PP0-----  ------dd")
7667cf9345cSTaylor SimpsonDEF_ENC32(C2_all8,      ICLASS_CR" 1011  1010--ss  PP0-----  ------dd")
7677cf9345cSTaylor SimpsonDEF_ENC32(C2_not,       ICLASS_CR" 1011  1100--ss  PP0-----  ------dd")
7687cf9345cSTaylor SimpsonDEF_ENC32(C2_orn,       ICLASS_CR" 1011  1110--ss  PP0---tt  ------dd")
7697cf9345cSTaylor Simpson
7707cf9345cSTaylor SimpsonDEF_ENC32(C4_and_and,   ICLASS_CR" 1011  0001--ss  PP0---tt  uu----dd")
7717cf9345cSTaylor SimpsonDEF_ENC32(C4_and_or,    ICLASS_CR" 1011  0011--ss  PP0---tt  uu----dd")
7727cf9345cSTaylor SimpsonDEF_ENC32(C4_or_and,    ICLASS_CR" 1011  0101--ss  PP0---tt  uu----dd")
7737cf9345cSTaylor SimpsonDEF_ENC32(C4_or_or,     ICLASS_CR" 1011  0111--ss  PP0---tt  uu----dd")
7747cf9345cSTaylor SimpsonDEF_ENC32(C4_and_andn,  ICLASS_CR" 1011  1001--ss  PP0---tt  uu----dd")
7757cf9345cSTaylor SimpsonDEF_ENC32(C4_and_orn,   ICLASS_CR" 1011  1011--ss  PP0---tt  uu----dd")
7767cf9345cSTaylor SimpsonDEF_ENC32(C4_or_andn,   ICLASS_CR" 1011  1101--ss  PP0---tt  uu----dd")
7777cf9345cSTaylor SimpsonDEF_ENC32(C4_or_orn,    ICLASS_CR" 1011  1111--ss  PP0---tt  uu----dd")
7787cf9345cSTaylor Simpson
7797cf9345cSTaylor SimpsonDEF_ENC32(C4_fastcorner9,       ICLASS_CR"1011 0000--ss  PP1---tt 1--1--dd")
7807cf9345cSTaylor SimpsonDEF_ENC32(C4_fastcorner9_not,   ICLASS_CR"1011 0001--ss  PP1---tt 1--1--dd")
7817cf9345cSTaylor Simpson
7827cf9345cSTaylor Simpson
7837cf9345cSTaylor Simpson
7847cf9345cSTaylor Simpson/*******************************/
7857cf9345cSTaylor Simpson/*                             */
7867cf9345cSTaylor Simpson/*                             */
7877cf9345cSTaylor Simpson/*           M                 */
7887cf9345cSTaylor Simpson/*                             */
7897cf9345cSTaylor Simpson/*                             */
7907cf9345cSTaylor Simpson/*******************************/
7917cf9345cSTaylor Simpson
7927cf9345cSTaylor Simpson
7937cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_M" ---- -------- PP------ --------",M)
7947cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_M" !!!! -------- PP------ --------",M_RegType,"Register Type")
7957cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_M" ---- !!!----- PP------ --------",M_MajOp,"Major Opcode")
7967cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_M" ---- -------- PP------ !!!-----",M_MinOp,"Minor Opcode")
7977cf9345cSTaylor Simpson
7987cf9345cSTaylor Simpson
7997cf9345cSTaylor Simpson
8007cf9345cSTaylor Simpson#define SP_MPY(TAG,REGTYPE,DSTCHARS,SAT,RND,UNS)\
8017cf9345cSTaylor SimpsonDEF_ENC32(TAG##_ll_s0, ICLASS_M  REGTYPE "0"  UNS RND"sssss  PP-ttttt "SAT"00"   DSTCHARS)\
8027cf9345cSTaylor SimpsonDEF_ENC32(TAG##_lh_s0, ICLASS_M  REGTYPE "0"  UNS RND"sssss  PP-ttttt "SAT"01"   DSTCHARS)\
8037cf9345cSTaylor SimpsonDEF_ENC32(TAG##_hl_s0, ICLASS_M  REGTYPE "0"  UNS RND"sssss  PP-ttttt "SAT"10"   DSTCHARS)\
8047cf9345cSTaylor SimpsonDEF_ENC32(TAG##_hh_s0, ICLASS_M  REGTYPE "0"  UNS RND"sssss  PP-ttttt "SAT"11"   DSTCHARS)\
8057cf9345cSTaylor SimpsonDEF_ENC32(TAG##_ll_s1, ICLASS_M  REGTYPE "1"  UNS RND"sssss  PP-ttttt "SAT"00"   DSTCHARS)\
8067cf9345cSTaylor SimpsonDEF_ENC32(TAG##_lh_s1, ICLASS_M  REGTYPE "1"  UNS RND"sssss  PP-ttttt "SAT"01"   DSTCHARS)\
8077cf9345cSTaylor SimpsonDEF_ENC32(TAG##_hl_s1, ICLASS_M  REGTYPE "1"  UNS RND"sssss  PP-ttttt "SAT"10"   DSTCHARS)\
8087cf9345cSTaylor SimpsonDEF_ENC32(TAG##_hh_s1, ICLASS_M  REGTYPE "1"  UNS RND"sssss  PP-ttttt "SAT"11"   DSTCHARS)
8097cf9345cSTaylor Simpson
8107cf9345cSTaylor Simpson/* Double precision                   */
8117cf9345cSTaylor Simpson#define MPY_ENC(TAG,REGTYPE,DSTCHARS,SAT,RNDNAC,UNS,SHFT,VMIN2)\
8127cf9345cSTaylor SimpsonDEF_ENC32(TAG, ICLASS_M REGTYPE SHFT UNS RNDNAC"sssss  PP0ttttt "SAT VMIN2 DSTCHARS)
8137cf9345cSTaylor Simpson
8147cf9345cSTaylor Simpson#define MPYI_ENC(TAG,REGTYPE,DSTCHARS,RNDNAC,UNS,SHFT)\
8157cf9345cSTaylor SimpsonDEF_ENC32(TAG, ICLASS_M REGTYPE SHFT UNS RNDNAC"sssss  PP0iiiii iii" DSTCHARS)
8167cf9345cSTaylor Simpson
8177cf9345cSTaylor Simpson
8187cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 0000 -------- PP------ --------","[#0] Rd=(Rs,#u8)")
8197cf9345cSTaylor SimpsonMPYI_ENC(M2_mpysip,          "0000","ddddd","-","-","0"     )
8207cf9345cSTaylor SimpsonMPYI_ENC(M2_mpysin,          "0000","ddddd","-","-","1"     )
8217cf9345cSTaylor Simpson
8227cf9345cSTaylor Simpson
8237cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 0001 -------- PP------ --------","[#1] Rx=(Rs,#u8)")
8247cf9345cSTaylor SimpsonMPYI_ENC(M2_macsip,          "0001","xxxxx","-","-","0"     )
8257cf9345cSTaylor SimpsonMPYI_ENC(M2_macsin,          "0001","xxxxx","-","-","1"     )
8267cf9345cSTaylor Simpson
8277cf9345cSTaylor Simpson
8287cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 0010 -------- PP------ --------","[#2] Rx=(Rs,#s8)")
8297cf9345cSTaylor SimpsonMPYI_ENC(M2_accii,           "0010","xxxxx","-","-","0"     )
8307cf9345cSTaylor SimpsonMPYI_ENC(M2_naccii,          "0010","xxxxx","-","-","1"     )
8317cf9345cSTaylor Simpson
8327cf9345cSTaylor Simpson
8337cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 0011 -------- PP------ --------","[#3] Ry=(Ru,(Rs,Ry)) ")
8347cf9345cSTaylor SimpsonDEF_ENC32(M4_mpyrr_addr,ICLASS_M" 0011 000sssss PP-yyyyy ---uuuuu")
8357cf9345cSTaylor Simpson
8367cf9345cSTaylor Simpson
8377cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 0100 -------- PP------ --------","[#4] Rdd=(Rs,Rt)")
8387cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_M"         0100 -------- PP------ --!-----",Ma_tH,"Rt is High") /*Rt high */
8397cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_M"         0100 -------- PP------ -!------",Ma_sH,"Rs is High") /* Rs high */
8407cf9345cSTaylor SimpsonSP_MPY(M2_mpyd,              "0100","ddddd","-","0","0")
8417cf9345cSTaylor SimpsonSP_MPY(M2_mpyd_rnd,          "0100","ddddd","-","1","0")
8427cf9345cSTaylor SimpsonSP_MPY(M2_mpyud,             "0100","ddddd","-","0","1")
8437cf9345cSTaylor Simpson
8447cf9345cSTaylor Simpson
8457cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 0101 -------- PP------ --------","[#5] Rdd=(Rs,Rt)")
8467cf9345cSTaylor SimpsonMPY_ENC(M2_dpmpyss_s0,       "0101","ddddd","0","0","0","0","00")
8477cf9345cSTaylor SimpsonMPY_ENC(M2_dpmpyuu_s0,       "0101","ddddd","0","0","1","0","00")
8487cf9345cSTaylor SimpsonMPY_ENC(M2_vmpy2s_s0,        "0101","ddddd","1","0","0","0","01")
8497cf9345cSTaylor SimpsonMPY_ENC(M2_vmpy2s_s1,        "0101","ddddd","1","0","0","1","01")
8507cf9345cSTaylor SimpsonMPY_ENC(M2_cmpyi_s0,         "0101","ddddd","0","0","0","0","01")
8517cf9345cSTaylor SimpsonMPY_ENC(M2_cmpyr_s0,         "0101","ddddd","0","0","0","0","10")
8527cf9345cSTaylor SimpsonMPY_ENC(M2_cmpys_s0,         "0101","ddddd","1","0","0","0","10")
8537cf9345cSTaylor SimpsonMPY_ENC(M2_cmpys_s1,         "0101","ddddd","1","0","0","1","10")
8547cf9345cSTaylor SimpsonMPY_ENC(M2_cmpysc_s0,        "0101","ddddd","1","0","1","0","10")
8557cf9345cSTaylor SimpsonMPY_ENC(M2_cmpysc_s1,        "0101","ddddd","1","0","1","1","10")
8567cf9345cSTaylor SimpsonMPY_ENC(M2_vmpy2su_s0,       "0101","ddddd","1","0","0","0","11")
8577cf9345cSTaylor SimpsonMPY_ENC(M2_vmpy2su_s1,       "0101","ddddd","1","0","0","1","11")
8587cf9345cSTaylor SimpsonMPY_ENC(M4_pmpyw,            "0101","ddddd","1","0","1","0","11")
8597cf9345cSTaylor SimpsonMPY_ENC(M4_vpmpyh,           "0101","ddddd","1","0","1","1","11")
8607cf9345cSTaylor SimpsonMPY_ENC(M5_vmpybuu,          "0101","ddddd","0","0","0","1","01")
8617cf9345cSTaylor SimpsonMPY_ENC(M5_vmpybsu,          "0101","ddddd","0","0","1","0","01")
8627cf9345cSTaylor Simpson
8637cf9345cSTaylor Simpson
8647cf9345cSTaylor Simpson
8657cf9345cSTaylor Simpson
8667cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 0110 -------- PP------ --------","[#6] Rxx=(Rs,Rt)")
8677cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_M"         0110 -------- PP------ --!-----",Mb_tH,"Rt is High") /*Rt high */
8687cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_M"         0110 -------- PP------ -!------",Mb_sH,"Rs is High") /* Rs high */
8697cf9345cSTaylor SimpsonSP_MPY(M2_mpyd_acc,          "0110","xxxxx","0","0","0")
8707cf9345cSTaylor SimpsonSP_MPY(M2_mpyud_acc,         "0110","xxxxx","0","0","1")
8717cf9345cSTaylor SimpsonSP_MPY(M2_mpyd_nac,          "0110","xxxxx","0","1","0")
8727cf9345cSTaylor SimpsonSP_MPY(M2_mpyud_nac,         "0110","xxxxx","0","1","1")
8737cf9345cSTaylor Simpson
8747cf9345cSTaylor Simpson
8757cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 0111 -------- PP------ --------","[#7] Rxx=(Rs,Rt)")
8767cf9345cSTaylor SimpsonMPY_ENC(M2_dpmpyss_acc_s0,   "0111","xxxxx","0","0","0","0","00")
8777cf9345cSTaylor SimpsonMPY_ENC(M2_dpmpyss_nac_s0,   "0111","xxxxx","0","1","0","0","00")
8787cf9345cSTaylor SimpsonMPY_ENC(M2_dpmpyuu_acc_s0,   "0111","xxxxx","0","0","1","0","00")
8797cf9345cSTaylor SimpsonMPY_ENC(M2_dpmpyuu_nac_s0,   "0111","xxxxx","0","1","1","0","00")
8807cf9345cSTaylor SimpsonMPY_ENC(M2_vmac2s_s0,        "0111","xxxxx","1","0","0","0","01")
8817cf9345cSTaylor SimpsonMPY_ENC(M2_vmac2s_s1,        "0111","xxxxx","1","0","0","1","01")
8827cf9345cSTaylor SimpsonMPY_ENC(M2_cmaci_s0,         "0111","xxxxx","0","0","0","0","01")
8837cf9345cSTaylor SimpsonMPY_ENC(M2_cmacr_s0,         "0111","xxxxx","0","0","0","0","10")
8847cf9345cSTaylor SimpsonMPY_ENC(M2_cmacs_s0,         "0111","xxxxx","1","0","0","0","10")
8857cf9345cSTaylor SimpsonMPY_ENC(M2_cmacs_s1,         "0111","xxxxx","1","0","0","1","10")
8867cf9345cSTaylor SimpsonMPY_ENC(M2_cmacsc_s0,        "0111","xxxxx","1","0","1","0","10")
8877cf9345cSTaylor SimpsonMPY_ENC(M2_cmacsc_s1,        "0111","xxxxx","1","0","1","1","10")
8887cf9345cSTaylor SimpsonMPY_ENC(M2_vmac2,            "0111","xxxxx","0","1","0","0","01")
8897cf9345cSTaylor SimpsonMPY_ENC(M2_cnacs_s0,         "0111","xxxxx","1","0","0","0","11")
8907cf9345cSTaylor SimpsonMPY_ENC(M2_cnacs_s1,         "0111","xxxxx","1","0","0","1","11")
8917cf9345cSTaylor SimpsonMPY_ENC(M2_cnacsc_s0,        "0111","xxxxx","1","0","1","0","11")
8927cf9345cSTaylor SimpsonMPY_ENC(M2_cnacsc_s1,        "0111","xxxxx","1","0","1","1","11")
8937cf9345cSTaylor SimpsonMPY_ENC(M2_vmac2su_s0,       "0111","xxxxx","1","1","1","0","01")
8947cf9345cSTaylor SimpsonMPY_ENC(M2_vmac2su_s1,       "0111","xxxxx","1","1","1","1","01")
8957cf9345cSTaylor SimpsonMPY_ENC(M4_pmpyw_acc,        "0111","xxxxx","1","1","0","0","11")
8967cf9345cSTaylor SimpsonMPY_ENC(M4_vpmpyh_acc,       "0111","xxxxx","1","1","0","1","11")
8977cf9345cSTaylor SimpsonMPY_ENC(M5_vmacbuu,          "0111","xxxxx","0","0","0","1","01")
8987cf9345cSTaylor SimpsonMPY_ENC(M5_vmacbsu,          "0111","xxxxx","0","0","1","1","01")
8997cf9345cSTaylor Simpson
9007cf9345cSTaylor Simpson
9017cf9345cSTaylor Simpson
9027cf9345cSTaylor Simpson
9037cf9345cSTaylor Simpson
9047cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 1000 -------- PP------ --------","[#8] Rdd=(Rss,Rtt)")
9057cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmpyi_s0,       "1000","ddddd","0","0","0","0","00")
9067cf9345cSTaylor SimpsonMPY_ENC(M2_vdmpys_s0,        "1000","ddddd","1","0","0","0","00")
9077cf9345cSTaylor SimpsonMPY_ENC(M2_vdmpys_s1,        "1000","ddddd","1","0","0","1","00")
9087cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmpyi_s0c,      "1000","ddddd","0","0","1","0","00")
9097cf9345cSTaylor SimpsonMPY_ENC(M2_vabsdiffw,        "1000","ddddd","0","1","0","0","00")
9107cf9345cSTaylor SimpsonMPY_ENC(M6_vabsdiffub,       "1000","ddddd","0","1","0","1","00")
9117cf9345cSTaylor SimpsonMPY_ENC(M2_vabsdiffh,        "1000","ddddd","0","1","1","0","00")
9127cf9345cSTaylor SimpsonMPY_ENC(M6_vabsdiffb,        "1000","ddddd","0","1","1","1","00")
9137cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmpys_s1_h,     "1000","ddddd","1","1","0","1","00")
9147cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmpys_s1_l,     "1000","ddddd","1","1","1","1","00")
9157cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmpyr_s0c,      "1000","ddddd","0","1","1","0","01")
9167cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmpyr_s0,       "1000","ddddd","0","0","0","0","01")
9177cf9345cSTaylor SimpsonMPY_ENC(A2_vraddub,          "1000","ddddd","0","0","1","0","01")
9187cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyl_s0,         "1000","ddddd","1","0","0","0","01")
9197cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyl_s1,         "1000","ddddd","1","0","0","1","01")
9207cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyl_rs0,        "1000","ddddd","1","1","0","0","01")
9217cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyl_rs1,        "1000","ddddd","1","1","0","1","01")
9227cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyul_s0,        "1000","ddddd","1","0","1","0","01")
9237cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyul_s1,        "1000","ddddd","1","0","1","1","01")
9247cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyul_rs0,       "1000","ddddd","1","1","1","0","01")
9257cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyul_rs1,       "1000","ddddd","1","1","1","1","01")
9267cf9345cSTaylor SimpsonMPY_ENC(M2_vrmpy_s0,         "1000","ddddd","0","0","0","0","10")
9277cf9345cSTaylor SimpsonMPY_ENC(A2_vrsadub,          "1000","ddddd","0","0","1","0","10")
9287cf9345cSTaylor SimpsonMPY_ENC(M2_vmpy2es_s0,       "1000","ddddd","1","0","0","0","10")
9297cf9345cSTaylor SimpsonMPY_ENC(M2_vmpy2es_s1,       "1000","ddddd","1","0","0","1","10")
9307cf9345cSTaylor SimpsonMPY_ENC(M2_vcmpy_s0_sat_i,   "1000","ddddd","1","0","1","0","10")
9317cf9345cSTaylor SimpsonMPY_ENC(M2_vcmpy_s0_sat_r,   "1000","ddddd","1","1","0","0","10")
9327cf9345cSTaylor SimpsonMPY_ENC(M2_vcmpy_s1_sat_i,   "1000","ddddd","1","0","1","1","10")
9337cf9345cSTaylor SimpsonMPY_ENC(M2_vcmpy_s1_sat_r,   "1000","ddddd","1","1","0","1","10")
9347cf9345cSTaylor Simpson
9357cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyh_s0,         "1000","ddddd","1","0","0","0","11")
9367cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyh_s1,         "1000","ddddd","1","0","0","1","11")
9377cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyh_rs0,        "1000","ddddd","1","1","0","0","11")
9387cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyh_rs1,        "1000","ddddd","1","1","0","1","11")
9397cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyuh_s0,        "1000","ddddd","1","0","1","0","11")
9407cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyuh_s1,        "1000","ddddd","1","0","1","1","11")
9417cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyuh_rs0,       "1000","ddddd","1","1","1","0","11")
9427cf9345cSTaylor SimpsonMPY_ENC(M2_mmpyuh_rs1,       "1000","ddddd","1","1","1","1","11")
9437cf9345cSTaylor Simpson
9447cf9345cSTaylor SimpsonMPY_ENC(M4_vrmpyeh_s0,       "1000","ddddd","1","0","1","0","00")
9457cf9345cSTaylor SimpsonMPY_ENC(M4_vrmpyeh_s1,       "1000","ddddd","1","0","1","1","00")
9467cf9345cSTaylor SimpsonMPY_ENC(M4_vrmpyoh_s0,       "1000","ddddd","0","1","0","0","10")
9477cf9345cSTaylor SimpsonMPY_ENC(M4_vrmpyoh_s1,       "1000","ddddd","0","1","0","1","10")
9487cf9345cSTaylor SimpsonMPY_ENC(M5_vrmpybuu,         "1000","ddddd","0","0","0","1","01")
9497cf9345cSTaylor SimpsonMPY_ENC(M5_vrmpybsu,         "1000","ddddd","0","0","1","1","01")
9507cf9345cSTaylor SimpsonMPY_ENC(M5_vdmpybsu,         "1000","ddddd","0","1","0","1","01")
9517cf9345cSTaylor Simpson
9527cf9345cSTaylor SimpsonMPY_ENC(F2_dfadd,            "1000","ddddd","0","0","0","0","11")
9537cf9345cSTaylor SimpsonMPY_ENC(F2_dfsub,            "1000","ddddd","0","0","0","1","11")
9547cf9345cSTaylor SimpsonMPY_ENC(F2_dfmpyfix,         "1000","ddddd","0","0","1","0","11")
9557cf9345cSTaylor SimpsonMPY_ENC(F2_dfmin,            "1000","ddddd","0","0","1","1","11")
9567cf9345cSTaylor SimpsonMPY_ENC(F2_dfmax,            "1000","ddddd","0","1","0","0","11")
9577cf9345cSTaylor SimpsonMPY_ENC(F2_dfmpyll,          "1000","ddddd","0","1","0","1","11")
9587cf9345cSTaylor Simpson
9597cf9345cSTaylor SimpsonMPY_ENC(M7_dcmpyrw,          "1000","ddddd","0","0","0","1","10")
9607cf9345cSTaylor SimpsonMPY_ENC(M7_dcmpyrwc,         "1000","ddddd","0","0","1","1","10")
9617cf9345cSTaylor SimpsonMPY_ENC(M7_dcmpyiw,          "1000","ddddd","0","1","1","0","10")
9627cf9345cSTaylor SimpsonMPY_ENC(M7_dcmpyiwc,         "1000","ddddd","0","1","1","1","10")
9637cf9345cSTaylor Simpson
9647cf9345cSTaylor Simpson
9657cf9345cSTaylor Simpson
9667cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 1001 -------- PP------ --------","[#9] Rd=(Rss,Rtt)")
9677cf9345cSTaylor SimpsonMPY_ENC(M2_vdmpyrs_s0,       "1001","ddddd","0","0","0","0","00")
9687cf9345cSTaylor SimpsonMPY_ENC(M2_vdmpyrs_s1,       "1001","ddddd","0","0","0","1","00")
9697cf9345cSTaylor Simpson
9707cf9345cSTaylor SimpsonMPY_ENC(M7_wcmpyrw,          "1001","ddddd","0","0","1","0","00")
9717cf9345cSTaylor SimpsonMPY_ENC(M7_wcmpyrw_rnd,      "1001","ddddd","0","0","1","1","00")
9727cf9345cSTaylor SimpsonMPY_ENC(M7_wcmpyiw,          "1001","ddddd","0","1","0","0","00")
9737cf9345cSTaylor SimpsonMPY_ENC(M7_wcmpyiw_rnd,      "1001","ddddd","0","1","0","1","00")
9747cf9345cSTaylor Simpson
9757cf9345cSTaylor SimpsonMPY_ENC(M7_wcmpyrwc,         "1001","ddddd","0","1","1","0","00")
9767cf9345cSTaylor SimpsonMPY_ENC(M7_wcmpyrwc_rnd,     "1001","ddddd","0","1","1","1","00")
9777cf9345cSTaylor SimpsonMPY_ENC(M7_wcmpyiwc,         "1001","ddddd","1","0","0","0","00")
9787cf9345cSTaylor SimpsonMPY_ENC(M7_wcmpyiwc_rnd,     "1001","ddddd","1","0","0","1","00")
9797cf9345cSTaylor Simpson
9807cf9345cSTaylor Simpson
9817cf9345cSTaylor Simpson
9827cf9345cSTaylor SimpsonMPY_ENC(M2_vradduh,          "1001","ddddd","-","-","-","0","01")
9837cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmpys_s1rp_h,   "1001","ddddd","1","1","-","1","10")
9847cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmpys_s1rp_l,   "1001","ddddd","1","1","-","1","11")
9857cf9345cSTaylor SimpsonMPY_ENC(M2_vraddh,           "1001","ddddd","1","1","-","0","11")
9867cf9345cSTaylor Simpson
9877cf9345cSTaylor Simpson
9887cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 1010 -------- PP------ --------","[#10] Rxx=(Rss,Rtt)")
9897cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmaci_s0,       "1010","xxxxx","0","0","0","0","00")
9907cf9345cSTaylor SimpsonMPY_ENC(M2_vdmacs_s0,        "1010","xxxxx","1","0","0","0","00")
9917cf9345cSTaylor SimpsonMPY_ENC(M2_vdmacs_s1,        "1010","xxxxx","1","0","0","1","00")
9927cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmaci_s0c,      "1010","xxxxx","0","0","1","0","00")
9937cf9345cSTaylor SimpsonMPY_ENC(M2_vcmac_s0_sat_i,   "1010","xxxxx","1","0","1","0","00")
9947cf9345cSTaylor SimpsonMPY_ENC(M2_vcmac_s0_sat_r,   "1010","xxxxx","1","1","0","0","00")
9957cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmpys_acc_s1_h, "1010","xxxxx","1","1","0","1","00")
9967cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmpys_acc_s1_l, "1010","xxxxx","1","1","1","1","00")
9977cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmacr_s0,       "1010","xxxxx","0","0","0","0","01")
9987cf9345cSTaylor SimpsonMPY_ENC(A2_vraddub_acc,      "1010","xxxxx","0","0","1","0","01")
9997cf9345cSTaylor SimpsonMPY_ENC(M2_mmacls_s0,        "1010","xxxxx","1","0","0","0","01")
10007cf9345cSTaylor SimpsonMPY_ENC(M2_mmacls_s1,        "1010","xxxxx","1","0","0","1","01")
10017cf9345cSTaylor SimpsonMPY_ENC(M2_mmacls_rs0,       "1010","xxxxx","1","1","0","0","01")
10027cf9345cSTaylor SimpsonMPY_ENC(M2_mmacls_rs1,       "1010","xxxxx","1","1","0","1","01")
10037cf9345cSTaylor SimpsonMPY_ENC(M2_mmaculs_s0,       "1010","xxxxx","1","0","1","0","01")
10047cf9345cSTaylor SimpsonMPY_ENC(M2_mmaculs_s1,       "1010","xxxxx","1","0","1","1","01")
10057cf9345cSTaylor SimpsonMPY_ENC(M2_mmaculs_rs0,      "1010","xxxxx","1","1","1","0","01")
10067cf9345cSTaylor SimpsonMPY_ENC(M2_mmaculs_rs1,      "1010","xxxxx","1","1","1","1","01")
10077cf9345cSTaylor SimpsonMPY_ENC(M2_vrcmacr_s0c,      "1010","xxxxx","0","1","1","0","01")
10087cf9345cSTaylor SimpsonMPY_ENC(M2_vrmac_s0,         "1010","xxxxx","0","0","0","0","10")
10097cf9345cSTaylor SimpsonMPY_ENC(A2_vrsadub_acc,      "1010","xxxxx","0","0","1","0","10")
10107cf9345cSTaylor SimpsonMPY_ENC(M2_vmac2es_s0,       "1010","xxxxx","1","0","0","0","10")
10117cf9345cSTaylor SimpsonMPY_ENC(M2_vmac2es_s1,       "1010","xxxxx","1","0","0","1","10")
10127cf9345cSTaylor SimpsonMPY_ENC(M2_vmac2es,          "1010","xxxxx","0","1","0","0","10")
10137cf9345cSTaylor SimpsonMPY_ENC(M2_mmachs_s0,        "1010","xxxxx","1","0","0","0","11")
10147cf9345cSTaylor SimpsonMPY_ENC(M2_mmachs_s1,        "1010","xxxxx","1","0","0","1","11")
10157cf9345cSTaylor SimpsonMPY_ENC(M2_mmachs_rs0,       "1010","xxxxx","1","1","0","0","11")
10167cf9345cSTaylor SimpsonMPY_ENC(M2_mmachs_rs1,       "1010","xxxxx","1","1","0","1","11")
10177cf9345cSTaylor SimpsonMPY_ENC(M2_mmacuhs_s0,       "1010","xxxxx","1","0","1","0","11")
10187cf9345cSTaylor SimpsonMPY_ENC(M2_mmacuhs_s1,       "1010","xxxxx","1","0","1","1","11")
10197cf9345cSTaylor SimpsonMPY_ENC(M2_mmacuhs_rs0,      "1010","xxxxx","1","1","1","0","11")
10207cf9345cSTaylor SimpsonMPY_ENC(M2_mmacuhs_rs1,      "1010","xxxxx","1","1","1","1","11")
10217cf9345cSTaylor SimpsonMPY_ENC(M4_vrmpyeh_acc_s0,   "1010","xxxxx","1","1","0","0","10")
10227cf9345cSTaylor SimpsonMPY_ENC(M4_vrmpyeh_acc_s1,   "1010","xxxxx","1","1","0","1","10")
10237cf9345cSTaylor SimpsonMPY_ENC(M4_vrmpyoh_acc_s0,   "1010","xxxxx","1","1","1","0","10")
10247cf9345cSTaylor SimpsonMPY_ENC(M4_vrmpyoh_acc_s1,   "1010","xxxxx","1","1","1","1","10")
10257cf9345cSTaylor SimpsonMPY_ENC(M5_vrmacbuu,         "1010","xxxxx","0","0","0","1","01")
10267cf9345cSTaylor SimpsonMPY_ENC(M5_vrmacbsu,         "1010","xxxxx","0","0","1","1","01")
10277cf9345cSTaylor SimpsonMPY_ENC(M5_vdmacbsu,         "1010","xxxxx","0","1","0","0","01")
10287cf9345cSTaylor Simpson
10297cf9345cSTaylor SimpsonMPY_ENC(F2_dfmpylh,          "1010","xxxxx","0","0","0","0","11")
10307cf9345cSTaylor SimpsonMPY_ENC(F2_dfmpyhh,          "1010","xxxxx","0","0","0","1","11")
10317cf9345cSTaylor Simpson
10327cf9345cSTaylor Simpson
10337cf9345cSTaylor SimpsonMPY_ENC(M7_dcmpyrw_acc,      "1010","xxxxx","0","0","0","1","10")
10347cf9345cSTaylor SimpsonMPY_ENC(M7_dcmpyrwc_acc,     "1010","xxxxx","0","0","1","1","10")
10357cf9345cSTaylor SimpsonMPY_ENC(M7_dcmpyiw_acc,      "1010","xxxxx","0","1","1","0","10")
10367cf9345cSTaylor SimpsonMPY_ENC(M7_dcmpyiwc_acc,     "1010","xxxxx","1","0","1","0","10")
10377cf9345cSTaylor Simpson
10387cf9345cSTaylor Simpson
10397cf9345cSTaylor Simpson
10407cf9345cSTaylor Simpson
1041da74cd2dSTaylor SimpsonMPY_ENC(A5_ACS,              "1010","xxxxx","0","1","0","1","ee")
10420a65d286STaylor SimpsonMPY_ENC(A6_vminub_RdP,       "1010","ddddd","0","1","1","1","ee")
10437cf9345cSTaylor Simpson/*
10447cf9345cSTaylor Simpson*/
10457cf9345cSTaylor Simpson
10467cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 1011 -------- PP------ --------","[#11] Reserved")
10477cf9345cSTaylor SimpsonMPY_ENC(F2_sfadd,            "1011","ddddd","0","0","0","0","00")
10487cf9345cSTaylor SimpsonMPY_ENC(F2_sfsub,            "1011","ddddd","0","0","0","0","01")
10497cf9345cSTaylor SimpsonMPY_ENC(F2_sfmax,            "1011","ddddd","0","0","0","1","00")
10507cf9345cSTaylor SimpsonMPY_ENC(F2_sfmin,            "1011","ddddd","0","0","0","1","01")
10517cf9345cSTaylor SimpsonMPY_ENC(F2_sfmpy,            "1011","ddddd","0","0","1","0","00")
10527cf9345cSTaylor SimpsonMPY_ENC(F2_sffixupn,         "1011","ddddd","0","0","1","1","00")
10537cf9345cSTaylor SimpsonMPY_ENC(F2_sffixupd,         "1011","ddddd","0","0","1","1","01")
1054d934c16dSTaylor SimpsonMPY_ENC(F2_sfrecipa,         "1011","ddddd","1","1","1","1","ee")
10557cf9345cSTaylor Simpson
10567cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 1100 -------- PP------ --------","[#12] Rd=(Rs,Rt)")
10577cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_M"         1100 -------- PP------ --!-----",Mc_tH,"Rt is High") /*Rt high */
10587cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_M"         1100 -------- PP------ -!------",Mc_sH,"Rs is High") /* Rs high */
10597cf9345cSTaylor SimpsonSP_MPY(M2_mpy,               "1100","ddddd","0","0","0")
10607cf9345cSTaylor SimpsonSP_MPY(M2_mpy_sat,           "1100","ddddd","1","0","0")
10617cf9345cSTaylor SimpsonSP_MPY(M2_mpy_rnd,           "1100","ddddd","0","1","0")
10627cf9345cSTaylor SimpsonSP_MPY(M2_mpy_sat_rnd,       "1100","ddddd","1","1","0")
10637cf9345cSTaylor SimpsonSP_MPY(M2_mpyu,              "1100","ddddd","0","0","1")
10647cf9345cSTaylor Simpson
10657cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 1101 -------- PP------ --------","[#13] Rd=(Rs,Rt)")
10667cf9345cSTaylor Simpson/* EJP: same as mpyi MPY_ENC(M2_mpyui,            "1101","ddddd","0","0","1","0","00") */
10677cf9345cSTaylor SimpsonMPY_ENC(M2_mpyi,             "1101","ddddd","0","0","0","0","00")
10687cf9345cSTaylor SimpsonMPY_ENC(M2_mpy_up,           "1101","ddddd","0","0","0","0","01")
10697cf9345cSTaylor SimpsonMPY_ENC(M2_mpyu_up,          "1101","ddddd","0","0","1","0","01")
10707cf9345cSTaylor SimpsonMPY_ENC(M2_dpmpyss_rnd_s0,   "1101","ddddd","0","1","0","0","01")
10717cf9345cSTaylor SimpsonMPY_ENC(M2_cmpyrs_s0,        "1101","ddddd","1","1","0","0","10")
10727cf9345cSTaylor SimpsonMPY_ENC(M2_cmpyrs_s1,        "1101","ddddd","1","1","0","1","10")
10737cf9345cSTaylor SimpsonMPY_ENC(M2_cmpyrsc_s0,       "1101","ddddd","1","1","1","0","10")
10747cf9345cSTaylor SimpsonMPY_ENC(M2_cmpyrsc_s1,       "1101","ddddd","1","1","1","1","10")
10757cf9345cSTaylor SimpsonMPY_ENC(M2_vmpy2s_s0pack,    "1101","ddddd","1","1","0","0","11")
10767cf9345cSTaylor SimpsonMPY_ENC(M2_vmpy2s_s1pack,    "1101","ddddd","1","1","0","1","11")
10777cf9345cSTaylor SimpsonMPY_ENC(M2_hmmpyh_rs1,       "1101","ddddd","1","1","0","1","00")
10787cf9345cSTaylor SimpsonMPY_ENC(M2_hmmpyl_rs1,       "1101","ddddd","1","1","1","1","00")
10797cf9345cSTaylor Simpson
10807cf9345cSTaylor SimpsonMPY_ENC(M2_hmmpyh_s1,        "1101","ddddd","0","1","0","1","00")
10817cf9345cSTaylor SimpsonMPY_ENC(M2_hmmpyl_s1,        "1101","ddddd","0","1","0","1","01")
10827cf9345cSTaylor SimpsonMPY_ENC(M2_mpy_up_s1,        "1101","ddddd","0","1","0","1","10")
10837cf9345cSTaylor SimpsonMPY_ENC(M2_mpy_up_s1_sat,    "1101","ddddd","0","1","1","1","00")
10847cf9345cSTaylor SimpsonMPY_ENC(M2_mpysu_up,         "1101","ddddd","0","1","1","0","01")
10857cf9345cSTaylor Simpson
10867cf9345cSTaylor Simpson
10877cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 1110 -------- PP------ --------","[#14] Rx=(Rs,Rt)")
10887cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_M"         1110 -------- PP------ --!-----",Md_tH,"Rt is High") /*Rt high */
10897cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_M"         1110 -------- PP------ -!------",Md_sH,"Rs is High") /* Rs high */
10907cf9345cSTaylor SimpsonSP_MPY(M2_mpyu_acc,          "1110","xxxxx","0","0","1")
10917cf9345cSTaylor SimpsonSP_MPY(M2_mpy_acc,           "1110","xxxxx","0","0","0")
10927cf9345cSTaylor SimpsonSP_MPY(M2_mpy_acc_sat,       "1110","xxxxx","1","0","0")
10937cf9345cSTaylor SimpsonSP_MPY(M2_mpyu_nac,          "1110","xxxxx","0","1","1")
10947cf9345cSTaylor SimpsonSP_MPY(M2_mpy_nac,           "1110","xxxxx","0","1","0")
10957cf9345cSTaylor SimpsonSP_MPY(M2_mpy_nac_sat,       "1110","xxxxx","1","1","0")
10967cf9345cSTaylor Simpson
10977cf9345cSTaylor Simpson
10987cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_M" 1111 -------- PP------ --------","[#15] Rx=(Rs,Rt)")
10997cf9345cSTaylor SimpsonMPY_ENC(M2_maci,             "1111","xxxxx","0","0","0","0","00")
11007cf9345cSTaylor SimpsonMPY_ENC(M2_mnaci,            "1111","xxxxx","0","0","0","1","00")
11017cf9345cSTaylor SimpsonMPY_ENC(M2_acci,             "1111","xxxxx","0","0","0","0","01")
11027cf9345cSTaylor SimpsonMPY_ENC(M2_nacci,            "1111","xxxxx","0","0","0","1","01")
11037cf9345cSTaylor SimpsonMPY_ENC(M2_xor_xacc,         "1111","xxxxx","0","0","0","1","11")
11047cf9345cSTaylor SimpsonMPY_ENC(M2_subacc,           "1111","xxxxx","0","0","0","0","11")
11057cf9345cSTaylor Simpson
11067cf9345cSTaylor SimpsonMPY_ENC(M4_mac_up_s1_sat,    "1111","xxxxx","0","1","1","0","00")
11077cf9345cSTaylor SimpsonMPY_ENC(M4_nac_up_s1_sat,    "1111","xxxxx","0","1","1","0","01")
11087cf9345cSTaylor Simpson
11097cf9345cSTaylor SimpsonMPY_ENC(M4_and_and,          "1111","xxxxx","0","0","1","0","00")
11107cf9345cSTaylor SimpsonMPY_ENC(M4_and_or,           "1111","xxxxx","0","0","1","0","01")
11117cf9345cSTaylor SimpsonMPY_ENC(M4_and_xor,          "1111","xxxxx","0","0","1","0","10")
11127cf9345cSTaylor SimpsonMPY_ENC(M4_or_and,           "1111","xxxxx","0","0","1","0","11")
11137cf9345cSTaylor SimpsonMPY_ENC(M4_or_or,            "1111","xxxxx","0","0","1","1","00")
11147cf9345cSTaylor SimpsonMPY_ENC(M4_or_xor,           "1111","xxxxx","0","0","1","1","01")
11157cf9345cSTaylor SimpsonMPY_ENC(M4_xor_and,          "1111","xxxxx","0","0","1","1","10")
11167cf9345cSTaylor SimpsonMPY_ENC(M4_xor_or,           "1111","xxxxx","0","0","1","1","11")
11177cf9345cSTaylor Simpson
11187cf9345cSTaylor SimpsonMPY_ENC(M4_or_andn,          "1111","xxxxx","0","1","0","0","00")
11197cf9345cSTaylor SimpsonMPY_ENC(M4_and_andn,         "1111","xxxxx","0","1","0","0","01")
11207cf9345cSTaylor SimpsonMPY_ENC(M4_xor_andn,         "1111","xxxxx","0","1","0","0","10")
11217cf9345cSTaylor Simpson
11227cf9345cSTaylor SimpsonMPY_ENC(F2_sffma,            "1111","xxxxx","1","0","0","0","00")
11237cf9345cSTaylor SimpsonMPY_ENC(F2_sffms,            "1111","xxxxx","1","0","0","0","01")
11247cf9345cSTaylor Simpson
11257cf9345cSTaylor SimpsonMPY_ENC(F2_sffma_lib,        "1111","xxxxx","1","0","0","0","10")
11267cf9345cSTaylor SimpsonMPY_ENC(F2_sffms_lib,        "1111","xxxxx","1","0","0","0","11")
11277cf9345cSTaylor Simpson
11287cf9345cSTaylor SimpsonMPY_ENC(F2_sffma_sc,         "1111","xxxxx","1","1","1","0","uu")
11297cf9345cSTaylor Simpson
11307cf9345cSTaylor Simpson
11317cf9345cSTaylor Simpson/*******************************/
11327cf9345cSTaylor Simpson/*                             */
11337cf9345cSTaylor Simpson/*                             */
11347cf9345cSTaylor Simpson/*           ALU32_2op         */
11357cf9345cSTaylor Simpson/*                             */
11367cf9345cSTaylor Simpson/*                             */
11377cf9345cSTaylor Simpson/*******************************/
11387cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ADDI" ---- -------- PP------ --------",ALU32_ADDI)
11397cf9345cSTaylor Simpson
11407cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ALU2op" ---- -------- PP------ --------",ALU32_2op)
11417cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ALU2op" !--- -------- PP------ --------",A2_Rs,"No Rs read")
11427cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ALU2op" -!!! -------- PP------ --------",A2_MajOp,"Major Opcode")
11437cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ALU2op" ---- !!!----- PP------ --------",A2_MinOp,"Minor Opcode")
11447cf9345cSTaylor Simpson
11457cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ALU3op" -!!! -------- PP------ --------",A3_MajOp,"Major Opcode")
11467cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ALU3op" ---- !!!----- PP------ --------",A3_MinOp,"Minor Opcode")
11477cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ALU3op" ---- -------- PP------ --------",ALU32_3op)
11487cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ALU3op" !--- -------- PP------ --------",A3_P,"Predicated")
11497cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ALU3op" ---- -------- PP!----- --------",A3_DN,"Dot-new")
11507cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ALU3op" ---- -------- PP------ !-------",A3_PS,"Predicate sense")
11517cf9345cSTaylor Simpson
11527cf9345cSTaylor Simpson
11537cf9345cSTaylor Simpson/*************************/
11547cf9345cSTaylor Simpson/* Our good friend addi  */
11557cf9345cSTaylor Simpson/*************************/
11567cf9345cSTaylor SimpsonDEF_ENC32(A2_addi,    ICLASS_ADDI"  iiii iiisssss PPiiiiii iiiddddd")
11577cf9345cSTaylor Simpson
11587cf9345cSTaylor Simpson
11597cf9345cSTaylor Simpson/*******************************/
11607cf9345cSTaylor Simpson/* Standard ALU32 insns        */
11617cf9345cSTaylor Simpson/*******************************/
11627cf9345cSTaylor Simpson
11637cf9345cSTaylor Simpson#define ALU32_IRR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
11647cf9345cSTaylor SimpsonDEF_ENC32(TAG, ICLASS_ALU2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"iiiii "VMIN3 DSTCHARS)
11657cf9345cSTaylor Simpson
11667cf9345cSTaylor Simpson#define ALU32_RR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
11677cf9345cSTaylor SimpsonDEF_ENC32(TAG, ICLASS_ALU2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"----- "VMIN3 DSTCHARS)
11687cf9345cSTaylor Simpson
11697cf9345cSTaylor Simpson#define CONDA32_RR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
11707cf9345cSTaylor SimpsonDEF_ENC32(TAG##t,   ICLASS_ALU2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"-00uu "VMIN3 DSTCHARS)\
11717cf9345cSTaylor SimpsonDEF_ENC32(TAG##f,   ICLASS_ALU2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"-10uu "VMIN3 DSTCHARS)\
11727cf9345cSTaylor SimpsonDEF_ENC32(TAG##tnew,ICLASS_ALU2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"-01uu "VMIN3 DSTCHARS)\
11737cf9345cSTaylor SimpsonDEF_ENC32(TAG##fnew,ICLASS_ALU2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"-11uu "VMIN3 DSTCHARS)
11747cf9345cSTaylor Simpson
11757cf9345cSTaylor Simpson
11767cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0000 -------- PP------ --------","[#0] (Pu) Rd=(Rs)")
11777cf9345cSTaylor SimpsonDEF_FIELD32(            ICLASS_ALU2op" 0000 -------- PP!----- --------",A32a_C,"Conditional")
11787cf9345cSTaylor SimpsonDEF_FIELD32(            ICLASS_ALU2op" 0000 -------- PP--!--- --------",A32a_S,"Predicate sense")
11797cf9345cSTaylor SimpsonDEF_FIELD32(            ICLASS_ALU2op" 0000 -------- PP---!-- --------",A32a_dn,"Dot-new")
11807cf9345cSTaylor Simpson
11817cf9345cSTaylor SimpsonALU32_RR_ENC(A2_aslh,                 "0000","000","0","---","ddddd")
11827cf9345cSTaylor SimpsonALU32_RR_ENC(A2_asrh,                 "0000","001","0","---","ddddd")
11837cf9345cSTaylor SimpsonALU32_RR_ENC(A2_tfr,                  "0000","011","0","---","ddddd")
11847cf9345cSTaylor SimpsonALU32_RR_ENC(A2_sxtb,                 "0000","101","0","---","ddddd")
11857cf9345cSTaylor SimpsonALU32_RR_ENC(A2_zxth,                 "0000","110","0","---","ddddd")
11867cf9345cSTaylor SimpsonALU32_RR_ENC(A2_sxth,                 "0000","111","0","---","ddddd")
11877cf9345cSTaylor Simpson
11887cf9345cSTaylor SimpsonCONDA32_RR_ENC(A4_paslh,               "0000","000","1","---","ddddd")
11897cf9345cSTaylor SimpsonCONDA32_RR_ENC(A4_pasrh,               "0000","001","1","---","ddddd")
11907cf9345cSTaylor SimpsonCONDA32_RR_ENC(A4_pzxtb,               "0000","100","1","---","ddddd")
11917cf9345cSTaylor SimpsonCONDA32_RR_ENC(A4_psxtb,               "0000","101","1","---","ddddd")
11927cf9345cSTaylor SimpsonCONDA32_RR_ENC(A4_pzxth,               "0000","110","1","---","ddddd")
11937cf9345cSTaylor SimpsonCONDA32_RR_ENC(A4_psxth,               "0000","111","1","---","ddddd")
11947cf9345cSTaylor Simpson
11957cf9345cSTaylor Simpson
11967cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0001 -------- PP------ --------","[#1] Rx=(#u16)")
11977cf9345cSTaylor SimpsonDEF_ENC32(A2_tfril,     ICLASS_ALU2op" 0001 ii1xxxxx PPiiiiii iiiiiiii")
11987cf9345cSTaylor Simpson
11997cf9345cSTaylor Simpson
12007cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0010 -------- PP------ --------","[#2] Rx=(#u16)")
12017cf9345cSTaylor SimpsonDEF_ENC32(A2_tfrih,     ICLASS_ALU2op" 0010 ii1xxxxx PPiiiiii iiiiiiii")
12027cf9345cSTaylor Simpson
12037cf9345cSTaylor Simpson
12047cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0011 -------- PP------ --------","[#3] Rd=(Pu,Rs,#s8)")
12057cf9345cSTaylor SimpsonDEF_ENC32(C2_muxir,     ICLASS_ALU2op" 0011 0uusssss PP0iiiii iiiddddd")
12067cf9345cSTaylor SimpsonDEF_ENC32(C2_muxri,     ICLASS_ALU2op" 0011 1uusssss PP0iiiii iiiddddd")
12077cf9345cSTaylor Simpson
12087cf9345cSTaylor SimpsonDEF_ENC32(A4_combineri, ICLASS_ALU2op" 0011 -00sssss PP1iiiii iiiddddd") /* Rdd = (Rs,#s8) */
12097cf9345cSTaylor SimpsonDEF_ENC32(A4_combineir, ICLASS_ALU2op" 0011 -01sssss PP1iiiii iiiddddd") /* Rdd = (Rs,#s8) */
12107cf9345cSTaylor SimpsonDEF_ENC32(A4_rcmpeqi,   ICLASS_ALU2op" 0011 -10sssss PP1iiiii iiiddddd") /* Rd = (Rs,#s8) */
12117cf9345cSTaylor SimpsonDEF_ENC32(A4_rcmpneqi,  ICLASS_ALU2op" 0011 -11sssss PP1iiiii iiiddddd") /* Rd = (Rs,#s8) */
12127cf9345cSTaylor Simpson
12137cf9345cSTaylor Simpson
12147cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0100 -------- PP------ --------","[#4] (Pu) Rd=(Rs,#s8)")
12157cf9345cSTaylor SimpsonDEF_FIELD32(            ICLASS_ALU2op" 0100 -------- PP!----- --------",A32a_DN,"Dot-new")
12167cf9345cSTaylor SimpsonDEF_FIELD32(            ICLASS_ALU2op" 0100 !------- PP------ --------",A32a_PS,"Predicate sense")
12177cf9345cSTaylor SimpsonDEF_ENC32(A2_paddit,    ICLASS_ALU2op" 0100 0uusssss PP0iiiii iiiddddd")
12187cf9345cSTaylor SimpsonDEF_ENC32(A2_padditnew, ICLASS_ALU2op" 0100 0uusssss PP1iiiii iiiddddd")
12197cf9345cSTaylor SimpsonDEF_ENC32(A2_paddif,    ICLASS_ALU2op" 0100 1uusssss PP0iiiii iiiddddd")
12207cf9345cSTaylor SimpsonDEF_ENC32(A2_paddifnew, ICLASS_ALU2op" 0100 1uusssss PP1iiiii iiiddddd")
12217cf9345cSTaylor Simpson
12227cf9345cSTaylor Simpson
12237cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(     ICLASS_ALU2op" 0101 -------- PP------ --------","[#5] Pd=(Rs,#s10)")
12247cf9345cSTaylor SimpsonDEF_ENC32(C2_cmpeqi,     ICLASS_ALU2op" 0101 00isssss PPiiiiii iii000dd")
12257cf9345cSTaylor SimpsonDEF_ENC32(C2_cmpgti,     ICLASS_ALU2op" 0101 01isssss PPiiiiii iii000dd")
12267cf9345cSTaylor SimpsonDEF_ENC32(C2_cmpgtui,    ICLASS_ALU2op" 0101 100sssss PPiiiiii iii000dd")
12277cf9345cSTaylor Simpson
12287cf9345cSTaylor SimpsonDEF_ENC32(C4_cmpneqi,    ICLASS_ALU2op" 0101 00isssss PPiiiiii iii100dd")
12297cf9345cSTaylor SimpsonDEF_ENC32(C4_cmpltei,    ICLASS_ALU2op" 0101 01isssss PPiiiiii iii100dd")
12307cf9345cSTaylor SimpsonDEF_ENC32(C4_cmplteui,   ICLASS_ALU2op" 0101 100sssss PPiiiiii iii100dd")
12317cf9345cSTaylor Simpson
12327cf9345cSTaylor Simpson
12337cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0110 -------- PP------ --------","[#6] Rd=(Rs,#s10)")
12347cf9345cSTaylor SimpsonALU32_IRR_ENC(A2_andir,               "0110","00i","i","iii","ddddd")
12357cf9345cSTaylor SimpsonALU32_IRR_ENC(A2_subri,               "0110","01i","i","iii","ddddd")
12367cf9345cSTaylor SimpsonALU32_IRR_ENC(A2_orir,                "0110","10i","i","iii","ddddd")
12377cf9345cSTaylor Simpson
12387cf9345cSTaylor Simpson
12397cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0111 -------- PP------ --------","[#7] Reserved")
12407cf9345cSTaylor Simpson
12417cf9345cSTaylor Simpson
12427cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 1000 -------- PP------ --------","[#8] Rd=#s16")
12437cf9345cSTaylor SimpsonDEF_ENC32(A2_tfrsi,     ICLASS_ALU2op" 1000 ii-iiiii PPiiiiii iiiddddd")
12447cf9345cSTaylor Simpson
12457cf9345cSTaylor Simpson
12467cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 1001 -------- PP------ --------","[#9] Reserved")
12477cf9345cSTaylor Simpson
12487cf9345cSTaylor Simpson
12497cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 101- -------- PP------ --------","[#10,#11] Rd=(Pu,#s8,#S8)")
12507cf9345cSTaylor SimpsonDEF_ENC32(C2_muxii,     ICLASS_ALU2op" 101u uIIIIIII PPIiiiii iiiddddd")
12517cf9345cSTaylor Simpson
12527cf9345cSTaylor Simpson
12537cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 1100 -------- PP------ --------","[#12] Rdd=(#s8,#S8)")
12547cf9345cSTaylor SimpsonDEF_ENC32(A2_combineii, ICLASS_ALU2op" 1100 0IIIIIII PPIiiiii iiiddddd")
12557cf9345cSTaylor SimpsonDEF_ENC32(A4_combineii, ICLASS_ALU2op" 1100 1--IIIII PPIiiiii iiiddddd")
12567cf9345cSTaylor Simpson
12577cf9345cSTaylor Simpson
12587cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 1101 -------- PP------ --------","[#13] Reserved")
12597cf9345cSTaylor Simpson
12607cf9345cSTaylor Simpson
12617cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 1110 -------- PP------ --------","[#14] (Pu) Rd=#s12")
12627cf9345cSTaylor SimpsonDEF_FIELD32(            ICLASS_ALU2op" 1110 ---0---- PP!----- --------",A32c_DN,"Dot-new")
12637cf9345cSTaylor SimpsonDEF_FIELD32(            ICLASS_ALU2op" 1110 !--0---- PP------ --------",A32c_PS,"Predicate sense")
12647cf9345cSTaylor SimpsonDEF_ENC32(C2_cmovenewit,ICLASS_ALU2op" 1110 0uu0iiii PP1iiiii iiiddddd")
12657cf9345cSTaylor SimpsonDEF_ENC32(C2_cmovenewif,ICLASS_ALU2op" 1110 1uu0iiii PP1iiiii iiiddddd")
12667cf9345cSTaylor SimpsonDEF_ENC32(C2_cmoveit,   ICLASS_ALU2op" 1110 0uu0iiii PP0iiiii iiiddddd")
12677cf9345cSTaylor SimpsonDEF_ENC32(C2_cmoveif,   ICLASS_ALU2op" 1110 1uu0iiii PP0iiiii iiiddddd")
12687cf9345cSTaylor Simpson
12697cf9345cSTaylor Simpson
12707cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(    ICLASS_ALU2op" 1111 -------- PP------ --------","[#15] nop")
12717cf9345cSTaylor SimpsonDEF_ENC32(A2_nop,       ICLASS_ALU2op" 1111 -------- PP------ --------")
12727cf9345cSTaylor Simpson
12737cf9345cSTaylor Simpson
12747cf9345cSTaylor Simpson
12757cf9345cSTaylor Simpson
12767cf9345cSTaylor Simpson
12777cf9345cSTaylor Simpson
12787cf9345cSTaylor Simpson
12797cf9345cSTaylor Simpson
12807cf9345cSTaylor Simpson
12817cf9345cSTaylor Simpson
12827cf9345cSTaylor Simpson
12837cf9345cSTaylor Simpson
12847cf9345cSTaylor Simpson/*******************************/
12857cf9345cSTaylor Simpson/*                             */
12867cf9345cSTaylor Simpson/*                             */
12877cf9345cSTaylor Simpson/*    ALU32_3op                */
12887cf9345cSTaylor Simpson/*                             */
12897cf9345cSTaylor Simpson/*                             */
12907cf9345cSTaylor Simpson/*******************************/
12917cf9345cSTaylor Simpson
12927cf9345cSTaylor Simpson
12937cf9345cSTaylor Simpson#define V2A32_RRR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
12947cf9345cSTaylor SimpsonDEF_ENC32(TAG, ICLASS_ALU3op" "MAJ4"  "MIN3"sssss  PP"SMOD1"ttttt "VMIN3 DSTCHARS)
12957cf9345cSTaylor Simpson
12967cf9345cSTaylor Simpson#define V2A32_RR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
12977cf9345cSTaylor SimpsonDEF_ENC32(TAG, ICLASS_ALU3op" "MAJ4"  "MIN3"sssss  PP"SMOD1"----- "VMIN3 DSTCHARS)
12987cf9345cSTaylor Simpson
12997cf9345cSTaylor Simpson
13007cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  0000 -------- PP------ --------","[#0] Reserved")
13017cf9345cSTaylor Simpson
13027cf9345cSTaylor Simpson
13037cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  0001 -------- PP------ --------","[#1] Rd=(Rs,Rt)")
13047cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_and,              "0001","000","-","---","ddddd")
13057cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_or,               "0001","001","-","---","ddddd")
13067cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_xor,              "0001","011","-","---","ddddd")
13077cf9345cSTaylor SimpsonV2A32_RRR_ENC(A4_andn,             "0001","100","-","---","ddddd")
13087cf9345cSTaylor SimpsonV2A32_RRR_ENC(A4_orn,              "0001","101","-","---","ddddd")
13097cf9345cSTaylor Simpson
13107cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  0010 -------- PP------ --------","[#2] Pd=(Rs,Rt)")
13117cf9345cSTaylor SimpsonV2A32_RRR_ENC(C2_cmpeq,            "0010","-00","-","---","000dd")
13127cf9345cSTaylor SimpsonV2A32_RRR_ENC(C2_cmpgt,            "0010","-10","-","---","000dd")
13137cf9345cSTaylor SimpsonV2A32_RRR_ENC(C2_cmpgtu,           "0010","-11","-","---","000dd")
13147cf9345cSTaylor Simpson
13157cf9345cSTaylor SimpsonV2A32_RRR_ENC(C4_cmpneq,           "0010","-00","-","---","100dd")
13167cf9345cSTaylor SimpsonV2A32_RRR_ENC(C4_cmplte,           "0010","-10","-","---","100dd")
13177cf9345cSTaylor SimpsonV2A32_RRR_ENC(C4_cmplteu,          "0010","-11","-","---","100dd")
13187cf9345cSTaylor Simpson
13197cf9345cSTaylor Simpson
13207cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  0011 -------- PP------ --------","[#3] Rd=(Rs,Rt)")
13217cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_add,              "0011","000","-","---","ddddd")
13227cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_sub,              "0011","001","-","---","ddddd")
13237cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_combine_hh,       "0011","100","-","---","ddddd")
13247cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_combine_hl,       "0011","101","-","---","ddddd")
13257cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_combine_lh,       "0011","110","-","---","ddddd")
13267cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_combine_ll,       "0011","111","-","---","ddddd")
13277cf9345cSTaylor SimpsonV2A32_RRR_ENC(A4_rcmpeq,           "0011","010","-","---","ddddd")
13287cf9345cSTaylor SimpsonV2A32_RRR_ENC(A4_rcmpneq,          "0011","011","-","---","ddddd")
13297cf9345cSTaylor Simpson
13307cf9345cSTaylor Simpson
13317cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  0100 -------- PP------ --------","[#4] Rd=(Pu,Rs,Rt)")
13327cf9345cSTaylor SimpsonV2A32_RRR_ENC(C2_mux,              "0100","---","-","-uu","ddddd")
13337cf9345cSTaylor Simpson
13347cf9345cSTaylor Simpson
13357cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  0101 -------- PP------ --------","[#5] Rdd=(Rs,Rt)")
13367cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_combinew,         "0101","0--","-","---","ddddd")
13377cf9345cSTaylor SimpsonV2A32_RRR_ENC(S2_packhl,           "0101","1--","-","---","ddddd")
13387cf9345cSTaylor Simpson
13397cf9345cSTaylor Simpson
13407cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  0110 -------- PP------ --------","[#6] Rd=(Rs,Rt)")
13417cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_svaddh,           "0110","000","-","---","ddddd")
13427cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_svaddhs,          "0110","001","-","---","ddddd")
13437cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_svadduhs,         "0110","011","-","---","ddddd")
13447cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_svsubh,           "0110","100","-","---","ddddd")
13457cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_svsubhs,          "0110","101","-","---","ddddd")
13467cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_svsubuhs,         "0110","111","-","---","ddddd")
13477cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_addsat,           "0110","010","-","---","ddddd")
13487cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_subsat,           "0110","110","-","---","ddddd")
13497cf9345cSTaylor Simpson
13507cf9345cSTaylor Simpson
13517cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  0111 -------- PP------ --------","[#7] Rd=(Rs,Rt)")
13527cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_svavgh,           "0111","-00","-","---","ddddd")
13537cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_svavghs,          "0111","-01","-","---","ddddd")
13547cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_svnavgh,          "0111","-11","-","---","ddddd")
13557cf9345cSTaylor Simpson
13567cf9345cSTaylor Simpson
13577cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  1000 -------- PP------ --------","[#8] Reserved")
13587cf9345cSTaylor Simpson
13597cf9345cSTaylor Simpson
13607cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  1001 -------- PP------ --------","[#9] (Pu) Rd=(Rs,Rt)")
13617cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_pandt,            "1001","-00","0","0uu","ddddd")
13627cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_pandtnew,         "1001","-00","1","0uu","ddddd")
13637cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_pandf,            "1001","-00","0","1uu","ddddd")
13647cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_pandfnew,         "1001","-00","1","1uu","ddddd")
13657cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_port,             "1001","-01","0","0uu","ddddd")
13667cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_portnew,          "1001","-01","1","0uu","ddddd")
13677cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_porf,             "1001","-01","0","1uu","ddddd")
13687cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_porfnew,          "1001","-01","1","1uu","ddddd")
13697cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_pxort,            "1001","-11","0","0uu","ddddd")
13707cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_pxortnew,         "1001","-11","1","0uu","ddddd")
13717cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_pxorf,            "1001","-11","0","1uu","ddddd")
13727cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_pxorfnew,         "1001","-11","1","1uu","ddddd")
13737cf9345cSTaylor Simpson
13747cf9345cSTaylor Simpson
13757cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  1010 -------- PP------ --------","[#10] Reserved")
13767cf9345cSTaylor Simpson
13777cf9345cSTaylor Simpson
13787cf9345cSTaylor Simpson
13797cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  1011 -------- PP------ --------","[#11] (Pu) Rd=(Rs,Rt)")
13807cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_paddt,            "1011","0-0","0","0uu","ddddd")
13817cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_paddtnew,         "1011","0-0","1","0uu","ddddd")
13827cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_paddf,            "1011","0-0","0","1uu","ddddd")
13837cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_paddfnew,         "1011","0-0","1","1uu","ddddd")
13847cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_psubt,            "1011","0-1","0","0uu","ddddd")
13857cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_psubtnew,         "1011","0-1","1","0uu","ddddd")
13867cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_psubf,            "1011","0-1","0","1uu","ddddd")
13877cf9345cSTaylor SimpsonV2A32_RRR_ENC(A2_psubfnew,         "1011","0-1","1","1uu","ddddd")
13887cf9345cSTaylor Simpson
13897cf9345cSTaylor Simpson
13907cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  1100 -------- PP------ --------","[#12] Reserved")
13917cf9345cSTaylor Simpson
13927cf9345cSTaylor Simpson
13937cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  1101 -------- PP------ --------","[#13] (Pu) Rdd=(Rs,Rt)")
13947cf9345cSTaylor SimpsonV2A32_RRR_ENC(C2_ccombinewnewt,    "1101","000","1","0uu","ddddd")
13957cf9345cSTaylor SimpsonV2A32_RRR_ENC(C2_ccombinewnewf,    "1101","000","1","1uu","ddddd")
13967cf9345cSTaylor SimpsonV2A32_RRR_ENC(C2_ccombinewt,       "1101","000","0","0uu","ddddd")
13977cf9345cSTaylor SimpsonV2A32_RRR_ENC(C2_ccombinewf,       "1101","000","0","1uu","ddddd")
13987cf9345cSTaylor Simpson
13997cf9345cSTaylor Simpson
14007cf9345cSTaylor Simpson
14017cf9345cSTaylor Simpson
14027cf9345cSTaylor Simpson
14037cf9345cSTaylor Simpson
14047cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU3op"  1110 -------- PP------ --------","[#14] Reserved")
14057cf9345cSTaylor Simpson
14067cf9345cSTaylor Simpson
14077cf9345cSTaylor Simpson
14087cf9345cSTaylor Simpson
14097cf9345cSTaylor Simpson
14107cf9345cSTaylor Simpson
14117cf9345cSTaylor Simpson
14127cf9345cSTaylor Simpson
14137cf9345cSTaylor Simpson
14147cf9345cSTaylor Simpson/*******************************/
14157cf9345cSTaylor Simpson/*                             */
14167cf9345cSTaylor Simpson/*                             */
14177cf9345cSTaylor Simpson/*    S                        */
14187cf9345cSTaylor Simpson/*                             */
14197cf9345cSTaylor Simpson/*                             */
14207cf9345cSTaylor Simpson/*******************************/
14217cf9345cSTaylor Simpson
14227cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_S2op" ---- -------- PP------ --------",S_2op)
14237cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_S2op" !!!! -------- PP------ --------",STYPEB_RegType,"Register Type")
14247cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_S2op" ---- !!------ PP------ --------",S2_MajOp,"Major Opcode")
14257cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_S2op" ---- -------- PP------ !!!-----",S2_MinOp,"Minor Opcode")
14267cf9345cSTaylor Simpson
14277cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_S3op" ---- -------- PP------ --------",S_3op)
14287cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_S3op" !!!! -------- PP------ --------",STYPEA_RegType,"Register Type")
14297cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_S3op" ---- !!------ PP------ --------",S3_Maj,"Major Opcode")
14307cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_S3op" ---- -------- PP------ !!------",S3_Min,"Minor Opcode")
14317cf9345cSTaylor Simpson
14327cf9345cSTaylor Simpson
14337cf9345cSTaylor Simpson#define SH_RRR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
14347cf9345cSTaylor SimpsonDEF_ENC32(TAG,ICLASS_S3op" "MAJ4"  "MIN3"sssss  PP"SMOD1"ttttt "VMIN3 DSTCHARS)
14357cf9345cSTaylor Simpson
14367cf9345cSTaylor Simpson#define SH_RRRiENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
14377cf9345cSTaylor SimpsonDEF_ENC32(TAG,ICLASS_S3op" "MAJ4"  "MIN3"iiiii  PP"SMOD1"ttttt "VMIN3 DSTCHARS)
14387cf9345cSTaylor Simpson
14397cf9345cSTaylor Simpson#define SH_RRR_ENCX(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
14407cf9345cSTaylor SimpsonDEF_ENC32(TAG,ICLASS_S3op" "MAJ4"  "MIN3"sssss  PP"SMOD1"xxxxx "VMIN3 DSTCHARS)
14417cf9345cSTaylor Simpson
14427cf9345cSTaylor Simpson#define SH3_RR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
14437cf9345cSTaylor SimpsonDEF_ENC32(TAG,ICLASS_S3op" "MAJ4"  "MIN3"sssss  PP"SMOD1"----- "VMIN3 DSTCHARS)
14447cf9345cSTaylor Simpson
14457cf9345cSTaylor Simpson#define SH_PPP_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
14467cf9345cSTaylor SimpsonDEF_ENC32(TAG,ICLASS_S3op" "MAJ4"  "MIN3"---ss  PP"SMOD1"---tt "VMIN3 DSTCHARS)
14477cf9345cSTaylor Simpson
14487cf9345cSTaylor Simpson#define SH2_RR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
14497cf9345cSTaylor SimpsonDEF_ENC32(TAG,ICLASS_S2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"----- "VMIN3 DSTCHARS)
14507cf9345cSTaylor Simpson
14517cf9345cSTaylor Simpson#define SH2_PPP_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
14527cf9345cSTaylor SimpsonDEF_ENC32(TAG,ICLASS_S2op" "MAJ4"  "MIN3"---ss  PP"SMOD1"---tt "VMIN3 DSTCHARS)
14537cf9345cSTaylor Simpson
14547cf9345cSTaylor Simpson#define SH_RRI4_ENC(TAG,MAJ4,MIN3,VMIN3,DSTCHARS) \
14557cf9345cSTaylor SimpsonDEF_ENC32(TAG,ICLASS_S2op" "MAJ4" "MIN3 "sssss PP00iiii " VMIN3 DSTCHARS)
14567cf9345cSTaylor Simpson
14577cf9345cSTaylor Simpson#define SH_RRI5_ENC(TAG,MAJ4,MIN3,VMIN3,DSTCHARS) \
14587cf9345cSTaylor SimpsonDEF_ENC32(TAG,ICLASS_S2op" "MAJ4" "MIN3 "sssss PP0iiiii " VMIN3 DSTCHARS)
14597cf9345cSTaylor Simpson
14607cf9345cSTaylor Simpson#define SH_RRI6_ENC(TAG,MAJ4,MIN3,VMIN3,DSTCHARS) \
14617cf9345cSTaylor SimpsonDEF_ENC32(TAG,ICLASS_S2op" "MAJ4" "MIN3 "sssss PPiiiiii " VMIN3 DSTCHARS)
14627cf9345cSTaylor Simpson
14637cf9345cSTaylor Simpson#define RSHIFTTYPES(TAGEND,MAJ4,MIN3,SMOD1,DMOD1,DSTCHARS) \
14647cf9345cSTaylor SimpsonSH_RRR_ENC(S2_asr_r_##TAGEND,MAJ4,MIN3,SMOD1,"00"DMOD1,DSTCHARS) \
14657cf9345cSTaylor SimpsonSH_RRR_ENC(S2_lsr_r_##TAGEND,MAJ4,MIN3,SMOD1,"01"DMOD1,DSTCHARS) \
14667cf9345cSTaylor SimpsonSH_RRR_ENC(S2_asl_r_##TAGEND,MAJ4,MIN3,SMOD1,"10"DMOD1,DSTCHARS) \
14677cf9345cSTaylor SimpsonSH_RRR_ENC(S2_lsl_r_##TAGEND,MAJ4,MIN3,SMOD1,"11"DMOD1,DSTCHARS)
14687cf9345cSTaylor Simpson
14697cf9345cSTaylor Simpson
14707cf9345cSTaylor Simpson#define I5SHIFTTYPES(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
14717cf9345cSTaylor SimpsonSH_RRI5_ENC(S2_asr_i_##TAGEND,MAJ4,MIN3,SMOD1 "00",DSTCHARS) \
14727cf9345cSTaylor SimpsonSH_RRI5_ENC(S2_lsr_i_##TAGEND,MAJ4,MIN3,SMOD1 "01",DSTCHARS) \
14737cf9345cSTaylor SimpsonSH_RRI5_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS) \
14747cf9345cSTaylor SimpsonSH_RRI5_ENC(S6_rol_i_##TAGEND,MAJ4,MIN3,SMOD1 "11",DSTCHARS)
14757cf9345cSTaylor Simpson
14767cf9345cSTaylor Simpson#define I5SHIFTTYPES_NOROL(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
14777cf9345cSTaylor SimpsonSH_RRI5_ENC(S2_asr_i_##TAGEND,MAJ4,MIN3,SMOD1 "00",DSTCHARS) \
14787cf9345cSTaylor SimpsonSH_RRI5_ENC(S2_lsr_i_##TAGEND,MAJ4,MIN3,SMOD1 "01",DSTCHARS) \
14797cf9345cSTaylor SimpsonSH_RRI5_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS)
14807cf9345cSTaylor Simpson
14817cf9345cSTaylor Simpson#define I5SHIFTTYPES_NOASR(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
14827cf9345cSTaylor SimpsonSH_RRI5_ENC(S2_lsr_i_##TAGEND,MAJ4,MIN3,SMOD1 "01",DSTCHARS) \
14837cf9345cSTaylor SimpsonSH_RRI5_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS) \
14847cf9345cSTaylor SimpsonSH_RRI5_ENC(S6_rol_i_##TAGEND,MAJ4,MIN3,SMOD1 "11",DSTCHARS)
14857cf9345cSTaylor Simpson
14867cf9345cSTaylor Simpson#define I4SHIFTTYPES(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
14877cf9345cSTaylor SimpsonSH_RRI4_ENC(S2_asr_i_##TAGEND,MAJ4,MIN3,SMOD1 "00",DSTCHARS) \
14887cf9345cSTaylor SimpsonSH_RRI4_ENC(S2_lsr_i_##TAGEND,MAJ4,MIN3,SMOD1 "01",DSTCHARS) \
14897cf9345cSTaylor SimpsonSH_RRI4_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS)
14907cf9345cSTaylor Simpson
14917cf9345cSTaylor Simpson#define I5ASHIFTTYPES(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
14927cf9345cSTaylor SimpsonSH_RRI5_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS)
14937cf9345cSTaylor Simpson
14947cf9345cSTaylor Simpson#define I4ASHIFTTYPES(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
14957cf9345cSTaylor SimpsonSH_RRI4_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS)
14967cf9345cSTaylor Simpson
14977cf9345cSTaylor Simpson#define I6SHIFTTYPES(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
14987cf9345cSTaylor SimpsonSH_RRI6_ENC(S2_asr_i_##TAGEND,MAJ4,MIN3,SMOD1 "00",DSTCHARS) \
14997cf9345cSTaylor SimpsonSH_RRI6_ENC(S2_lsr_i_##TAGEND,MAJ4,MIN3,SMOD1 "01",DSTCHARS) \
15007cf9345cSTaylor SimpsonSH_RRI6_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS) \
15017cf9345cSTaylor SimpsonSH_RRI6_ENC(S6_rol_i_##TAGEND,MAJ4,MIN3,SMOD1 "11",DSTCHARS) \
15027cf9345cSTaylor Simpson
15037cf9345cSTaylor Simpson#define I6SHIFTTYPES_NOASR(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
15047cf9345cSTaylor SimpsonSH_RRI6_ENC(S2_lsr_i_##TAGEND,MAJ4,MIN3,SMOD1 "01",DSTCHARS) \
15057cf9345cSTaylor SimpsonSH_RRI6_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS) \
15067cf9345cSTaylor SimpsonSH_RRI6_ENC(S6_rol_i_##TAGEND,MAJ4,MIN3,SMOD1 "11",DSTCHARS)
15077cf9345cSTaylor Simpson
15087cf9345cSTaylor Simpson
15097cf9345cSTaylor Simpson
15107cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op" 0000 -------- PP------ --------","[#0] Rdd=(Rss,#u6)")
15117cf9345cSTaylor Simpson/* EJP: there is actually quite a bit of space here, look at the reserved bits */
15127cf9345cSTaylor SimpsonI6SHIFTTYPES(p,                 "0000","000","0","ddddd")
15137cf9345cSTaylor SimpsonI5SHIFTTYPES_NOROL(vw,          "0000","010","0","ddddd")
15147cf9345cSTaylor SimpsonI4SHIFTTYPES(vh,                "0000","100","0","ddddd")
15157cf9345cSTaylor Simpson
15167cf9345cSTaylor Simpson
15177cf9345cSTaylor Simpson
15187cf9345cSTaylor Simpson/* False assume an immediate */
15197cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vsathub_nopack, "0000","000","-","1 00","ddddd")
15207cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vsatwuh_nopack, "0000","000","-","1 01","ddddd")
15217cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vsatwh_nopack,  "0000","000","-","1 10","ddddd")
15227cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vsathb_nopack,  "0000","000","-","1 11","ddddd")
15237cf9345cSTaylor Simpson
15247cf9345cSTaylor SimpsonSH_RRI4_ENC(S5_vasrhrnd,      "0000","001",    "0 00","ddddd")
15257cf9345cSTaylor Simpson
15267cf9345cSTaylor SimpsonSH2_RR_ENC(A2_vabsh,          "0000","010","-","1 00","ddddd")
15277cf9345cSTaylor SimpsonSH2_RR_ENC(A2_vabshsat,       "0000","010","-","1 01","ddddd")
15287cf9345cSTaylor SimpsonSH2_RR_ENC(A2_vabsw,          "0000","010","-","1 10","ddddd")
15297cf9345cSTaylor SimpsonSH2_RR_ENC(A2_vabswsat,       "0000","010","-","1 11","ddddd")
15307cf9345cSTaylor Simpson
15317cf9345cSTaylor SimpsonSH2_RR_ENC(A2_notp,           "0000","100","-","1 00","ddddd")
15327cf9345cSTaylor SimpsonSH2_RR_ENC(A2_negp,           "0000","100","-","1 01","ddddd")
15337cf9345cSTaylor SimpsonSH2_RR_ENC(A2_absp,           "0000","100","-","1 10","ddddd")
15347cf9345cSTaylor SimpsonSH2_RR_ENC(A2_vconj,          "0000","100","-","1 11","ddddd")
15357cf9345cSTaylor Simpson
15367cf9345cSTaylor SimpsonSH2_RR_ENC(S2_deinterleave,   "0000","110","-","1 00","ddddd")
15377cf9345cSTaylor SimpsonSH2_RR_ENC(S2_interleave,     "0000","110","-","1 01","ddddd")
15387cf9345cSTaylor SimpsonSH2_RR_ENC(S2_brevp,          "0000","110","-","1 10","ddddd")
15397cf9345cSTaylor SimpsonSH_RRI6_ENC(S2_asr_i_p_rnd,   "0000","110",    "1 11","ddddd")
15407cf9345cSTaylor Simpson
15417cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_df2d,      "0000","111","0","0 00","ddddd")
15427cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_df2ud,     "0000","111","0","0 01","ddddd")
15437cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_ud2df,     "0000","111","0","0 10","ddddd")
15447cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_d2df,      "0000","111","0","0 11","ddddd")
15457cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_df2d_chop, "0000","111","0","1 10","ddddd")
15467cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_df2ud_chop,"0000","111","0","1 11","ddddd")
15477cf9345cSTaylor Simpson
15487cf9345cSTaylor Simpson
15497cf9345cSTaylor Simpson
15507cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"    0001 -------- PP------ --------","[#1] Rdd=(Rss,#u6,#U6)")
15517cf9345cSTaylor SimpsonDEF_ENC32(S2_extractup,ICLASS_S2op" 0001 IIIsssss PPiiiiii IIIddddd")
15527cf9345cSTaylor Simpson
15537cf9345cSTaylor Simpson
15547cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op" 0010 -------- PP------ --------","[#2] Rxx=(Rss,#u6)")
15557cf9345cSTaylor SimpsonI6SHIFTTYPES(p_nac,             "0010","00-","0","xxxxx")
15567cf9345cSTaylor SimpsonI6SHIFTTYPES(p_acc,             "0010","00-","1","xxxxx")
15577cf9345cSTaylor SimpsonI6SHIFTTYPES(p_and,             "0010","01-","0","xxxxx")
15587cf9345cSTaylor SimpsonI6SHIFTTYPES(p_or,              "0010","01-","1","xxxxx")
15597cf9345cSTaylor SimpsonI6SHIFTTYPES_NOASR(p_xacc,      "0010","10-","0","xxxxx")
15607cf9345cSTaylor Simpson
15617cf9345cSTaylor Simpson
15627cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"  0011 -------- PP------ --------","[#3] Rxx=(Rss,#u6,#U6)")
15637cf9345cSTaylor SimpsonDEF_ENC32(S2_insertp,ICLASS_S2op" 0011 IIIsssss PPiiiiii IIIxxxxx")
15647cf9345cSTaylor Simpson
15657cf9345cSTaylor Simpson
15667cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"  0100 -------- PP------ --------","[#4] Rdd=(Rs)")
15677cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vsxtbh,            "0100","00-","-","00-","ddddd")
15687cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vzxtbh,            "0100","00-","-","01-","ddddd")
15697cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vsxthw,            "0100","00-","-","10-","ddddd")
15707cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vzxthw,            "0100","00-","-","11-","ddddd")
15717cf9345cSTaylor SimpsonSH2_RR_ENC(A2_sxtw,              "0100","01-","-","00-","ddddd")
15727cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vsplatrh,          "0100","01-","-","01-","ddddd")
15737cf9345cSTaylor SimpsonSH2_RR_ENC(S6_vsplatrbp,         "0100","01-","-","10-","ddddd")
15747cf9345cSTaylor Simpson
15757cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_sf2df,        "0100","1--","-","000","ddddd")
15767cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_uw2df,        "0100","1--","-","001","ddddd")
15777cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_w2df,         "0100","1--","-","010","ddddd")
15787cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_sf2ud,        "0100","1--","-","011","ddddd")
15797cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_sf2d,         "0100","1--","-","100","ddddd")
15807cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_sf2ud_chop,   "0100","1--","-","101","ddddd")
15817cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_sf2d_chop,    "0100","1--","-","110","ddddd")
15827cf9345cSTaylor Simpson
15837cf9345cSTaylor Simpson
15847cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"   0101 -------- PP------ --------","[#5] Pd=(Rs,#u6)")
15857cf9345cSTaylor SimpsonDEF_ENC32(S2_tstbit_i,ICLASS_S2op" 0101 000sssss PP0iiiii ------dd")
15867cf9345cSTaylor SimpsonDEF_ENC32(C2_tfrrp,   ICLASS_S2op" 0101 010sssss PP------ ------dd")
15877cf9345cSTaylor SimpsonDEF_ENC32(C2_bitsclri,ICLASS_S2op" 0101 100sssss PPiiiiii ------dd")
15887cf9345cSTaylor SimpsonDEF_ENC32(S4_ntstbit_i,ICLASS_S2op"0101 001sssss PP0iiiii ------dd")
15897cf9345cSTaylor SimpsonDEF_ENC32(C4_nbitsclri,ICLASS_S2op"0101 101sssss PPiiiiii ------dd")
15907cf9345cSTaylor SimpsonDEF_ENC32(F2_sfclass,  ICLASS_S2op"0101 111sssss PP0iiiii ------dd")
15917cf9345cSTaylor Simpson
15927cf9345cSTaylor Simpson
15937cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"   0110 -------- PP------ --------","[#6] Rdd=(Pt)")
15947cf9345cSTaylor SimpsonDEF_ENC32(C2_mask, ICLASS_S2op"    0110   --- -----  PP----tt --- ddddd")
15957cf9345cSTaylor Simpson
15967cf9345cSTaylor Simpson
15977cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"    0111 -------- PP------ --------","[#7] Rx=(Rs,#u4,#S6)")
15987cf9345cSTaylor SimpsonDEF_ENC32(S2_tableidxb,ICLASS_S2op" 0111 00isssss PPIIIIII iiixxxxx")
15997cf9345cSTaylor SimpsonDEF_ENC32(S2_tableidxh,ICLASS_S2op" 0111 01isssss PPIIIIII iiixxxxx")
16007cf9345cSTaylor SimpsonDEF_ENC32(S2_tableidxw,ICLASS_S2op" 0111 10isssss PPIIIIII iiixxxxx")
16017cf9345cSTaylor SimpsonDEF_ENC32(S2_tableidxd,ICLASS_S2op" 0111 11isssss PPIIIIII iiixxxxx")
16027cf9345cSTaylor Simpson
16037cf9345cSTaylor Simpson
16047cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"   1000 -------- PP------ --------","[#8] Rd=(Rss,#u6)")
16057cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vsathub,            "1000","000","-","000","ddddd")
16067cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vsatwh,             "1000","000","-","010","ddddd")
16077cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vsatwuh,            "1000","000","-","100","ddddd")
16087cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vsathb,             "1000","000","-","110","ddddd")
16097cf9345cSTaylor SimpsonSH2_RR_ENC(S2_clbp,               "1000","010","-","000","ddddd")
16107cf9345cSTaylor SimpsonSH2_RR_ENC(S2_cl0p,               "1000","010","-","010","ddddd")
16117cf9345cSTaylor SimpsonSH2_RR_ENC(S2_cl1p,               "1000","010","-","100","ddddd")
16127cf9345cSTaylor SimpsonSH2_RR_ENC(S2_ct0p,               "1000","111","-","010","ddddd")
16137cf9345cSTaylor SimpsonSH2_RR_ENC(S2_ct1p,               "1000","111","-","100","ddddd")
16147cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vtrunohb,           "1000","100","-","000","ddddd")
16157cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vtrunehb,           "1000","100","-","010","ddddd")
16167cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vrndpackwh,         "1000","100","-","100","ddddd")
16177cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vrndpackwhs,        "1000","100","-","110","ddddd")
16187cf9345cSTaylor SimpsonSH2_RR_ENC(A2_sat,                "1000","110","-","000","ddddd")
16197cf9345cSTaylor SimpsonSH2_RR_ENC(A2_roundsat,           "1000","110","-","001","ddddd")
16207cf9345cSTaylor SimpsonSH_RRI5_ENC(S2_asr_i_svw_trun,    "1000","110",    "010","ddddd")
16217cf9345cSTaylor SimpsonSH_RRI5_ENC(A4_bitspliti,         "1000","110",    "100","ddddd")
16227cf9345cSTaylor Simpson
16237cf9345cSTaylor SimpsonSH_RRI5_ENC(A7_clip,              "1000","110",    "101","ddddd")
16247cf9345cSTaylor SimpsonSH_RRI5_ENC(A7_vclip,             "1000","110",    "110","ddddd")
16257cf9345cSTaylor Simpson
16267cf9345cSTaylor Simpson
16277cf9345cSTaylor SimpsonSH2_RR_ENC(S4_clbpnorm,           "1000","011","-","000","ddddd")
16287cf9345cSTaylor SimpsonSH_RRI6_ENC(S4_clbpaddi,          "1000","011",    "010","ddddd")
16297cf9345cSTaylor SimpsonSH2_RR_ENC(S5_popcountp,          "1000","011","-","011","ddddd")
16307cf9345cSTaylor Simpson
16317cf9345cSTaylor SimpsonSH_RRI4_ENC(S5_asrhub_rnd_sat,    "1000","011",    "100","ddddd")
16327cf9345cSTaylor SimpsonSH_RRI4_ENC(S5_asrhub_sat,        "1000","011",    "101","ddddd")
16337cf9345cSTaylor Simpson
16347cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_df2sf,         "1000","000","-","001","ddddd")
16357cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_ud2sf,         "1000","001","-","001","ddddd")
16367cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_d2sf,          "1000","010","-","001","ddddd")
16377cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_df2uw,         "1000","011","-","001","ddddd")
16387cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_df2w,          "1000","100","-","001","ddddd")
16397cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_df2uw_chop,    "1000","101","-","001","ddddd")
16407cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_df2w_chop,     "1000","111","-","001","ddddd")
16417cf9345cSTaylor Simpson
16427cf9345cSTaylor Simpson
16437cf9345cSTaylor Simpson
16447cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"   1001 -------- PP------ --------","[#9] Rd=(Ps,Pt)")
16457cf9345cSTaylor SimpsonDEF_ENC32(C2_vitpack, ICLASS_S2op" 1001   -00 ---ss  PP----tt --- ddddd")
16467cf9345cSTaylor SimpsonDEF_ENC32(C2_tfrpr,   ICLASS_S2op" 1001   -1- ---ss  PP------ --- ddddd")
16477cf9345cSTaylor Simpson
16487cf9345cSTaylor Simpson
16497cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"   1010 -------- PP------ --------","[#10] Rdd=(Rss,#u6,#U6)")
16507cf9345cSTaylor SimpsonDEF_ENC32(S4_extractp,ICLASS_S2op" 1010 IIIsssss PPiiiiii IIIddddd")
16517cf9345cSTaylor Simpson
16527cf9345cSTaylor Simpson
16537cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"   1011 -------- PP------ --------","[#11] Rd=(Rs)")
16547cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_uw2sf,         "1011","001","-","000","ddddd")
16557cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_w2sf,          "1011","010","-","000","ddddd")
16567cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_sf2uw,         "1011","011","-","000","ddddd")
16577cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_sf2w,          "1011","100","-","000","ddddd")
16587cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_sf2uw_chop,    "1011","011","-","001","ddddd")
16597cf9345cSTaylor SimpsonSH2_RR_ENC(F2_conv_sf2w_chop,     "1011","100","-","001","ddddd")
16607cf9345cSTaylor SimpsonSH2_RR_ENC(F2_sffixupr,           "1011","101","-","000","ddddd")
1661dd8705bdSTaylor SimpsonSH2_RR_ENC(F2_sfinvsqrta,         "1011","111","-","0ee","ddddd")
16627cf9345cSTaylor Simpson
16637cf9345cSTaylor Simpson
16647cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"      1100 -------- PP------ --------","[#12] Rd=(Rs,#u6)")
16657cf9345cSTaylor SimpsonI5SHIFTTYPES(r,                      "1100","000",            "0  ","ddddd")
16667cf9345cSTaylor SimpsonSH_RRI5_ENC(S2_asl_i_r_sat,          "1100","010",            "010","ddddd")
16677cf9345cSTaylor SimpsonSH_RRI5_ENC(S2_asr_i_r_rnd,          "1100","010",            "000","ddddd")
16687cf9345cSTaylor Simpson
16697cf9345cSTaylor SimpsonSH2_RR_ENC(S2_svsathb,               "1100","10-","-",        "00-","ddddd")
16707cf9345cSTaylor SimpsonSH2_RR_ENC(S2_svsathub,              "1100","10-","-",        "01-","ddddd")
16717cf9345cSTaylor Simpson
16727cf9345cSTaylor SimpsonSH_RRI5_ENC(A4_cround_ri,            "1100","111",            "00-","ddddd")
16737cf9345cSTaylor SimpsonSH_RRI6_ENC(A7_croundd_ri,           "1100","111",            "01-","ddddd")
16747cf9345cSTaylor SimpsonSH_RRI5_ENC(A4_round_ri,             "1100","111",            "10-","ddddd")
16757cf9345cSTaylor SimpsonSH_RRI5_ENC(A4_round_ri_sat,         "1100","111",            "11-","ddddd")
16767cf9345cSTaylor Simpson
16777cf9345cSTaylor SimpsonDEF_ENC32(S2_setbit_i,   ICLASS_S2op" 1100   110sssss PP0iiiii 000ddddd")
16787cf9345cSTaylor SimpsonDEF_ENC32(S2_clrbit_i,   ICLASS_S2op" 1100   110sssss PP0iiiii 001ddddd")
16797cf9345cSTaylor SimpsonDEF_ENC32(S2_togglebit_i,ICLASS_S2op" 1100   110sssss PP0iiiii 010ddddd")
16807cf9345cSTaylor Simpson
16817cf9345cSTaylor SimpsonDEF_ENC32(S4_clbaddi    ,ICLASS_S2op" 1100   001sssss PPiiiiii 000ddddd")
16827cf9345cSTaylor Simpson
16837cf9345cSTaylor Simpson
16847cf9345cSTaylor Simpson
16857cf9345cSTaylor Simpson/* False read #u6 */
16867cf9345cSTaylor SimpsonSH2_RR_ENC(S2_clb,                   "1100","000","-","1 00","ddddd")
16877cf9345cSTaylor SimpsonSH2_RR_ENC(S2_cl0,                   "1100","000","-","1 01","ddddd")
16887cf9345cSTaylor SimpsonSH2_RR_ENC(S2_cl1,                   "1100","000","-","1 10","ddddd")
16897cf9345cSTaylor SimpsonSH2_RR_ENC(S2_clbnorm,               "1100","000","-","1 11","ddddd")
16907cf9345cSTaylor SimpsonSH2_RR_ENC(S2_ct0,                   "1100","010","-","1 00","ddddd")
16917cf9345cSTaylor SimpsonSH2_RR_ENC(S2_ct1,                   "1100","010","-","1 01","ddddd")
16927cf9345cSTaylor SimpsonSH2_RR_ENC(S2_brev,                  "1100","010","-","1 10","ddddd")
16937cf9345cSTaylor SimpsonSH2_RR_ENC(S2_vsplatrb,              "1100","010","-","1 11","ddddd")
16947cf9345cSTaylor SimpsonSH2_RR_ENC(A2_abs,                   "1100","100","-","1 00","ddddd")
16957cf9345cSTaylor SimpsonSH2_RR_ENC(A2_abssat,                "1100","100","-","1 01","ddddd")
16967cf9345cSTaylor SimpsonSH2_RR_ENC(A2_negsat,                "1100","100","-","1 10","ddddd")
16977cf9345cSTaylor SimpsonSH2_RR_ENC(A2_swiz,                  "1100","100","-","1 11","ddddd")
16987cf9345cSTaylor SimpsonSH2_RR_ENC(A2_sath,                  "1100","110","-","1 00","ddddd")
16997cf9345cSTaylor SimpsonSH2_RR_ENC(A2_satuh,                 "1100","110","-","1 01","ddddd")
17007cf9345cSTaylor SimpsonSH2_RR_ENC(A2_satub,                 "1100","110","-","1 10","ddddd")
17017cf9345cSTaylor SimpsonSH2_RR_ENC(A2_satb,                  "1100","110","-","1 11","ddddd")
17027cf9345cSTaylor Simpson
17037cf9345cSTaylor Simpson
17047cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"     1101 -------- PP------ --------","[#13] Rd=(Rs,#u6,#U6)")
17057cf9345cSTaylor SimpsonDEF_ENC32(S2_extractu,  ICLASS_S2op" 1101 0IIsssss PP0iiiii IIIddddd")
17067cf9345cSTaylor SimpsonDEF_ENC32(S4_extract,   ICLASS_S2op" 1101 1IIsssss PP0iiiii IIIddddd")
17077cf9345cSTaylor SimpsonDEF_ENC32(S2_mask,    ICLASS_S2op"   1101 0II----- PP1iiiii IIIddddd")
17087cf9345cSTaylor Simpson
17097cf9345cSTaylor Simpson
17107cf9345cSTaylor Simpson
17117cf9345cSTaylor Simpson
17127cf9345cSTaylor Simpson
17137cf9345cSTaylor Simpson
17147cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"     1110 -------- PP------ --------","[#14] Rx=(Rs,#u6)")
17157cf9345cSTaylor SimpsonI5SHIFTTYPES(r_nac,       "1110","00-","0","xxxxx")
17167cf9345cSTaylor SimpsonI5SHIFTTYPES(r_acc,       "1110","00-","1","xxxxx")
17177cf9345cSTaylor SimpsonI5SHIFTTYPES(r_and,       "1110","01-","0","xxxxx")
17187cf9345cSTaylor SimpsonI5SHIFTTYPES(r_or,        "1110","01-","1","xxxxx")
17197cf9345cSTaylor SimpsonI5SHIFTTYPES_NOASR(r_xacc,"1110","10-","0","xxxxx")
17207cf9345cSTaylor Simpson
17217cf9345cSTaylor Simpson
17227cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S2op"     1111 -------- PP------ --------","[#15] Rs=(Rs,#u6,#U6)")
17237cf9345cSTaylor SimpsonDEF_ENC32(S2_insert,    ICLASS_S2op" 1111 0IIsssss PP0iiiii IIIxxxxx")
17247cf9345cSTaylor Simpson
17257cf9345cSTaylor Simpson
17267cf9345cSTaylor Simpson
17277cf9345cSTaylor Simpson
17287cf9345cSTaylor Simpson
17297cf9345cSTaylor Simpson/*************************/
17307cf9345cSTaylor Simpson/* S_3_operand           */
17317cf9345cSTaylor Simpson/*************************/
17327cf9345cSTaylor Simpson
17337cf9345cSTaylor Simpson
17347cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 0000 -------- PP------ --------","[#0] Rdd=(Rss,Rtt,#u3)")
17357cf9345cSTaylor SimpsonSH_RRR_ENC(S2_valignib,         "0000","0--","-","iii","ddddd")
17367cf9345cSTaylor SimpsonSH_RRR_ENC(S2_vspliceib,        "0000","1--","-","iii","ddddd")
17377cf9345cSTaylor Simpson
17387cf9345cSTaylor Simpson
17397cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 0001 -------- PP------ --------","[#1] Rdd=(Rss,Rtt)")
17407cf9345cSTaylor SimpsonSH_RRR_ENC(S2_extractup_rp,     "0001","00-","-","00-","ddddd")
17417cf9345cSTaylor SimpsonSH_RRR_ENC(S2_shuffeb,          "0001","00-","-","01-","ddddd")
17427cf9345cSTaylor SimpsonSH_RRR_ENC(S2_shuffob,          "0001","00-","-","10-","ddddd")
17437cf9345cSTaylor SimpsonSH_RRR_ENC(S2_shuffeh,          "0001","00-","-","11-","ddddd")
17447cf9345cSTaylor Simpson
17457cf9345cSTaylor SimpsonSH_RRR_ENC(S2_shuffoh,          "0001","10-","-","000","ddddd")
17467cf9345cSTaylor SimpsonSH_RRR_ENC(S2_vtrunewh,         "0001","10-","-","010","ddddd")
17477cf9345cSTaylor SimpsonSH_RRR_ENC(S6_vtrunehb_ppp,     "0001","10-","-","011","ddddd")
17487cf9345cSTaylor SimpsonSH_RRR_ENC(S2_vtrunowh,         "0001","10-","-","100","ddddd")
17497cf9345cSTaylor SimpsonSH_RRR_ENC(S6_vtrunohb_ppp,     "0001","10-","-","101","ddddd")
17507cf9345cSTaylor SimpsonSH_RRR_ENC(S2_lfsp,             "0001","10-","-","110","ddddd")
17517cf9345cSTaylor Simpson
17527cf9345cSTaylor SimpsonSH_RRR_ENC(S4_vxaddsubw,        "0001","01-","-","000","ddddd")
17537cf9345cSTaylor SimpsonSH_RRR_ENC(A5_vaddhubs,         "0001","01-","-","001","ddddd")
17547cf9345cSTaylor SimpsonSH_RRR_ENC(S4_vxsubaddw,        "0001","01-","-","010","ddddd")
17557cf9345cSTaylor SimpsonSH_RRR_ENC(S4_vxaddsubh,        "0001","01-","-","100","ddddd")
17567cf9345cSTaylor SimpsonSH_RRR_ENC(S4_vxsubaddh,        "0001","01-","-","110","ddddd")
17577cf9345cSTaylor Simpson
17587cf9345cSTaylor SimpsonSH_RRR_ENC(S4_vxaddsubhr,       "0001","11-","-","00-","ddddd")
17597cf9345cSTaylor SimpsonSH_RRR_ENC(S4_vxsubaddhr,       "0001","11-","-","01-","ddddd")
17607cf9345cSTaylor SimpsonSH_RRR_ENC(S4_extractp_rp,      "0001","11-","-","10-","ddddd")
1761e628c015STaylor SimpsonSH_RRR_ENC(S2_cabacdecbin,      "0001","11-","-","11-","ddddd") /* implicit P0 write */
17627cf9345cSTaylor Simpson
17637cf9345cSTaylor Simpson
17647cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 0010 -------- PP------ --------","[#2] Rdd=(Rss,Rtt,Pu)")
17657cf9345cSTaylor SimpsonSH_RRR_ENC(S2_valignrb,         "0010","0--","-","-uu","ddddd")
17667cf9345cSTaylor SimpsonSH_RRR_ENC(S2_vsplicerb,        "0010","100","-","-uu","ddddd")
176757d352acSTaylor SimpsonSH_RRR_ENC(A4_addp_c,           "0010","110","-","-xx","ddddd")
176857d352acSTaylor SimpsonSH_RRR_ENC(A4_subp_c,           "0010","111","-","-xx","ddddd")
17697cf9345cSTaylor Simpson
17707cf9345cSTaylor Simpson
17717cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 0011 -------- PP------ --------","[#3] Rdd=(Rss,Rt)")
17727cf9345cSTaylor SimpsonRSHIFTTYPES(vw,                 "0011","00-","-","-","ddddd")
17737cf9345cSTaylor SimpsonRSHIFTTYPES(vh,                 "0011","01-","-","-","ddddd")
17747cf9345cSTaylor SimpsonRSHIFTTYPES(p,                  "0011","10-","-","-","ddddd")
17757cf9345cSTaylor SimpsonSH_RRR_ENC(S2_vcrotate,         "0011","11-","-","00-","ddddd")
17767cf9345cSTaylor SimpsonSH_RRR_ENC(S2_vcnegh,           "0011","11-","-","01-","ddddd")
17777cf9345cSTaylor SimpsonSH_RRR_ENC(S4_vrcrotate,        "0011","11-","i","11i","ddddd")
17787cf9345cSTaylor Simpson
17797cf9345cSTaylor Simpson
17807cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 0100 -------- PP------ --------","[#4] Rd=(Rs,Rt,#u3)")
17817cf9345cSTaylor SimpsonDEF_ENC32(S2_addasl_rrri, ICLASS_S3op" 0100   000 sssss PP0ttttt iiiddddd")
17827cf9345cSTaylor Simpson
17837cf9345cSTaylor Simpson
17847cf9345cSTaylor Simpson
17857cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 0101 -------- PP------ --------","[#5] Rd=(Rss,Rt)")
17867cf9345cSTaylor SimpsonSH_RRR_ENC(S2_asr_r_svw_trun,   "0101","---","-","010","ddddd")
17877cf9345cSTaylor SimpsonSH_RRR_ENC(M4_cmpyi_wh,         "0101","---","-","100","ddddd")
17887cf9345cSTaylor SimpsonSH_RRR_ENC(M4_cmpyr_wh,         "0101","---","-","110","ddddd")
17897cf9345cSTaylor SimpsonSH_RRR_ENC(M4_cmpyi_whc,        "0101","---","-","101","ddddd")
17907cf9345cSTaylor SimpsonSH_RRR_ENC(M4_cmpyr_whc,        "0101","---","-","111","ddddd")
17917cf9345cSTaylor Simpson
17927cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 0110 -------- PP------ --------","[#6] Rd=(Rs,Rt)")
17937cf9345cSTaylor SimpsonSH_RRR_ENC(S2_asr_r_r_sat,      "0110","00-","-","00-","ddddd") \
17947cf9345cSTaylor SimpsonSH_RRR_ENC(S2_asl_r_r_sat,      "0110","00-","-","10-","ddddd")
17957cf9345cSTaylor Simpson
17967cf9345cSTaylor SimpsonRSHIFTTYPES(r,                  "0110","01-","-","-","ddddd")
17977cf9345cSTaylor Simpson
17987cf9345cSTaylor SimpsonSH_RRR_ENC(S2_setbit_r,         "0110","10-","-","00-","ddddd")
17997cf9345cSTaylor SimpsonSH_RRR_ENC(S2_clrbit_r,         "0110","10-","-","01-","ddddd")
18007cf9345cSTaylor SimpsonSH_RRR_ENC(S2_togglebit_r,      "0110","10-","-","10-","ddddd")
18017cf9345cSTaylor SimpsonSH_RRRiENC(S4_lsli,             "0110","10-","-","11i","ddddd")
18027cf9345cSTaylor Simpson
18037cf9345cSTaylor SimpsonSH_RRR_ENC(A4_cround_rr,        "0110","11-","-","00-","ddddd")
18047cf9345cSTaylor SimpsonSH_RRR_ENC(A7_croundd_rr,       "0110","11-","-","01-","ddddd")
18057cf9345cSTaylor SimpsonSH_RRR_ENC(A4_round_rr,         "0110","11-","-","10-","ddddd")
18067cf9345cSTaylor SimpsonSH_RRR_ENC(A4_round_rr_sat,     "0110","11-","-","11-","ddddd")
18077cf9345cSTaylor Simpson
18087cf9345cSTaylor Simpson
18097cf9345cSTaylor Simpson
18107cf9345cSTaylor Simpson
18117cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 0111 -------- PP------ --------","[#7] Pd=(Rs,Rt)")
18127cf9345cSTaylor SimpsonSH_RRR_ENC(S2_tstbit_r,         "0111","000","-","---","---dd")
18137cf9345cSTaylor SimpsonSH_RRR_ENC(C2_bitsset,          "0111","010","-","---","---dd")
18147cf9345cSTaylor SimpsonSH_RRR_ENC(C2_bitsclr,          "0111","100","-","---","---dd")
18157cf9345cSTaylor SimpsonSH_RRR_ENC(A4_cmpheq,           "0111","110","-","011","---dd")
18167cf9345cSTaylor SimpsonSH_RRR_ENC(A4_cmphgt,           "0111","110","-","100","---dd")
18177cf9345cSTaylor SimpsonSH_RRR_ENC(A4_cmphgtu,          "0111","110","-","101","---dd")
18187cf9345cSTaylor SimpsonSH_RRR_ENC(A4_cmpbeq,           "0111","110","-","110","---dd")
18197cf9345cSTaylor SimpsonSH_RRR_ENC(A4_cmpbgtu,          "0111","110","-","111","---dd")
18207cf9345cSTaylor SimpsonSH_RRR_ENC(A4_cmpbgt,           "0111","110","-","010","---dd")
18217cf9345cSTaylor SimpsonSH_RRR_ENC(S4_ntstbit_r,        "0111","001","-","---","---dd")
18227cf9345cSTaylor SimpsonSH_RRR_ENC(C4_nbitsset,         "0111","011","-","---","---dd")
18237cf9345cSTaylor SimpsonSH_RRR_ENC(C4_nbitsclr,         "0111","101","-","---","---dd")
18247cf9345cSTaylor Simpson
18257cf9345cSTaylor SimpsonSH_RRR_ENC(F2_sfcmpge,          "0111","111","-","000","---dd")
18267cf9345cSTaylor SimpsonSH_RRR_ENC(F2_sfcmpuo,          "0111","111","-","001","---dd")
18277cf9345cSTaylor SimpsonSH_RRR_ENC(F2_sfcmpeq,          "0111","111","-","011","---dd")
18287cf9345cSTaylor SimpsonSH_RRR_ENC(F2_sfcmpgt,          "0111","111","-","100","---dd")
18297cf9345cSTaylor Simpson
18307cf9345cSTaylor Simpson
18317cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 1000 -------- PP------ --------","[#8] Rx=(Rs,Rtt)")
18327cf9345cSTaylor SimpsonSH_RRR_ENC(S2_insert_rp,        "1000","---","-","---","xxxxx")
18337cf9345cSTaylor Simpson
18347cf9345cSTaylor Simpson
18357cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 1001 -------- PP------ --------","[#9] Rd=(Rs,Rtt)")
18367cf9345cSTaylor SimpsonSH_RRR_ENC(S2_extractu_rp,      "1001","00-","-","00-","ddddd")
18377cf9345cSTaylor SimpsonSH_RRR_ENC(S4_extract_rp,       "1001","00-","-","01-","ddddd")
18387cf9345cSTaylor Simpson
18397cf9345cSTaylor Simpson
18407cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 1010 -------- PP------ --------","[#10] Rxx=(Rss,Rtt)")
18417cf9345cSTaylor SimpsonSH_RRR_ENC(S2_insertp_rp,       "1010","0--","0","---","xxxxx")
18427cf9345cSTaylor SimpsonSH_RRR_ENC(M4_xor_xacc,         "1010","10-","0","000","xxxxx")
18437cf9345cSTaylor Simpson
18447cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 1011 -------- PP------ --------","[#11] Rxx=(Rss,Rt)")
18457cf9345cSTaylor SimpsonRSHIFTTYPES(p_or,               "1011","000","-","-","xxxxx")
18467cf9345cSTaylor SimpsonRSHIFTTYPES(p_and,              "1011","010","-","-","xxxxx")
18477cf9345cSTaylor SimpsonRSHIFTTYPES(p_nac,              "1011","100","-","-","xxxxx")
18487cf9345cSTaylor SimpsonRSHIFTTYPES(p_acc,              "1011","110","-","-","xxxxx")
18497cf9345cSTaylor SimpsonRSHIFTTYPES(p_xor,              "1011","011","-","-","xxxxx")
18507cf9345cSTaylor Simpson
18517cf9345cSTaylor SimpsonSH_RRR_ENCX(A4_vrmaxh,          "1011","001","0","001","uuuuu")
18527cf9345cSTaylor SimpsonSH_RRR_ENCX(A4_vrmaxuh,         "1011","001","1","001","uuuuu")
18537cf9345cSTaylor SimpsonSH_RRR_ENCX(A4_vrmaxw,          "1011","001","0","010","uuuuu")
18547cf9345cSTaylor SimpsonSH_RRR_ENCX(A4_vrmaxuw,         "1011","001","1","010","uuuuu")
18557cf9345cSTaylor Simpson
18567cf9345cSTaylor SimpsonSH_RRR_ENCX(A4_vrminh,          "1011","001","0","101","uuuuu")
18577cf9345cSTaylor SimpsonSH_RRR_ENCX(A4_vrminuh,         "1011","001","1","101","uuuuu")
18587cf9345cSTaylor SimpsonSH_RRR_ENCX(A4_vrminw,          "1011","001","0","110","uuuuu")
18597cf9345cSTaylor SimpsonSH_RRR_ENCX(A4_vrminuw,         "1011","001","1","110","uuuuu")
18607cf9345cSTaylor Simpson
18617cf9345cSTaylor SimpsonSH_RRR_ENC(S2_vrcnegh,          "1011","001","1","111","xxxxx")
18627cf9345cSTaylor Simpson
18637cf9345cSTaylor SimpsonSH_RRR_ENC(S4_vrcrotate_acc,    "1011","101","i","--i","xxxxx")
18647cf9345cSTaylor Simpson
18657cf9345cSTaylor Simpson
18667cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 1100 -------- PP------ --------","[#12] Rx=(Rs,Rt)")
18677cf9345cSTaylor SimpsonRSHIFTTYPES(r_or,               "1100","00-","-","-","xxxxx")
18687cf9345cSTaylor SimpsonRSHIFTTYPES(r_and,              "1100","01-","-","-","xxxxx")
18697cf9345cSTaylor SimpsonRSHIFTTYPES(r_nac,              "1100","10-","-","-","xxxxx")
18707cf9345cSTaylor SimpsonRSHIFTTYPES(r_acc,              "1100","11-","-","-","xxxxx")
18717cf9345cSTaylor Simpson
18727cf9345cSTaylor Simpson
18737cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 1101 -------- PP------ --------","[#13] Reserved")
18747cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 1110 -------- PP------ --------","[#14] Reserved")
18757cf9345cSTaylor Simpson
18767cf9345cSTaylor Simpson
18777cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_S3op" 1111 -------- PP------ --------","[#14] User Instruction")
18787cf9345cSTaylor Simpson
18797cf9345cSTaylor Simpson
18807cf9345cSTaylor Simpson
18817cf9345cSTaylor Simpson
18827cf9345cSTaylor Simpson
18837cf9345cSTaylor Simpson
18847cf9345cSTaylor Simpson
18857cf9345cSTaylor Simpson
18867cf9345cSTaylor Simpson
18877cf9345cSTaylor Simpson
18887cf9345cSTaylor Simpson
18897cf9345cSTaylor Simpson
18907cf9345cSTaylor Simpson
18917cf9345cSTaylor Simpson/*******************************/
18927cf9345cSTaylor Simpson/*                             */
18937cf9345cSTaylor Simpson/*                             */
18947cf9345cSTaylor Simpson/*           ALU64             */
18957cf9345cSTaylor Simpson/*                             */
18967cf9345cSTaylor Simpson/*                             */
18977cf9345cSTaylor Simpson/*******************************/
18987cf9345cSTaylor SimpsonDEF_CLASS32(ICLASS_ALU64" ---- -------- PP------ --------",ALU64)
18997cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ALU64" !!!! -------- PP------ --------",ALU64_RegType,"Register Type")
19007cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ALU64" 0--- !!!----- PP------ --------",A_MajOp,"Major Opcode")
19017cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ALU64" 0--- -------- PP------ !!!-----",A_MinOp,"Minor Opcode")
19027cf9345cSTaylor SimpsonDEF_FIELD32(ICLASS_ALU64" 11-- -------- PP------ ---!!!!!",A_MajOp,"Major Opcode")
19037cf9345cSTaylor Simpson
19047cf9345cSTaylor Simpson
19057cf9345cSTaylor Simpson
19067cf9345cSTaylor Simpson#define ALU64_RRR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
19077cf9345cSTaylor SimpsonDEF_ENC32(TAG, ICLASS_ALU64" "MAJ4"  "MIN3"sssss  PP"SMOD1"ttttt "VMIN3 DSTCHARS)
19087cf9345cSTaylor Simpson
19097cf9345cSTaylor Simpson#define LEGACY_ALU64_RRR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
19107cf9345cSTaylor SimpsonLEGACY_DEF_ENC32(TAG, ICLASS_ALU64" "MAJ4"  "MIN3"sssss  PP"SMOD1"ttttt "VMIN3 DSTCHARS)
19117cf9345cSTaylor Simpson
19127cf9345cSTaylor Simpson
19137cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 0000 -------- PP------ --------","[#0] Rd=(Rss,Rtt)")
19147cf9345cSTaylor SimpsonALU64_RRR_ENC(S2_parityp,        "0000","---","-","---","ddddd")
19157cf9345cSTaylor Simpson
19167cf9345cSTaylor Simpson
19177cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 0001 -------- PP------ --------","[#1] Rdd=(Pu,Rss,Rtt)")
19187cf9345cSTaylor SimpsonALU64_RRR_ENC(C2_vmux,           "0001","---","-","-uu","ddddd")
19197cf9345cSTaylor Simpson
19207cf9345cSTaylor Simpson
19217cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 0010 -------- PP------ --------","[#2] Pd=(Rss,Rtt)")
19227cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vcmpweq,        "0010","0--","0","000","---dd")
19237cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vcmpwgt,        "0010","0--","0","001","---dd")
19247cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vcmpwgtu,       "0010","0--","0","010","---dd")
19257cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vcmpheq,        "0010","0--","0","011","---dd")
19267cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vcmphgt,        "0010","0--","0","100","---dd")
19277cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vcmphgtu,       "0010","0--","0","101","---dd")
19287cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vcmpbeq,        "0010","0--","0","110","---dd")
19297cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vcmpbgtu,       "0010","0--","0","111","---dd")
19307cf9345cSTaylor Simpson
19317cf9345cSTaylor SimpsonALU64_RRR_ENC(A4_vcmpbeq_any,    "0010","0--","1","000","---dd")
19327cf9345cSTaylor SimpsonALU64_RRR_ENC(A6_vcmpbeq_notany, "0010","0--","1","001","---dd")
19337cf9345cSTaylor SimpsonALU64_RRR_ENC(A4_vcmpbgt,        "0010","0--","1","010","---dd")
19347cf9345cSTaylor SimpsonALU64_RRR_ENC(A4_tlbmatch,       "0010","0--","1","011","---dd")
19357cf9345cSTaylor SimpsonALU64_RRR_ENC(A4_boundscheck_lo, "0010","0--","1","100","---dd")
19367cf9345cSTaylor SimpsonALU64_RRR_ENC(A4_boundscheck_hi, "0010","0--","1","101","---dd")
19377cf9345cSTaylor Simpson
19387cf9345cSTaylor SimpsonALU64_RRR_ENC(C2_cmpeqp,         "0010","100","-","000","---dd")
19397cf9345cSTaylor SimpsonALU64_RRR_ENC(C2_cmpgtp,         "0010","100","-","010","---dd")
19407cf9345cSTaylor SimpsonALU64_RRR_ENC(C2_cmpgtup,        "0010","100","-","100","---dd")
19417cf9345cSTaylor Simpson
19427cf9345cSTaylor SimpsonALU64_RRR_ENC(F2_dfcmpeq,        "0010","111","-","000","---dd")
19437cf9345cSTaylor SimpsonALU64_RRR_ENC(F2_dfcmpgt,        "0010","111","-","001","---dd")
19447cf9345cSTaylor SimpsonALU64_RRR_ENC(F2_dfcmpge,        "0010","111","-","010","---dd")
19457cf9345cSTaylor SimpsonALU64_RRR_ENC(F2_dfcmpuo,        "0010","111","-","011","---dd")
19467cf9345cSTaylor Simpson
19477cf9345cSTaylor Simpson
19487cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 0011 -------- PP------ --------","[#3] Rdd=(Rss,Rtt)")
19497cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vaddub,         "0011","000","-","000","ddddd")
19507cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vaddubs,        "0011","000","-","001","ddddd")
19517cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vaddh,          "0011","000","-","010","ddddd")
19527cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vaddhs,         "0011","000","-","011","ddddd")
19537cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vadduhs,        "0011","000","-","100","ddddd")
19547cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vaddw,          "0011","000","-","101","ddddd")
19557cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vaddws,         "0011","000","-","110","ddddd")
19567cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addp,           "0011","000","-","111","ddddd")
19577cf9345cSTaylor Simpson
19587cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vsubub,         "0011","001","-","000","ddddd")
19597cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vsububs,        "0011","001","-","001","ddddd")
19607cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vsubh,          "0011","001","-","010","ddddd")
19617cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vsubhs,         "0011","001","-","011","ddddd")
19627cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vsubuhs,        "0011","001","-","100","ddddd")
19637cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vsubw,          "0011","001","-","101","ddddd")
19647cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vsubws,         "0011","001","-","110","ddddd")
19657cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subp,           "0011","001","-","111","ddddd")
19667cf9345cSTaylor Simpson
19677cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vavgub,         "0011","010","-","000","ddddd")
19687cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vavgubr,        "0011","010","-","001","ddddd")
19697cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vavgh,          "0011","010","-","010","ddddd")
19707cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vavghr,         "0011","010","-","011","ddddd")
19717cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vavghcr,        "0011","010","-","100","ddddd")
19727cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vavguh,         "0011","010","-","101","ddddd")
19737cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vavguhr,        "0011","010","-","11-","ddddd")
19747cf9345cSTaylor Simpson
19757cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vavgw,          "0011","011","-","000","ddddd")
19767cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vavgwr,         "0011","011","-","001","ddddd")
19777cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vavgwcr,        "0011","011","-","010","ddddd")
19787cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vavguw,         "0011","011","-","011","ddddd")
19797cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vavguwr,        "0011","011","-","100","ddddd")
19807cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addpsat,        "0011","011","-","101","ddddd")
19817cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addspl,         "0011","011","-","110","ddddd")
19827cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addsph,         "0011","011","-","111","ddddd")
19837cf9345cSTaylor Simpson
19847cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vnavgh,         "0011","100","-","000","ddddd")
19857cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vnavghr,        "0011","100","-","001","ddddd")
19867cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vnavghcr,       "0011","100","-","010","ddddd")
19877cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vnavgw,         "0011","100","-","011","ddddd")
19887cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vnavgwr,        "0011","100","-","10-","ddddd")
19897cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vnavgwcr,       "0011","100","-","11-","ddddd")
19907cf9345cSTaylor Simpson
19917cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vminub,         "0011","101","-","000","ddddd")
19927cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vminh,          "0011","101","-","001","ddddd")
19937cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vminuh,         "0011","101","-","010","ddddd")
19947cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vminw,          "0011","101","-","011","ddddd")
19957cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vminuw,         "0011","101","-","100","ddddd")
19967cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vmaxuw,         "0011","101","-","101","ddddd")
19977cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_minp,           "0011","101","-","110","ddddd")
19987cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_minup,          "0011","101","-","111","ddddd")
19997cf9345cSTaylor Simpson
20007cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vmaxub,         "0011","110","-","000","ddddd")
20017cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vmaxh,          "0011","110","-","001","ddddd")
20027cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vmaxuh,         "0011","110","-","010","ddddd")
20037cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vmaxw,          "0011","110","-","011","ddddd")
20047cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_maxp,           "0011","110","-","100","ddddd")
20057cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_maxup,          "0011","110","-","101","ddddd")
20067cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vmaxb,          "0011","110","-","110","ddddd")
20077cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_vminb,          "0011","110","-","111","ddddd")
20087cf9345cSTaylor Simpson
20097cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_andp,           "0011","111","-","000","ddddd")
20107cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_orp,            "0011","111","-","010","ddddd")
20117cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_xorp,           "0011","111","-","100","ddddd")
20127cf9345cSTaylor SimpsonALU64_RRR_ENC(A4_andnp,          "0011","111","-","001","ddddd")
20137cf9345cSTaylor SimpsonALU64_RRR_ENC(A4_ornp,           "0011","111","-","011","ddddd")
20147cf9345cSTaylor Simpson
20157cf9345cSTaylor SimpsonALU64_RRR_ENC(A4_modwrapu,       "0011","111","-","111","ddddd")
20167cf9345cSTaylor Simpson
20177cf9345cSTaylor Simpson
20187cf9345cSTaylor Simpson
20197cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 0100 -------- PP------ --------","[#4] Rdd=(Rs,Rt)")
20207cf9345cSTaylor SimpsonLEGACY_ALU64_RRR_ENC(S2_packhl,  "0100","--0","-","---","ddddd")
20217cf9345cSTaylor SimpsonALU64_RRR_ENC(A4_bitsplit,       "0100","--1","-","---","ddddd")
20227cf9345cSTaylor Simpson
20237cf9345cSTaylor Simpson
20247cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 0101 -------- PP------ --------","[#5] Rd=(Rs,Rt)")
20257cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addh_l16_ll,    "0101","000","-","00-","ddddd")
20267cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addh_l16_hl,    "0101","000","-","01-","ddddd")
20277cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addh_l16_sat_ll,"0101","000","-","10-","ddddd")
20287cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addh_l16_sat_hl,"0101","000","-","11-","ddddd")
20297cf9345cSTaylor Simpson
20307cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subh_l16_ll,    "0101","001","-","00-","ddddd")
20317cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subh_l16_hl,    "0101","001","-","01-","ddddd")
20327cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subh_l16_sat_ll,"0101","001","-","10-","ddddd")
20337cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subh_l16_sat_hl,"0101","001","-","11-","ddddd")
20347cf9345cSTaylor Simpson
20357cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addh_h16_ll,    "0101","010","-","000","ddddd")
20367cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addh_h16_lh,    "0101","010","-","001","ddddd")
20377cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addh_h16_hl,    "0101","010","-","010","ddddd")
20387cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addh_h16_hh,    "0101","010","-","011","ddddd")
20397cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addh_h16_sat_ll,"0101","010","-","100","ddddd")
20407cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addh_h16_sat_lh,"0101","010","-","101","ddddd")
20417cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addh_h16_sat_hl,"0101","010","-","110","ddddd")
20427cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_addh_h16_sat_hh,"0101","010","-","111","ddddd")
20437cf9345cSTaylor Simpson
20447cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subh_h16_ll,    "0101","011","-","000","ddddd")
20457cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subh_h16_lh,    "0101","011","-","001","ddddd")
20467cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subh_h16_hl,    "0101","011","-","010","ddddd")
20477cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subh_h16_hh,    "0101","011","-","011","ddddd")
20487cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subh_h16_sat_ll,"0101","011","-","100","ddddd")
20497cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subh_h16_sat_lh,"0101","011","-","101","ddddd")
20507cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subh_h16_sat_hl,"0101","011","-","110","ddddd")
20517cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_subh_h16_sat_hh,"0101","011","-","111","ddddd")
20527cf9345cSTaylor Simpson
20537cf9345cSTaylor SimpsonLEGACY_ALU64_RRR_ENC(A2_addsat,  "0101","100","-","0--","ddddd")
20547cf9345cSTaylor SimpsonLEGACY_ALU64_RRR_ENC(A2_subsat,  "0101","100","-","1--","ddddd")
20557cf9345cSTaylor Simpson
20567cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_min,            "0101","101","-","0--","ddddd")
20577cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_minu,           "0101","101","-","1--","ddddd")
20587cf9345cSTaylor Simpson
20597cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_max,            "0101","110","-","0--","ddddd")
20607cf9345cSTaylor SimpsonALU64_RRR_ENC(A2_maxu,           "0101","110","-","1--","ddddd")
20617cf9345cSTaylor Simpson
20627cf9345cSTaylor SimpsonALU64_RRR_ENC(S4_parity,         "0101","111","-","---","ddddd")
20637cf9345cSTaylor Simpson
20647cf9345cSTaylor Simpson
20657cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 0110 -------- PP------ --------","[#6] Rd=#u10 ")
20667cf9345cSTaylor SimpsonDEF_ENC32(F2_sfimm_p,     ICLASS_ALU64" 0110   00i ----- PPiiiiii iiiddddd")
20677cf9345cSTaylor SimpsonDEF_ENC32(F2_sfimm_n,     ICLASS_ALU64" 0110   01i ----- PPiiiiii iiiddddd")
20687cf9345cSTaylor Simpson
20697cf9345cSTaylor Simpson
20707cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 0111 -------- PP------ --------","[#7] Rd=(Rs,Rt,#u6)")
20717cf9345cSTaylor SimpsonDEF_ENC32(M4_mpyrr_addi,  ICLASS_ALU64" 0111   0ii sssss PPittttt iiiddddd")
20727cf9345cSTaylor Simpson
20737cf9345cSTaylor Simpson
20747cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 1000 -------- PP------ --------","[#8] Rd=(Rs,#u6,#U6)")
20757cf9345cSTaylor SimpsonDEF_ENC32(M4_mpyri_addi,  ICLASS_ALU64" 1000   Iii sssss PPiddddd iiiIIIII")
20767cf9345cSTaylor Simpson
20777cf9345cSTaylor Simpson
20787cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 1001 -------- PP------ --------","[#9] Rdd=#u10 ")
20797cf9345cSTaylor SimpsonDEF_ENC32(F2_dfimm_p,     ICLASS_ALU64" 1001   00i ----- PPiiiiii iiiddddd")
20807cf9345cSTaylor SimpsonDEF_ENC32(F2_dfimm_n,     ICLASS_ALU64" 1001   01i ----- PPiiiiii iiiddddd")
20817cf9345cSTaylor Simpson
20827cf9345cSTaylor Simpson
20837cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 1010 -------- PP------ --------","[#10] Rx=(Rs,Rx,#s10)")
20847cf9345cSTaylor SimpsonDEF_ENC32(S4_or_andix,    ICLASS_ALU64" 1010   01i xxxxx PPiiiiii iiiuuuuu")
20857cf9345cSTaylor SimpsonDEF_ENC32(S4_or_andi,     ICLASS_ALU64" 1010   00i sssss PPiiiiii iiixxxxx")
20867cf9345cSTaylor SimpsonDEF_ENC32(S4_or_ori,      ICLASS_ALU64" 1010   10i sssss PPiiiiii iiixxxxx")
20877cf9345cSTaylor Simpson
20887cf9345cSTaylor Simpson
20897cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 1011 -------- PP------ --------","[#11] Rd=(Rs,Rd,#s6)")
20907cf9345cSTaylor SimpsonDEF_ENC32(S4_addaddi,     ICLASS_ALU64" 1011   0ii sssss PPiddddd iiiuuuuu")
20917cf9345cSTaylor SimpsonDEF_ENC32(S4_subaddi,     ICLASS_ALU64" 1011   1ii sssss PPiddddd iiiuuuuu")
20927cf9345cSTaylor Simpson
20937cf9345cSTaylor Simpson
20947cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64"     1100 -------- PP------ --------","[#12] Pd=(Rss,#s8)")
20957cf9345cSTaylor SimpsonDEF_ENC32(A4_vcmpbeqi,   ICLASS_ALU64"1100 000sssss PP-iiiii iii00-dd")
20967cf9345cSTaylor SimpsonDEF_ENC32(A4_vcmpbgti,   ICLASS_ALU64"1100 001sssss PP-iiiii iii00-dd")
20977cf9345cSTaylor SimpsonDEF_ENC32(A4_vcmpbgtui,  ICLASS_ALU64"1100 010sssss PP-0iiii iii00-dd")
20987cf9345cSTaylor SimpsonDEF_ENC32(A4_vcmpheqi,   ICLASS_ALU64"1100 000sssss PP-iiiii iii01-dd")
20997cf9345cSTaylor SimpsonDEF_ENC32(A4_vcmphgti,   ICLASS_ALU64"1100 001sssss PP-iiiii iii01-dd")
21007cf9345cSTaylor SimpsonDEF_ENC32(A4_vcmphgtui,  ICLASS_ALU64"1100 010sssss PP-0iiii iii01-dd")
21017cf9345cSTaylor SimpsonDEF_ENC32(A4_vcmpweqi,   ICLASS_ALU64"1100 000sssss PP-iiiii iii10-dd")
21027cf9345cSTaylor SimpsonDEF_ENC32(A4_vcmpwgti,   ICLASS_ALU64"1100 001sssss PP-iiiii iii10-dd")
21037cf9345cSTaylor SimpsonDEF_ENC32(A4_vcmpwgtui,  ICLASS_ALU64"1100 010sssss PP-0iiii iii10-dd")
21047cf9345cSTaylor Simpson
21057cf9345cSTaylor SimpsonDEF_ENC32(F2_dfclass,    ICLASS_ALU64"1100 100sssss PP-000ii iii10-dd")
21067cf9345cSTaylor Simpson
21077cf9345cSTaylor Simpson
21087cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 1101 -------- PP------ --------","[#13] Pd=(Rs,#s8)")
21097cf9345cSTaylor SimpsonDEF_ENC32(A4_cmpbeqi,    ICLASS_ALU64"1101 -00sssss PP-iiiii iii00-dd")
21107cf9345cSTaylor SimpsonDEF_ENC32(A4_cmpbgti,    ICLASS_ALU64"1101 -01sssss PP-iiiii iii00-dd")
21117cf9345cSTaylor SimpsonDEF_ENC32(A4_cmpbgtui,   ICLASS_ALU64"1101 -10sssss PP-0iiii iii00-dd")
21127cf9345cSTaylor SimpsonDEF_ENC32(A4_cmpheqi,    ICLASS_ALU64"1101 -00sssss PP-iiiii iii01-dd")
21137cf9345cSTaylor SimpsonDEF_ENC32(A4_cmphgti,    ICLASS_ALU64"1101 -01sssss PP-iiiii iii01-dd")
21147cf9345cSTaylor SimpsonDEF_ENC32(A4_cmphgtui,   ICLASS_ALU64"1101 -10sssss PP-0iiii iii01-dd")
21157cf9345cSTaylor Simpson
21167cf9345cSTaylor Simpson
21177cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 1110 -------- PP------ --------","[#14] Rx=(#u9,op(Rx,#u5))")
21187cf9345cSTaylor Simpson
21197cf9345cSTaylor Simpson#define OP_OPI_RI(TAG,OPB)\
21207cf9345cSTaylor SimpsonDEF_ENC32(S4_andi_##TAG##_ri,ICLASS_ALU64" 1110 iiixxxxx PPiIIIII iii"OPB"i00-")\
21217cf9345cSTaylor SimpsonDEF_ENC32(S4_ori_##TAG##_ri, ICLASS_ALU64" 1110 iiixxxxx PPiIIIII iii"OPB"i01-")\
21227cf9345cSTaylor SimpsonDEF_ENC32(S4_addi_##TAG##_ri,ICLASS_ALU64" 1110 iiixxxxx PPiIIIII iii"OPB"i10-")\
21237cf9345cSTaylor SimpsonDEF_ENC32(S4_subi_##TAG##_ri,ICLASS_ALU64" 1110 iiixxxxx PPiIIIII iii"OPB"i11-")
21247cf9345cSTaylor Simpson
21257cf9345cSTaylor SimpsonOP_OPI_RI(asl,"0")
21267cf9345cSTaylor SimpsonOP_OPI_RI(lsr,"1")
21277cf9345cSTaylor Simpson
21287cf9345cSTaylor Simpson
21297cf9345cSTaylor SimpsonDEF_FIELDROW_DESC32(ICLASS_ALU64" 1111 -------- PP------ --------","[#15] Rd=(Rs,Ru,#u6:2)")
21307cf9345cSTaylor SimpsonDEF_ENC32(M4_mpyri_addr_u2, ICLASS_ALU64" 1111   0ii sssss PPiddddd iiiuuuuu")
21317cf9345cSTaylor SimpsonDEF_ENC32(M4_mpyri_addr,    ICLASS_ALU64" 1111   1ii sssss PPiddddd iiiuuuuu")
2132