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