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")