qemu

FORK: QEMU emulator
git clone https://git.neptards.moe/neptards/qemu.git
Log | Files | Refs | Submodules | LICENSE

encode_pp.def (99930B)


      1 /*
      2  *  Copyright(c) 2019-2021 Qualcomm Innovation Center, Inc. All Rights Reserved.
      3  *
      4  *  This program is free software; you can redistribute it and/or modify
      5  *  it under the terms of the GNU General Public License as published by
      6  *  the Free Software Foundation; either version 2 of the License, or
      7  *  (at your option) any later version.
      8  *
      9  *  This program is distributed in the hope that it will be useful,
     10  *  but WITHOUT ANY WARRANTY; without even the implied warranty of
     11  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     12  *  GNU General Public License for more details.
     13  *
     14  *  You should have received a copy of the GNU General Public License
     15  *  along with this program; if not, see <http://www.gnu.org/licenses/>.
     16  */
     17 
     18 /*
     19  * Encodings for 32 bit instructions
     20  *
     21  */
     22 
     23 
     24 
     25 
     26 DEF_CLASS32("---- ---- -------- PP------ --------",ALL_PP)
     27 DEF_FIELD32("---- ---- -------- !!------ --------",Parse,"Packet/Loop parse bits")
     28 DEF_FIELD32("!!!! ---- -------- PP------ --------",ICLASS,"Instruction Class")
     29 
     30 #define ICLASS_EXTENDER   "0000"
     31 #define ICLASS_CJ         "0001"
     32 #define ICLASS_NCJ        "0010"
     33 #define ICLASS_V4LDST     "0011"
     34 #define ICLASS_V2LDST     "0100"
     35 #define ICLASS_J          "0101"
     36 #define ICLASS_CR         "0110"
     37 #define ICLASS_ALU2op     "0111"
     38 #define ICLASS_S2op       "1000"
     39 #define ICLASS_LD         "1001"
     40 #define ICLASS_ST         "1010"
     41 #define ICLASS_ADDI       "1011"
     42 #define ICLASS_S3op       "1100"
     43 #define ICLASS_ALU64      "1101"
     44 #define ICLASS_M          "1110"
     45 #define ICLASS_ALU3op     "1111"
     46 
     47 
     48 
     49 /*******************************/
     50 /*                             */
     51 /*                             */
     52 /*     V4 Immediate Payload    */
     53 /*                             */
     54 /*                             */
     55 /*******************************/
     56 
     57 DEF_CLASS32(ICLASS_EXTENDER" ---- -------- PP------ --------",EXTENDER)
     58 DEF_ENC32(A4_ext, ICLASS_EXTENDER "iiii iiiiiiii PPiiiiii iiiiiiii")
     59 
     60 
     61 
     62 /*******************************/
     63 /*                             */
     64 /*                             */
     65 /*     V2 PREDICATED LD/ST     */
     66 /*                             */
     67 /*                             */
     68 /*******************************/
     69 
     70 DEF_CLASS32(ICLASS_V2LDST" ---- -------- PP------ --------",V2LDST)
     71 DEF_CLASS32(ICLASS_V2LDST" ---1 -------- PP------ --------",V2LD)
     72 DEF_CLASS32(ICLASS_V2LDST" ---0 -------- PP------ --------",V2ST)
     73 DEF_CLASS32(ICLASS_V2LDST" 0--1 -------- PP------ --------",PLD)
     74 DEF_CLASS32(ICLASS_V2LDST" 0--0 -------- PP------ --------",PST)
     75 DEF_CLASS32(ICLASS_V2LDST" 1--1 -------- PP------ --------",GPLD)
     76 DEF_CLASS32(ICLASS_V2LDST" 1--0 -------- PP------ --------",GPST)
     77 
     78 DEF_FIELD32(ICLASS_V2LDST" 0!-- -------- PP------ --------",PMEM_Sense,"Sense")
     79 DEF_FIELD32(ICLASS_V2LDST" 0-!- -------- PP------ --------",PMEM_PredNew,"PredNew")
     80 DEF_FIELD32(ICLASS_V2LDST" ---1 !!------ PP------ --------",PMEML_Type,"Type")
     81 DEF_FIELD32(ICLASS_V2LDST" ---1 --!----- PP------ --------",PMEML_UN,"Unsigned")
     82 DEF_FIELD32(ICLASS_V2LDST" ---0 !!!----- PP------ --------",PMEMS_Type,"Type")
     83 
     84 #define STD_PLD_IOENC(TAG,OPC) \
     85 DEF_ENC32(L2_pload##TAG##t_io,   ICLASS_V2LDST" 0001 "OPC"  sssss  PP0ttiii  iiiddddd")\
     86 DEF_ENC32(L2_pload##TAG##f_io,   ICLASS_V2LDST" 0101 "OPC"  sssss  PP0ttiii  iiiddddd")\
     87 DEF_ENC32(L2_pload##TAG##tnew_io,ICLASS_V2LDST" 0011 "OPC"  sssss  PP0ttiii  iiiddddd")\
     88 DEF_ENC32(L2_pload##TAG##fnew_io,ICLASS_V2LDST" 0111 "OPC"  sssss  PP0ttiii  iiiddddd")
     89 
     90 STD_PLD_IOENC(rb,  "000")
     91 STD_PLD_IOENC(rub, "001")
     92 STD_PLD_IOENC(rh,  "010")
     93 STD_PLD_IOENC(ruh, "011")
     94 STD_PLD_IOENC(ri,  "100")
     95 STD_PLD_IOENC(rd,  "110") /* note dest reg field LSB=0, 1 is reserved */
     96 
     97 
     98 
     99 #define STD_PST_IOENC(TAG,OPC,SRC) \
    100 DEF_ENC32(S2_pstore##TAG##t_io,   ICLASS_V2LDST" 0000 "OPC"  sssss  PPi"SRC"  iiiii0vv")\
    101 DEF_ENC32(S2_pstore##TAG##f_io,   ICLASS_V2LDST" 0100 "OPC"  sssss  PPi"SRC"  iiiii0vv")\
    102 DEF_ENC32(S4_pstore##TAG##tnew_io,ICLASS_V2LDST" 0010 "OPC"  sssss  PPi"SRC"  iiiii0vv")\
    103 DEF_ENC32(S4_pstore##TAG##fnew_io,ICLASS_V2LDST" 0110 "OPC"  sssss  PPi"SRC"  iiiii0vv")
    104 
    105 STD_PST_IOENC(rb,    "000","ttttt")
    106 STD_PST_IOENC(rh,    "010","ttttt")
    107 STD_PST_IOENC(rf,    "011","ttttt")
    108 STD_PST_IOENC(ri,    "100","ttttt")
    109 STD_PST_IOENC(rd,    "110","ttttt")
    110 STD_PST_IOENC(rbnew, "101","00ttt")
    111 STD_PST_IOENC(rhnew, "101","01ttt")
    112 STD_PST_IOENC(rinew, "101","10ttt")
    113 
    114 
    115 
    116 
    117 
    118 /*******************************/
    119 /*                             */
    120 /*                             */
    121 /*     V2 GP-RELATIVE LD/ST    */
    122 /*                             */
    123 /*                             */
    124 /*******************************/
    125 #define STD_LD_GP(TAG,OPC) \
    126 DEF_ENC32(L2_load##TAG##gp,   ICLASS_V2LDST" 1ii1 "OPC"  iiiii  PPiiiiii  iiiddddd")
    127 
    128 STD_LD_GP(rb,  "000")
    129 STD_LD_GP(rub, "001")
    130 STD_LD_GP(rh,  "010")
    131 STD_LD_GP(ruh, "011")
    132 STD_LD_GP(ri,  "100")
    133 STD_LD_GP(rd,  "110") /* note dest reg field LSB=0, 1 is reserved */
    134 
    135 #define STD_ST_GP(TAG,OPC,SRC) \
    136 DEF_ENC32(S2_store##TAG##gp,  ICLASS_V2LDST" 1ii0 "OPC"  iiiii  PPi"SRC"  iiiiiiii")
    137 
    138 STD_ST_GP(rb,   "000","ttttt")
    139 STD_ST_GP(rh,   "010","ttttt")
    140 STD_ST_GP(rf,   "011","ttttt")
    141 STD_ST_GP(ri,   "100","ttttt")
    142 STD_ST_GP(rd,   "110","ttttt")
    143 STD_ST_GP(rbnew,"101","00ttt")
    144 STD_ST_GP(rhnew,"101","01ttt")
    145 STD_ST_GP(rinew,"101","10ttt")
    146 
    147 
    148 
    149 
    150 
    151 /*******************************/
    152 /*                             */
    153 /*                             */
    154 /*     V4LDST                  */
    155 /*                             */
    156 /*                             */
    157 /*******************************/
    158 
    159 
    160 DEF_CLASS32(ICLASS_V4LDST" ---- -------- PP------ --------",V4LDST)
    161 DEF_CLASS32(ICLASS_V4LDST" 0--- -------- PP------ --------",Pred_RplusR)
    162 DEF_CLASS32(ICLASS_V4LDST" 100- -------- PP------ --------",Pred_StoreImmed)
    163 DEF_CLASS32(ICLASS_V4LDST" 101- -------- PP------ --------",RplusR)
    164 DEF_CLASS32(ICLASS_V4LDST" 110- -------- PP------ --------",StoreImmed)
    165 DEF_CLASS32(ICLASS_V4LDST" 111- -------- PP------ --------",MemOp)
    166 
    167 
    168 
    169 
    170 /*******************************/
    171 /*    Pred (R+R)               */
    172 /*******************************/
    173 
    174 #define STD_PLD_RRENC(TAG,OPC) \
    175 DEF_ENC32(L4_pload##TAG##t_rr,   ICLASS_V4LDST" 00 00 "OPC"  sssss  PPittttt  ivvddddd")\
    176 DEF_ENC32(L4_pload##TAG##f_rr,   ICLASS_V4LDST" 00 01 "OPC"  sssss  PPittttt  ivvddddd")\
    177 DEF_ENC32(L4_pload##TAG##tnew_rr,ICLASS_V4LDST" 00 10 "OPC"  sssss  PPittttt  ivvddddd")\
    178 DEF_ENC32(L4_pload##TAG##fnew_rr,ICLASS_V4LDST" 00 11 "OPC"  sssss  PPittttt  ivvddddd")
    179 
    180 STD_PLD_RRENC(rb,  "000")
    181 STD_PLD_RRENC(rub, "001")
    182 STD_PLD_RRENC(rh,  "010")
    183 STD_PLD_RRENC(ruh, "011")
    184 STD_PLD_RRENC(ri,  "100")
    185 STD_PLD_RRENC(rd,  "110")
    186 
    187 #define STD_PST_RRENC(TAG,OPC,SRC) \
    188 DEF_ENC32(S4_pstore##TAG##t_rr,   ICLASS_V4LDST" 01 00 "OPC"  sssss  PPiuuuuu  ivv"SRC)\
    189 DEF_ENC32(S4_pstore##TAG##f_rr,   ICLASS_V4LDST" 01 01 "OPC"  sssss  PPiuuuuu  ivv"SRC)\
    190 DEF_ENC32(S4_pstore##TAG##tnew_rr,ICLASS_V4LDST" 01 10 "OPC"  sssss  PPiuuuuu  ivv"SRC)\
    191 DEF_ENC32(S4_pstore##TAG##fnew_rr,ICLASS_V4LDST" 01 11 "OPC"  sssss  PPiuuuuu  ivv"SRC)
    192 
    193 STD_PST_RRENC(rb,    "000","ttttt")
    194 STD_PST_RRENC(rh,    "010","ttttt")
    195 STD_PST_RRENC(rf,    "011","ttttt")
    196 STD_PST_RRENC(ri,    "100","ttttt")
    197 STD_PST_RRENC(rd,    "110","ttttt")
    198 STD_PST_RRENC(rbnew, "101","00ttt")
    199 STD_PST_RRENC(rhnew, "101","01ttt")
    200 STD_PST_RRENC(rinew, "101","10ttt")
    201 
    202 
    203 
    204 /*******************************/
    205 /*     Pred Store immediates   */
    206 /*******************************/
    207 
    208 #define V4_PSTI(TAG,OPC) \
    209 DEF_ENC32(S4_storei##TAG##t_io,    ICLASS_V4LDST" 100 00  "OPC"  sssss  PPIiiiii  ivvIIIII")\
    210 DEF_ENC32(S4_storei##TAG##f_io,    ICLASS_V4LDST" 100 01  "OPC"  sssss  PPIiiiii  ivvIIIII")\
    211 DEF_ENC32(S4_storei##TAG##tnew_io, ICLASS_V4LDST" 100 10  "OPC"  sssss  PPIiiiii  ivvIIIII")\
    212 DEF_ENC32(S4_storei##TAG##fnew_io, ICLASS_V4LDST" 100 11  "OPC"  sssss  PPIiiiii  ivvIIIII")
    213 
    214 V4_PSTI(rb, "00")
    215 V4_PSTI(rh, "01")
    216 V4_PSTI(ri, "10")
    217 
    218 
    219 
    220 /*******************************/
    221 /*    (R+R)                    */
    222 /*******************************/
    223 
    224 #define STD_LD_RRENC(TAG,OPC) \
    225 DEF_ENC32(L4_load##TAG##_rr,     ICLASS_V4LDST" 1010 "OPC"  sssss  PPittttt  i--ddddd")
    226 
    227 STD_LD_RRENC(rb,  "000")
    228 STD_LD_RRENC(rub, "001")
    229 STD_LD_RRENC(rh,  "010")
    230 STD_LD_RRENC(ruh, "011")
    231 STD_LD_RRENC(ri,  "100")
    232 STD_LD_RRENC(rd,  "110")
    233 
    234 #define STD_ST_RRENC(TAG,OPC,SRC) \
    235 DEF_ENC32(S4_store##TAG##_rr,     ICLASS_V4LDST" 1011 "OPC"  sssss  PPiuuuuu  i--"SRC)
    236 
    237 STD_ST_RRENC(rb,    "000","ttttt")
    238 STD_ST_RRENC(rh,    "010","ttttt")
    239 STD_ST_RRENC(rf,    "011","ttttt")
    240 STD_ST_RRENC(ri,    "100","ttttt")
    241 STD_ST_RRENC(rd,    "110","ttttt")
    242 STD_ST_RRENC(rbnew, "101","00ttt")
    243 STD_ST_RRENC(rhnew, "101","01ttt")
    244 STD_ST_RRENC(rinew, "101","10ttt")
    245 
    246 
    247 
    248 
    249 /*******************************/
    250 /*     Store immediates        */
    251 /*******************************/
    252 
    253 #define V4_STI(TAG,OPC) \
    254 DEF_ENC32(S4_storei##TAG##_io,     ICLASS_V4LDST" 110 -- "OPC"  sssss  PPIiiiii  iIIIIIII")
    255 
    256 
    257 V4_STI(rb, "00")
    258 V4_STI(rh, "01")
    259 V4_STI(ri, "10")
    260 
    261 
    262 /*******************************/
    263 /*     Memops                 */
    264 /*******************************/
    265 
    266 #define MEMOPENC(TAG,OPC) \
    267 DEF_ENC32(L4_add_##TAG##_io,         ICLASS_V4LDST" 111 0- " OPC "sssss  PP0iiiii  i00ttttt")\
    268 DEF_ENC32(L4_sub_##TAG##_io,         ICLASS_V4LDST" 111 0- " OPC "sssss  PP0iiiii  i01ttttt")\
    269 DEF_ENC32(L4_and_##TAG##_io,         ICLASS_V4LDST" 111 0- " OPC "sssss  PP0iiiii  i10ttttt")\
    270 DEF_ENC32(L4_or_##TAG##_io,          ICLASS_V4LDST" 111 0- " OPC "sssss  PP0iiiii  i11ttttt")\
    271 \
    272 DEF_ENC32(L4_iadd_##TAG##_io,        ICLASS_V4LDST" 111 1- " OPC "sssss  PP0iiiii  i00IIIII")\
    273 DEF_ENC32(L4_isub_##TAG##_io,        ICLASS_V4LDST" 111 1- " OPC "sssss  PP0iiiii  i01IIIII")\
    274 DEF_ENC32(L4_iand_##TAG##_io,        ICLASS_V4LDST" 111 1- " OPC "sssss  PP0iiiii  i10IIIII")\
    275 DEF_ENC32(L4_ior_##TAG##_io,         ICLASS_V4LDST" 111 1- " OPC "sssss  PP0iiiii  i11IIIII")
    276 
    277 
    278 
    279 MEMOPENC(memopw,"10")
    280 MEMOPENC(memoph,"01")
    281 MEMOPENC(memopb,"00")
    282 
    283 
    284 
    285 
    286 /*******************************/
    287 /*                             */
    288 /*                             */
    289 /*           LOAD              */
    290 /*                             */
    291 /*                             */
    292 /*******************************/
    293 DEF_CLASS32(ICLASS_LD" ---- -------- PP------ --------",LD)
    294 
    295 
    296 DEF_CLASS32(ICLASS_LD" 0--- -------- PP------ --------",LD_ADDR_ROFFSET)
    297 DEF_CLASS32(ICLASS_LD" 100- -------- PP----0- --------",LD_ADDR_POST_CIRC_IMMED)
    298 DEF_CLASS32(ICLASS_LD" 101- -------- PP00---- --------",LD_ADDR_POST_IMMED)
    299 DEF_CLASS32(ICLASS_LD" 101- -------- PP01---- --------",LD_ADDR_ABS_UPDATE_V4)
    300 DEF_CLASS32(ICLASS_LD" 101- -------- PP1----- --------",LD_ADDR_POST_IMMED_PRED_V2)
    301 DEF_CLASS32(ICLASS_LD" 110- -------- PP-0---- 0-------",LD_ADDR_POST_REG)
    302 DEF_CLASS32(ICLASS_LD" 110- -------- PP-1---- --------",LD_ADDR_ABS_PLUS_REG_V4)
    303 DEF_CLASS32(ICLASS_LD" 100- -------- PP----1- --------",LD_ADDR_POST_CREG_V2)
    304 DEF_CLASS32(ICLASS_LD" 111- -------- PP------ 0-------",LD_ADDR_POST_BREV_REG)
    305 DEF_CLASS32(ICLASS_LD" 111- -------- PP------ 1-------",LD_ADDR_PRED_ABS_V4)
    306 
    307 DEF_FIELD32(ICLASS_LD" !!!- -------- PP------ --------",LD_Amode,"Amode")
    308 DEF_FIELD32(ICLASS_LD" ---! !!------ PP------ --------",LD_Type,"Type")
    309 DEF_FIELD32(ICLASS_LD" ---- --!----- PP------ --------",LD_UN,"Unsigned")
    310 
    311 #define STD_LD_ENC(TAG,OPC) \
    312 DEF_ENC32(L2_load##TAG##_io,   ICLASS_LD" 0 ii "OPC"  sssss  PPiiiiii  iiiddddd")\
    313 DEF_ENC32(L2_load##TAG##_pci,  ICLASS_LD" 1 00 "OPC"  xxxxx  PPu0--0i  iiiddddd")\
    314 DEF_ENC32(L2_load##TAG##_pi,   ICLASS_LD" 1 01 "OPC"  xxxxx  PP00---i  iiiddddd")\
    315 DEF_ENC32(L4_load##TAG##_ap,   ICLASS_LD" 1 01 "OPC"  eeeee  PP01IIII  -IIddddd")\
    316 DEF_ENC32(L2_load##TAG##_pr,   ICLASS_LD" 1 10 "OPC"  xxxxx  PPu0----  0--ddddd")\
    317 DEF_ENC32(L4_load##TAG##_ur,   ICLASS_LD" 1 10 "OPC"  ttttt  PPi1IIII  iIIddddd")\
    318 DEF_ENC32(L2_load##TAG##_pcr,  ICLASS_LD" 1 00 "OPC"  xxxxx  PPu0--1-  0--ddddd")\
    319 DEF_ENC32(L2_load##TAG##_pbr,  ICLASS_LD" 1 11 "OPC"  xxxxx  PPu0----  0--ddddd")
    320 
    321 
    322 #define STD_LDX_ENC(TAG,OPC) \
    323 DEF_ENC32(L2_load##TAG##_io,   ICLASS_LD" 0 ii "OPC"  sssss  PPiiiiii  iiiyyyyy")\
    324 DEF_ENC32(L2_load##TAG##_pci,  ICLASS_LD" 1 00 "OPC"  xxxxx  PPu0--0i  iiiyyyyy")\
    325 DEF_ENC32(L2_load##TAG##_pi,   ICLASS_LD" 1 01 "OPC"  xxxxx  PP00---i  iiiyyyyy")\
    326 DEF_ENC32(L4_load##TAG##_ap,   ICLASS_LD" 1 01 "OPC"  eeeee  PP01IIII  -IIyyyyy")\
    327 DEF_ENC32(L2_load##TAG##_pr,   ICLASS_LD" 1 10 "OPC"  xxxxx  PPu0----  0--yyyyy")\
    328 DEF_ENC32(L4_load##TAG##_ur,   ICLASS_LD" 1 10 "OPC"  ttttt  PPi1IIII  iIIyyyyy")\
    329 DEF_ENC32(L2_load##TAG##_pcr,  ICLASS_LD" 1 00 "OPC"  xxxxx  PPu0--1-  0--yyyyy")\
    330 DEF_ENC32(L2_load##TAG##_pbr,  ICLASS_LD" 1 11 "OPC"  xxxxx  PPu0----  0--yyyyy")
    331 
    332 
    333 #define STD_PLD_ENC(TAG,OPC) \
    334 DEF_ENC32(L2_pload##TAG##t_pi,    ICLASS_LD" 1 01 "OPC"  xxxxx  PP100tti  iiiddddd")\
    335 DEF_ENC32(L2_pload##TAG##f_pi,    ICLASS_LD" 1 01 "OPC"  xxxxx  PP101tti  iiiddddd")\
    336 DEF_ENC32(L2_pload##TAG##tnew_pi, ICLASS_LD" 1 01 "OPC"  xxxxx  PP110tti  iiiddddd")\
    337 DEF_ENC32(L2_pload##TAG##fnew_pi, ICLASS_LD" 1 01 "OPC"  xxxxx  PP111tti  iiiddddd")\
    338 DEF_ENC32(L4_pload##TAG##t_abs,   ICLASS_LD" 1 11 "OPC"  iiiii  PP100tti  1--ddddd")\
    339 DEF_ENC32(L4_pload##TAG##f_abs,   ICLASS_LD" 1 11 "OPC"  iiiii  PP101tti  1--ddddd")\
    340 DEF_ENC32(L4_pload##TAG##tnew_abs,ICLASS_LD" 1 11 "OPC"  iiiii  PP110tti  1--ddddd")\
    341 DEF_ENC32(L4_pload##TAG##fnew_abs,ICLASS_LD" 1 11 "OPC"  iiiii  PP111tti  1--ddddd")
    342 
    343 
    344 /*               0 000  misc: dealloc,loadw_locked,dcfetch      */
    345 STD_LD_ENC(bzw4,"0 101")
    346 STD_LD_ENC(bzw2,"0 011")
    347 
    348 STD_LD_ENC(bsw4,"0 111")
    349 STD_LD_ENC(bsw2,"0 001")
    350 
    351 STD_LDX_ENC(alignh,"0 010")
    352 STD_LDX_ENC(alignb,"0 100")
    353 
    354 STD_LD_ENC(rb,  "1 000")
    355 STD_LD_ENC(rub, "1 001")
    356 STD_LD_ENC(rh,  "1 010")
    357 STD_LD_ENC(ruh, "1 011")
    358 STD_LD_ENC(ri,  "1 100")
    359 STD_LD_ENC(rd,  "1 110") /* note dest reg field LSB=0, 1 is reserved */
    360 
    361 STD_PLD_ENC(rb,  "1 000")
    362 STD_PLD_ENC(rub, "1 001")
    363 STD_PLD_ENC(rh,  "1 010")
    364 STD_PLD_ENC(ruh, "1 011")
    365 STD_PLD_ENC(ri,  "1 100")
    366 STD_PLD_ENC(rd,  "1 110") /* note dest reg field LSB=0, 1 is reserved */
    367 
    368 
    369 DEF_CLASS32(    ICLASS_LD" 0--0 000----- PP------ --------",LD_MISC)
    370 DEF_ANTICLASS32(ICLASS_LD" 0--0 000----- PP------ --------",LD_ADDR_ROFFSET)
    371 DEF_ANTICLASS32(ICLASS_LD" 1000 000----- PP------ --------",LD_ADDR_POST_CIRC_IMMED)
    372 DEF_ANTICLASS32(ICLASS_LD" 1010 000----- PP------ --------",LD_ADDR_POST_IMMED)
    373 DEF_ANTICLASS32(ICLASS_LD" 1100 000----- PP------ --------",LD_ADDR_POST_REG)
    374 DEF_ANTICLASS32(ICLASS_LD" 1110 000----- PP------ --------",LD_ADDR_POST_REG)
    375 
    376 DEF_ENC32(L2_deallocframe,    ICLASS_LD" 000 0 000 sssss PP0----- ---ddddd")
    377 DEF_ENC32(L4_return,          ICLASS_LD" 011 0 000 sssss PP0000-- ---ddddd")
    378 DEF_ENC32(L4_return_t,        ICLASS_LD" 011 0 000 sssss PP0100vv ---ddddd")
    379 DEF_ENC32(L4_return_f,        ICLASS_LD" 011 0 000 sssss PP1100vv ---ddddd")
    380 DEF_ENC32(L4_return_tnew_pt,  ICLASS_LD" 011 0 000 sssss PP0110vv ---ddddd")
    381 DEF_ENC32(L4_return_fnew_pt,  ICLASS_LD" 011 0 000 sssss PP1110vv ---ddddd")
    382 DEF_ENC32(L4_return_tnew_pnt, ICLASS_LD" 011 0 000 sssss PP0010vv ---ddddd")
    383 DEF_ENC32(L4_return_fnew_pnt, ICLASS_LD" 011 0 000 sssss PP1010vv ---ddddd")
    384 
    385 DEF_ENC32(L2_loadw_locked,ICLASS_LD" 001 0 000 sssss PP00---- -00ddddd")
    386 
    387 
    388 
    389 
    390 
    391 
    392 DEF_ENC32(L4_loadd_locked,ICLASS_LD" 001 0 000 sssss PP01---- -00ddddd")
    393 DEF_EXT_SPACE(EXTRACTW,   ICLASS_LD" 001 0 000 iiiii PP0iiiii -01iiiii")
    394 DEF_ENC32(Y2_dcfetchbo,   ICLASS_LD" 010 0 000 sssss PP0--iii iiiiiiii")
    395 
    396 
    397 
    398 
    399 
    400 
    401 
    402 
    403 /*******************************/
    404 /*                             */
    405 /*                             */
    406 /*           STORE             */
    407 /*                             */
    408 /*                             */
    409 /*******************************/
    410 
    411 DEF_CLASS32(ICLASS_ST" ---- -------- PP------ --------",ST)
    412 
    413 DEF_FIELD32(ICLASS_ST" !!!- -------- PP------ --------",ST_Amode,"Amode")
    414 DEF_FIELD32(ICLASS_ST" ---! !!------ PP------ --------",ST_Type,"Type")
    415 DEF_FIELD32(ICLASS_ST" ---- --!----- PP------ --------",ST_UN,"Unsigned")
    416 
    417 DEF_CLASS32(ICLASS_ST" 0--1 -------- PP------ --------",ST_ADDR_ROFFSET)
    418 DEF_CLASS32(ICLASS_ST" 1001 -------- PP------ ------0-",ST_ADDR_POST_CIRC_IMMED)
    419 DEF_CLASS32(ICLASS_ST" 1011 -------- PP0----- 0-----0-",ST_ADDR_POST_IMMED)
    420 DEF_CLASS32(ICLASS_ST" 1011 -------- PP0----- 1-------",ST_ADDR_ABS_UPDATE_V4)
    421 DEF_CLASS32(ICLASS_ST" 1011 -------- PP1----- --------",ST_ADDR_POST_IMMED_PRED_V2)
    422 DEF_CLASS32(ICLASS_ST" 1111 -------- PP------ 1-------",ST_ADDR_PRED_ABS_V4)
    423 DEF_CLASS32(ICLASS_ST" 1101 -------- PP------ 0-------",ST_ADDR_POST_REG)
    424 DEF_CLASS32(ICLASS_ST" 1101 -------- PP------ 1-------",ST_ADDR_ABS_PLUS_REG_V4)
    425 DEF_CLASS32(ICLASS_ST" 1001 -------- PP------ ------1-",ST_ADDR_POST_CREG_V2)
    426 DEF_CLASS32(ICLASS_ST" 1111 -------- PP------ 0-------",ST_ADDR_POST_BREV_REG)
    427 DEF_CLASS32(ICLASS_ST" 0--0 1------- PP------ --------",ST_MISC_STORELIKE)
    428 DEF_CLASS32(ICLASS_ST" 1--0 0------- PP------ --------",ST_MISC_BUSOP)
    429 DEF_CLASS32(ICLASS_ST" 0--0 0------- PP------ --------",ST_MISC_CACHEOP)
    430 
    431 
    432 #define STD_ST_ENC(TAG,OPC,SRC) \
    433 DEF_ENC32(S2_store##TAG##_io,   ICLASS_ST" 0 ii "OPC"  sssss  PPi"SRC"  iiiiiiii")\
    434 DEF_ENC32(S2_store##TAG##_pci,  ICLASS_ST" 1 00 "OPC"  xxxxx  PPu"SRC"  0iiii-0-")\
    435 DEF_ENC32(S2_store##TAG##_pi,   ICLASS_ST" 1 01 "OPC"  xxxxx  PP0"SRC"  0iiii-0-")\
    436 DEF_ENC32(S4_store##TAG##_ap,   ICLASS_ST" 1 01 "OPC"  eeeee  PP0"SRC"  1-IIIIII")\
    437 DEF_ENC32(S2_store##TAG##_pr,   ICLASS_ST" 1 10 "OPC"  xxxxx  PPu"SRC"  0-------")\
    438 DEF_ENC32(S4_store##TAG##_ur,   ICLASS_ST" 1 10 "OPC"  uuuuu  PPi"SRC"  1iIIIIII")\
    439 DEF_ENC32(S2_store##TAG##_pcr,  ICLASS_ST" 1 00 "OPC"  xxxxx  PPu"SRC"  0-----1-")\
    440 DEF_ENC32(S2_store##TAG##_pbr,  ICLASS_ST" 1 11 "OPC"  xxxxx  PPu"SRC"  0-------")
    441 
    442 
    443 #define STD_PST_ENC(TAG,OPC,SRC) \
    444 DEF_ENC32(S2_pstore##TAG##t_pi,    ICLASS_ST" 1 01 "OPC"  xxxxx  PP1"SRC"  0iiii0vv")\
    445 DEF_ENC32(S2_pstore##TAG##f_pi,    ICLASS_ST" 1 01 "OPC"  xxxxx  PP1"SRC"  0iiii1vv")\
    446 DEF_ENC32(S2_pstore##TAG##tnew_pi, ICLASS_ST" 1 01 "OPC"  xxxxx  PP1"SRC"  1iiii0vv")\
    447 DEF_ENC32(S2_pstore##TAG##fnew_pi, ICLASS_ST" 1 01 "OPC"  xxxxx  PP1"SRC"  1iiii1vv")\
    448 DEF_ENC32(S4_pstore##TAG##t_abs,   ICLASS_ST" 1 11 "OPC"  ---ii  PP0"SRC"  1iiii0vv")\
    449 DEF_ENC32(S4_pstore##TAG##f_abs,   ICLASS_ST" 1 11 "OPC"  ---ii  PP0"SRC"  1iiii1vv")\
    450 DEF_ENC32(S4_pstore##TAG##tnew_abs,ICLASS_ST" 1 11 "OPC"  ---ii  PP1"SRC"  1iiii0vv")\
    451 DEF_ENC32(S4_pstore##TAG##fnew_abs,ICLASS_ST" 1 11 "OPC"  ---ii  PP1"SRC"  1iiii1vv")
    452 
    453 
    454 /*                 0 0--  Store Misc */
    455 /*                 0 1xx  Available */
    456 STD_ST_ENC(rb,    "1 000","ttttt")
    457 STD_ST_ENC(rh,    "1 010","ttttt")
    458 STD_ST_ENC(rf,    "1 011","ttttt")
    459 STD_ST_ENC(ri,    "1 100","ttttt")
    460 STD_ST_ENC(rd,    "1 110","ttttt")
    461 STD_ST_ENC(rbnew, "1 101","00ttt")
    462 STD_ST_ENC(rhnew, "1 101","01ttt")
    463 STD_ST_ENC(rinew, "1 101","10ttt")
    464 
    465 STD_PST_ENC(rb,    "1 000","ttttt")
    466 STD_PST_ENC(rh,    "1 010","ttttt")
    467 STD_PST_ENC(rf,    "1 011","ttttt")
    468 STD_PST_ENC(ri,    "1 100","ttttt")
    469 STD_PST_ENC(rd,    "1 110","ttttt")
    470 STD_PST_ENC(rbnew, "1 101","00ttt")
    471 STD_PST_ENC(rhnew, "1 101","01ttt")
    472 STD_PST_ENC(rinew, "1 101","10ttt")
    473 
    474 
    475 
    476 /* User */
    477 /*                                   xx - st_misc */
    478 /*                                                */
    479 /*                               x bus/cache     */
    480 /*                                    x store/cache     */
    481 DEF_ENC32(S2_allocframe,   ICLASS_ST" 000 01 00xxxxx PP000iii iiiiiiii")
    482 DEF_ENC32(S2_storew_locked,ICLASS_ST" 000 01 01sssss PP-ttttt ------dd")
    483 DEF_ENC32(S4_stored_locked,ICLASS_ST" 000 01 11sssss PP0ttttt ------dd")
    484 DEF_ENC32(Y2_dczeroa,      ICLASS_ST" 000 01 10sssss PP0----- --------")
    485 
    486 
    487 DEF_ENC32(Y2_barrier,      ICLASS_ST" 100 00 00----- PP------ 000-----")
    488 DEF_ENC32(Y2_syncht,       ICLASS_ST" 100 00 10----- PP------ --------")
    489 
    490 
    491 
    492 DEF_ENC32(Y2_dccleana,     ICLASS_ST" 000 00 00sssss PP------ --------")
    493 DEF_ENC32(Y2_dcinva,       ICLASS_ST" 000 00 01sssss PP------ --------")
    494 DEF_ENC32(Y2_dccleaninva,  ICLASS_ST" 000 00 10sssss PP------ --------")
    495 
    496 DEF_ENC32(Y4_l2fetch,      ICLASS_ST" 011 00 00sssss PP-ttttt 000-----")
    497 DEF_ENC32(Y5_l2fetch,      ICLASS_ST" 011 01 00sssss PP-ttttt --------")
    498 
    499 /*******************************/
    500 /*                             */
    501 /*                             */
    502 /*           JUMP              */
    503 /*                             */
    504 /*                             */
    505 /*******************************/
    506 
    507 DEF_CLASS32(ICLASS_J" ---- -------- PP------ --------",J)
    508 DEF_CLASS32(ICLASS_J" 0--- -------- PP------ --------",JUMPR_MISC)
    509 DEF_CLASS32(ICLASS_J" 10-- -------- PP------ --------",UCJUMP)
    510 DEF_CLASS32(ICLASS_J" 110- -------- PP------ --------",CJUMP)
    511 DEF_FIELD32(ICLASS_J" 110- -------- PP--!--- --------",J_DN,"Dot-new")
    512 DEF_FIELD32(ICLASS_J" 110- -------- PP-!---- --------",J_PT,"Predict-taken")
    513 
    514 
    515 
    516 DEF_FIELDROW_DESC32(ICLASS_J" 0000 -------- PP------ --------","[#0] PC=(Rs), R31=return")
    517 DEF_ENC32(J2_callr,     ICLASS_J" 0000  101sssss  PP------  --------")
    518 
    519 DEF_FIELDROW_DESC32(ICLASS_J" 0001 -------- PP------ --------","[#1] if (Pu) PC=(Rs), R31=return")
    520 DEF_ENC32(J2_callrt,    ICLASS_J" 0001  000sssss  PP----uu  --------")
    521 DEF_ENC32(J2_callrf,    ICLASS_J" 0001  001sssss  PP----uu  --------")
    522 
    523 DEF_FIELDROW_DESC32(ICLASS_J" 0010 -------- PP------ --------","[#2] PC=(Rs); ")
    524 DEF_ENC32(J2_jumpr,      ICLASS_J" 0010  100sssss  PP------  --------")
    525 DEF_ENC32(J4_hintjumpr,  ICLASS_J" 0010  101sssss  PP------  --------")
    526 
    527 DEF_FIELDROW_DESC32(ICLASS_J" 0011 -------- PP------ --------","[#3] if (Pu) PC=(Rs) ")
    528 DEF_ENC32(J2_jumprt,   ICLASS_J" 0011  010sssss  PP-00-uu  --------")
    529 DEF_ENC32(J2_jumprf,   ICLASS_J" 0011  011sssss  PP-00-uu  --------")
    530 DEF_ENC32(J2_jumprtpt,    ICLASS_J" 0011  010sssss  PP-10-uu  --------")
    531 DEF_ENC32(J2_jumprfpt,    ICLASS_J" 0011  011sssss  PP-10-uu  --------")
    532 DEF_ENC32(J2_jumprtnew,   ICLASS_J" 0011  010sssss  PP-01-uu  --------")
    533 DEF_ENC32(J2_jumprfnew,   ICLASS_J" 0011  011sssss  PP-01-uu  --------")
    534 DEF_ENC32(J2_jumprtnewpt, ICLASS_J" 0011  010sssss  PP-11-uu  --------")
    535 DEF_ENC32(J2_jumprfnewpt, ICLASS_J" 0011  011sssss  PP-11-uu  --------")
    536 
    537 DEF_FIELDROW_DESC32(ICLASS_J" 0100 -------- PP------ --------","[#4] (#u8) ")
    538 DEF_ENC32(J2_trap0,     ICLASS_J" 0100  00------  PP-iiiii  ---iii--")
    539 DEF_ENC32(J2_pause,     ICLASS_J" 0100  01------  PP-iiiii  ---iii--")
    540 
    541 DEF_FIELDROW_DESC32(ICLASS_J" 0110 -------- PP------ --------","[#6] icop(Rs) ")
    542 DEF_ENC32(Y2_icinva,    ICLASS_J" 0110  110sssss  PP000---  --------")
    543 
    544 DEF_FIELDROW_DESC32(ICLASS_J" 0111 -------- PP------ --------","[#7] () ")
    545 DEF_ENC32(Y2_isync,     ICLASS_J" 0111  11000000  PP0---00  00000010")
    546 
    547 /* JUMP */
    548 DEF_FIELDROW_DESC32(ICLASS_J" 100- -------- PP------ --------","[#8,9] PC=(#r22)")
    549 DEF_ENC32(J2_jump,      ICLASS_J" 100i  iiiiiiii  PPiiiiii  iiiiiii-")
    550 
    551 DEF_FIELDROW_DESC32(ICLASS_J" 101- -------- PP------ --------","[#10,11] PC=(#r22), R31=return")
    552 DEF_ENC32(J2_call,      ICLASS_J" 101i  iiiiiiii  PPiiiiii  iiiiiii0")
    553 
    554 DEF_FIELDROW_DESC32(ICLASS_J" 1100 -------- PP------ --------","[#12] if (Pu) PC=(#r15)")
    555 DEF_ENC32(J2_jumpt,  ICLASS_J" 1100  ii0iiiii  PPi00-uu  iiiiiii-")
    556 DEF_ENC32(J2_jumpf,  ICLASS_J" 1100  ii1iiiii  PPi00-uu  iiiiiii-")
    557 DEF_ENC32(J2_jumptpt,   ICLASS_J" 1100  ii0iiiii  PPi10-uu  iiiiiii-")
    558 DEF_ENC32(J2_jumpfpt,   ICLASS_J" 1100  ii1iiiii  PPi10-uu  iiiiiii-")
    559 DEF_ENC32(J2_jumptnew,  ICLASS_J" 1100  ii0iiiii  PPi01-uu  iiiiiii-")
    560 DEF_ENC32(J2_jumpfnew,  ICLASS_J" 1100  ii1iiiii  PPi01-uu  iiiiiii-")
    561 DEF_ENC32(J2_jumptnewpt,ICLASS_J" 1100  ii0iiiii  PPi11-uu  iiiiiii-")
    562 DEF_ENC32(J2_jumpfnewpt,ICLASS_J" 1100  ii1iiiii  PPi11-uu  iiiiiii-")
    563 
    564 DEF_FIELDROW_DESC32(ICLASS_J" 1101 -------- PP------ --------","[#13] if (Pu) PC=(#r15), R31=return")
    565 DEF_ENC32(J2_callt,     ICLASS_J" 1101  ii0iiiii  PPi-0-uu  iiiiiii-")
    566 DEF_ENC32(J2_callf,     ICLASS_J" 1101  ii1iiiii  PPi-0-uu  iiiiiii-")
    567 
    568 
    569 
    570 
    571 
    572 
    573 
    574 /*******************************/
    575 /*                             */
    576 /*        V4                   */
    577 /*   COMPOUND COMPARE-JUMPS    */
    578 /*                             */
    579 /*                             */
    580 /*******************************/
    581 
    582 
    583 /* EJP: this has to match what we have in htmldocs.py... so I will call it CJ, we can change it */
    584 DEF_CLASS32(ICLASS_CJ" 0--- -------- PP------ --------",CJ)
    585 
    586 DEF_FIELDROW_DESC32(ICLASS_CJ" 00-- -------- -------- --------","[#0-3]  pd=cmp.xx(R,#u5) ; if ([!]p0.new) jump:[h] #s9:2 ")
    587 DEF_FIELDROW_DESC32(ICLASS_CJ" 010- -------- -------- --------","[#4,5]  pd=cmp.eq(R,R) ; if ([!]p0.new) jump:[h] #s9:2 ")
    588 DEF_FIELDROW_DESC32(ICLASS_CJ" 0110 -------- -------- --------","[#6]    Rd=#u6 ; jump #s9:2 ")
    589 DEF_FIELDROW_DESC32(ICLASS_CJ" 0111 -------- -------- --------","[#7]    Rd=Rs ; jump #s9:2 ")
    590 
    591 
    592 #define CMPJMPI_ENC(TAG,OPC) \
    593 DEF_ENC32(TAG##i_tp0_jump_t,      ICLASS_CJ" 00 0 "OPC"  0iissss  PP1IIIII  iiiiiii-") \
    594 DEF_ENC32(TAG##i_fp0_jump_t,      ICLASS_CJ" 00 0 "OPC"  1iissss  PP1IIIII  iiiiiii-") \
    595 DEF_ENC32(TAG##i_tp0_jump_nt,     ICLASS_CJ" 00 0 "OPC"  0iissss  PP0IIIII  iiiiiii-") \
    596 DEF_ENC32(TAG##i_fp0_jump_nt,     ICLASS_CJ" 00 0 "OPC"  1iissss  PP0IIIII  iiiiiii-") \
    597 \
    598 DEF_ENC32(TAG##i_tp1_jump_t,      ICLASS_CJ" 00 1 "OPC"  0iissss  PP1IIIII  iiiiiii-") \
    599 DEF_ENC32(TAG##i_fp1_jump_t,      ICLASS_CJ" 00 1 "OPC"  1iissss  PP1IIIII  iiiiiii-") \
    600 DEF_ENC32(TAG##i_tp1_jump_nt,     ICLASS_CJ" 00 1 "OPC"  0iissss  PP0IIIII  iiiiiii-") \
    601 DEF_ENC32(TAG##i_fp1_jump_nt,     ICLASS_CJ" 00 1 "OPC"  1iissss  PP0IIIII  iiiiiii-")
    602 
    603 CMPJMPI_ENC(J4_cmpeq,"00")
    604 CMPJMPI_ENC(J4_cmpgt,"01")
    605 CMPJMPI_ENC(J4_cmpgtu,"10")
    606 
    607 
    608 #define CMPJMP1I_ENC(TAG,OPC) \
    609 DEF_ENC32(TAG##_tp0_jump_t,      ICLASS_CJ" 00 0  11  0iissss  PP1---"OPC"  iiiiiii-") \
    610 DEF_ENC32(TAG##_fp0_jump_t,      ICLASS_CJ" 00 0  11  1iissss  PP1---"OPC"  iiiiiii-") \
    611 DEF_ENC32(TAG##_tp0_jump_nt,     ICLASS_CJ" 00 0  11  0iissss  PP0---"OPC"  iiiiiii-") \
    612 DEF_ENC32(TAG##_fp0_jump_nt,     ICLASS_CJ" 00 0  11  1iissss  PP0---"OPC"  iiiiiii-") \
    613 \
    614 DEF_ENC32(TAG##_tp1_jump_t,      ICLASS_CJ" 00 1  11  0iissss  PP1---"OPC"  iiiiiii-") \
    615 DEF_ENC32(TAG##_fp1_jump_t,      ICLASS_CJ" 00 1  11  1iissss  PP1---"OPC"  iiiiiii-") \
    616 DEF_ENC32(TAG##_tp1_jump_nt,     ICLASS_CJ" 00 1  11  0iissss  PP0---"OPC"  iiiiiii-") \
    617 DEF_ENC32(TAG##_fp1_jump_nt,     ICLASS_CJ" 00 1  11  1iissss  PP0---"OPC"  iiiiiii-")
    618 
    619 CMPJMP1I_ENC(J4_cmpeqn1,"00")
    620 CMPJMP1I_ENC(J4_cmpgtn1,"01")
    621 CMPJMP1I_ENC(J4_tstbit0,"11")
    622 
    623 
    624 
    625 #define CMPJMPR_ENC(TAG,OPC) \
    626 DEF_ENC32(TAG##_tp0_jump_t,       ICLASS_CJ" 01 0 "OPC"  0iissss  PP10tttt  iiiiiii-") \
    627 DEF_ENC32(TAG##_fp0_jump_t,       ICLASS_CJ" 01 0 "OPC"  1iissss  PP10tttt  iiiiiii-") \
    628 DEF_ENC32(TAG##_tp0_jump_nt,      ICLASS_CJ" 01 0 "OPC"  0iissss  PP00tttt  iiiiiii-") \
    629 DEF_ENC32(TAG##_fp0_jump_nt,      ICLASS_CJ" 01 0 "OPC"  1iissss  PP00tttt  iiiiiii-") \
    630 \
    631 DEF_ENC32(TAG##_tp1_jump_t,       ICLASS_CJ" 01 0 "OPC"  0iissss  PP11tttt  iiiiiii-") \
    632 DEF_ENC32(TAG##_fp1_jump_t,       ICLASS_CJ" 01 0 "OPC"  1iissss  PP11tttt  iiiiiii-") \
    633 DEF_ENC32(TAG##_tp1_jump_nt,      ICLASS_CJ" 01 0 "OPC"  0iissss  PP01tttt  iiiiiii-") \
    634 DEF_ENC32(TAG##_fp1_jump_nt,      ICLASS_CJ" 01 0 "OPC"  1iissss  PP01tttt  iiiiiii-")
    635 
    636 CMPJMPR_ENC(J4_cmpeq,"00")
    637 CMPJMPR_ENC(J4_cmpgt,"01")
    638 CMPJMPR_ENC(J4_cmpgtu,"10")
    639 
    640 
    641 DEF_ENC32(J4_jumpseti,            ICLASS_CJ" 0110  --iidddd  PPIIIIII  iiiiiii-")
    642 DEF_ENC32(J4_jumpsetr,            ICLASS_CJ" 0111  --iissss  PP--dddd  iiiiiii-")
    643 
    644 
    645 DEF_EXT_SPACE(EXT_CJ,             ICLASS_CJ"1 iii  iiiiiiii  PPiiiiii  iiiiiiii")
    646 
    647 
    648 
    649 DEF_CLASS32(ICLASS_NCJ" 0--- -------- PP------ --------",NCJ)
    650 DEF_FIELDROW_DESC32(ICLASS_NCJ" 00-- -------- -------- --------","[#0-3] if (cmp.xx(R.new,R)) jump:[h] #s9:2 ")
    651 DEF_FIELDROW_DESC32(ICLASS_NCJ" 01-- -------- -------- --------","[#4-7] if (cmp.xx(R.new,#U5)) jump:[h] #s9:2 ")
    652 
    653 #define OPRJMP_ENC(TAG,OPC) \
    654 DEF_ENC32(TAG##_t_jumpnv_t,       ICLASS_NCJ" 00 "OPC"  0ii-sss  PP1ttttt  iiiiiii-") \
    655 DEF_ENC32(TAG##_f_jumpnv_t,       ICLASS_NCJ" 00 "OPC"  1ii-sss  PP1ttttt  iiiiiii-") \
    656 DEF_ENC32(TAG##_t_jumpnv_nt,      ICLASS_NCJ" 00 "OPC"  0ii-sss  PP0ttttt  iiiiiii-") \
    657 DEF_ENC32(TAG##_f_jumpnv_nt,      ICLASS_NCJ" 00 "OPC"  1ii-sss  PP0ttttt  iiiiiii-")
    658 
    659 OPRJMP_ENC(J4_cmpeq,   "000")
    660 OPRJMP_ENC(J4_cmpgt,   "001")
    661 OPRJMP_ENC(J4_cmpgtu,  "010")
    662 OPRJMP_ENC(J4_cmplt,   "011")
    663 OPRJMP_ENC(J4_cmpltu,  "100")
    664 
    665 
    666 #define OPIJMP_ENC(TAG,OPC) \
    667 DEF_ENC32(TAG##_t_jumpnv_t,       ICLASS_NCJ" 01 "OPC"  0ii-sss  PP1IIIII  iiiiiii-") \
    668 DEF_ENC32(TAG##_f_jumpnv_t,       ICLASS_NCJ" 01 "OPC"  1ii-sss  PP1IIIII  iiiiiii-") \
    669 DEF_ENC32(TAG##_t_jumpnv_nt,      ICLASS_NCJ" 01 "OPC"  0ii-sss  PP0IIIII  iiiiiii-") \
    670 DEF_ENC32(TAG##_f_jumpnv_nt,      ICLASS_NCJ" 01 "OPC"  1ii-sss  PP0IIIII  iiiiiii-")
    671 
    672 OPIJMP_ENC(J4_cmpeqi,  "000")
    673 OPIJMP_ENC(J4_cmpgti,  "001")
    674 OPIJMP_ENC(J4_cmpgtui, "010")
    675 
    676 
    677 #define OPI1JMP_ENC(TAG,OPC) \
    678 DEF_ENC32(TAG##_t_jumpnv_t,       ICLASS_NCJ" 01 "OPC"  0ii-sss  PP1-----  iiiiiii-") \
    679 DEF_ENC32(TAG##_f_jumpnv_t,       ICLASS_NCJ" 01 "OPC"  1ii-sss  PP1-----  iiiiiii-") \
    680 DEF_ENC32(TAG##_t_jumpnv_nt,      ICLASS_NCJ" 01 "OPC"  0ii-sss  PP0-----  iiiiiii-") \
    681 DEF_ENC32(TAG##_f_jumpnv_nt,      ICLASS_NCJ" 01 "OPC"  1ii-sss  PP0-----  iiiiiii-")
    682 
    683 OPI1JMP_ENC(J4_cmpeqn1,  "100")
    684 OPI1JMP_ENC(J4_cmpgtn1,  "101")
    685 OPI1JMP_ENC(J4_tstbit0,  "011")
    686 
    687 
    688 DEF_EXT_SPACE(EXT_NCJ,             ICLASS_NCJ"1 iii  iiiiiiii  PPiiiiii  iiiiiiii")
    689 
    690 
    691 
    692 /*******************************/
    693 /*                             */
    694 /*                             */
    695 /*           CR                */
    696 /*                             */
    697 /*                             */
    698 /*******************************/
    699 
    700 
    701 
    702 DEF_CLASS32(ICLASS_CR" ---- -------- PP------ --------",CR)
    703 DEF_CLASS32(ICLASS_CR" -0-- -------- PP------ --------",CRUSER)
    704 DEF_CLASS32(ICLASS_CR" -1-- -------- PP------ --------",CRSUPER)
    705 
    706 DEF_FIELD32(ICLASS_CR" -!-- -------- PP------ --------",CR_sm,"Supervisor mode only")
    707 
    708 /* User CR ops */
    709 
    710 DEF_FIELDROW_DESC32(    ICLASS_CR" 0000  --------  PP------  --------","[#0] (Rs,#r8)")
    711 DEF_ENC32(J2_loop0r,    ICLASS_CR" 0000  000sssss  PP-iiiii  ---ii---")
    712 DEF_ENC32(J2_loop1r,    ICLASS_CR" 0000  001sssss  PP-iiiii  ---ii---")
    713 DEF_ENC32(J2_ploop1sr,  ICLASS_CR" 0000  101sssss  PP-iiiii  ---ii---")
    714 DEF_ENC32(J2_ploop2sr,  ICLASS_CR" 0000  110sssss  PP-iiiii  ---ii---")
    715 DEF_ENC32(J2_ploop3sr,  ICLASS_CR" 0000  111sssss  PP-iiiii  ---ii---")
    716 
    717 DEF_FIELDROW_DESC32(     ICLASS_CR" 0001  --------  PP------  --------","[#1] (Rs,#r13)")
    718 DEF_ENC32(J2_jumprz,     ICLASS_CR" 0001  00isssss  PPi0iiii  iiiiiii-")
    719 DEF_ENC32(J2_jumprzpt,   ICLASS_CR" 0001  00isssss  PPi1iiii  iiiiiii-")
    720 DEF_ENC32(J2_jumprnz,    ICLASS_CR" 0001  10isssss  PPi0iiii  iiiiiii-")
    721 DEF_ENC32(J2_jumprnzpt,  ICLASS_CR" 0001  10isssss  PPi1iiii  iiiiiii-")
    722 
    723 DEF_ENC32(J2_jumprgtez,  ICLASS_CR" 0001  01isssss  PPi0iiii  iiiiiii-")
    724 DEF_ENC32(J2_jumprgtezpt,ICLASS_CR" 0001  01isssss  PPi1iiii  iiiiiii-")
    725 DEF_ENC32(J2_jumprltez,  ICLASS_CR" 0001  11isssss  PPi0iiii  iiiiiii-")
    726 DEF_ENC32(J2_jumprltezpt,ICLASS_CR" 0001  11isssss  PPi1iiii  iiiiiii-")
    727 
    728 DEF_FIELDROW_DESC32(    ICLASS_CR" 0010  --------  PP------  --------","[#2] Cd=Rs ")
    729 DEF_ENC32(A2_tfrrcr,    ICLASS_CR" 0010  001sssss  PP------  ---ddddd")
    730 
    731 DEF_FIELDROW_DESC32(    ICLASS_CR" 0011  --------  PP------  --------","[#3] Cdd=Rss ")
    732 DEF_ENC32(A4_tfrpcp,    ICLASS_CR" 0011  001sssss  PP------  ---ddddd")
    733 
    734 DEF_FIELDROW_DESC32(    ICLASS_CR" 1000  --------  PP------  --------","[#8] Rdd=Css ")
    735 DEF_ENC32(A4_tfrcpp,    ICLASS_CR" 1000  000sssss  PP------  ---ddddd")
    736 
    737 DEF_FIELDROW_DESC32(    ICLASS_CR" 1001  --------  PP------  --------","[#9] (#r8,#U10)")
    738 DEF_ENC32(J2_ploop1si,  ICLASS_CR" 1001  101IIIII  PP-iiiii  IIIii-II")
    739 DEF_ENC32(J2_ploop2si,  ICLASS_CR" 1001  110IIIII  PP-iiiii  IIIii-II")
    740 DEF_ENC32(J2_ploop3si,  ICLASS_CR" 1001  111IIIII  PP-iiiii  IIIii-II")
    741 DEF_ENC32(J2_loop0i,    ICLASS_CR" 1001  000IIIII  PP-iiiii  IIIii-II")
    742 DEF_ENC32(J2_loop1i,    ICLASS_CR" 1001  001IIIII  PP-iiiii  IIIii-II")
    743 
    744 DEF_FIELDROW_DESC32(    ICLASS_CR" 1010  --------  PP------  --------","[#10] Rd=Cs ")
    745 DEF_ENC32(A2_tfrcrr,    ICLASS_CR" 1010  000sssss  PP------  ---ddddd")
    746 DEF_ENC32(C4_addipc,    ICLASS_CR" 1010  01001001  PP-iiiii  i--ddddd")
    747 
    748 
    749 DEF_FIELDROW_DESC32(    ICLASS_CR" 1011  --------  PP0-----  --------","[#11] Pd=(Ps,Pt,Pu)")
    750 DEF_ENC32(C2_and,       ICLASS_CR" 1011  0000--ss  PP0---tt  ------dd")
    751 DEF_ENC32(C2_or,        ICLASS_CR" 1011  0010--ss  PP0---tt  ------dd")
    752 DEF_ENC32(C2_xor,       ICLASS_CR" 1011  0100--ss  PP0---tt  ------dd")
    753 DEF_ENC32(C2_andn,      ICLASS_CR" 1011  0110--ss  PP0---tt  ------dd")
    754 DEF_ENC32(C2_any8,      ICLASS_CR" 1011  1000--ss  PP0-----  ------dd")
    755 DEF_ENC32(C2_all8,      ICLASS_CR" 1011  1010--ss  PP0-----  ------dd")
    756 DEF_ENC32(C2_not,       ICLASS_CR" 1011  1100--ss  PP0-----  ------dd")
    757 DEF_ENC32(C2_orn,       ICLASS_CR" 1011  1110--ss  PP0---tt  ------dd")
    758 
    759 DEF_ENC32(C4_and_and,   ICLASS_CR" 1011  0001--ss  PP0---tt  uu----dd")
    760 DEF_ENC32(C4_and_or,    ICLASS_CR" 1011  0011--ss  PP0---tt  uu----dd")
    761 DEF_ENC32(C4_or_and,    ICLASS_CR" 1011  0101--ss  PP0---tt  uu----dd")
    762 DEF_ENC32(C4_or_or,     ICLASS_CR" 1011  0111--ss  PP0---tt  uu----dd")
    763 DEF_ENC32(C4_and_andn,  ICLASS_CR" 1011  1001--ss  PP0---tt  uu----dd")
    764 DEF_ENC32(C4_and_orn,   ICLASS_CR" 1011  1011--ss  PP0---tt  uu----dd")
    765 DEF_ENC32(C4_or_andn,   ICLASS_CR" 1011  1101--ss  PP0---tt  uu----dd")
    766 DEF_ENC32(C4_or_orn,    ICLASS_CR" 1011  1111--ss  PP0---tt  uu----dd")
    767 
    768 DEF_ENC32(C4_fastcorner9,       ICLASS_CR"1011 0000--ss  PP1---tt 1--1--dd")
    769 DEF_ENC32(C4_fastcorner9_not,   ICLASS_CR"1011 0001--ss  PP1---tt 1--1--dd")
    770 
    771 
    772 
    773 /*******************************/
    774 /*                             */
    775 /*                             */
    776 /*           M                 */
    777 /*                             */
    778 /*                             */
    779 /*******************************/
    780 
    781 
    782 DEF_CLASS32(ICLASS_M" ---- -------- PP------ --------",M)
    783 DEF_FIELD32(ICLASS_M" !!!! -------- PP------ --------",M_RegType,"Register Type")
    784 DEF_FIELD32(ICLASS_M" ---- !!!----- PP------ --------",M_MajOp,"Major Opcode")
    785 DEF_FIELD32(ICLASS_M" ---- -------- PP------ !!!-----",M_MinOp,"Minor Opcode")
    786 
    787 
    788 
    789 #define SP_MPY(TAG,REGTYPE,DSTCHARS,SAT,RND,UNS)\
    790 DEF_ENC32(TAG##_ll_s0, ICLASS_M  REGTYPE "0"  UNS RND"sssss  PP-ttttt "SAT"00"   DSTCHARS)\
    791 DEF_ENC32(TAG##_lh_s0, ICLASS_M  REGTYPE "0"  UNS RND"sssss  PP-ttttt "SAT"01"   DSTCHARS)\
    792 DEF_ENC32(TAG##_hl_s0, ICLASS_M  REGTYPE "0"  UNS RND"sssss  PP-ttttt "SAT"10"   DSTCHARS)\
    793 DEF_ENC32(TAG##_hh_s0, ICLASS_M  REGTYPE "0"  UNS RND"sssss  PP-ttttt "SAT"11"   DSTCHARS)\
    794 DEF_ENC32(TAG##_ll_s1, ICLASS_M  REGTYPE "1"  UNS RND"sssss  PP-ttttt "SAT"00"   DSTCHARS)\
    795 DEF_ENC32(TAG##_lh_s1, ICLASS_M  REGTYPE "1"  UNS RND"sssss  PP-ttttt "SAT"01"   DSTCHARS)\
    796 DEF_ENC32(TAG##_hl_s1, ICLASS_M  REGTYPE "1"  UNS RND"sssss  PP-ttttt "SAT"10"   DSTCHARS)\
    797 DEF_ENC32(TAG##_hh_s1, ICLASS_M  REGTYPE "1"  UNS RND"sssss  PP-ttttt "SAT"11"   DSTCHARS)
    798 
    799 /* Double precision                   */
    800 #define MPY_ENC(TAG,REGTYPE,DSTCHARS,SAT,RNDNAC,UNS,SHFT,VMIN2)\
    801 DEF_ENC32(TAG, ICLASS_M REGTYPE SHFT UNS RNDNAC"sssss  PP0ttttt "SAT VMIN2 DSTCHARS)
    802 
    803 #define MPYI_ENC(TAG,REGTYPE,DSTCHARS,RNDNAC,UNS,SHFT)\
    804 DEF_ENC32(TAG, ICLASS_M REGTYPE SHFT UNS RNDNAC"sssss  PP0iiiii iii" DSTCHARS)
    805 
    806 
    807 DEF_FIELDROW_DESC32(ICLASS_M" 0000 -------- PP------ --------","[#0] Rd=(Rs,#u8)")
    808 MPYI_ENC(M2_mpysip,          "0000","ddddd","-","-","0"     )
    809 MPYI_ENC(M2_mpysin,          "0000","ddddd","-","-","1"     )
    810 
    811 
    812 DEF_FIELDROW_DESC32(ICLASS_M" 0001 -------- PP------ --------","[#1] Rx=(Rs,#u8)")
    813 MPYI_ENC(M2_macsip,          "0001","xxxxx","-","-","0"     )
    814 MPYI_ENC(M2_macsin,          "0001","xxxxx","-","-","1"     )
    815 
    816 
    817 DEF_FIELDROW_DESC32(ICLASS_M" 0010 -------- PP------ --------","[#2] Rx=(Rs,#s8)")
    818 MPYI_ENC(M2_accii,           "0010","xxxxx","-","-","0"     )
    819 MPYI_ENC(M2_naccii,          "0010","xxxxx","-","-","1"     )
    820 
    821 
    822 DEF_FIELDROW_DESC32(ICLASS_M" 0011 -------- PP------ --------","[#3] Ry=(Ru,(Rs,Ry)) ")
    823 DEF_ENC32(M4_mpyrr_addr,ICLASS_M" 0011 000sssss PP-yyyyy ---uuuuu")
    824 
    825 
    826 DEF_FIELDROW_DESC32(ICLASS_M" 0100 -------- PP------ --------","[#4] Rdd=(Rs,Rt)")
    827 DEF_FIELD32(ICLASS_M"         0100 -------- PP------ --!-----",Ma_tH,"Rt is High") /*Rt high */
    828 DEF_FIELD32(ICLASS_M"         0100 -------- PP------ -!------",Ma_sH,"Rs is High") /* Rs high */
    829 SP_MPY(M2_mpyd,              "0100","ddddd","-","0","0")
    830 SP_MPY(M2_mpyd_rnd,          "0100","ddddd","-","1","0")
    831 SP_MPY(M2_mpyud,             "0100","ddddd","-","0","1")
    832 
    833 
    834 DEF_FIELDROW_DESC32(ICLASS_M" 0101 -------- PP------ --------","[#5] Rdd=(Rs,Rt)")
    835 MPY_ENC(M2_dpmpyss_s0,       "0101","ddddd","0","0","0","0","00")
    836 MPY_ENC(M2_dpmpyuu_s0,       "0101","ddddd","0","0","1","0","00")
    837 MPY_ENC(M2_vmpy2s_s0,        "0101","ddddd","1","0","0","0","01")
    838 MPY_ENC(M2_vmpy2s_s1,        "0101","ddddd","1","0","0","1","01")
    839 MPY_ENC(M2_cmpyi_s0,         "0101","ddddd","0","0","0","0","01")
    840 MPY_ENC(M2_cmpyr_s0,         "0101","ddddd","0","0","0","0","10")
    841 MPY_ENC(M2_cmpys_s0,         "0101","ddddd","1","0","0","0","10")
    842 MPY_ENC(M2_cmpys_s1,         "0101","ddddd","1","0","0","1","10")
    843 MPY_ENC(M2_cmpysc_s0,        "0101","ddddd","1","0","1","0","10")
    844 MPY_ENC(M2_cmpysc_s1,        "0101","ddddd","1","0","1","1","10")
    845 MPY_ENC(M2_vmpy2su_s0,       "0101","ddddd","1","0","0","0","11")
    846 MPY_ENC(M2_vmpy2su_s1,       "0101","ddddd","1","0","0","1","11")
    847 MPY_ENC(M4_pmpyw,            "0101","ddddd","1","0","1","0","11")
    848 MPY_ENC(M4_vpmpyh,           "0101","ddddd","1","0","1","1","11")
    849 MPY_ENC(M5_vmpybuu,          "0101","ddddd","0","0","0","1","01")
    850 MPY_ENC(M5_vmpybsu,          "0101","ddddd","0","0","1","0","01")
    851 
    852 
    853 
    854 
    855 DEF_FIELDROW_DESC32(ICLASS_M" 0110 -------- PP------ --------","[#6] Rxx=(Rs,Rt)")
    856 DEF_FIELD32(ICLASS_M"         0110 -------- PP------ --!-----",Mb_tH,"Rt is High") /*Rt high */
    857 DEF_FIELD32(ICLASS_M"         0110 -------- PP------ -!------",Mb_sH,"Rs is High") /* Rs high */
    858 SP_MPY(M2_mpyd_acc,          "0110","xxxxx","0","0","0")
    859 SP_MPY(M2_mpyud_acc,         "0110","xxxxx","0","0","1")
    860 SP_MPY(M2_mpyd_nac,          "0110","xxxxx","0","1","0")
    861 SP_MPY(M2_mpyud_nac,         "0110","xxxxx","0","1","1")
    862 
    863 
    864 DEF_FIELDROW_DESC32(ICLASS_M" 0111 -------- PP------ --------","[#7] Rxx=(Rs,Rt)")
    865 MPY_ENC(M2_dpmpyss_acc_s0,   "0111","xxxxx","0","0","0","0","00")
    866 MPY_ENC(M2_dpmpyss_nac_s0,   "0111","xxxxx","0","1","0","0","00")
    867 MPY_ENC(M2_dpmpyuu_acc_s0,   "0111","xxxxx","0","0","1","0","00")
    868 MPY_ENC(M2_dpmpyuu_nac_s0,   "0111","xxxxx","0","1","1","0","00")
    869 MPY_ENC(M2_vmac2s_s0,        "0111","xxxxx","1","0","0","0","01")
    870 MPY_ENC(M2_vmac2s_s1,        "0111","xxxxx","1","0","0","1","01")
    871 MPY_ENC(M2_cmaci_s0,         "0111","xxxxx","0","0","0","0","01")
    872 MPY_ENC(M2_cmacr_s0,         "0111","xxxxx","0","0","0","0","10")
    873 MPY_ENC(M2_cmacs_s0,         "0111","xxxxx","1","0","0","0","10")
    874 MPY_ENC(M2_cmacs_s1,         "0111","xxxxx","1","0","0","1","10")
    875 MPY_ENC(M2_cmacsc_s0,        "0111","xxxxx","1","0","1","0","10")
    876 MPY_ENC(M2_cmacsc_s1,        "0111","xxxxx","1","0","1","1","10")
    877 MPY_ENC(M2_vmac2,            "0111","xxxxx","0","1","0","0","01")
    878 MPY_ENC(M2_cnacs_s0,         "0111","xxxxx","1","0","0","0","11")
    879 MPY_ENC(M2_cnacs_s1,         "0111","xxxxx","1","0","0","1","11")
    880 MPY_ENC(M2_cnacsc_s0,        "0111","xxxxx","1","0","1","0","11")
    881 MPY_ENC(M2_cnacsc_s1,        "0111","xxxxx","1","0","1","1","11")
    882 MPY_ENC(M2_vmac2su_s0,       "0111","xxxxx","1","1","1","0","01")
    883 MPY_ENC(M2_vmac2su_s1,       "0111","xxxxx","1","1","1","1","01")
    884 MPY_ENC(M4_pmpyw_acc,        "0111","xxxxx","1","1","0","0","11")
    885 MPY_ENC(M4_vpmpyh_acc,       "0111","xxxxx","1","1","0","1","11")
    886 MPY_ENC(M5_vmacbuu,          "0111","xxxxx","0","0","0","1","01")
    887 MPY_ENC(M5_vmacbsu,          "0111","xxxxx","0","0","1","1","01")
    888 
    889 
    890 
    891 
    892 
    893 DEF_FIELDROW_DESC32(ICLASS_M" 1000 -------- PP------ --------","[#8] Rdd=(Rss,Rtt)")
    894 MPY_ENC(M2_vrcmpyi_s0,       "1000","ddddd","0","0","0","0","00")
    895 MPY_ENC(M2_vdmpys_s0,        "1000","ddddd","1","0","0","0","00")
    896 MPY_ENC(M2_vdmpys_s1,        "1000","ddddd","1","0","0","1","00")
    897 MPY_ENC(M2_vrcmpyi_s0c,      "1000","ddddd","0","0","1","0","00")
    898 MPY_ENC(M2_vabsdiffw,        "1000","ddddd","0","1","0","0","00")
    899 MPY_ENC(M6_vabsdiffub,       "1000","ddddd","0","1","0","1","00")
    900 MPY_ENC(M2_vabsdiffh,        "1000","ddddd","0","1","1","0","00")
    901 MPY_ENC(M6_vabsdiffb,        "1000","ddddd","0","1","1","1","00")
    902 MPY_ENC(M2_vrcmpys_s1_h,     "1000","ddddd","1","1","0","1","00")
    903 MPY_ENC(M2_vrcmpys_s1_l,     "1000","ddddd","1","1","1","1","00")
    904 MPY_ENC(M2_vrcmpyr_s0c,      "1000","ddddd","0","1","1","0","01")
    905 MPY_ENC(M2_vrcmpyr_s0,       "1000","ddddd","0","0","0","0","01")
    906 MPY_ENC(A2_vraddub,          "1000","ddddd","0","0","1","0","01")
    907 MPY_ENC(M2_mmpyl_s0,         "1000","ddddd","1","0","0","0","01")
    908 MPY_ENC(M2_mmpyl_s1,         "1000","ddddd","1","0","0","1","01")
    909 MPY_ENC(M2_mmpyl_rs0,        "1000","ddddd","1","1","0","0","01")
    910 MPY_ENC(M2_mmpyl_rs1,        "1000","ddddd","1","1","0","1","01")
    911 MPY_ENC(M2_mmpyul_s0,        "1000","ddddd","1","0","1","0","01")
    912 MPY_ENC(M2_mmpyul_s1,        "1000","ddddd","1","0","1","1","01")
    913 MPY_ENC(M2_mmpyul_rs0,       "1000","ddddd","1","1","1","0","01")
    914 MPY_ENC(M2_mmpyul_rs1,       "1000","ddddd","1","1","1","1","01")
    915 MPY_ENC(M2_vrmpy_s0,         "1000","ddddd","0","0","0","0","10")
    916 MPY_ENC(A2_vrsadub,          "1000","ddddd","0","0","1","0","10")
    917 MPY_ENC(M2_vmpy2es_s0,       "1000","ddddd","1","0","0","0","10")
    918 MPY_ENC(M2_vmpy2es_s1,       "1000","ddddd","1","0","0","1","10")
    919 MPY_ENC(M2_vcmpy_s0_sat_i,   "1000","ddddd","1","0","1","0","10")
    920 MPY_ENC(M2_vcmpy_s0_sat_r,   "1000","ddddd","1","1","0","0","10")
    921 MPY_ENC(M2_vcmpy_s1_sat_i,   "1000","ddddd","1","0","1","1","10")
    922 MPY_ENC(M2_vcmpy_s1_sat_r,   "1000","ddddd","1","1","0","1","10")
    923 
    924 MPY_ENC(M2_mmpyh_s0,         "1000","ddddd","1","0","0","0","11")
    925 MPY_ENC(M2_mmpyh_s1,         "1000","ddddd","1","0","0","1","11")
    926 MPY_ENC(M2_mmpyh_rs0,        "1000","ddddd","1","1","0","0","11")
    927 MPY_ENC(M2_mmpyh_rs1,        "1000","ddddd","1","1","0","1","11")
    928 MPY_ENC(M2_mmpyuh_s0,        "1000","ddddd","1","0","1","0","11")
    929 MPY_ENC(M2_mmpyuh_s1,        "1000","ddddd","1","0","1","1","11")
    930 MPY_ENC(M2_mmpyuh_rs0,       "1000","ddddd","1","1","1","0","11")
    931 MPY_ENC(M2_mmpyuh_rs1,       "1000","ddddd","1","1","1","1","11")
    932 
    933 MPY_ENC(M4_vrmpyeh_s0,       "1000","ddddd","1","0","1","0","00")
    934 MPY_ENC(M4_vrmpyeh_s1,       "1000","ddddd","1","0","1","1","00")
    935 MPY_ENC(M4_vrmpyoh_s0,       "1000","ddddd","0","1","0","0","10")
    936 MPY_ENC(M4_vrmpyoh_s1,       "1000","ddddd","0","1","0","1","10")
    937 MPY_ENC(M5_vrmpybuu,         "1000","ddddd","0","0","0","1","01")
    938 MPY_ENC(M5_vrmpybsu,         "1000","ddddd","0","0","1","1","01")
    939 MPY_ENC(M5_vdmpybsu,         "1000","ddddd","0","1","0","1","01")
    940 
    941 MPY_ENC(F2_dfadd,            "1000","ddddd","0","0","0","0","11")
    942 MPY_ENC(F2_dfsub,            "1000","ddddd","0","0","0","1","11")
    943 MPY_ENC(F2_dfmpyfix,         "1000","ddddd","0","0","1","0","11")
    944 MPY_ENC(F2_dfmin,            "1000","ddddd","0","0","1","1","11")
    945 MPY_ENC(F2_dfmax,            "1000","ddddd","0","1","0","0","11")
    946 MPY_ENC(F2_dfmpyll,          "1000","ddddd","0","1","0","1","11")
    947 
    948 MPY_ENC(M7_dcmpyrw,          "1000","ddddd","0","0","0","1","10")
    949 MPY_ENC(M7_dcmpyrwc,         "1000","ddddd","0","0","1","1","10")
    950 MPY_ENC(M7_dcmpyiw,          "1000","ddddd","0","1","1","0","10")
    951 MPY_ENC(M7_dcmpyiwc,         "1000","ddddd","0","1","1","1","10")
    952 
    953 
    954 
    955 DEF_FIELDROW_DESC32(ICLASS_M" 1001 -------- PP------ --------","[#9] Rd=(Rss,Rtt)")
    956 MPY_ENC(M2_vdmpyrs_s0,       "1001","ddddd","0","0","0","0","00")
    957 MPY_ENC(M2_vdmpyrs_s1,       "1001","ddddd","0","0","0","1","00")
    958 
    959 MPY_ENC(M7_wcmpyrw,          "1001","ddddd","0","0","1","0","00")
    960 MPY_ENC(M7_wcmpyrw_rnd,      "1001","ddddd","0","0","1","1","00")
    961 MPY_ENC(M7_wcmpyiw,          "1001","ddddd","0","1","0","0","00")
    962 MPY_ENC(M7_wcmpyiw_rnd,      "1001","ddddd","0","1","0","1","00")
    963 
    964 MPY_ENC(M7_wcmpyrwc,         "1001","ddddd","0","1","1","0","00")
    965 MPY_ENC(M7_wcmpyrwc_rnd,     "1001","ddddd","0","1","1","1","00")
    966 MPY_ENC(M7_wcmpyiwc,         "1001","ddddd","1","0","0","0","00")
    967 MPY_ENC(M7_wcmpyiwc_rnd,     "1001","ddddd","1","0","0","1","00")
    968 
    969 
    970 
    971 MPY_ENC(M2_vradduh,          "1001","ddddd","-","-","-","0","01")
    972 MPY_ENC(M2_vrcmpys_s1rp_h,   "1001","ddddd","1","1","-","1","10")
    973 MPY_ENC(M2_vrcmpys_s1rp_l,   "1001","ddddd","1","1","-","1","11")
    974 MPY_ENC(M2_vraddh,           "1001","ddddd","1","1","-","0","11")
    975 
    976 
    977 DEF_FIELDROW_DESC32(ICLASS_M" 1010 -------- PP------ --------","[#10] Rxx=(Rss,Rtt)")
    978 MPY_ENC(M2_vrcmaci_s0,       "1010","xxxxx","0","0","0","0","00")
    979 MPY_ENC(M2_vdmacs_s0,        "1010","xxxxx","1","0","0","0","00")
    980 MPY_ENC(M2_vdmacs_s1,        "1010","xxxxx","1","0","0","1","00")
    981 MPY_ENC(M2_vrcmaci_s0c,      "1010","xxxxx","0","0","1","0","00")
    982 MPY_ENC(M2_vcmac_s0_sat_i,   "1010","xxxxx","1","0","1","0","00")
    983 MPY_ENC(M2_vcmac_s0_sat_r,   "1010","xxxxx","1","1","0","0","00")
    984 MPY_ENC(M2_vrcmpys_acc_s1_h, "1010","xxxxx","1","1","0","1","00")
    985 MPY_ENC(M2_vrcmpys_acc_s1_l, "1010","xxxxx","1","1","1","1","00")
    986 MPY_ENC(M2_vrcmacr_s0,       "1010","xxxxx","0","0","0","0","01")
    987 MPY_ENC(A2_vraddub_acc,      "1010","xxxxx","0","0","1","0","01")
    988 MPY_ENC(M2_mmacls_s0,        "1010","xxxxx","1","0","0","0","01")
    989 MPY_ENC(M2_mmacls_s1,        "1010","xxxxx","1","0","0","1","01")
    990 MPY_ENC(M2_mmacls_rs0,       "1010","xxxxx","1","1","0","0","01")
    991 MPY_ENC(M2_mmacls_rs1,       "1010","xxxxx","1","1","0","1","01")
    992 MPY_ENC(M2_mmaculs_s0,       "1010","xxxxx","1","0","1","0","01")
    993 MPY_ENC(M2_mmaculs_s1,       "1010","xxxxx","1","0","1","1","01")
    994 MPY_ENC(M2_mmaculs_rs0,      "1010","xxxxx","1","1","1","0","01")
    995 MPY_ENC(M2_mmaculs_rs1,      "1010","xxxxx","1","1","1","1","01")
    996 MPY_ENC(M2_vrcmacr_s0c,      "1010","xxxxx","0","1","1","0","01")
    997 MPY_ENC(M2_vrmac_s0,         "1010","xxxxx","0","0","0","0","10")
    998 MPY_ENC(A2_vrsadub_acc,      "1010","xxxxx","0","0","1","0","10")
    999 MPY_ENC(M2_vmac2es_s0,       "1010","xxxxx","1","0","0","0","10")
   1000 MPY_ENC(M2_vmac2es_s1,       "1010","xxxxx","1","0","0","1","10")
   1001 MPY_ENC(M2_vmac2es,          "1010","xxxxx","0","1","0","0","10")
   1002 MPY_ENC(M2_mmachs_s0,        "1010","xxxxx","1","0","0","0","11")
   1003 MPY_ENC(M2_mmachs_s1,        "1010","xxxxx","1","0","0","1","11")
   1004 MPY_ENC(M2_mmachs_rs0,       "1010","xxxxx","1","1","0","0","11")
   1005 MPY_ENC(M2_mmachs_rs1,       "1010","xxxxx","1","1","0","1","11")
   1006 MPY_ENC(M2_mmacuhs_s0,       "1010","xxxxx","1","0","1","0","11")
   1007 MPY_ENC(M2_mmacuhs_s1,       "1010","xxxxx","1","0","1","1","11")
   1008 MPY_ENC(M2_mmacuhs_rs0,      "1010","xxxxx","1","1","1","0","11")
   1009 MPY_ENC(M2_mmacuhs_rs1,      "1010","xxxxx","1","1","1","1","11")
   1010 MPY_ENC(M4_vrmpyeh_acc_s0,   "1010","xxxxx","1","1","0","0","10")
   1011 MPY_ENC(M4_vrmpyeh_acc_s1,   "1010","xxxxx","1","1","0","1","10")
   1012 MPY_ENC(M4_vrmpyoh_acc_s0,   "1010","xxxxx","1","1","1","0","10")
   1013 MPY_ENC(M4_vrmpyoh_acc_s1,   "1010","xxxxx","1","1","1","1","10")
   1014 MPY_ENC(M5_vrmacbuu,         "1010","xxxxx","0","0","0","1","01")
   1015 MPY_ENC(M5_vrmacbsu,         "1010","xxxxx","0","0","1","1","01")
   1016 MPY_ENC(M5_vdmacbsu,         "1010","xxxxx","0","1","0","0","01")
   1017 
   1018 MPY_ENC(F2_dfmpylh,          "1010","xxxxx","0","0","0","0","11")
   1019 MPY_ENC(F2_dfmpyhh,          "1010","xxxxx","0","0","0","1","11")
   1020 
   1021 
   1022 MPY_ENC(M7_dcmpyrw_acc,      "1010","xxxxx","0","0","0","1","10")
   1023 MPY_ENC(M7_dcmpyrwc_acc,     "1010","xxxxx","0","0","1","1","10")
   1024 MPY_ENC(M7_dcmpyiw_acc,      "1010","xxxxx","0","1","1","0","10")
   1025 MPY_ENC(M7_dcmpyiwc_acc,     "1010","xxxxx","1","0","1","0","10")
   1026 
   1027 
   1028 
   1029 
   1030 MPY_ENC(A5_ACS,              "1010","xxxxx","0","1","0","1","ee")
   1031 MPY_ENC(A6_vminub_RdP,       "1010","ddddd","0","1","1","1","ee")
   1032 /*
   1033 */
   1034 
   1035 DEF_FIELDROW_DESC32(ICLASS_M" 1011 -------- PP------ --------","[#11] Reserved")
   1036 MPY_ENC(F2_sfadd,            "1011","ddddd","0","0","0","0","00")
   1037 MPY_ENC(F2_sfsub,            "1011","ddddd","0","0","0","0","01")
   1038 MPY_ENC(F2_sfmax,            "1011","ddddd","0","0","0","1","00")
   1039 MPY_ENC(F2_sfmin,            "1011","ddddd","0","0","0","1","01")
   1040 MPY_ENC(F2_sfmpy,            "1011","ddddd","0","0","1","0","00")
   1041 MPY_ENC(F2_sffixupn,         "1011","ddddd","0","0","1","1","00")
   1042 MPY_ENC(F2_sffixupd,         "1011","ddddd","0","0","1","1","01")
   1043 MPY_ENC(F2_sfrecipa,         "1011","ddddd","1","1","1","1","ee")
   1044 
   1045 DEF_FIELDROW_DESC32(ICLASS_M" 1100 -------- PP------ --------","[#12] Rd=(Rs,Rt)")
   1046 DEF_FIELD32(ICLASS_M"         1100 -------- PP------ --!-----",Mc_tH,"Rt is High") /*Rt high */
   1047 DEF_FIELD32(ICLASS_M"         1100 -------- PP------ -!------",Mc_sH,"Rs is High") /* Rs high */
   1048 SP_MPY(M2_mpy,               "1100","ddddd","0","0","0")
   1049 SP_MPY(M2_mpy_sat,           "1100","ddddd","1","0","0")
   1050 SP_MPY(M2_mpy_rnd,           "1100","ddddd","0","1","0")
   1051 SP_MPY(M2_mpy_sat_rnd,       "1100","ddddd","1","1","0")
   1052 SP_MPY(M2_mpyu,              "1100","ddddd","0","0","1")
   1053 
   1054 DEF_FIELDROW_DESC32(ICLASS_M" 1101 -------- PP------ --------","[#13] Rd=(Rs,Rt)")
   1055 /* EJP: same as mpyi MPY_ENC(M2_mpyui,            "1101","ddddd","0","0","1","0","00") */
   1056 MPY_ENC(M2_mpyi,             "1101","ddddd","0","0","0","0","00")
   1057 MPY_ENC(M2_mpy_up,           "1101","ddddd","0","0","0","0","01")
   1058 MPY_ENC(M2_mpyu_up,          "1101","ddddd","0","0","1","0","01")
   1059 MPY_ENC(M2_dpmpyss_rnd_s0,   "1101","ddddd","0","1","0","0","01")
   1060 MPY_ENC(M2_cmpyrs_s0,        "1101","ddddd","1","1","0","0","10")
   1061 MPY_ENC(M2_cmpyrs_s1,        "1101","ddddd","1","1","0","1","10")
   1062 MPY_ENC(M2_cmpyrsc_s0,       "1101","ddddd","1","1","1","0","10")
   1063 MPY_ENC(M2_cmpyrsc_s1,       "1101","ddddd","1","1","1","1","10")
   1064 MPY_ENC(M2_vmpy2s_s0pack,    "1101","ddddd","1","1","0","0","11")
   1065 MPY_ENC(M2_vmpy2s_s1pack,    "1101","ddddd","1","1","0","1","11")
   1066 MPY_ENC(M2_hmmpyh_rs1,       "1101","ddddd","1","1","0","1","00")
   1067 MPY_ENC(M2_hmmpyl_rs1,       "1101","ddddd","1","1","1","1","00")
   1068 
   1069 MPY_ENC(M2_hmmpyh_s1,        "1101","ddddd","0","1","0","1","00")
   1070 MPY_ENC(M2_hmmpyl_s1,        "1101","ddddd","0","1","0","1","01")
   1071 MPY_ENC(M2_mpy_up_s1,        "1101","ddddd","0","1","0","1","10")
   1072 MPY_ENC(M2_mpy_up_s1_sat,    "1101","ddddd","0","1","1","1","00")
   1073 MPY_ENC(M2_mpysu_up,         "1101","ddddd","0","1","1","0","01")
   1074 
   1075 
   1076 DEF_FIELDROW_DESC32(ICLASS_M" 1110 -------- PP------ --------","[#14] Rx=(Rs,Rt)")
   1077 DEF_FIELD32(ICLASS_M"         1110 -------- PP------ --!-----",Md_tH,"Rt is High") /*Rt high */
   1078 DEF_FIELD32(ICLASS_M"         1110 -------- PP------ -!------",Md_sH,"Rs is High") /* Rs high */
   1079 SP_MPY(M2_mpyu_acc,          "1110","xxxxx","0","0","1")
   1080 SP_MPY(M2_mpy_acc,           "1110","xxxxx","0","0","0")
   1081 SP_MPY(M2_mpy_acc_sat,       "1110","xxxxx","1","0","0")
   1082 SP_MPY(M2_mpyu_nac,          "1110","xxxxx","0","1","1")
   1083 SP_MPY(M2_mpy_nac,           "1110","xxxxx","0","1","0")
   1084 SP_MPY(M2_mpy_nac_sat,       "1110","xxxxx","1","1","0")
   1085 
   1086 
   1087 DEF_FIELDROW_DESC32(ICLASS_M" 1111 -------- PP------ --------","[#15] Rx=(Rs,Rt)")
   1088 MPY_ENC(M2_maci,             "1111","xxxxx","0","0","0","0","00")
   1089 MPY_ENC(M2_mnaci,            "1111","xxxxx","0","0","0","1","00")
   1090 MPY_ENC(M2_acci,             "1111","xxxxx","0","0","0","0","01")
   1091 MPY_ENC(M2_nacci,            "1111","xxxxx","0","0","0","1","01")
   1092 MPY_ENC(M2_xor_xacc,         "1111","xxxxx","0","0","0","1","11")
   1093 MPY_ENC(M2_subacc,           "1111","xxxxx","0","0","0","0","11")
   1094 
   1095 MPY_ENC(M4_mac_up_s1_sat,    "1111","xxxxx","0","1","1","0","00")
   1096 MPY_ENC(M4_nac_up_s1_sat,    "1111","xxxxx","0","1","1","0","01")
   1097 
   1098 MPY_ENC(M4_and_and,          "1111","xxxxx","0","0","1","0","00")
   1099 MPY_ENC(M4_and_or,           "1111","xxxxx","0","0","1","0","01")
   1100 MPY_ENC(M4_and_xor,          "1111","xxxxx","0","0","1","0","10")
   1101 MPY_ENC(M4_or_and,           "1111","xxxxx","0","0","1","0","11")
   1102 MPY_ENC(M4_or_or,            "1111","xxxxx","0","0","1","1","00")
   1103 MPY_ENC(M4_or_xor,           "1111","xxxxx","0","0","1","1","01")
   1104 MPY_ENC(M4_xor_and,          "1111","xxxxx","0","0","1","1","10")
   1105 MPY_ENC(M4_xor_or,           "1111","xxxxx","0","0","1","1","11")
   1106 
   1107 MPY_ENC(M4_or_andn,          "1111","xxxxx","0","1","0","0","00")
   1108 MPY_ENC(M4_and_andn,         "1111","xxxxx","0","1","0","0","01")
   1109 MPY_ENC(M4_xor_andn,         "1111","xxxxx","0","1","0","0","10")
   1110 
   1111 MPY_ENC(F2_sffma,            "1111","xxxxx","1","0","0","0","00")
   1112 MPY_ENC(F2_sffms,            "1111","xxxxx","1","0","0","0","01")
   1113 
   1114 MPY_ENC(F2_sffma_lib,        "1111","xxxxx","1","0","0","0","10")
   1115 MPY_ENC(F2_sffms_lib,        "1111","xxxxx","1","0","0","0","11")
   1116 
   1117 MPY_ENC(F2_sffma_sc,         "1111","xxxxx","1","1","1","0","uu")
   1118 
   1119 
   1120 /*******************************/
   1121 /*                             */
   1122 /*                             */
   1123 /*           ALU32_2op         */
   1124 /*                             */
   1125 /*                             */
   1126 /*******************************/
   1127 DEF_CLASS32(ICLASS_ADDI" ---- -------- PP------ --------",ALU32_ADDI)
   1128 
   1129 DEF_CLASS32(ICLASS_ALU2op" ---- -------- PP------ --------",ALU32_2op)
   1130 DEF_FIELD32(ICLASS_ALU2op" !--- -------- PP------ --------",A2_Rs,"No Rs read")
   1131 DEF_FIELD32(ICLASS_ALU2op" -!!! -------- PP------ --------",A2_MajOp,"Major Opcode")
   1132 DEF_FIELD32(ICLASS_ALU2op" ---- !!!----- PP------ --------",A2_MinOp,"Minor Opcode")
   1133 
   1134 DEF_FIELD32(ICLASS_ALU3op" -!!! -------- PP------ --------",A3_MajOp,"Major Opcode")
   1135 DEF_FIELD32(ICLASS_ALU3op" ---- !!!----- PP------ --------",A3_MinOp,"Minor Opcode")
   1136 DEF_CLASS32(ICLASS_ALU3op" ---- -------- PP------ --------",ALU32_3op)
   1137 DEF_FIELD32(ICLASS_ALU3op" !--- -------- PP------ --------",A3_P,"Predicated")
   1138 DEF_FIELD32(ICLASS_ALU3op" ---- -------- PP!----- --------",A3_DN,"Dot-new")
   1139 DEF_FIELD32(ICLASS_ALU3op" ---- -------- PP------ !-------",A3_PS,"Predicate sense")
   1140 
   1141 
   1142 /*************************/
   1143 /* Our good friend addi  */
   1144 /*************************/
   1145 DEF_ENC32(A2_addi,    ICLASS_ADDI"  iiii iiisssss PPiiiiii iiiddddd")
   1146 
   1147 
   1148 /*******************************/
   1149 /* Standard ALU32 insns        */
   1150 /*******************************/
   1151 
   1152 #define ALU32_IRR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
   1153 DEF_ENC32(TAG, ICLASS_ALU2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"iiiii "VMIN3 DSTCHARS)
   1154 
   1155 #define ALU32_RR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
   1156 DEF_ENC32(TAG, ICLASS_ALU2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"----- "VMIN3 DSTCHARS)
   1157 
   1158 #define CONDA32_RR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
   1159 DEF_ENC32(TAG##t,   ICLASS_ALU2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"-00uu "VMIN3 DSTCHARS)\
   1160 DEF_ENC32(TAG##f,   ICLASS_ALU2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"-10uu "VMIN3 DSTCHARS)\
   1161 DEF_ENC32(TAG##tnew,ICLASS_ALU2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"-01uu "VMIN3 DSTCHARS)\
   1162 DEF_ENC32(TAG##fnew,ICLASS_ALU2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"-11uu "VMIN3 DSTCHARS)
   1163 
   1164 
   1165 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0000 -------- PP------ --------","[#0] (Pu) Rd=(Rs)")
   1166 DEF_FIELD32(            ICLASS_ALU2op" 0000 -------- PP!----- --------",A32a_C,"Conditional")
   1167 DEF_FIELD32(            ICLASS_ALU2op" 0000 -------- PP--!--- --------",A32a_S,"Predicate sense")
   1168 DEF_FIELD32(            ICLASS_ALU2op" 0000 -------- PP---!-- --------",A32a_dn,"Dot-new")
   1169 
   1170 ALU32_RR_ENC(A2_aslh,                 "0000","000","0","---","ddddd")
   1171 ALU32_RR_ENC(A2_asrh,                 "0000","001","0","---","ddddd")
   1172 ALU32_RR_ENC(A2_tfr,                  "0000","011","0","---","ddddd")
   1173 ALU32_RR_ENC(A2_sxtb,                 "0000","101","0","---","ddddd")
   1174 ALU32_RR_ENC(A2_zxth,                 "0000","110","0","---","ddddd")
   1175 ALU32_RR_ENC(A2_sxth,                 "0000","111","0","---","ddddd")
   1176 
   1177 CONDA32_RR_ENC(A4_paslh,               "0000","000","1","---","ddddd")
   1178 CONDA32_RR_ENC(A4_pasrh,               "0000","001","1","---","ddddd")
   1179 CONDA32_RR_ENC(A4_pzxtb,               "0000","100","1","---","ddddd")
   1180 CONDA32_RR_ENC(A4_psxtb,               "0000","101","1","---","ddddd")
   1181 CONDA32_RR_ENC(A4_pzxth,               "0000","110","1","---","ddddd")
   1182 CONDA32_RR_ENC(A4_psxth,               "0000","111","1","---","ddddd")
   1183 
   1184 
   1185 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0001 -------- PP------ --------","[#1] Rx=(#u16)")
   1186 DEF_ENC32(A2_tfril,     ICLASS_ALU2op" 0001 ii1xxxxx PPiiiiii iiiiiiii")
   1187 
   1188 
   1189 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0010 -------- PP------ --------","[#2] Rx=(#u16)")
   1190 DEF_ENC32(A2_tfrih,     ICLASS_ALU2op" 0010 ii1xxxxx PPiiiiii iiiiiiii")
   1191 
   1192 
   1193 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0011 -------- PP------ --------","[#3] Rd=(Pu,Rs,#s8)")
   1194 DEF_ENC32(C2_muxir,     ICLASS_ALU2op" 0011 0uusssss PP0iiiii iiiddddd")
   1195 DEF_ENC32(C2_muxri,     ICLASS_ALU2op" 0011 1uusssss PP0iiiii iiiddddd")
   1196 
   1197 DEF_ENC32(A4_combineri, ICLASS_ALU2op" 0011 -00sssss PP1iiiii iiiddddd") /* Rdd = (Rs,#s8) */
   1198 DEF_ENC32(A4_combineir, ICLASS_ALU2op" 0011 -01sssss PP1iiiii iiiddddd") /* Rdd = (Rs,#s8) */
   1199 DEF_ENC32(A4_rcmpeqi,   ICLASS_ALU2op" 0011 -10sssss PP1iiiii iiiddddd") /* Rd = (Rs,#s8) */
   1200 DEF_ENC32(A4_rcmpneqi,  ICLASS_ALU2op" 0011 -11sssss PP1iiiii iiiddddd") /* Rd = (Rs,#s8) */
   1201 
   1202 
   1203 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0100 -------- PP------ --------","[#4] (Pu) Rd=(Rs,#s8)")
   1204 DEF_FIELD32(            ICLASS_ALU2op" 0100 -------- PP!----- --------",A32a_DN,"Dot-new")
   1205 DEF_FIELD32(            ICLASS_ALU2op" 0100 !------- PP------ --------",A32a_PS,"Predicate sense")
   1206 DEF_ENC32(A2_paddit,    ICLASS_ALU2op" 0100 0uusssss PP0iiiii iiiddddd")
   1207 DEF_ENC32(A2_padditnew, ICLASS_ALU2op" 0100 0uusssss PP1iiiii iiiddddd")
   1208 DEF_ENC32(A2_paddif,    ICLASS_ALU2op" 0100 1uusssss PP0iiiii iiiddddd")
   1209 DEF_ENC32(A2_paddifnew, ICLASS_ALU2op" 0100 1uusssss PP1iiiii iiiddddd")
   1210 
   1211 
   1212 DEF_FIELDROW_DESC32(     ICLASS_ALU2op" 0101 -------- PP------ --------","[#5] Pd=(Rs,#s10)")
   1213 DEF_ENC32(C2_cmpeqi,     ICLASS_ALU2op" 0101 00isssss PPiiiiii iii000dd")
   1214 DEF_ENC32(C2_cmpgti,     ICLASS_ALU2op" 0101 01isssss PPiiiiii iii000dd")
   1215 DEF_ENC32(C2_cmpgtui,    ICLASS_ALU2op" 0101 100sssss PPiiiiii iii000dd")
   1216 
   1217 DEF_ENC32(C4_cmpneqi,    ICLASS_ALU2op" 0101 00isssss PPiiiiii iii100dd")
   1218 DEF_ENC32(C4_cmpltei,    ICLASS_ALU2op" 0101 01isssss PPiiiiii iii100dd")
   1219 DEF_ENC32(C4_cmplteui,   ICLASS_ALU2op" 0101 100sssss PPiiiiii iii100dd")
   1220 
   1221 
   1222 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0110 -------- PP------ --------","[#6] Rd=(Rs,#s10)")
   1223 ALU32_IRR_ENC(A2_andir,               "0110","00i","i","iii","ddddd")
   1224 ALU32_IRR_ENC(A2_subri,               "0110","01i","i","iii","ddddd")
   1225 ALU32_IRR_ENC(A2_orir,                "0110","10i","i","iii","ddddd")
   1226 
   1227 
   1228 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 0111 -------- PP------ --------","[#7] Reserved")
   1229 
   1230 
   1231 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 1000 -------- PP------ --------","[#8] Rd=#s16")
   1232 DEF_ENC32(A2_tfrsi,     ICLASS_ALU2op" 1000 ii-iiiii PPiiiiii iiiddddd")
   1233 
   1234 
   1235 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 1001 -------- PP------ --------","[#9] Reserved")
   1236 
   1237 
   1238 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 101- -------- PP------ --------","[#10,#11] Rd=(Pu,#s8,#S8)")
   1239 DEF_ENC32(C2_muxii,     ICLASS_ALU2op" 101u uIIIIIII PPIiiiii iiiddddd")
   1240 
   1241 
   1242 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 1100 -------- PP------ --------","[#12] Rdd=(#s8,#S8)")
   1243 DEF_ENC32(A2_combineii, ICLASS_ALU2op" 1100 0IIIIIII PPIiiiii iiiddddd")
   1244 DEF_ENC32(A4_combineii, ICLASS_ALU2op" 1100 1--IIIII PPIiiiii iiiddddd")
   1245 
   1246 
   1247 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 1101 -------- PP------ --------","[#13] Reserved")
   1248 
   1249 
   1250 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 1110 -------- PP------ --------","[#14] (Pu) Rd=#s12")
   1251 DEF_FIELD32(            ICLASS_ALU2op" 1110 ---0---- PP!----- --------",A32c_DN,"Dot-new")
   1252 DEF_FIELD32(            ICLASS_ALU2op" 1110 !--0---- PP------ --------",A32c_PS,"Predicate sense")
   1253 DEF_ENC32(C2_cmovenewit,ICLASS_ALU2op" 1110 0uu0iiii PP1iiiii iiiddddd")
   1254 DEF_ENC32(C2_cmovenewif,ICLASS_ALU2op" 1110 1uu0iiii PP1iiiii iiiddddd")
   1255 DEF_ENC32(C2_cmoveit,   ICLASS_ALU2op" 1110 0uu0iiii PP0iiiii iiiddddd")
   1256 DEF_ENC32(C2_cmoveif,   ICLASS_ALU2op" 1110 1uu0iiii PP0iiiii iiiddddd")
   1257 
   1258 
   1259 DEF_FIELDROW_DESC32(    ICLASS_ALU2op" 1111 -------- PP------ --------","[#15] nop")
   1260 DEF_ENC32(A2_nop,       ICLASS_ALU2op" 1111 -------- PP------ --------")
   1261 
   1262 
   1263 
   1264 
   1265 
   1266 
   1267 
   1268 
   1269 
   1270 
   1271 
   1272 
   1273 /*******************************/
   1274 /*                             */
   1275 /*                             */
   1276 /*    ALU32_3op                */
   1277 /*                             */
   1278 /*                             */
   1279 /*******************************/
   1280 
   1281 
   1282 #define V2A32_RRR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
   1283 DEF_ENC32(TAG, ICLASS_ALU3op" "MAJ4"  "MIN3"sssss  PP"SMOD1"ttttt "VMIN3 DSTCHARS)
   1284 
   1285 #define V2A32_RR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
   1286 DEF_ENC32(TAG, ICLASS_ALU3op" "MAJ4"  "MIN3"sssss  PP"SMOD1"----- "VMIN3 DSTCHARS)
   1287 
   1288 
   1289 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  0000 -------- PP------ --------","[#0] Reserved")
   1290 
   1291 
   1292 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  0001 -------- PP------ --------","[#1] Rd=(Rs,Rt)")
   1293 V2A32_RRR_ENC(A2_and,              "0001","000","-","---","ddddd")
   1294 V2A32_RRR_ENC(A2_or,               "0001","001","-","---","ddddd")
   1295 V2A32_RRR_ENC(A2_xor,              "0001","011","-","---","ddddd")
   1296 V2A32_RRR_ENC(A4_andn,             "0001","100","-","---","ddddd")
   1297 V2A32_RRR_ENC(A4_orn,              "0001","101","-","---","ddddd")
   1298 
   1299 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  0010 -------- PP------ --------","[#2] Pd=(Rs,Rt)")
   1300 V2A32_RRR_ENC(C2_cmpeq,            "0010","-00","-","---","000dd")
   1301 V2A32_RRR_ENC(C2_cmpgt,            "0010","-10","-","---","000dd")
   1302 V2A32_RRR_ENC(C2_cmpgtu,           "0010","-11","-","---","000dd")
   1303 
   1304 V2A32_RRR_ENC(C4_cmpneq,           "0010","-00","-","---","100dd")
   1305 V2A32_RRR_ENC(C4_cmplte,           "0010","-10","-","---","100dd")
   1306 V2A32_RRR_ENC(C4_cmplteu,          "0010","-11","-","---","100dd")
   1307 
   1308 
   1309 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  0011 -------- PP------ --------","[#3] Rd=(Rs,Rt)")
   1310 V2A32_RRR_ENC(A2_add,              "0011","000","-","---","ddddd")
   1311 V2A32_RRR_ENC(A2_sub,              "0011","001","-","---","ddddd")
   1312 V2A32_RRR_ENC(A2_combine_hh,       "0011","100","-","---","ddddd")
   1313 V2A32_RRR_ENC(A2_combine_hl,       "0011","101","-","---","ddddd")
   1314 V2A32_RRR_ENC(A2_combine_lh,       "0011","110","-","---","ddddd")
   1315 V2A32_RRR_ENC(A2_combine_ll,       "0011","111","-","---","ddddd")
   1316 V2A32_RRR_ENC(A4_rcmpeq,           "0011","010","-","---","ddddd")
   1317 V2A32_RRR_ENC(A4_rcmpneq,          "0011","011","-","---","ddddd")
   1318 
   1319 
   1320 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  0100 -------- PP------ --------","[#4] Rd=(Pu,Rs,Rt)")
   1321 V2A32_RRR_ENC(C2_mux,              "0100","---","-","-uu","ddddd")
   1322 
   1323 
   1324 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  0101 -------- PP------ --------","[#5] Rdd=(Rs,Rt)")
   1325 V2A32_RRR_ENC(A2_combinew,         "0101","0--","-","---","ddddd")
   1326 V2A32_RRR_ENC(S2_packhl,           "0101","1--","-","---","ddddd")
   1327 
   1328 
   1329 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  0110 -------- PP------ --------","[#6] Rd=(Rs,Rt)")
   1330 V2A32_RRR_ENC(A2_svaddh,           "0110","000","-","---","ddddd")
   1331 V2A32_RRR_ENC(A2_svaddhs,          "0110","001","-","---","ddddd")
   1332 V2A32_RRR_ENC(A2_svadduhs,         "0110","011","-","---","ddddd")
   1333 V2A32_RRR_ENC(A2_svsubh,           "0110","100","-","---","ddddd")
   1334 V2A32_RRR_ENC(A2_svsubhs,          "0110","101","-","---","ddddd")
   1335 V2A32_RRR_ENC(A2_svsubuhs,         "0110","111","-","---","ddddd")
   1336 V2A32_RRR_ENC(A2_addsat,           "0110","010","-","---","ddddd")
   1337 V2A32_RRR_ENC(A2_subsat,           "0110","110","-","---","ddddd")
   1338 
   1339 
   1340 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  0111 -------- PP------ --------","[#7] Rd=(Rs,Rt)")
   1341 V2A32_RRR_ENC(A2_svavgh,           "0111","-00","-","---","ddddd")
   1342 V2A32_RRR_ENC(A2_svavghs,          "0111","-01","-","---","ddddd")
   1343 V2A32_RRR_ENC(A2_svnavgh,          "0111","-11","-","---","ddddd")
   1344 
   1345 
   1346 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  1000 -------- PP------ --------","[#8] Reserved")
   1347 
   1348 
   1349 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  1001 -------- PP------ --------","[#9] (Pu) Rd=(Rs,Rt)")
   1350 V2A32_RRR_ENC(A2_pandt,            "1001","-00","0","0uu","ddddd")
   1351 V2A32_RRR_ENC(A2_pandtnew,         "1001","-00","1","0uu","ddddd")
   1352 V2A32_RRR_ENC(A2_pandf,            "1001","-00","0","1uu","ddddd")
   1353 V2A32_RRR_ENC(A2_pandfnew,         "1001","-00","1","1uu","ddddd")
   1354 V2A32_RRR_ENC(A2_port,             "1001","-01","0","0uu","ddddd")
   1355 V2A32_RRR_ENC(A2_portnew,          "1001","-01","1","0uu","ddddd")
   1356 V2A32_RRR_ENC(A2_porf,             "1001","-01","0","1uu","ddddd")
   1357 V2A32_RRR_ENC(A2_porfnew,          "1001","-01","1","1uu","ddddd")
   1358 V2A32_RRR_ENC(A2_pxort,            "1001","-11","0","0uu","ddddd")
   1359 V2A32_RRR_ENC(A2_pxortnew,         "1001","-11","1","0uu","ddddd")
   1360 V2A32_RRR_ENC(A2_pxorf,            "1001","-11","0","1uu","ddddd")
   1361 V2A32_RRR_ENC(A2_pxorfnew,         "1001","-11","1","1uu","ddddd")
   1362 
   1363 
   1364 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  1010 -------- PP------ --------","[#10] Reserved")
   1365 
   1366 
   1367 
   1368 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  1011 -------- PP------ --------","[#11] (Pu) Rd=(Rs,Rt)")
   1369 V2A32_RRR_ENC(A2_paddt,            "1011","0-0","0","0uu","ddddd")
   1370 V2A32_RRR_ENC(A2_paddtnew,         "1011","0-0","1","0uu","ddddd")
   1371 V2A32_RRR_ENC(A2_paddf,            "1011","0-0","0","1uu","ddddd")
   1372 V2A32_RRR_ENC(A2_paddfnew,         "1011","0-0","1","1uu","ddddd")
   1373 V2A32_RRR_ENC(A2_psubt,            "1011","0-1","0","0uu","ddddd")
   1374 V2A32_RRR_ENC(A2_psubtnew,         "1011","0-1","1","0uu","ddddd")
   1375 V2A32_RRR_ENC(A2_psubf,            "1011","0-1","0","1uu","ddddd")
   1376 V2A32_RRR_ENC(A2_psubfnew,         "1011","0-1","1","1uu","ddddd")
   1377 
   1378 
   1379 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  1100 -------- PP------ --------","[#12] Reserved")
   1380 
   1381 
   1382 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  1101 -------- PP------ --------","[#13] (Pu) Rdd=(Rs,Rt)")
   1383 V2A32_RRR_ENC(C2_ccombinewnewt,    "1101","000","1","0uu","ddddd")
   1384 V2A32_RRR_ENC(C2_ccombinewnewf,    "1101","000","1","1uu","ddddd")
   1385 V2A32_RRR_ENC(C2_ccombinewt,       "1101","000","0","0uu","ddddd")
   1386 V2A32_RRR_ENC(C2_ccombinewf,       "1101","000","0","1uu","ddddd")
   1387 
   1388 
   1389 
   1390 
   1391 
   1392 
   1393 DEF_FIELDROW_DESC32(ICLASS_ALU3op"  1110 -------- PP------ --------","[#14] Reserved")
   1394 
   1395 
   1396 
   1397 
   1398 
   1399 
   1400 
   1401 
   1402 
   1403 /*******************************/
   1404 /*                             */
   1405 /*                             */
   1406 /*    S                        */
   1407 /*                             */
   1408 /*                             */
   1409 /*******************************/
   1410 
   1411 DEF_CLASS32(ICLASS_S2op" ---- -------- PP------ --------",S_2op)
   1412 DEF_FIELD32(ICLASS_S2op" !!!! -------- PP------ --------",STYPEB_RegType,"Register Type")
   1413 DEF_FIELD32(ICLASS_S2op" ---- !!------ PP------ --------",S2_MajOp,"Major Opcode")
   1414 DEF_FIELD32(ICLASS_S2op" ---- -------- PP------ !!!-----",S2_MinOp,"Minor Opcode")
   1415 
   1416 DEF_CLASS32(ICLASS_S3op" ---- -------- PP------ --------",S_3op)
   1417 DEF_FIELD32(ICLASS_S3op" !!!! -------- PP------ --------",STYPEA_RegType,"Register Type")
   1418 DEF_FIELD32(ICLASS_S3op" ---- !!------ PP------ --------",S3_Maj,"Major Opcode")
   1419 DEF_FIELD32(ICLASS_S3op" ---- -------- PP------ !!------",S3_Min,"Minor Opcode")
   1420 
   1421 
   1422 #define SH_RRR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
   1423 DEF_ENC32(TAG,ICLASS_S3op" "MAJ4"  "MIN3"sssss  PP"SMOD1"ttttt "VMIN3 DSTCHARS)
   1424 
   1425 #define SH_RRRiENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
   1426 DEF_ENC32(TAG,ICLASS_S3op" "MAJ4"  "MIN3"iiiii  PP"SMOD1"ttttt "VMIN3 DSTCHARS)
   1427 
   1428 #define SH_RRR_ENCX(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
   1429 DEF_ENC32(TAG,ICLASS_S3op" "MAJ4"  "MIN3"sssss  PP"SMOD1"xxxxx "VMIN3 DSTCHARS)
   1430 
   1431 #define SH3_RR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
   1432 DEF_ENC32(TAG,ICLASS_S3op" "MAJ4"  "MIN3"sssss  PP"SMOD1"----- "VMIN3 DSTCHARS)
   1433 
   1434 #define SH_PPP_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
   1435 DEF_ENC32(TAG,ICLASS_S3op" "MAJ4"  "MIN3"---ss  PP"SMOD1"---tt "VMIN3 DSTCHARS)
   1436 
   1437 #define SH2_RR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
   1438 DEF_ENC32(TAG,ICLASS_S2op" "MAJ4"  "MIN3"sssss  PP"SMOD1"----- "VMIN3 DSTCHARS)
   1439 
   1440 #define SH2_PPP_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS) \
   1441 DEF_ENC32(TAG,ICLASS_S2op" "MAJ4"  "MIN3"---ss  PP"SMOD1"---tt "VMIN3 DSTCHARS)
   1442 
   1443 #define SH_RRI4_ENC(TAG,MAJ4,MIN3,VMIN3,DSTCHARS) \
   1444 DEF_ENC32(TAG,ICLASS_S2op" "MAJ4" "MIN3 "sssss PP00iiii " VMIN3 DSTCHARS)
   1445 
   1446 #define SH_RRI5_ENC(TAG,MAJ4,MIN3,VMIN3,DSTCHARS) \
   1447 DEF_ENC32(TAG,ICLASS_S2op" "MAJ4" "MIN3 "sssss PP0iiiii " VMIN3 DSTCHARS)
   1448 
   1449 #define SH_RRI6_ENC(TAG,MAJ4,MIN3,VMIN3,DSTCHARS) \
   1450 DEF_ENC32(TAG,ICLASS_S2op" "MAJ4" "MIN3 "sssss PPiiiiii " VMIN3 DSTCHARS)
   1451 
   1452 #define RSHIFTTYPES(TAGEND,MAJ4,MIN3,SMOD1,DMOD1,DSTCHARS) \
   1453 SH_RRR_ENC(S2_asr_r_##TAGEND,MAJ4,MIN3,SMOD1,"00"DMOD1,DSTCHARS) \
   1454 SH_RRR_ENC(S2_lsr_r_##TAGEND,MAJ4,MIN3,SMOD1,"01"DMOD1,DSTCHARS) \
   1455 SH_RRR_ENC(S2_asl_r_##TAGEND,MAJ4,MIN3,SMOD1,"10"DMOD1,DSTCHARS) \
   1456 SH_RRR_ENC(S2_lsl_r_##TAGEND,MAJ4,MIN3,SMOD1,"11"DMOD1,DSTCHARS)
   1457 
   1458 
   1459 #define I5SHIFTTYPES(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
   1460 SH_RRI5_ENC(S2_asr_i_##TAGEND,MAJ4,MIN3,SMOD1 "00",DSTCHARS) \
   1461 SH_RRI5_ENC(S2_lsr_i_##TAGEND,MAJ4,MIN3,SMOD1 "01",DSTCHARS) \
   1462 SH_RRI5_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS) \
   1463 SH_RRI5_ENC(S6_rol_i_##TAGEND,MAJ4,MIN3,SMOD1 "11",DSTCHARS)
   1464 
   1465 #define I5SHIFTTYPES_NOROL(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
   1466 SH_RRI5_ENC(S2_asr_i_##TAGEND,MAJ4,MIN3,SMOD1 "00",DSTCHARS) \
   1467 SH_RRI5_ENC(S2_lsr_i_##TAGEND,MAJ4,MIN3,SMOD1 "01",DSTCHARS) \
   1468 SH_RRI5_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS)
   1469 
   1470 #define I5SHIFTTYPES_NOASR(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
   1471 SH_RRI5_ENC(S2_lsr_i_##TAGEND,MAJ4,MIN3,SMOD1 "01",DSTCHARS) \
   1472 SH_RRI5_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS) \
   1473 SH_RRI5_ENC(S6_rol_i_##TAGEND,MAJ4,MIN3,SMOD1 "11",DSTCHARS)
   1474 
   1475 #define I4SHIFTTYPES(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
   1476 SH_RRI4_ENC(S2_asr_i_##TAGEND,MAJ4,MIN3,SMOD1 "00",DSTCHARS) \
   1477 SH_RRI4_ENC(S2_lsr_i_##TAGEND,MAJ4,MIN3,SMOD1 "01",DSTCHARS) \
   1478 SH_RRI4_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS)
   1479 
   1480 #define I5ASHIFTTYPES(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
   1481 SH_RRI5_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS)
   1482 
   1483 #define I4ASHIFTTYPES(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
   1484 SH_RRI4_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS)
   1485 
   1486 #define I6SHIFTTYPES(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
   1487 SH_RRI6_ENC(S2_asr_i_##TAGEND,MAJ4,MIN3,SMOD1 "00",DSTCHARS) \
   1488 SH_RRI6_ENC(S2_lsr_i_##TAGEND,MAJ4,MIN3,SMOD1 "01",DSTCHARS) \
   1489 SH_RRI6_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS) \
   1490 SH_RRI6_ENC(S6_rol_i_##TAGEND,MAJ4,MIN3,SMOD1 "11",DSTCHARS) \
   1491 
   1492 #define I6SHIFTTYPES_NOASR(TAGEND,MAJ4,MIN3,SMOD1,DSTCHARS) \
   1493 SH_RRI6_ENC(S2_lsr_i_##TAGEND,MAJ4,MIN3,SMOD1 "01",DSTCHARS) \
   1494 SH_RRI6_ENC(S2_asl_i_##TAGEND,MAJ4,MIN3,SMOD1 "10",DSTCHARS) \
   1495 SH_RRI6_ENC(S6_rol_i_##TAGEND,MAJ4,MIN3,SMOD1 "11",DSTCHARS)
   1496 
   1497 
   1498 
   1499 DEF_FIELDROW_DESC32(ICLASS_S2op" 0000 -------- PP------ --------","[#0] Rdd=(Rss,#u6)")
   1500 /* EJP: there is actually quite a bit of space here, look at the reserved bits */
   1501 I6SHIFTTYPES(p,                 "0000","000","0","ddddd")
   1502 I5SHIFTTYPES_NOROL(vw,          "0000","010","0","ddddd")
   1503 I4SHIFTTYPES(vh,                "0000","100","0","ddddd")
   1504 
   1505 
   1506 
   1507 /* False assume an immediate */
   1508 SH2_RR_ENC(S2_vsathub_nopack, "0000","000","-","1 00","ddddd")
   1509 SH2_RR_ENC(S2_vsatwuh_nopack, "0000","000","-","1 01","ddddd")
   1510 SH2_RR_ENC(S2_vsatwh_nopack,  "0000","000","-","1 10","ddddd")
   1511 SH2_RR_ENC(S2_vsathb_nopack,  "0000","000","-","1 11","ddddd")
   1512 
   1513 SH_RRI4_ENC(S5_vasrhrnd,      "0000","001",    "0 00","ddddd")
   1514 
   1515 SH2_RR_ENC(A2_vabsh,          "0000","010","-","1 00","ddddd")
   1516 SH2_RR_ENC(A2_vabshsat,       "0000","010","-","1 01","ddddd")
   1517 SH2_RR_ENC(A2_vabsw,          "0000","010","-","1 10","ddddd")
   1518 SH2_RR_ENC(A2_vabswsat,       "0000","010","-","1 11","ddddd")
   1519 
   1520 SH2_RR_ENC(A2_notp,           "0000","100","-","1 00","ddddd")
   1521 SH2_RR_ENC(A2_negp,           "0000","100","-","1 01","ddddd")
   1522 SH2_RR_ENC(A2_absp,           "0000","100","-","1 10","ddddd")
   1523 SH2_RR_ENC(A2_vconj,          "0000","100","-","1 11","ddddd")
   1524 
   1525 SH2_RR_ENC(S2_deinterleave,   "0000","110","-","1 00","ddddd")
   1526 SH2_RR_ENC(S2_interleave,     "0000","110","-","1 01","ddddd")
   1527 SH2_RR_ENC(S2_brevp,          "0000","110","-","1 10","ddddd")
   1528 SH_RRI6_ENC(S2_asr_i_p_rnd,   "0000","110",    "1 11","ddddd")
   1529 
   1530 SH2_RR_ENC(F2_conv_df2d,      "0000","111","0","0 00","ddddd")
   1531 SH2_RR_ENC(F2_conv_df2ud,     "0000","111","0","0 01","ddddd")
   1532 SH2_RR_ENC(F2_conv_ud2df,     "0000","111","0","0 10","ddddd")
   1533 SH2_RR_ENC(F2_conv_d2df,      "0000","111","0","0 11","ddddd")
   1534 SH2_RR_ENC(F2_conv_df2d_chop, "0000","111","0","1 10","ddddd")
   1535 SH2_RR_ENC(F2_conv_df2ud_chop,"0000","111","0","1 11","ddddd")
   1536 
   1537 
   1538 
   1539 DEF_FIELDROW_DESC32(ICLASS_S2op"    0001 -------- PP------ --------","[#1] Rdd=(Rss,#u6,#U6)")
   1540 DEF_ENC32(S2_extractup,ICLASS_S2op" 0001 IIIsssss PPiiiiii IIIddddd")
   1541 
   1542 
   1543 DEF_FIELDROW_DESC32(ICLASS_S2op" 0010 -------- PP------ --------","[#2] Rxx=(Rss,#u6)")
   1544 I6SHIFTTYPES(p_nac,             "0010","00-","0","xxxxx")
   1545 I6SHIFTTYPES(p_acc,             "0010","00-","1","xxxxx")
   1546 I6SHIFTTYPES(p_and,             "0010","01-","0","xxxxx")
   1547 I6SHIFTTYPES(p_or,              "0010","01-","1","xxxxx")
   1548 I6SHIFTTYPES_NOASR(p_xacc,      "0010","10-","0","xxxxx")
   1549 
   1550 
   1551 DEF_FIELDROW_DESC32(ICLASS_S2op"  0011 -------- PP------ --------","[#3] Rxx=(Rss,#u6,#U6)")
   1552 DEF_ENC32(S2_insertp,ICLASS_S2op" 0011 IIIsssss PPiiiiii IIIxxxxx")
   1553 
   1554 
   1555 DEF_FIELDROW_DESC32(ICLASS_S2op"  0100 -------- PP------ --------","[#4] Rdd=(Rs)")
   1556 SH2_RR_ENC(S2_vsxtbh,            "0100","00-","-","00-","ddddd")
   1557 SH2_RR_ENC(S2_vzxtbh,            "0100","00-","-","01-","ddddd")
   1558 SH2_RR_ENC(S2_vsxthw,            "0100","00-","-","10-","ddddd")
   1559 SH2_RR_ENC(S2_vzxthw,            "0100","00-","-","11-","ddddd")
   1560 SH2_RR_ENC(A2_sxtw,              "0100","01-","-","00-","ddddd")
   1561 SH2_RR_ENC(S2_vsplatrh,          "0100","01-","-","01-","ddddd")
   1562 SH2_RR_ENC(S6_vsplatrbp,         "0100","01-","-","10-","ddddd")
   1563 
   1564 SH2_RR_ENC(F2_conv_sf2df,        "0100","1--","-","000","ddddd")
   1565 SH2_RR_ENC(F2_conv_uw2df,        "0100","1--","-","001","ddddd")
   1566 SH2_RR_ENC(F2_conv_w2df,         "0100","1--","-","010","ddddd")
   1567 SH2_RR_ENC(F2_conv_sf2ud,        "0100","1--","-","011","ddddd")
   1568 SH2_RR_ENC(F2_conv_sf2d,         "0100","1--","-","100","ddddd")
   1569 SH2_RR_ENC(F2_conv_sf2ud_chop,   "0100","1--","-","101","ddddd")
   1570 SH2_RR_ENC(F2_conv_sf2d_chop,    "0100","1--","-","110","ddddd")
   1571 
   1572 
   1573 DEF_FIELDROW_DESC32(ICLASS_S2op"   0101 -------- PP------ --------","[#5] Pd=(Rs,#u6)")
   1574 DEF_ENC32(S2_tstbit_i,ICLASS_S2op" 0101 000sssss PP0iiiii ------dd")
   1575 DEF_ENC32(C2_tfrrp,   ICLASS_S2op" 0101 010sssss PP------ ------dd")
   1576 DEF_ENC32(C2_bitsclri,ICLASS_S2op" 0101 100sssss PPiiiiii ------dd")
   1577 DEF_ENC32(S4_ntstbit_i,ICLASS_S2op"0101 001sssss PP0iiiii ------dd")
   1578 DEF_ENC32(C4_nbitsclri,ICLASS_S2op"0101 101sssss PPiiiiii ------dd")
   1579 DEF_ENC32(F2_sfclass,  ICLASS_S2op"0101 111sssss PP0iiiii ------dd")
   1580 
   1581 
   1582 DEF_FIELDROW_DESC32(ICLASS_S2op"   0110 -------- PP------ --------","[#6] Rdd=(Pt)")
   1583 DEF_ENC32(C2_mask, ICLASS_S2op"    0110   --- -----  PP----tt --- ddddd")
   1584 
   1585 
   1586 DEF_FIELDROW_DESC32(ICLASS_S2op"    0111 -------- PP------ --------","[#7] Rx=(Rs,#u4,#S6)")
   1587 DEF_ENC32(S2_tableidxb,ICLASS_S2op" 0111 00isssss PPIIIIII iiixxxxx")
   1588 DEF_ENC32(S2_tableidxh,ICLASS_S2op" 0111 01isssss PPIIIIII iiixxxxx")
   1589 DEF_ENC32(S2_tableidxw,ICLASS_S2op" 0111 10isssss PPIIIIII iiixxxxx")
   1590 DEF_ENC32(S2_tableidxd,ICLASS_S2op" 0111 11isssss PPIIIIII iiixxxxx")
   1591 
   1592 
   1593 DEF_FIELDROW_DESC32(ICLASS_S2op"   1000 -------- PP------ --------","[#8] Rd=(Rss,#u6)")
   1594 SH2_RR_ENC(S2_vsathub,            "1000","000","-","000","ddddd")
   1595 SH2_RR_ENC(S2_vsatwh,             "1000","000","-","010","ddddd")
   1596 SH2_RR_ENC(S2_vsatwuh,            "1000","000","-","100","ddddd")
   1597 SH2_RR_ENC(S2_vsathb,             "1000","000","-","110","ddddd")
   1598 SH2_RR_ENC(S2_clbp,               "1000","010","-","000","ddddd")
   1599 SH2_RR_ENC(S2_cl0p,               "1000","010","-","010","ddddd")
   1600 SH2_RR_ENC(S2_cl1p,               "1000","010","-","100","ddddd")
   1601 SH2_RR_ENC(S2_ct0p,               "1000","111","-","010","ddddd")
   1602 SH2_RR_ENC(S2_ct1p,               "1000","111","-","100","ddddd")
   1603 SH2_RR_ENC(S2_vtrunohb,           "1000","100","-","000","ddddd")
   1604 SH2_RR_ENC(S2_vtrunehb,           "1000","100","-","010","ddddd")
   1605 SH2_RR_ENC(S2_vrndpackwh,         "1000","100","-","100","ddddd")
   1606 SH2_RR_ENC(S2_vrndpackwhs,        "1000","100","-","110","ddddd")
   1607 SH2_RR_ENC(A2_sat,                "1000","110","-","000","ddddd")
   1608 SH2_RR_ENC(A2_roundsat,           "1000","110","-","001","ddddd")
   1609 SH_RRI5_ENC(S2_asr_i_svw_trun,    "1000","110",    "010","ddddd")
   1610 SH_RRI5_ENC(A4_bitspliti,         "1000","110",    "100","ddddd")
   1611 
   1612 SH_RRI5_ENC(A7_clip,              "1000","110",    "101","ddddd")
   1613 SH_RRI5_ENC(A7_vclip,             "1000","110",    "110","ddddd")
   1614 
   1615 
   1616 SH2_RR_ENC(S4_clbpnorm,           "1000","011","-","000","ddddd")
   1617 SH_RRI6_ENC(S4_clbpaddi,          "1000","011",    "010","ddddd")
   1618 SH2_RR_ENC(S5_popcountp,          "1000","011","-","011","ddddd")
   1619 
   1620 SH_RRI4_ENC(S5_asrhub_rnd_sat,    "1000","011",    "100","ddddd")
   1621 SH_RRI4_ENC(S5_asrhub_sat,        "1000","011",    "101","ddddd")
   1622 
   1623 SH2_RR_ENC(F2_conv_df2sf,         "1000","000","-","001","ddddd")
   1624 SH2_RR_ENC(F2_conv_ud2sf,         "1000","001","-","001","ddddd")
   1625 SH2_RR_ENC(F2_conv_d2sf,          "1000","010","-","001","ddddd")
   1626 SH2_RR_ENC(F2_conv_df2uw,         "1000","011","-","001","ddddd")
   1627 SH2_RR_ENC(F2_conv_df2w,          "1000","100","-","001","ddddd")
   1628 SH2_RR_ENC(F2_conv_df2uw_chop,    "1000","101","-","001","ddddd")
   1629 SH2_RR_ENC(F2_conv_df2w_chop,     "1000","111","-","001","ddddd")
   1630 
   1631 
   1632 
   1633 DEF_FIELDROW_DESC32(ICLASS_S2op"   1001 -------- PP------ --------","[#9] Rd=(Ps,Pt)")
   1634 DEF_ENC32(C2_vitpack, ICLASS_S2op" 1001   -00 ---ss  PP----tt --- ddddd")
   1635 DEF_ENC32(C2_tfrpr,   ICLASS_S2op" 1001   -1- ---ss  PP------ --- ddddd")
   1636 
   1637 
   1638 DEF_FIELDROW_DESC32(ICLASS_S2op"   1010 -------- PP------ --------","[#10] Rdd=(Rss,#u6,#U6)")
   1639 DEF_ENC32(S4_extractp,ICLASS_S2op" 1010 IIIsssss PPiiiiii IIIddddd")
   1640 
   1641 
   1642 DEF_FIELDROW_DESC32(ICLASS_S2op"   1011 -------- PP------ --------","[#11] Rd=(Rs)")
   1643 SH2_RR_ENC(F2_conv_uw2sf,         "1011","001","-","000","ddddd")
   1644 SH2_RR_ENC(F2_conv_w2sf,          "1011","010","-","000","ddddd")
   1645 SH2_RR_ENC(F2_conv_sf2uw,         "1011","011","-","000","ddddd")
   1646 SH2_RR_ENC(F2_conv_sf2w,          "1011","100","-","000","ddddd")
   1647 SH2_RR_ENC(F2_conv_sf2uw_chop,    "1011","011","-","001","ddddd")
   1648 SH2_RR_ENC(F2_conv_sf2w_chop,     "1011","100","-","001","ddddd")
   1649 SH2_RR_ENC(F2_sffixupr,           "1011","101","-","000","ddddd")
   1650 SH2_RR_ENC(F2_sfinvsqrta,         "1011","111","-","0ee","ddddd")
   1651 
   1652 
   1653 DEF_FIELDROW_DESC32(ICLASS_S2op"      1100 -------- PP------ --------","[#12] Rd=(Rs,#u6)")
   1654 I5SHIFTTYPES(r,                      "1100","000",            "0  ","ddddd")
   1655 SH_RRI5_ENC(S2_asl_i_r_sat,          "1100","010",            "010","ddddd")
   1656 SH_RRI5_ENC(S2_asr_i_r_rnd,          "1100","010",            "000","ddddd")
   1657 
   1658 SH2_RR_ENC(S2_svsathb,               "1100","10-","-",        "00-","ddddd")
   1659 SH2_RR_ENC(S2_svsathub,              "1100","10-","-",        "01-","ddddd")
   1660 
   1661 SH_RRI5_ENC(A4_cround_ri,            "1100","111",            "00-","ddddd")
   1662 SH_RRI6_ENC(A7_croundd_ri,           "1100","111",            "01-","ddddd")
   1663 SH_RRI5_ENC(A4_round_ri,             "1100","111",            "10-","ddddd")
   1664 SH_RRI5_ENC(A4_round_ri_sat,         "1100","111",            "11-","ddddd")
   1665 
   1666 DEF_ENC32(S2_setbit_i,   ICLASS_S2op" 1100   110sssss PP0iiiii 000ddddd")
   1667 DEF_ENC32(S2_clrbit_i,   ICLASS_S2op" 1100   110sssss PP0iiiii 001ddddd")
   1668 DEF_ENC32(S2_togglebit_i,ICLASS_S2op" 1100   110sssss PP0iiiii 010ddddd")
   1669 
   1670 DEF_ENC32(S4_clbaddi    ,ICLASS_S2op" 1100   001sssss PPiiiiii 000ddddd")
   1671 
   1672 
   1673 
   1674 /* False read #u6 */
   1675 SH2_RR_ENC(S2_clb,                   "1100","000","-","1 00","ddddd")
   1676 SH2_RR_ENC(S2_cl0,                   "1100","000","-","1 01","ddddd")
   1677 SH2_RR_ENC(S2_cl1,                   "1100","000","-","1 10","ddddd")
   1678 SH2_RR_ENC(S2_clbnorm,               "1100","000","-","1 11","ddddd")
   1679 SH2_RR_ENC(S2_ct0,                   "1100","010","-","1 00","ddddd")
   1680 SH2_RR_ENC(S2_ct1,                   "1100","010","-","1 01","ddddd")
   1681 SH2_RR_ENC(S2_brev,                  "1100","010","-","1 10","ddddd")
   1682 SH2_RR_ENC(S2_vsplatrb,              "1100","010","-","1 11","ddddd")
   1683 SH2_RR_ENC(A2_abs,                   "1100","100","-","1 00","ddddd")
   1684 SH2_RR_ENC(A2_abssat,                "1100","100","-","1 01","ddddd")
   1685 SH2_RR_ENC(A2_negsat,                "1100","100","-","1 10","ddddd")
   1686 SH2_RR_ENC(A2_swiz,                  "1100","100","-","1 11","ddddd")
   1687 SH2_RR_ENC(A2_sath,                  "1100","110","-","1 00","ddddd")
   1688 SH2_RR_ENC(A2_satuh,                 "1100","110","-","1 01","ddddd")
   1689 SH2_RR_ENC(A2_satub,                 "1100","110","-","1 10","ddddd")
   1690 SH2_RR_ENC(A2_satb,                  "1100","110","-","1 11","ddddd")
   1691 
   1692 
   1693 DEF_FIELDROW_DESC32(ICLASS_S2op"     1101 -------- PP------ --------","[#13] Rd=(Rs,#u6,#U6)")
   1694 DEF_ENC32(S2_extractu,  ICLASS_S2op" 1101 0IIsssss PP0iiiii IIIddddd")
   1695 DEF_ENC32(S4_extract,   ICLASS_S2op" 1101 1IIsssss PP0iiiii IIIddddd")
   1696 DEF_ENC32(S2_mask,    ICLASS_S2op"   1101 0II----- PP1iiiii IIIddddd")
   1697 
   1698 
   1699 
   1700 
   1701 
   1702 
   1703 DEF_FIELDROW_DESC32(ICLASS_S2op"     1110 -------- PP------ --------","[#14] Rx=(Rs,#u6)")
   1704 I5SHIFTTYPES(r_nac,       "1110","00-","0","xxxxx")
   1705 I5SHIFTTYPES(r_acc,       "1110","00-","1","xxxxx")
   1706 I5SHIFTTYPES(r_and,       "1110","01-","0","xxxxx")
   1707 I5SHIFTTYPES(r_or,        "1110","01-","1","xxxxx")
   1708 I5SHIFTTYPES_NOASR(r_xacc,"1110","10-","0","xxxxx")
   1709 
   1710 
   1711 DEF_FIELDROW_DESC32(ICLASS_S2op"     1111 -------- PP------ --------","[#15] Rs=(Rs,#u6,#U6)")
   1712 DEF_ENC32(S2_insert,    ICLASS_S2op" 1111 0IIsssss PP0iiiii IIIxxxxx")
   1713 
   1714 
   1715 
   1716 
   1717 
   1718 /*************************/
   1719 /* S_3_operand           */
   1720 /*************************/
   1721 
   1722 
   1723 DEF_FIELDROW_DESC32(ICLASS_S3op" 0000 -------- PP------ --------","[#0] Rdd=(Rss,Rtt,#u3)")
   1724 SH_RRR_ENC(S2_valignib,         "0000","0--","-","iii","ddddd")
   1725 SH_RRR_ENC(S2_vspliceib,        "0000","1--","-","iii","ddddd")
   1726 
   1727 
   1728 DEF_FIELDROW_DESC32(ICLASS_S3op" 0001 -------- PP------ --------","[#1] Rdd=(Rss,Rtt)")
   1729 SH_RRR_ENC(S2_extractup_rp,     "0001","00-","-","00-","ddddd")
   1730 SH_RRR_ENC(S2_shuffeb,          "0001","00-","-","01-","ddddd")
   1731 SH_RRR_ENC(S2_shuffob,          "0001","00-","-","10-","ddddd")
   1732 SH_RRR_ENC(S2_shuffeh,          "0001","00-","-","11-","ddddd")
   1733 
   1734 SH_RRR_ENC(S2_shuffoh,          "0001","10-","-","000","ddddd")
   1735 SH_RRR_ENC(S2_vtrunewh,         "0001","10-","-","010","ddddd")
   1736 SH_RRR_ENC(S6_vtrunehb_ppp,     "0001","10-","-","011","ddddd")
   1737 SH_RRR_ENC(S2_vtrunowh,         "0001","10-","-","100","ddddd")
   1738 SH_RRR_ENC(S6_vtrunohb_ppp,     "0001","10-","-","101","ddddd")
   1739 SH_RRR_ENC(S2_lfsp,             "0001","10-","-","110","ddddd")
   1740 
   1741 SH_RRR_ENC(S4_vxaddsubw,        "0001","01-","-","000","ddddd")
   1742 SH_RRR_ENC(A5_vaddhubs,         "0001","01-","-","001","ddddd")
   1743 SH_RRR_ENC(S4_vxsubaddw,        "0001","01-","-","010","ddddd")
   1744 SH_RRR_ENC(S4_vxaddsubh,        "0001","01-","-","100","ddddd")
   1745 SH_RRR_ENC(S4_vxsubaddh,        "0001","01-","-","110","ddddd")
   1746 
   1747 SH_RRR_ENC(S4_vxaddsubhr,       "0001","11-","-","00-","ddddd")
   1748 SH_RRR_ENC(S4_vxsubaddhr,       "0001","11-","-","01-","ddddd")
   1749 SH_RRR_ENC(S4_extractp_rp,      "0001","11-","-","10-","ddddd")
   1750 SH_RRR_ENC(S2_cabacdecbin,      "0001","11-","-","11-","ddddd") /* implicit P0 write */
   1751 
   1752 
   1753 DEF_FIELDROW_DESC32(ICLASS_S3op" 0010 -------- PP------ --------","[#2] Rdd=(Rss,Rtt,Pu)")
   1754 SH_RRR_ENC(S2_valignrb,         "0010","0--","-","-uu","ddddd")
   1755 SH_RRR_ENC(S2_vsplicerb,        "0010","100","-","-uu","ddddd")
   1756 SH_RRR_ENC(A4_addp_c,           "0010","110","-","-xx","ddddd")
   1757 SH_RRR_ENC(A4_subp_c,           "0010","111","-","-xx","ddddd")
   1758 
   1759 
   1760 DEF_FIELDROW_DESC32(ICLASS_S3op" 0011 -------- PP------ --------","[#3] Rdd=(Rss,Rt)")
   1761 RSHIFTTYPES(vw,                 "0011","00-","-","-","ddddd")
   1762 RSHIFTTYPES(vh,                 "0011","01-","-","-","ddddd")
   1763 RSHIFTTYPES(p,                  "0011","10-","-","-","ddddd")
   1764 SH_RRR_ENC(S2_vcrotate,         "0011","11-","-","00-","ddddd")
   1765 SH_RRR_ENC(S2_vcnegh,           "0011","11-","-","01-","ddddd")
   1766 SH_RRR_ENC(S4_vrcrotate,        "0011","11-","i","11i","ddddd")
   1767 
   1768 
   1769 DEF_FIELDROW_DESC32(ICLASS_S3op" 0100 -------- PP------ --------","[#4] Rd=(Rs,Rt,#u3)")
   1770 DEF_ENC32(S2_addasl_rrri, ICLASS_S3op" 0100   000 sssss PP0ttttt iiiddddd")
   1771 
   1772 
   1773 
   1774 DEF_FIELDROW_DESC32(ICLASS_S3op" 0101 -------- PP------ --------","[#5] Rd=(Rss,Rt)")
   1775 SH_RRR_ENC(S2_asr_r_svw_trun,   "0101","---","-","010","ddddd")
   1776 SH_RRR_ENC(M4_cmpyi_wh,         "0101","---","-","100","ddddd")
   1777 SH_RRR_ENC(M4_cmpyr_wh,         "0101","---","-","110","ddddd")
   1778 SH_RRR_ENC(M4_cmpyi_whc,        "0101","---","-","101","ddddd")
   1779 SH_RRR_ENC(M4_cmpyr_whc,        "0101","---","-","111","ddddd")
   1780 
   1781 DEF_FIELDROW_DESC32(ICLASS_S3op" 0110 -------- PP------ --------","[#6] Rd=(Rs,Rt)")
   1782 SH_RRR_ENC(S2_asr_r_r_sat,      "0110","00-","-","00-","ddddd") \
   1783 SH_RRR_ENC(S2_asl_r_r_sat,      "0110","00-","-","10-","ddddd")
   1784 
   1785 RSHIFTTYPES(r,                  "0110","01-","-","-","ddddd")
   1786 
   1787 SH_RRR_ENC(S2_setbit_r,         "0110","10-","-","00-","ddddd")
   1788 SH_RRR_ENC(S2_clrbit_r,         "0110","10-","-","01-","ddddd")
   1789 SH_RRR_ENC(S2_togglebit_r,      "0110","10-","-","10-","ddddd")
   1790 SH_RRRiENC(S4_lsli,             "0110","10-","-","11i","ddddd")
   1791 
   1792 SH_RRR_ENC(A4_cround_rr,        "0110","11-","-","00-","ddddd")
   1793 SH_RRR_ENC(A7_croundd_rr,       "0110","11-","-","01-","ddddd")
   1794 SH_RRR_ENC(A4_round_rr,         "0110","11-","-","10-","ddddd")
   1795 SH_RRR_ENC(A4_round_rr_sat,     "0110","11-","-","11-","ddddd")
   1796 
   1797 
   1798 
   1799 
   1800 DEF_FIELDROW_DESC32(ICLASS_S3op" 0111 -------- PP------ --------","[#7] Pd=(Rs,Rt)")
   1801 SH_RRR_ENC(S2_tstbit_r,         "0111","000","-","---","---dd")
   1802 SH_RRR_ENC(C2_bitsset,          "0111","010","-","---","---dd")
   1803 SH_RRR_ENC(C2_bitsclr,          "0111","100","-","---","---dd")
   1804 SH_RRR_ENC(A4_cmpheq,           "0111","110","-","011","---dd")
   1805 SH_RRR_ENC(A4_cmphgt,           "0111","110","-","100","---dd")
   1806 SH_RRR_ENC(A4_cmphgtu,          "0111","110","-","101","---dd")
   1807 SH_RRR_ENC(A4_cmpbeq,           "0111","110","-","110","---dd")
   1808 SH_RRR_ENC(A4_cmpbgtu,          "0111","110","-","111","---dd")
   1809 SH_RRR_ENC(A4_cmpbgt,           "0111","110","-","010","---dd")
   1810 SH_RRR_ENC(S4_ntstbit_r,        "0111","001","-","---","---dd")
   1811 SH_RRR_ENC(C4_nbitsset,         "0111","011","-","---","---dd")
   1812 SH_RRR_ENC(C4_nbitsclr,         "0111","101","-","---","---dd")
   1813 
   1814 SH_RRR_ENC(F2_sfcmpge,          "0111","111","-","000","---dd")
   1815 SH_RRR_ENC(F2_sfcmpuo,          "0111","111","-","001","---dd")
   1816 SH_RRR_ENC(F2_sfcmpeq,          "0111","111","-","011","---dd")
   1817 SH_RRR_ENC(F2_sfcmpgt,          "0111","111","-","100","---dd")
   1818 
   1819 
   1820 DEF_FIELDROW_DESC32(ICLASS_S3op" 1000 -------- PP------ --------","[#8] Rx=(Rs,Rtt)")
   1821 SH_RRR_ENC(S2_insert_rp,        "1000","---","-","---","xxxxx")
   1822 
   1823 
   1824 DEF_FIELDROW_DESC32(ICLASS_S3op" 1001 -------- PP------ --------","[#9] Rd=(Rs,Rtt)")
   1825 SH_RRR_ENC(S2_extractu_rp,      "1001","00-","-","00-","ddddd")
   1826 SH_RRR_ENC(S4_extract_rp,       "1001","00-","-","01-","ddddd")
   1827 
   1828 
   1829 DEF_FIELDROW_DESC32(ICLASS_S3op" 1010 -------- PP------ --------","[#10] Rxx=(Rss,Rtt)")
   1830 SH_RRR_ENC(S2_insertp_rp,       "1010","0--","0","---","xxxxx")
   1831 SH_RRR_ENC(M4_xor_xacc,         "1010","10-","0","000","xxxxx")
   1832 
   1833 DEF_FIELDROW_DESC32(ICLASS_S3op" 1011 -------- PP------ --------","[#11] Rxx=(Rss,Rt)")
   1834 RSHIFTTYPES(p_or,               "1011","000","-","-","xxxxx")
   1835 RSHIFTTYPES(p_and,              "1011","010","-","-","xxxxx")
   1836 RSHIFTTYPES(p_nac,              "1011","100","-","-","xxxxx")
   1837 RSHIFTTYPES(p_acc,              "1011","110","-","-","xxxxx")
   1838 RSHIFTTYPES(p_xor,              "1011","011","-","-","xxxxx")
   1839 
   1840 SH_RRR_ENCX(A4_vrmaxh,          "1011","001","0","001","uuuuu")
   1841 SH_RRR_ENCX(A4_vrmaxuh,         "1011","001","1","001","uuuuu")
   1842 SH_RRR_ENCX(A4_vrmaxw,          "1011","001","0","010","uuuuu")
   1843 SH_RRR_ENCX(A4_vrmaxuw,         "1011","001","1","010","uuuuu")
   1844 
   1845 SH_RRR_ENCX(A4_vrminh,          "1011","001","0","101","uuuuu")
   1846 SH_RRR_ENCX(A4_vrminuh,         "1011","001","1","101","uuuuu")
   1847 SH_RRR_ENCX(A4_vrminw,          "1011","001","0","110","uuuuu")
   1848 SH_RRR_ENCX(A4_vrminuw,         "1011","001","1","110","uuuuu")
   1849 
   1850 SH_RRR_ENC(S2_vrcnegh,          "1011","001","1","111","xxxxx")
   1851 
   1852 SH_RRR_ENC(S4_vrcrotate_acc,    "1011","101","i","--i","xxxxx")
   1853 
   1854 
   1855 DEF_FIELDROW_DESC32(ICLASS_S3op" 1100 -------- PP------ --------","[#12] Rx=(Rs,Rt)")
   1856 RSHIFTTYPES(r_or,               "1100","00-","-","-","xxxxx")
   1857 RSHIFTTYPES(r_and,              "1100","01-","-","-","xxxxx")
   1858 RSHIFTTYPES(r_nac,              "1100","10-","-","-","xxxxx")
   1859 RSHIFTTYPES(r_acc,              "1100","11-","-","-","xxxxx")
   1860 
   1861 
   1862 DEF_FIELDROW_DESC32(ICLASS_S3op" 1101 -------- PP------ --------","[#13] Reserved")
   1863 DEF_FIELDROW_DESC32(ICLASS_S3op" 1110 -------- PP------ --------","[#14] Reserved")
   1864 
   1865 
   1866 DEF_FIELDROW_DESC32(ICLASS_S3op" 1111 -------- PP------ --------","[#14] User Instruction")
   1867 
   1868 
   1869 
   1870 
   1871 
   1872 
   1873 
   1874 
   1875 
   1876 
   1877 
   1878 
   1879 
   1880 /*******************************/
   1881 /*                             */
   1882 /*                             */
   1883 /*           ALU64             */
   1884 /*                             */
   1885 /*                             */
   1886 /*******************************/
   1887 DEF_CLASS32(ICLASS_ALU64" ---- -------- PP------ --------",ALU64)
   1888 DEF_FIELD32(ICLASS_ALU64" !!!! -------- PP------ --------",ALU64_RegType,"Register Type")
   1889 DEF_FIELD32(ICLASS_ALU64" 0--- !!!----- PP------ --------",A_MajOp,"Major Opcode")
   1890 DEF_FIELD32(ICLASS_ALU64" 0--- -------- PP------ !!!-----",A_MinOp,"Minor Opcode")
   1891 DEF_FIELD32(ICLASS_ALU64" 11-- -------- PP------ ---!!!!!",A_MajOp,"Major Opcode")
   1892 
   1893 
   1894 
   1895 #define ALU64_RRR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
   1896 DEF_ENC32(TAG, ICLASS_ALU64" "MAJ4"  "MIN3"sssss  PP"SMOD1"ttttt "VMIN3 DSTCHARS)
   1897 
   1898 #define LEGACY_ALU64_RRR_ENC(TAG,MAJ4,MIN3,SMOD1,VMIN3,DSTCHARS)\
   1899 LEGACY_DEF_ENC32(TAG, ICLASS_ALU64" "MAJ4"  "MIN3"sssss  PP"SMOD1"ttttt "VMIN3 DSTCHARS)
   1900 
   1901 
   1902 DEF_FIELDROW_DESC32(ICLASS_ALU64" 0000 -------- PP------ --------","[#0] Rd=(Rss,Rtt)")
   1903 ALU64_RRR_ENC(S2_parityp,        "0000","---","-","---","ddddd")
   1904 
   1905 
   1906 DEF_FIELDROW_DESC32(ICLASS_ALU64" 0001 -------- PP------ --------","[#1] Rdd=(Pu,Rss,Rtt)")
   1907 ALU64_RRR_ENC(C2_vmux,           "0001","---","-","-uu","ddddd")
   1908 
   1909 
   1910 DEF_FIELDROW_DESC32(ICLASS_ALU64" 0010 -------- PP------ --------","[#2] Pd=(Rss,Rtt)")
   1911 ALU64_RRR_ENC(A2_vcmpweq,        "0010","0--","0","000","---dd")
   1912 ALU64_RRR_ENC(A2_vcmpwgt,        "0010","0--","0","001","---dd")
   1913 ALU64_RRR_ENC(A2_vcmpwgtu,       "0010","0--","0","010","---dd")
   1914 ALU64_RRR_ENC(A2_vcmpheq,        "0010","0--","0","011","---dd")
   1915 ALU64_RRR_ENC(A2_vcmphgt,        "0010","0--","0","100","---dd")
   1916 ALU64_RRR_ENC(A2_vcmphgtu,       "0010","0--","0","101","---dd")
   1917 ALU64_RRR_ENC(A2_vcmpbeq,        "0010","0--","0","110","---dd")
   1918 ALU64_RRR_ENC(A2_vcmpbgtu,       "0010","0--","0","111","---dd")
   1919 
   1920 ALU64_RRR_ENC(A4_vcmpbeq_any,    "0010","0--","1","000","---dd")
   1921 ALU64_RRR_ENC(A6_vcmpbeq_notany, "0010","0--","1","001","---dd")
   1922 ALU64_RRR_ENC(A4_vcmpbgt,        "0010","0--","1","010","---dd")
   1923 ALU64_RRR_ENC(A4_tlbmatch,       "0010","0--","1","011","---dd")
   1924 ALU64_RRR_ENC(A4_boundscheck_lo, "0010","0--","1","100","---dd")
   1925 ALU64_RRR_ENC(A4_boundscheck_hi, "0010","0--","1","101","---dd")
   1926 
   1927 ALU64_RRR_ENC(C2_cmpeqp,         "0010","100","-","000","---dd")
   1928 ALU64_RRR_ENC(C2_cmpgtp,         "0010","100","-","010","---dd")
   1929 ALU64_RRR_ENC(C2_cmpgtup,        "0010","100","-","100","---dd")
   1930 
   1931 ALU64_RRR_ENC(F2_dfcmpeq,        "0010","111","-","000","---dd")
   1932 ALU64_RRR_ENC(F2_dfcmpgt,        "0010","111","-","001","---dd")
   1933 ALU64_RRR_ENC(F2_dfcmpge,        "0010","111","-","010","---dd")
   1934 ALU64_RRR_ENC(F2_dfcmpuo,        "0010","111","-","011","---dd")
   1935 
   1936 
   1937 DEF_FIELDROW_DESC32(ICLASS_ALU64" 0011 -------- PP------ --------","[#3] Rdd=(Rss,Rtt)")
   1938 ALU64_RRR_ENC(A2_vaddub,         "0011","000","-","000","ddddd")
   1939 ALU64_RRR_ENC(A2_vaddubs,        "0011","000","-","001","ddddd")
   1940 ALU64_RRR_ENC(A2_vaddh,          "0011","000","-","010","ddddd")
   1941 ALU64_RRR_ENC(A2_vaddhs,         "0011","000","-","011","ddddd")
   1942 ALU64_RRR_ENC(A2_vadduhs,        "0011","000","-","100","ddddd")
   1943 ALU64_RRR_ENC(A2_vaddw,          "0011","000","-","101","ddddd")
   1944 ALU64_RRR_ENC(A2_vaddws,         "0011","000","-","110","ddddd")
   1945 ALU64_RRR_ENC(A2_addp,           "0011","000","-","111","ddddd")
   1946 
   1947 ALU64_RRR_ENC(A2_vsubub,         "0011","001","-","000","ddddd")
   1948 ALU64_RRR_ENC(A2_vsububs,        "0011","001","-","001","ddddd")
   1949 ALU64_RRR_ENC(A2_vsubh,          "0011","001","-","010","ddddd")
   1950 ALU64_RRR_ENC(A2_vsubhs,         "0011","001","-","011","ddddd")
   1951 ALU64_RRR_ENC(A2_vsubuhs,        "0011","001","-","100","ddddd")
   1952 ALU64_RRR_ENC(A2_vsubw,          "0011","001","-","101","ddddd")
   1953 ALU64_RRR_ENC(A2_vsubws,         "0011","001","-","110","ddddd")
   1954 ALU64_RRR_ENC(A2_subp,           "0011","001","-","111","ddddd")
   1955 
   1956 ALU64_RRR_ENC(A2_vavgub,         "0011","010","-","000","ddddd")
   1957 ALU64_RRR_ENC(A2_vavgubr,        "0011","010","-","001","ddddd")
   1958 ALU64_RRR_ENC(A2_vavgh,          "0011","010","-","010","ddddd")
   1959 ALU64_RRR_ENC(A2_vavghr,         "0011","010","-","011","ddddd")
   1960 ALU64_RRR_ENC(A2_vavghcr,        "0011","010","-","100","ddddd")
   1961 ALU64_RRR_ENC(A2_vavguh,         "0011","010","-","101","ddddd")
   1962 ALU64_RRR_ENC(A2_vavguhr,        "0011","010","-","11-","ddddd")
   1963 
   1964 ALU64_RRR_ENC(A2_vavgw,          "0011","011","-","000","ddddd")
   1965 ALU64_RRR_ENC(A2_vavgwr,         "0011","011","-","001","ddddd")
   1966 ALU64_RRR_ENC(A2_vavgwcr,        "0011","011","-","010","ddddd")
   1967 ALU64_RRR_ENC(A2_vavguw,         "0011","011","-","011","ddddd")
   1968 ALU64_RRR_ENC(A2_vavguwr,        "0011","011","-","100","ddddd")
   1969 ALU64_RRR_ENC(A2_addpsat,        "0011","011","-","101","ddddd")
   1970 ALU64_RRR_ENC(A2_addspl,         "0011","011","-","110","ddddd")
   1971 ALU64_RRR_ENC(A2_addsph,         "0011","011","-","111","ddddd")
   1972 
   1973 ALU64_RRR_ENC(A2_vnavgh,         "0011","100","-","000","ddddd")
   1974 ALU64_RRR_ENC(A2_vnavghr,        "0011","100","-","001","ddddd")
   1975 ALU64_RRR_ENC(A2_vnavghcr,       "0011","100","-","010","ddddd")
   1976 ALU64_RRR_ENC(A2_vnavgw,         "0011","100","-","011","ddddd")
   1977 ALU64_RRR_ENC(A2_vnavgwr,        "0011","100","-","10-","ddddd")
   1978 ALU64_RRR_ENC(A2_vnavgwcr,       "0011","100","-","11-","ddddd")
   1979 
   1980 ALU64_RRR_ENC(A2_vminub,         "0011","101","-","000","ddddd")
   1981 ALU64_RRR_ENC(A2_vminh,          "0011","101","-","001","ddddd")
   1982 ALU64_RRR_ENC(A2_vminuh,         "0011","101","-","010","ddddd")
   1983 ALU64_RRR_ENC(A2_vminw,          "0011","101","-","011","ddddd")
   1984 ALU64_RRR_ENC(A2_vminuw,         "0011","101","-","100","ddddd")
   1985 ALU64_RRR_ENC(A2_vmaxuw,         "0011","101","-","101","ddddd")
   1986 ALU64_RRR_ENC(A2_minp,           "0011","101","-","110","ddddd")
   1987 ALU64_RRR_ENC(A2_minup,          "0011","101","-","111","ddddd")
   1988 
   1989 ALU64_RRR_ENC(A2_vmaxub,         "0011","110","-","000","ddddd")
   1990 ALU64_RRR_ENC(A2_vmaxh,          "0011","110","-","001","ddddd")
   1991 ALU64_RRR_ENC(A2_vmaxuh,         "0011","110","-","010","ddddd")
   1992 ALU64_RRR_ENC(A2_vmaxw,          "0011","110","-","011","ddddd")
   1993 ALU64_RRR_ENC(A2_maxp,           "0011","110","-","100","ddddd")
   1994 ALU64_RRR_ENC(A2_maxup,          "0011","110","-","101","ddddd")
   1995 ALU64_RRR_ENC(A2_vmaxb,          "0011","110","-","110","ddddd")
   1996 ALU64_RRR_ENC(A2_vminb,          "0011","110","-","111","ddddd")
   1997 
   1998 ALU64_RRR_ENC(A2_andp,           "0011","111","-","000","ddddd")
   1999 ALU64_RRR_ENC(A2_orp,            "0011","111","-","010","ddddd")
   2000 ALU64_RRR_ENC(A2_xorp,           "0011","111","-","100","ddddd")
   2001 ALU64_RRR_ENC(A4_andnp,          "0011","111","-","001","ddddd")
   2002 ALU64_RRR_ENC(A4_ornp,           "0011","111","-","011","ddddd")
   2003 
   2004 ALU64_RRR_ENC(A4_modwrapu,       "0011","111","-","111","ddddd")
   2005 
   2006 
   2007 
   2008 DEF_FIELDROW_DESC32(ICLASS_ALU64" 0100 -------- PP------ --------","[#4] Rdd=(Rs,Rt)")
   2009 LEGACY_ALU64_RRR_ENC(S2_packhl,  "0100","--0","-","---","ddddd")
   2010 ALU64_RRR_ENC(A4_bitsplit,       "0100","--1","-","---","ddddd")
   2011 
   2012 
   2013 DEF_FIELDROW_DESC32(ICLASS_ALU64" 0101 -------- PP------ --------","[#5] Rd=(Rs,Rt)")
   2014 ALU64_RRR_ENC(A2_addh_l16_ll,    "0101","000","-","00-","ddddd")
   2015 ALU64_RRR_ENC(A2_addh_l16_hl,    "0101","000","-","01-","ddddd")
   2016 ALU64_RRR_ENC(A2_addh_l16_sat_ll,"0101","000","-","10-","ddddd")
   2017 ALU64_RRR_ENC(A2_addh_l16_sat_hl,"0101","000","-","11-","ddddd")
   2018 
   2019 ALU64_RRR_ENC(A2_subh_l16_ll,    "0101","001","-","00-","ddddd")
   2020 ALU64_RRR_ENC(A2_subh_l16_hl,    "0101","001","-","01-","ddddd")
   2021 ALU64_RRR_ENC(A2_subh_l16_sat_ll,"0101","001","-","10-","ddddd")
   2022 ALU64_RRR_ENC(A2_subh_l16_sat_hl,"0101","001","-","11-","ddddd")
   2023 
   2024 ALU64_RRR_ENC(A2_addh_h16_ll,    "0101","010","-","000","ddddd")
   2025 ALU64_RRR_ENC(A2_addh_h16_lh,    "0101","010","-","001","ddddd")
   2026 ALU64_RRR_ENC(A2_addh_h16_hl,    "0101","010","-","010","ddddd")
   2027 ALU64_RRR_ENC(A2_addh_h16_hh,    "0101","010","-","011","ddddd")
   2028 ALU64_RRR_ENC(A2_addh_h16_sat_ll,"0101","010","-","100","ddddd")
   2029 ALU64_RRR_ENC(A2_addh_h16_sat_lh,"0101","010","-","101","ddddd")
   2030 ALU64_RRR_ENC(A2_addh_h16_sat_hl,"0101","010","-","110","ddddd")
   2031 ALU64_RRR_ENC(A2_addh_h16_sat_hh,"0101","010","-","111","ddddd")
   2032 
   2033 ALU64_RRR_ENC(A2_subh_h16_ll,    "0101","011","-","000","ddddd")
   2034 ALU64_RRR_ENC(A2_subh_h16_lh,    "0101","011","-","001","ddddd")
   2035 ALU64_RRR_ENC(A2_subh_h16_hl,    "0101","011","-","010","ddddd")
   2036 ALU64_RRR_ENC(A2_subh_h16_hh,    "0101","011","-","011","ddddd")
   2037 ALU64_RRR_ENC(A2_subh_h16_sat_ll,"0101","011","-","100","ddddd")
   2038 ALU64_RRR_ENC(A2_subh_h16_sat_lh,"0101","011","-","101","ddddd")
   2039 ALU64_RRR_ENC(A2_subh_h16_sat_hl,"0101","011","-","110","ddddd")
   2040 ALU64_RRR_ENC(A2_subh_h16_sat_hh,"0101","011","-","111","ddddd")
   2041 
   2042 LEGACY_ALU64_RRR_ENC(A2_addsat,  "0101","100","-","0--","ddddd")
   2043 LEGACY_ALU64_RRR_ENC(A2_subsat,  "0101","100","-","1--","ddddd")
   2044 
   2045 ALU64_RRR_ENC(A2_min,            "0101","101","-","0--","ddddd")
   2046 ALU64_RRR_ENC(A2_minu,           "0101","101","-","1--","ddddd")
   2047 
   2048 ALU64_RRR_ENC(A2_max,            "0101","110","-","0--","ddddd")
   2049 ALU64_RRR_ENC(A2_maxu,           "0101","110","-","1--","ddddd")
   2050 
   2051 ALU64_RRR_ENC(S4_parity,         "0101","111","-","---","ddddd")
   2052 
   2053 
   2054 DEF_FIELDROW_DESC32(ICLASS_ALU64" 0110 -------- PP------ --------","[#6] Rd=#u10 ")
   2055 DEF_ENC32(F2_sfimm_p,     ICLASS_ALU64" 0110   00i ----- PPiiiiii iiiddddd")
   2056 DEF_ENC32(F2_sfimm_n,     ICLASS_ALU64" 0110   01i ----- PPiiiiii iiiddddd")
   2057 
   2058 
   2059 DEF_FIELDROW_DESC32(ICLASS_ALU64" 0111 -------- PP------ --------","[#7] Rd=(Rs,Rt,#u6)")
   2060 DEF_ENC32(M4_mpyrr_addi,  ICLASS_ALU64" 0111   0ii sssss PPittttt iiiddddd")
   2061 
   2062 
   2063 DEF_FIELDROW_DESC32(ICLASS_ALU64" 1000 -------- PP------ --------","[#8] Rd=(Rs,#u6,#U6)")
   2064 DEF_ENC32(M4_mpyri_addi,  ICLASS_ALU64" 1000   Iii sssss PPiddddd iiiIIIII")
   2065 
   2066 
   2067 DEF_FIELDROW_DESC32(ICLASS_ALU64" 1001 -------- PP------ --------","[#9] Rdd=#u10 ")
   2068 DEF_ENC32(F2_dfimm_p,     ICLASS_ALU64" 1001   00i ----- PPiiiiii iiiddddd")
   2069 DEF_ENC32(F2_dfimm_n,     ICLASS_ALU64" 1001   01i ----- PPiiiiii iiiddddd")
   2070 
   2071 
   2072 DEF_FIELDROW_DESC32(ICLASS_ALU64" 1010 -------- PP------ --------","[#10] Rx=(Rs,Rx,#s10)")
   2073 DEF_ENC32(S4_or_andix,    ICLASS_ALU64" 1010   01i xxxxx PPiiiiii iiiuuuuu")
   2074 DEF_ENC32(S4_or_andi,     ICLASS_ALU64" 1010   00i sssss PPiiiiii iiixxxxx")
   2075 DEF_ENC32(S4_or_ori,      ICLASS_ALU64" 1010   10i sssss PPiiiiii iiixxxxx")
   2076 
   2077 
   2078 DEF_FIELDROW_DESC32(ICLASS_ALU64" 1011 -------- PP------ --------","[#11] Rd=(Rs,Rd,#s6)")
   2079 DEF_ENC32(S4_addaddi,     ICLASS_ALU64" 1011   0ii sssss PPiddddd iiiuuuuu")
   2080 DEF_ENC32(S4_subaddi,     ICLASS_ALU64" 1011   1ii sssss PPiddddd iiiuuuuu")
   2081 
   2082 
   2083 DEF_FIELDROW_DESC32(ICLASS_ALU64"     1100 -------- PP------ --------","[#12] Pd=(Rss,#s8)")
   2084 DEF_ENC32(A4_vcmpbeqi,   ICLASS_ALU64"1100 000sssss PP-iiiii iii00-dd")
   2085 DEF_ENC32(A4_vcmpbgti,   ICLASS_ALU64"1100 001sssss PP-iiiii iii00-dd")
   2086 DEF_ENC32(A4_vcmpbgtui,  ICLASS_ALU64"1100 010sssss PP-0iiii iii00-dd")
   2087 DEF_ENC32(A4_vcmpheqi,   ICLASS_ALU64"1100 000sssss PP-iiiii iii01-dd")
   2088 DEF_ENC32(A4_vcmphgti,   ICLASS_ALU64"1100 001sssss PP-iiiii iii01-dd")
   2089 DEF_ENC32(A4_vcmphgtui,  ICLASS_ALU64"1100 010sssss PP-0iiii iii01-dd")
   2090 DEF_ENC32(A4_vcmpweqi,   ICLASS_ALU64"1100 000sssss PP-iiiii iii10-dd")
   2091 DEF_ENC32(A4_vcmpwgti,   ICLASS_ALU64"1100 001sssss PP-iiiii iii10-dd")
   2092 DEF_ENC32(A4_vcmpwgtui,  ICLASS_ALU64"1100 010sssss PP-0iiii iii10-dd")
   2093 
   2094 DEF_ENC32(F2_dfclass,    ICLASS_ALU64"1100 100sssss PP-000ii iii10-dd")
   2095 
   2096 
   2097 DEF_FIELDROW_DESC32(ICLASS_ALU64" 1101 -------- PP------ --------","[#13] Pd=(Rs,#s8)")
   2098 DEF_ENC32(A4_cmpbeqi,    ICLASS_ALU64"1101 -00sssss PP-iiiii iii00-dd")
   2099 DEF_ENC32(A4_cmpbgti,    ICLASS_ALU64"1101 -01sssss PP-iiiii iii00-dd")
   2100 DEF_ENC32(A4_cmpbgtui,   ICLASS_ALU64"1101 -10sssss PP-0iiii iii00-dd")
   2101 DEF_ENC32(A4_cmpheqi,    ICLASS_ALU64"1101 -00sssss PP-iiiii iii01-dd")
   2102 DEF_ENC32(A4_cmphgti,    ICLASS_ALU64"1101 -01sssss PP-iiiii iii01-dd")
   2103 DEF_ENC32(A4_cmphgtui,   ICLASS_ALU64"1101 -10sssss PP-0iiii iii01-dd")
   2104 
   2105 
   2106 DEF_FIELDROW_DESC32(ICLASS_ALU64" 1110 -------- PP------ --------","[#14] Rx=(#u9,op(Rx,#u5))")
   2107 
   2108 #define OP_OPI_RI(TAG,OPB)\
   2109 DEF_ENC32(S4_andi_##TAG##_ri,ICLASS_ALU64" 1110 iiixxxxx PPiIIIII iii"OPB"i00-")\
   2110 DEF_ENC32(S4_ori_##TAG##_ri, ICLASS_ALU64" 1110 iiixxxxx PPiIIIII iii"OPB"i01-")\
   2111 DEF_ENC32(S4_addi_##TAG##_ri,ICLASS_ALU64" 1110 iiixxxxx PPiIIIII iii"OPB"i10-")\
   2112 DEF_ENC32(S4_subi_##TAG##_ri,ICLASS_ALU64" 1110 iiixxxxx PPiIIIII iii"OPB"i11-")
   2113 
   2114 OP_OPI_RI(asl,"0")
   2115 OP_OPI_RI(lsr,"1")
   2116 
   2117 
   2118 DEF_FIELDROW_DESC32(ICLASS_ALU64" 1111 -------- PP------ --------","[#15] Rd=(Rs,Ru,#u6:2)")
   2119 DEF_ENC32(M4_mpyri_addr_u2, ICLASS_ALU64" 1111   0ii sssss PPiddddd iiiuuuuu")
   2120 DEF_ENC32(M4_mpyri_addr,    ICLASS_ALU64" 1111   1ii sssss PPiddddd iiiuuuuu")