1 // Copyright 2015, VIXL authors 2 // All rights reserved. 3 // 4 // Redistribution and use in source and binary forms, with or without 5 // modification, are permitted provided that the following conditions are met: 6 // 7 // * Redistributions of source code must retain the above copyright notice, 8 // this list of conditions and the following disclaimer. 9 // * Redistributions in binary form must reproduce the above copyright notice, 10 // this list of conditions and the following disclaimer in the documentation 11 // and/or other materials provided with the distribution. 12 // * Neither the name of ARM Limited nor the names of its contributors may be 13 // used to endorse or promote products derived from this software without 14 // specific prior written permission. 15 // 16 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS CONTRIBUTORS "AS IS" AND 17 // ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 18 // WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 19 // DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE 20 // FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 21 // DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 22 // SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 23 // CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 24 // OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 25 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 26 27 28 // --------------------------------------------------------------------- 29 // This file is auto generated using tools/generate_simulator_traces.py. 30 // 31 // PLEASE DO NOT EDIT. 32 // --------------------------------------------------------------------- 33 34 #ifndef VIXL_ASSEMBLER_COND_RD_RN_RM_SMMUL_A32_H_ 35 #define VIXL_ASSEMBLER_COND_RD_RN_RM_SMMUL_A32_H_ 36 37 const byte kInstruction_smmul_hi_r1_r9_r5[] = { 38 0x19, 0xf5, 0x51, 0x87 // smmul hi r1 r9 r5 39 }; 40 const byte kInstruction_smmul_pl_r8_r6_r2[] = { 41 0x16, 0xf2, 0x58, 0x57 // smmul pl r8 r6 r2 42 }; 43 const byte kInstruction_smmul_hi_r5_r8_r2[] = { 44 0x18, 0xf2, 0x55, 0x87 // smmul hi r5 r8 r2 45 }; 46 const byte kInstruction_smmul_vc_r9_r2_r7[] = { 47 0x12, 0xf7, 0x59, 0x77 // smmul vc r9 r2 r7 48 }; 49 const byte kInstruction_smmul_lt_r4_r6_r3[] = { 50 0x16, 0xf3, 0x54, 0xb7 // smmul lt r4 r6 r3 51 }; 52 const byte kInstruction_smmul_le_r11_r6_r2[] = { 53 0x16, 0xf2, 0x5b, 0xd7 // smmul le r11 r6 r2 54 }; 55 const byte kInstruction_smmul_cc_r8_r14_r4[] = { 56 0x1e, 0xf4, 0x58, 0x37 // smmul cc r8 r14 r4 57 }; 58 const byte kInstruction_smmul_le_r5_r14_r6[] = { 59 0x1e, 0xf6, 0x55, 0xd7 // smmul le r5 r14 r6 60 }; 61 const byte kInstruction_smmul_lt_r6_r1_r0[] = { 62 0x11, 0xf0, 0x56, 0xb7 // smmul lt r6 r1 r0 63 }; 64 const byte kInstruction_smmul_lt_r5_r0_r9[] = { 65 0x10, 0xf9, 0x55, 0xb7 // smmul lt r5 r0 r9 66 }; 67 const byte kInstruction_smmul_le_r8_r12_r7[] = { 68 0x1c, 0xf7, 0x58, 0xd7 // smmul le r8 r12 r7 69 }; 70 const byte kInstruction_smmul_eq_r7_r14_r6[] = { 71 0x1e, 0xf6, 0x57, 0x07 // smmul eq r7 r14 r6 72 }; 73 const byte kInstruction_smmul_cs_r7_r4_r6[] = { 74 0x14, 0xf6, 0x57, 0x27 // smmul cs r7 r4 r6 75 }; 76 const byte kInstruction_smmul_gt_r9_r6_r9[] = { 77 0x16, 0xf9, 0x59, 0xc7 // smmul gt r9 r6 r9 78 }; 79 const byte kInstruction_smmul_ne_r13_r9_r1[] = { 80 0x19, 0xf1, 0x5d, 0x17 // smmul ne r13 r9 r1 81 }; 82 const byte kInstruction_smmul_ge_r13_r1_r13[] = { 83 0x11, 0xfd, 0x5d, 0xa7 // smmul ge r13 r1 r13 84 }; 85 const byte kInstruction_smmul_ls_r8_r10_r2[] = { 86 0x1a, 0xf2, 0x58, 0x97 // smmul ls r8 r10 r2 87 }; 88 const byte kInstruction_smmul_hi_r0_r13_r5[] = { 89 0x1d, 0xf5, 0x50, 0x87 // smmul hi r0 r13 r5 90 }; 91 const byte kInstruction_smmul_pl_r13_r7_r8[] = { 92 0x17, 0xf8, 0x5d, 0x57 // smmul pl r13 r7 r8 93 }; 94 const byte kInstruction_smmul_ge_r4_r13_r11[] = { 95 0x1d, 0xfb, 0x54, 0xa7 // smmul ge r4 r13 r11 96 }; 97 const byte kInstruction_smmul_cs_r5_r10_r5[] = { 98 0x1a, 0xf5, 0x55, 0x27 // smmul cs r5 r10 r5 99 }; 100 const byte kInstruction_smmul_cs_r5_r4_r3[] = { 101 0x14, 0xf3, 0x55, 0x27 // smmul cs r5 r4 r3 102 }; 103 const byte kInstruction_smmul_ls_r6_r14_r8[] = { 104 0x1e, 0xf8, 0x56, 0x97 // smmul ls r6 r14 r8 105 }; 106 const byte kInstruction_smmul_vs_r3_r8_r6[] = { 107 0x18, 0xf6, 0x53, 0x67 // smmul vs r3 r8 r6 108 }; 109 const byte kInstruction_smmul_vc_r7_r12_r3[] = { 110 0x1c, 0xf3, 0x57, 0x77 // smmul vc r7 r12 r3 111 }; 112 const byte kInstruction_smmul_ge_r1_r4_r1[] = { 113 0x14, 0xf1, 0x51, 0xa7 // smmul ge r1 r4 r1 114 }; 115 const byte kInstruction_smmul_cc_r4_r7_r10[] = { 116 0x17, 0xfa, 0x54, 0x37 // smmul cc r4 r7 r10 117 }; 118 const byte kInstruction_smmul_cc_r2_r0_r13[] = { 119 0x10, 0xfd, 0x52, 0x37 // smmul cc r2 r0 r13 120 }; 121 const byte kInstruction_smmul_vs_r9_r6_r8[] = { 122 0x16, 0xf8, 0x59, 0x67 // smmul vs r9 r6 r8 123 }; 124 const byte kInstruction_smmul_cs_r14_r11_r13[] = { 125 0x1b, 0xfd, 0x5e, 0x27 // smmul cs r14 r11 r13 126 }; 127 const byte kInstruction_smmul_pl_r5_r8_r4[] = { 128 0x18, 0xf4, 0x55, 0x57 // smmul pl r5 r8 r4 129 }; 130 const byte kInstruction_smmul_pl_r2_r3_r7[] = { 131 0x13, 0xf7, 0x52, 0x57 // smmul pl r2 r3 r7 132 }; 133 const byte kInstruction_smmul_cs_r7_r12_r14[] = { 134 0x1c, 0xfe, 0x57, 0x27 // smmul cs r7 r12 r14 135 }; 136 const byte kInstruction_smmul_hi_r6_r6_r1[] = { 137 0x16, 0xf1, 0x56, 0x87 // smmul hi r6 r6 r1 138 }; 139 const byte kInstruction_smmul_cc_r6_r9_r6[] = { 140 0x19, 0xf6, 0x56, 0x37 // smmul cc r6 r9 r6 141 }; 142 const byte kInstruction_smmul_ne_r12_r12_r0[] = { 143 0x1c, 0xf0, 0x5c, 0x17 // smmul ne r12 r12 r0 144 }; 145 const byte kInstruction_smmul_cc_r9_r3_r8[] = { 146 0x13, 0xf8, 0x59, 0x37 // smmul cc r9 r3 r8 147 }; 148 const byte kInstruction_smmul_mi_r13_r6_r1[] = { 149 0x16, 0xf1, 0x5d, 0x47 // smmul mi r13 r6 r1 150 }; 151 const byte kInstruction_smmul_lt_r4_r8_r6[] = { 152 0x18, 0xf6, 0x54, 0xb7 // smmul lt r4 r8 r6 153 }; 154 const byte kInstruction_smmul_hi_r11_r5_r9[] = { 155 0x15, 0xf9, 0x5b, 0x87 // smmul hi r11 r5 r9 156 }; 157 const byte kInstruction_smmul_cc_r6_r10_r6[] = { 158 0x1a, 0xf6, 0x56, 0x37 // smmul cc r6 r10 r6 159 }; 160 const byte kInstruction_smmul_eq_r10_r10_r5[] = { 161 0x1a, 0xf5, 0x5a, 0x07 // smmul eq r10 r10 r5 162 }; 163 const byte kInstruction_smmul_al_r5_r4_r11[] = { 164 0x14, 0xfb, 0x55, 0xe7 // smmul al r5 r4 r11 165 }; 166 const byte kInstruction_smmul_pl_r11_r11_r2[] = { 167 0x1b, 0xf2, 0x5b, 0x57 // smmul pl r11 r11 r2 168 }; 169 const byte kInstruction_smmul_ls_r6_r14_r12[] = { 170 0x1e, 0xfc, 0x56, 0x97 // smmul ls r6 r14 r12 171 }; 172 const byte kInstruction_smmul_vc_r7_r7_r2[] = { 173 0x17, 0xf2, 0x57, 0x77 // smmul vc r7 r7 r2 174 }; 175 const byte kInstruction_smmul_eq_r10_r8_r4[] = { 176 0x18, 0xf4, 0x5a, 0x07 // smmul eq r10 r8 r4 177 }; 178 const byte kInstruction_smmul_al_r14_r7_r2[] = { 179 0x17, 0xf2, 0x5e, 0xe7 // smmul al r14 r7 r2 180 }; 181 const byte kInstruction_smmul_cs_r3_r11_r10[] = { 182 0x1b, 0xfa, 0x53, 0x27 // smmul cs r3 r11 r10 183 }; 184 const byte kInstruction_smmul_ls_r11_r4_r0[] = { 185 0x14, 0xf0, 0x5b, 0x97 // smmul ls r11 r4 r0 186 }; 187 const byte kInstruction_smmul_hi_r11_r8_r9[] = { 188 0x18, 0xf9, 0x5b, 0x87 // smmul hi r11 r8 r9 189 }; 190 const byte kInstruction_smmul_vs_r2_r14_r13[] = { 191 0x1e, 0xfd, 0x52, 0x67 // smmul vs r2 r14 r13 192 }; 193 const byte kInstruction_smmul_al_r1_r13_r9[] = { 194 0x1d, 0xf9, 0x51, 0xe7 // smmul al r1 r13 r9 195 }; 196 const byte kInstruction_smmul_eq_r3_r9_r13[] = { 197 0x19, 0xfd, 0x53, 0x07 // smmul eq r3 r9 r13 198 }; 199 const byte kInstruction_smmul_ge_r10_r3_r13[] = { 200 0x13, 0xfd, 0x5a, 0xa7 // smmul ge r10 r3 r13 201 }; 202 const byte kInstruction_smmul_pl_r8_r5_r10[] = { 203 0x15, 0xfa, 0x58, 0x57 // smmul pl r8 r5 r10 204 }; 205 const byte kInstruction_smmul_vc_r8_r11_r6[] = { 206 0x1b, 0xf6, 0x58, 0x77 // smmul vc r8 r11 r6 207 }; 208 const byte kInstruction_smmul_eq_r0_r0_r5[] = { 209 0x10, 0xf5, 0x50, 0x07 // smmul eq r0 r0 r5 210 }; 211 const byte kInstruction_smmul_ne_r6_r5_r8[] = { 212 0x15, 0xf8, 0x56, 0x17 // smmul ne r6 r5 r8 213 }; 214 const byte kInstruction_smmul_hi_r5_r13_r3[] = { 215 0x1d, 0xf3, 0x55, 0x87 // smmul hi r5 r13 r3 216 }; 217 const byte kInstruction_smmul_ne_r11_r14_r14[] = { 218 0x1e, 0xfe, 0x5b, 0x17 // smmul ne r11 r14 r14 219 }; 220 const byte kInstruction_smmul_mi_r1_r0_r6[] = { 221 0x10, 0xf6, 0x51, 0x47 // smmul mi r1 r0 r6 222 }; 223 const byte kInstruction_smmul_le_r14_r8_r2[] = { 224 0x18, 0xf2, 0x5e, 0xd7 // smmul le r14 r8 r2 225 }; 226 const byte kInstruction_smmul_eq_r9_r6_r5[] = { 227 0x16, 0xf5, 0x59, 0x07 // smmul eq r9 r6 r5 228 }; 229 const byte kInstruction_smmul_eq_r11_r0_r13[] = { 230 0x10, 0xfd, 0x5b, 0x07 // smmul eq r11 r0 r13 231 }; 232 const byte kInstruction_smmul_pl_r4_r5_r14[] = { 233 0x15, 0xfe, 0x54, 0x57 // smmul pl r4 r5 r14 234 }; 235 const byte kInstruction_smmul_cs_r13_r5_r13[] = { 236 0x15, 0xfd, 0x5d, 0x27 // smmul cs r13 r5 r13 237 }; 238 const byte kInstruction_smmul_mi_r0_r13_r8[] = { 239 0x1d, 0xf8, 0x50, 0x47 // smmul mi r0 r13 r8 240 }; 241 const byte kInstruction_smmul_lt_r2_r13_r3[] = { 242 0x1d, 0xf3, 0x52, 0xb7 // smmul lt r2 r13 r3 243 }; 244 const byte kInstruction_smmul_ls_r8_r1_r11[] = { 245 0x11, 0xfb, 0x58, 0x97 // smmul ls r8 r1 r11 246 }; 247 const byte kInstruction_smmul_vc_r14_r11_r8[] = { 248 0x1b, 0xf8, 0x5e, 0x77 // smmul vc r14 r11 r8 249 }; 250 const byte kInstruction_smmul_lt_r4_r13_r12[] = { 251 0x1d, 0xfc, 0x54, 0xb7 // smmul lt r4 r13 r12 252 }; 253 const byte kInstruction_smmul_eq_r2_r1_r14[] = { 254 0x11, 0xfe, 0x52, 0x07 // smmul eq r2 r1 r14 255 }; 256 const byte kInstruction_smmul_eq_r9_r4_r14[] = { 257 0x14, 0xfe, 0x59, 0x07 // smmul eq r9 r4 r14 258 }; 259 const byte kInstruction_smmul_hi_r10_r6_r13[] = { 260 0x16, 0xfd, 0x5a, 0x87 // smmul hi r10 r6 r13 261 }; 262 const byte kInstruction_smmul_ge_r12_r9_r4[] = { 263 0x19, 0xf4, 0x5c, 0xa7 // smmul ge r12 r9 r4 264 }; 265 const byte kInstruction_smmul_le_r9_r11_r14[] = { 266 0x1b, 0xfe, 0x59, 0xd7 // smmul le r9 r11 r14 267 }; 268 const byte kInstruction_smmul_ls_r0_r9_r5[] = { 269 0x19, 0xf5, 0x50, 0x97 // smmul ls r0 r9 r5 270 }; 271 const byte kInstruction_smmul_mi_r2_r3_r8[] = { 272 0x13, 0xf8, 0x52, 0x47 // smmul mi r2 r3 r8 273 }; 274 const byte kInstruction_smmul_ne_r14_r10_r14[] = { 275 0x1a, 0xfe, 0x5e, 0x17 // smmul ne r14 r10 r14 276 }; 277 const byte kInstruction_smmul_eq_r6_r2_r10[] = { 278 0x12, 0xfa, 0x56, 0x07 // smmul eq r6 r2 r10 279 }; 280 const byte kInstruction_smmul_lt_r11_r0_r12[] = { 281 0x10, 0xfc, 0x5b, 0xb7 // smmul lt r11 r0 r12 282 }; 283 const byte kInstruction_smmul_ne_r1_r12_r10[] = { 284 0x1c, 0xfa, 0x51, 0x17 // smmul ne r1 r12 r10 285 }; 286 const byte kInstruction_smmul_cc_r1_r0_r2[] = { 287 0x10, 0xf2, 0x51, 0x37 // smmul cc r1 r0 r2 288 }; 289 const byte kInstruction_smmul_al_r5_r5_r7[] = { 290 0x15, 0xf7, 0x55, 0xe7 // smmul al r5 r5 r7 291 }; 292 const byte kInstruction_smmul_hi_r7_r13_r1[] = { 293 0x1d, 0xf1, 0x57, 0x87 // smmul hi r7 r13 r1 294 }; 295 const byte kInstruction_smmul_cs_r4_r4_r9[] = { 296 0x14, 0xf9, 0x54, 0x27 // smmul cs r4 r4 r9 297 }; 298 const byte kInstruction_smmul_eq_r14_r4_r14[] = { 299 0x14, 0xfe, 0x5e, 0x07 // smmul eq r14 r4 r14 300 }; 301 const byte kInstruction_smmul_vs_r10_r5_r14[] = { 302 0x15, 0xfe, 0x5a, 0x67 // smmul vs r10 r5 r14 303 }; 304 const byte kInstruction_smmul_gt_r4_r3_r11[] = { 305 0x13, 0xfb, 0x54, 0xc7 // smmul gt r4 r3 r11 306 }; 307 const byte kInstruction_smmul_ne_r14_r10_r12[] = { 308 0x1a, 0xfc, 0x5e, 0x17 // smmul ne r14 r10 r12 309 }; 310 const byte kInstruction_smmul_vs_r2_r11_r0[] = { 311 0x1b, 0xf0, 0x52, 0x67 // smmul vs r2 r11 r0 312 }; 313 const byte kInstruction_smmul_ge_r5_r12_r7[] = { 314 0x1c, 0xf7, 0x55, 0xa7 // smmul ge r5 r12 r7 315 }; 316 const byte kInstruction_smmul_mi_r7_r14_r6[] = { 317 0x1e, 0xf6, 0x57, 0x47 // smmul mi r7 r14 r6 318 }; 319 const byte kInstruction_smmul_gt_r8_r3_r8[] = { 320 0x13, 0xf8, 0x58, 0xc7 // smmul gt r8 r3 r8 321 }; 322 const byte kInstruction_smmul_hi_r9_r14_r3[] = { 323 0x1e, 0xf3, 0x59, 0x87 // smmul hi r9 r14 r3 324 }; 325 const byte kInstruction_smmul_vc_r2_r11_r2[] = { 326 0x1b, 0xf2, 0x52, 0x77 // smmul vc r2 r11 r2 327 }; 328 const byte kInstruction_smmul_hi_r11_r7_r12[] = { 329 0x17, 0xfc, 0x5b, 0x87 // smmul hi r11 r7 r12 330 }; 331 const byte kInstruction_smmul_cs_r6_r4_r11[] = { 332 0x14, 0xfb, 0x56, 0x27 // smmul cs r6 r4 r11 333 }; 334 const byte kInstruction_smmul_cs_r12_r5_r9[] = { 335 0x15, 0xf9, 0x5c, 0x27 // smmul cs r12 r5 r9 336 }; 337 const byte kInstruction_smmul_ls_r5_r10_r5[] = { 338 0x1a, 0xf5, 0x55, 0x97 // smmul ls r5 r10 r5 339 }; 340 const byte kInstruction_smmul_ls_r0_r9_r13[] = { 341 0x19, 0xfd, 0x50, 0x97 // smmul ls r0 r9 r13 342 }; 343 const byte kInstruction_smmul_lt_r3_r3_r5[] = { 344 0x13, 0xf5, 0x53, 0xb7 // smmul lt r3 r3 r5 345 }; 346 const byte kInstruction_smmul_mi_r0_r12_r8[] = { 347 0x1c, 0xf8, 0x50, 0x47 // smmul mi r0 r12 r8 348 }; 349 const byte kInstruction_smmul_pl_r3_r12_r12[] = { 350 0x1c, 0xfc, 0x53, 0x57 // smmul pl r3 r12 r12 351 }; 352 const byte kInstruction_smmul_eq_r8_r12_r5[] = { 353 0x1c, 0xf5, 0x58, 0x07 // smmul eq r8 r12 r5 354 }; 355 const byte kInstruction_smmul_cc_r7_r8_r1[] = { 356 0x18, 0xf1, 0x57, 0x37 // smmul cc r7 r8 r1 357 }; 358 const byte kInstruction_smmul_hi_r2_r13_r10[] = { 359 0x1d, 0xfa, 0x52, 0x87 // smmul hi r2 r13 r10 360 }; 361 const byte kInstruction_smmul_al_r7_r10_r10[] = { 362 0x1a, 0xfa, 0x57, 0xe7 // smmul al r7 r10 r10 363 }; 364 const byte kInstruction_smmul_vc_r1_r12_r2[] = { 365 0x1c, 0xf2, 0x51, 0x77 // smmul vc r1 r12 r2 366 }; 367 const byte kInstruction_smmul_cc_r8_r5_r8[] = { 368 0x15, 0xf8, 0x58, 0x37 // smmul cc r8 r5 r8 369 }; 370 const byte kInstruction_smmul_ls_r3_r7_r9[] = { 371 0x17, 0xf9, 0x53, 0x97 // smmul ls r3 r7 r9 372 }; 373 const byte kInstruction_smmul_al_r8_r10_r8[] = { 374 0x1a, 0xf8, 0x58, 0xe7 // smmul al r8 r10 r8 375 }; 376 const byte kInstruction_smmul_lt_r4_r12_r10[] = { 377 0x1c, 0xfa, 0x54, 0xb7 // smmul lt r4 r12 r10 378 }; 379 const byte kInstruction_smmul_ge_r10_r5_r11[] = { 380 0x15, 0xfb, 0x5a, 0xa7 // smmul ge r10 r5 r11 381 }; 382 const byte kInstruction_smmul_ls_r3_r14_r4[] = { 383 0x1e, 0xf4, 0x53, 0x97 // smmul ls r3 r14 r4 384 }; 385 const byte kInstruction_smmul_hi_r3_r6_r12[] = { 386 0x16, 0xfc, 0x53, 0x87 // smmul hi r3 r6 r12 387 }; 388 const byte kInstruction_smmul_hi_r6_r0_r4[] = { 389 0x10, 0xf4, 0x56, 0x87 // smmul hi r6 r0 r4 390 }; 391 const byte kInstruction_smmul_al_r11_r6_r0[] = { 392 0x16, 0xf0, 0x5b, 0xe7 // smmul al r11 r6 r0 393 }; 394 const byte kInstruction_smmul_mi_r3_r1_r9[] = { 395 0x11, 0xf9, 0x53, 0x47 // smmul mi r3 r1 r9 396 }; 397 const byte kInstruction_smmul_mi_r12_r13_r0[] = { 398 0x1d, 0xf0, 0x5c, 0x47 // smmul mi r12 r13 r0 399 }; 400 const byte kInstruction_smmul_le_r1_r2_r5[] = { 401 0x12, 0xf5, 0x51, 0xd7 // smmul le r1 r2 r5 402 }; 403 const byte kInstruction_smmul_hi_r4_r3_r14[] = { 404 0x13, 0xfe, 0x54, 0x87 // smmul hi r4 r3 r14 405 }; 406 const byte kInstruction_smmul_eq_r6_r11_r11[] = { 407 0x1b, 0xfb, 0x56, 0x07 // smmul eq r6 r11 r11 408 }; 409 const byte kInstruction_smmul_cc_r14_r11_r14[] = { 410 0x1b, 0xfe, 0x5e, 0x37 // smmul cc r14 r11 r14 411 }; 412 const byte kInstruction_smmul_hi_r4_r10_r0[] = { 413 0x1a, 0xf0, 0x54, 0x87 // smmul hi r4 r10 r0 414 }; 415 const byte kInstruction_smmul_cc_r7_r11_r1[] = { 416 0x1b, 0xf1, 0x57, 0x37 // smmul cc r7 r11 r1 417 }; 418 const byte kInstruction_smmul_mi_r14_r6_r10[] = { 419 0x16, 0xfa, 0x5e, 0x47 // smmul mi r14 r6 r10 420 }; 421 const byte kInstruction_smmul_eq_r2_r0_r11[] = { 422 0x10, 0xfb, 0x52, 0x07 // smmul eq r2 r0 r11 423 }; 424 const byte kInstruction_smmul_mi_r13_r5_r12[] = { 425 0x15, 0xfc, 0x5d, 0x47 // smmul mi r13 r5 r12 426 }; 427 const byte kInstruction_smmul_eq_r2_r12_r5[] = { 428 0x1c, 0xf5, 0x52, 0x07 // smmul eq r2 r12 r5 429 }; 430 const byte kInstruction_smmul_le_r12_r0_r2[] = { 431 0x10, 0xf2, 0x5c, 0xd7 // smmul le r12 r0 r2 432 }; 433 const byte kInstruction_smmul_vc_r10_r10_r9[] = { 434 0x1a, 0xf9, 0x5a, 0x77 // smmul vc r10 r10 r9 435 }; 436 const byte kInstruction_smmul_ls_r11_r11_r8[] = { 437 0x1b, 0xf8, 0x5b, 0x97 // smmul ls r11 r11 r8 438 }; 439 const byte kInstruction_smmul_hi_r10_r11_r9[] = { 440 0x1b, 0xf9, 0x5a, 0x87 // smmul hi r10 r11 r9 441 }; 442 const byte kInstruction_smmul_vs_r7_r12_r14[] = { 443 0x1c, 0xfe, 0x57, 0x67 // smmul vs r7 r12 r14 444 }; 445 const byte kInstruction_smmul_gt_r11_r14_r12[] = { 446 0x1e, 0xfc, 0x5b, 0xc7 // smmul gt r11 r14 r12 447 }; 448 const byte kInstruction_smmul_vs_r0_r12_r8[] = { 449 0x1c, 0xf8, 0x50, 0x67 // smmul vs r0 r12 r8 450 }; 451 const byte kInstruction_smmul_al_r0_r5_r7[] = { 452 0x15, 0xf7, 0x50, 0xe7 // smmul al r0 r5 r7 453 }; 454 const byte kInstruction_smmul_hi_r5_r13_r8[] = { 455 0x1d, 0xf8, 0x55, 0x87 // smmul hi r5 r13 r8 456 }; 457 const byte kInstruction_smmul_le_r9_r9_r7[] = { 458 0x19, 0xf7, 0x59, 0xd7 // smmul le r9 r9 r7 459 }; 460 const byte kInstruction_smmul_cc_r4_r9_r5[] = { 461 0x19, 0xf5, 0x54, 0x37 // smmul cc r4 r9 r5 462 }; 463 const byte kInstruction_smmul_vs_r8_r1_r3[] = { 464 0x11, 0xf3, 0x58, 0x67 // smmul vs r8 r1 r3 465 }; 466 const byte kInstruction_smmul_cc_r0_r10_r12[] = { 467 0x1a, 0xfc, 0x50, 0x37 // smmul cc r0 r10 r12 468 }; 469 const byte kInstruction_smmul_eq_r7_r14_r0[] = { 470 0x1e, 0xf0, 0x57, 0x07 // smmul eq r7 r14 r0 471 }; 472 const byte kInstruction_smmul_vs_r12_r9_r11[] = { 473 0x19, 0xfb, 0x5c, 0x67 // smmul vs r12 r9 r11 474 }; 475 const byte kInstruction_smmul_gt_r5_r9_r11[] = { 476 0x19, 0xfb, 0x55, 0xc7 // smmul gt r5 r9 r11 477 }; 478 const byte kInstruction_smmul_cs_r14_r13_r7[] = { 479 0x1d, 0xf7, 0x5e, 0x27 // smmul cs r14 r13 r7 480 }; 481 const byte kInstruction_smmul_mi_r11_r3_r10[] = { 482 0x13, 0xfa, 0x5b, 0x47 // smmul mi r11 r3 r10 483 }; 484 const byte kInstruction_smmul_hi_r11_r8_r12[] = { 485 0x18, 0xfc, 0x5b, 0x87 // smmul hi r11 r8 r12 486 }; 487 const byte kInstruction_smmul_cs_r3_r8_r13[] = { 488 0x18, 0xfd, 0x53, 0x27 // smmul cs r3 r8 r13 489 }; 490 const byte kInstruction_smmul_pl_r10_r12_r6[] = { 491 0x1c, 0xf6, 0x5a, 0x57 // smmul pl r10 r12 r6 492 }; 493 const byte kInstruction_smmul_vc_r7_r3_r2[] = { 494 0x13, 0xf2, 0x57, 0x77 // smmul vc r7 r3 r2 495 }; 496 const byte kInstruction_smmul_mi_r9_r0_r8[] = { 497 0x10, 0xf8, 0x59, 0x47 // smmul mi r9 r0 r8 498 }; 499 const byte kInstruction_smmul_eq_r2_r13_r7[] = { 500 0x1d, 0xf7, 0x52, 0x07 // smmul eq r2 r13 r7 501 }; 502 const byte kInstruction_smmul_ne_r2_r14_r0[] = { 503 0x1e, 0xf0, 0x52, 0x17 // smmul ne r2 r14 r0 504 }; 505 const byte kInstruction_smmul_vs_r4_r10_r0[] = { 506 0x1a, 0xf0, 0x54, 0x67 // smmul vs r4 r10 r0 507 }; 508 const byte kInstruction_smmul_ls_r0_r2_r2[] = { 509 0x12, 0xf2, 0x50, 0x97 // smmul ls r0 r2 r2 510 }; 511 const byte kInstruction_smmul_cc_r1_r6_r0[] = { 512 0x16, 0xf0, 0x51, 0x37 // smmul cc r1 r6 r0 513 }; 514 const byte kInstruction_smmul_lt_r12_r0_r8[] = { 515 0x10, 0xf8, 0x5c, 0xb7 // smmul lt r12 r0 r8 516 }; 517 const byte kInstruction_smmul_cc_r9_r3_r14[] = { 518 0x13, 0xfe, 0x59, 0x37 // smmul cc r9 r3 r14 519 }; 520 const byte kInstruction_smmul_vs_r7_r9_r1[] = { 521 0x19, 0xf1, 0x57, 0x67 // smmul vs r7 r9 r1 522 }; 523 const byte kInstruction_smmul_eq_r11_r9_r14[] = { 524 0x19, 0xfe, 0x5b, 0x07 // smmul eq r11 r9 r14 525 }; 526 const byte kInstruction_smmul_pl_r6_r10_r4[] = { 527 0x1a, 0xf4, 0x56, 0x57 // smmul pl r6 r10 r4 528 }; 529 const byte kInstruction_smmul_ne_r8_r5_r6[] = { 530 0x15, 0xf6, 0x58, 0x17 // smmul ne r8 r5 r6 531 }; 532 const byte kInstruction_smmul_cs_r0_r6_r2[] = { 533 0x16, 0xf2, 0x50, 0x27 // smmul cs r0 r6 r2 534 }; 535 const byte kInstruction_smmul_eq_r11_r12_r4[] = { 536 0x1c, 0xf4, 0x5b, 0x07 // smmul eq r11 r12 r4 537 }; 538 const byte kInstruction_smmul_lt_r14_r3_r14[] = { 539 0x13, 0xfe, 0x5e, 0xb7 // smmul lt r14 r3 r14 540 }; 541 const byte kInstruction_smmul_le_r7_r12_r14[] = { 542 0x1c, 0xfe, 0x57, 0xd7 // smmul le r7 r12 r14 543 }; 544 const byte kInstruction_smmul_hi_r2_r9_r9[] = { 545 0x19, 0xf9, 0x52, 0x87 // smmul hi r2 r9 r9 546 }; 547 const byte kInstruction_smmul_ne_r8_r1_r0[] = { 548 0x11, 0xf0, 0x58, 0x17 // smmul ne r8 r1 r0 549 }; 550 const byte kInstruction_smmul_cc_r5_r11_r2[] = { 551 0x1b, 0xf2, 0x55, 0x37 // smmul cc r5 r11 r2 552 }; 553 const byte kInstruction_smmul_hi_r0_r1_r2[] = { 554 0x11, 0xf2, 0x50, 0x87 // smmul hi r0 r1 r2 555 }; 556 const byte kInstruction_smmul_al_r4_r9_r4[] = { 557 0x19, 0xf4, 0x54, 0xe7 // smmul al r4 r9 r4 558 }; 559 const byte kInstruction_smmul_cs_r12_r7_r14[] = { 560 0x17, 0xfe, 0x5c, 0x27 // smmul cs r12 r7 r14 561 }; 562 const byte kInstruction_smmul_cc_r4_r12_r10[] = { 563 0x1c, 0xfa, 0x54, 0x37 // smmul cc r4 r12 r10 564 }; 565 const byte kInstruction_smmul_al_r3_r5_r10[] = { 566 0x15, 0xfa, 0x53, 0xe7 // smmul al r3 r5 r10 567 }; 568 const byte kInstruction_smmul_mi_r5_r3_r7[] = { 569 0x13, 0xf7, 0x55, 0x47 // smmul mi r5 r3 r7 570 }; 571 const byte kInstruction_smmul_ls_r10_r6_r2[] = { 572 0x16, 0xf2, 0x5a, 0x97 // smmul ls r10 r6 r2 573 }; 574 const byte kInstruction_smmul_mi_r0_r12_r11[] = { 575 0x1c, 0xfb, 0x50, 0x47 // smmul mi r0 r12 r11 576 }; 577 const byte kInstruction_smmul_vc_r12_r5_r6[] = { 578 0x15, 0xf6, 0x5c, 0x77 // smmul vc r12 r5 r6 579 }; 580 const byte kInstruction_smmul_cs_r3_r9_r4[] = { 581 0x19, 0xf4, 0x53, 0x27 // smmul cs r3 r9 r4 582 }; 583 const byte kInstruction_smmul_ls_r4_r9_r11[] = { 584 0x19, 0xfb, 0x54, 0x97 // smmul ls r4 r9 r11 585 }; 586 const byte kInstruction_smmul_le_r14_r8_r13[] = { 587 0x18, 0xfd, 0x5e, 0xd7 // smmul le r14 r8 r13 588 }; 589 const byte kInstruction_smmul_gt_r4_r10_r8[] = { 590 0x1a, 0xf8, 0x54, 0xc7 // smmul gt r4 r10 r8 591 }; 592 const byte kInstruction_smmul_al_r6_r9_r9[] = { 593 0x19, 0xf9, 0x56, 0xe7 // smmul al r6 r9 r9 594 }; 595 const byte kInstruction_smmul_ne_r8_r5_r12[] = { 596 0x15, 0xfc, 0x58, 0x17 // smmul ne r8 r5 r12 597 }; 598 const byte kInstruction_smmul_ne_r0_r4_r8[] = { 599 0x14, 0xf8, 0x50, 0x17 // smmul ne r0 r4 r8 600 }; 601 const byte kInstruction_smmul_mi_r7_r13_r3[] = { 602 0x1d, 0xf3, 0x57, 0x47 // smmul mi r7 r13 r3 603 }; 604 const byte kInstruction_smmul_cc_r11_r7_r0[] = { 605 0x17, 0xf0, 0x5b, 0x37 // smmul cc r11 r7 r0 606 }; 607 const byte kInstruction_smmul_hi_r1_r0_r12[] = { 608 0x10, 0xfc, 0x51, 0x87 // smmul hi r1 r0 r12 609 }; 610 const byte kInstruction_smmul_lt_r8_r9_r3[] = { 611 0x19, 0xf3, 0x58, 0xb7 // smmul lt r8 r9 r3 612 }; 613 const byte kInstruction_smmul_al_r0_r2_r1[] = { 614 0x12, 0xf1, 0x50, 0xe7 // smmul al r0 r2 r1 615 }; 616 const byte kInstruction_smmul_vs_r4_r3_r14[] = { 617 0x13, 0xfe, 0x54, 0x67 // smmul vs r4 r3 r14 618 }; 619 const byte kInstruction_smmul_ge_r2_r11_r1[] = { 620 0x1b, 0xf1, 0x52, 0xa7 // smmul ge r2 r11 r1 621 }; 622 const byte kInstruction_smmul_lt_r12_r9_r6[] = { 623 0x19, 0xf6, 0x5c, 0xb7 // smmul lt r12 r9 r6 624 }; 625 const byte kInstruction_smmul_ls_r8_r2_r7[] = { 626 0x12, 0xf7, 0x58, 0x97 // smmul ls r8 r2 r7 627 }; 628 const byte kInstruction_smmul_le_r8_r13_r3[] = { 629 0x1d, 0xf3, 0x58, 0xd7 // smmul le r8 r13 r3 630 }; 631 const byte kInstruction_smmul_eq_r11_r13_r14[] = { 632 0x1d, 0xfe, 0x5b, 0x07 // smmul eq r11 r13 r14 633 }; 634 const byte kInstruction_smmul_lt_r1_r6_r13[] = { 635 0x16, 0xfd, 0x51, 0xb7 // smmul lt r1 r6 r13 636 }; 637 const byte kInstruction_smmul_cs_r3_r8_r11[] = { 638 0x18, 0xfb, 0x53, 0x27 // smmul cs r3 r8 r11 639 }; 640 const byte kInstruction_smmul_pl_r12_r5_r4[] = { 641 0x15, 0xf4, 0x5c, 0x57 // smmul pl r12 r5 r4 642 }; 643 const byte kInstruction_smmul_eq_r8_r7_r2[] = { 644 0x17, 0xf2, 0x58, 0x07 // smmul eq r8 r7 r2 645 }; 646 const byte kInstruction_smmul_ls_r2_r12_r2[] = { 647 0x1c, 0xf2, 0x52, 0x97 // smmul ls r2 r12 r2 648 }; 649 const byte kInstruction_smmul_le_r14_r2_r3[] = { 650 0x12, 0xf3, 0x5e, 0xd7 // smmul le r14 r2 r3 651 }; 652 const byte kInstruction_smmul_ge_r10_r11_r6[] = { 653 0x1b, 0xf6, 0x5a, 0xa7 // smmul ge r10 r11 r6 654 }; 655 const byte kInstruction_smmul_hi_r0_r2_r2[] = { 656 0x12, 0xf2, 0x50, 0x87 // smmul hi r0 r2 r2 657 }; 658 const byte kInstruction_smmul_ge_r2_r0_r2[] = { 659 0x10, 0xf2, 0x52, 0xa7 // smmul ge r2 r0 r2 660 }; 661 const byte kInstruction_smmul_vs_r11_r14_r0[] = { 662 0x1e, 0xf0, 0x5b, 0x67 // smmul vs r11 r14 r0 663 }; 664 const byte kInstruction_smmul_lt_r2_r0_r1[] = { 665 0x10, 0xf1, 0x52, 0xb7 // smmul lt r2 r0 r1 666 }; 667 const byte kInstruction_smmul_cs_r2_r5_r11[] = { 668 0x15, 0xfb, 0x52, 0x27 // smmul cs r2 r5 r11 669 }; 670 const byte kInstruction_smmul_ls_r7_r14_r5[] = { 671 0x1e, 0xf5, 0x57, 0x97 // smmul ls r7 r14 r5 672 }; 673 const byte kInstruction_smmul_pl_r0_r0_r3[] = { 674 0x10, 0xf3, 0x50, 0x57 // smmul pl r0 r0 r3 675 }; 676 const byte kInstruction_smmul_ge_r6_r8_r8[] = { 677 0x18, 0xf8, 0x56, 0xa7 // smmul ge r6 r8 r8 678 }; 679 const byte kInstruction_smmul_le_r11_r1_r10[] = { 680 0x11, 0xfa, 0x5b, 0xd7 // smmul le r11 r1 r10 681 }; 682 const byte kInstruction_smmul_vs_r5_r2_r7[] = { 683 0x12, 0xf7, 0x55, 0x67 // smmul vs r5 r2 r7 684 }; 685 const byte kInstruction_smmul_ne_r4_r4_r8[] = { 686 0x14, 0xf8, 0x54, 0x17 // smmul ne r4 r4 r8 687 }; 688 const byte kInstruction_smmul_cc_r9_r14_r13[] = { 689 0x1e, 0xfd, 0x59, 0x37 // smmul cc r9 r14 r13 690 }; 691 const byte kInstruction_smmul_hi_r14_r6_r3[] = { 692 0x16, 0xf3, 0x5e, 0x87 // smmul hi r14 r6 r3 693 }; 694 const byte kInstruction_smmul_al_r0_r8_r0[] = { 695 0x18, 0xf0, 0x50, 0xe7 // smmul al r0 r8 r0 696 }; 697 const byte kInstruction_smmul_lt_r6_r11_r1[] = { 698 0x1b, 0xf1, 0x56, 0xb7 // smmul lt r6 r11 r1 699 }; 700 const byte kInstruction_smmul_ge_r7_r6_r12[] = { 701 0x16, 0xfc, 0x57, 0xa7 // smmul ge r7 r6 r12 702 }; 703 const byte kInstruction_smmul_cs_r4_r6_r14[] = { 704 0x16, 0xfe, 0x54, 0x27 // smmul cs r4 r6 r14 705 }; 706 const byte kInstruction_smmul_cs_r7_r6_r7[] = { 707 0x16, 0xf7, 0x57, 0x27 // smmul cs r7 r6 r7 708 }; 709 const byte kInstruction_smmul_cs_r3_r7_r10[] = { 710 0x17, 0xfa, 0x53, 0x27 // smmul cs r3 r7 r10 711 }; 712 const byte kInstruction_smmul_ne_r0_r2_r1[] = { 713 0x12, 0xf1, 0x50, 0x17 // smmul ne r0 r2 r1 714 }; 715 const byte kInstruction_smmul_vs_r9_r10_r13[] = { 716 0x1a, 0xfd, 0x59, 0x67 // smmul vs r9 r10 r13 717 }; 718 const byte kInstruction_smmul_vc_r11_r14_r12[] = { 719 0x1e, 0xfc, 0x5b, 0x77 // smmul vc r11 r14 r12 720 }; 721 const byte kInstruction_smmul_ge_r14_r8_r7[] = { 722 0x18, 0xf7, 0x5e, 0xa7 // smmul ge r14 r8 r7 723 }; 724 const byte kInstruction_smmul_lt_r13_r0_r11[] = { 725 0x10, 0xfb, 0x5d, 0xb7 // smmul lt r13 r0 r11 726 }; 727 const byte kInstruction_smmul_lt_r14_r13_r4[] = { 728 0x1d, 0xf4, 0x5e, 0xb7 // smmul lt r14 r13 r4 729 }; 730 const byte kInstruction_smmul_al_r1_r10_r9[] = { 731 0x1a, 0xf9, 0x51, 0xe7 // smmul al r1 r10 r9 732 }; 733 const byte kInstruction_smmul_ge_r11_r14_r11[] = { 734 0x1e, 0xfb, 0x5b, 0xa7 // smmul ge r11 r14 r11 735 }; 736 const byte kInstruction_smmul_cs_r11_r4_r11[] = { 737 0x14, 0xfb, 0x5b, 0x27 // smmul cs r11 r4 r11 738 }; 739 const byte kInstruction_smmul_ge_r0_r14_r7[] = { 740 0x1e, 0xf7, 0x50, 0xa7 // smmul ge r0 r14 r7 741 }; 742 const byte kInstruction_smmul_mi_r1_r2_r9[] = { 743 0x12, 0xf9, 0x51, 0x47 // smmul mi r1 r2 r9 744 }; 745 const byte kInstruction_smmul_eq_r5_r12_r3[] = { 746 0x1c, 0xf3, 0x55, 0x07 // smmul eq r5 r12 r3 747 }; 748 const byte kInstruction_smmul_ge_r1_r5_r12[] = { 749 0x15, 0xfc, 0x51, 0xa7 // smmul ge r1 r5 r12 750 }; 751 const byte kInstruction_smmul_lt_r10_r11_r4[] = { 752 0x1b, 0xf4, 0x5a, 0xb7 // smmul lt r10 r11 r4 753 }; 754 const byte kInstruction_smmul_le_r1_r1_r5[] = { 755 0x11, 0xf5, 0x51, 0xd7 // smmul le r1 r1 r5 756 }; 757 const byte kInstruction_smmul_al_r9_r1_r8[] = { 758 0x11, 0xf8, 0x59, 0xe7 // smmul al r9 r1 r8 759 }; 760 const byte kInstruction_smmul_ne_r6_r8_r4[] = { 761 0x18, 0xf4, 0x56, 0x17 // smmul ne r6 r8 r4 762 }; 763 const byte kInstruction_smmul_ge_r12_r2_r9[] = { 764 0x12, 0xf9, 0x5c, 0xa7 // smmul ge r12 r2 r9 765 }; 766 const byte kInstruction_smmul_pl_r4_r3_r10[] = { 767 0x13, 0xfa, 0x54, 0x57 // smmul pl r4 r3 r10 768 }; 769 const byte kInstruction_smmul_eq_r14_r4_r11[] = { 770 0x14, 0xfb, 0x5e, 0x07 // smmul eq r14 r4 r11 771 }; 772 const byte kInstruction_smmul_cc_r9_r7_r6[] = { 773 0x17, 0xf6, 0x59, 0x37 // smmul cc r9 r7 r6 774 }; 775 const byte kInstruction_smmul_ge_r12_r4_r5[] = { 776 0x14, 0xf5, 0x5c, 0xa7 // smmul ge r12 r4 r5 777 }; 778 const byte kInstruction_smmul_hi_r2_r3_r4[] = { 779 0x13, 0xf4, 0x52, 0x87 // smmul hi r2 r3 r4 780 }; 781 const byte kInstruction_smmul_cs_r0_r3_r1[] = { 782 0x13, 0xf1, 0x50, 0x27 // smmul cs r0 r3 r1 783 }; 784 const byte kInstruction_smmul_hi_r6_r2_r8[] = { 785 0x12, 0xf8, 0x56, 0x87 // smmul hi r6 r2 r8 786 }; 787 const byte kInstruction_smmul_cc_r3_r14_r13[] = { 788 0x1e, 0xfd, 0x53, 0x37 // smmul cc r3 r14 r13 789 }; 790 const byte kInstruction_smmul_gt_r11_r4_r7[] = { 791 0x14, 0xf7, 0x5b, 0xc7 // smmul gt r11 r4 r7 792 }; 793 const byte kInstruction_smmul_hi_r5_r0_r12[] = { 794 0x10, 0xfc, 0x55, 0x87 // smmul hi r5 r0 r12 795 }; 796 const byte kInstruction_smmul_gt_r0_r14_r14[] = { 797 0x1e, 0xfe, 0x50, 0xc7 // smmul gt r0 r14 r14 798 }; 799 const byte kInstruction_smmul_hi_r9_r0_r10[] = { 800 0x10, 0xfa, 0x59, 0x87 // smmul hi r9 r0 r10 801 }; 802 const byte kInstruction_smmul_vc_r7_r11_r8[] = { 803 0x1b, 0xf8, 0x57, 0x77 // smmul vc r7 r11 r8 804 }; 805 const byte kInstruction_smmul_pl_r11_r9_r6[] = { 806 0x19, 0xf6, 0x5b, 0x57 // smmul pl r11 r9 r6 807 }; 808 const byte kInstruction_smmul_al_r3_r3_r7[] = { 809 0x13, 0xf7, 0x53, 0xe7 // smmul al r3 r3 r7 810 }; 811 const byte kInstruction_smmul_mi_r5_r7_r9[] = { 812 0x17, 0xf9, 0x55, 0x47 // smmul mi r5 r7 r9 813 }; 814 const byte kInstruction_smmul_cc_r11_r2_r4[] = { 815 0x12, 0xf4, 0x5b, 0x37 // smmul cc r11 r2 r4 816 }; 817 const byte kInstruction_smmul_cc_r9_r13_r10[] = { 818 0x1d, 0xfa, 0x59, 0x37 // smmul cc r9 r13 r10 819 }; 820 const byte kInstruction_smmul_al_r5_r2_r6[] = { 821 0x12, 0xf6, 0x55, 0xe7 // smmul al r5 r2 r6 822 }; 823 const byte kInstruction_smmul_ge_r9_r4_r6[] = { 824 0x14, 0xf6, 0x59, 0xa7 // smmul ge r9 r4 r6 825 }; 826 const byte kInstruction_smmul_ls_r3_r3_r4[] = { 827 0x13, 0xf4, 0x53, 0x97 // smmul ls r3 r3 r4 828 }; 829 const byte kInstruction_smmul_ge_r14_r1_r8[] = { 830 0x11, 0xf8, 0x5e, 0xa7 // smmul ge r14 r1 r8 831 }; 832 const byte kInstruction_smmul_ls_r7_r12_r7[] = { 833 0x1c, 0xf7, 0x57, 0x97 // smmul ls r7 r12 r7 834 }; 835 const byte kInstruction_smmul_al_r11_r10_r5[] = { 836 0x1a, 0xf5, 0x5b, 0xe7 // smmul al r11 r10 r5 837 }; 838 const byte kInstruction_smmul_al_r7_r4_r6[] = { 839 0x14, 0xf6, 0x57, 0xe7 // smmul al r7 r4 r6 840 }; 841 const byte kInstruction_smmul_vs_r12_r4_r10[] = { 842 0x14, 0xfa, 0x5c, 0x67 // smmul vs r12 r4 r10 843 }; 844 const byte kInstruction_smmul_eq_r4_r4_r4[] = { 845 0x14, 0xf4, 0x54, 0x07 // smmul eq r4 r4 r4 846 }; 847 const byte kInstruction_smmul_vs_r6_r6_r12[] = { 848 0x16, 0xfc, 0x56, 0x67 // smmul vs r6 r6 r12 849 }; 850 const byte kInstruction_smmul_pl_r9_r3_r5[] = { 851 0x13, 0xf5, 0x59, 0x57 // smmul pl r9 r3 r5 852 }; 853 const byte kInstruction_smmul_eq_r6_r5_r13[] = { 854 0x15, 0xfd, 0x56, 0x07 // smmul eq r6 r5 r13 855 }; 856 const byte kInstruction_smmul_cc_r8_r2_r12[] = { 857 0x12, 0xfc, 0x58, 0x37 // smmul cc r8 r2 r12 858 }; 859 const byte kInstruction_smmul_le_r4_r2_r0[] = { 860 0x12, 0xf0, 0x54, 0xd7 // smmul le r4 r2 r0 861 }; 862 const byte kInstruction_smmul_lt_r7_r9_r8[] = { 863 0x19, 0xf8, 0x57, 0xb7 // smmul lt r7 r9 r8 864 }; 865 const byte kInstruction_smmul_le_r4_r7_r11[] = { 866 0x17, 0xfb, 0x54, 0xd7 // smmul le r4 r7 r11 867 }; 868 const byte kInstruction_smmul_eq_r5_r7_r5[] = { 869 0x17, 0xf5, 0x55, 0x07 // smmul eq r5 r7 r5 870 }; 871 const byte kInstruction_smmul_vc_r10_r7_r12[] = { 872 0x17, 0xfc, 0x5a, 0x77 // smmul vc r10 r7 r12 873 }; 874 const byte kInstruction_smmul_eq_r7_r10_r6[] = { 875 0x1a, 0xf6, 0x57, 0x07 // smmul eq r7 r10 r6 876 }; 877 const byte kInstruction_smmul_pl_r1_r12_r2[] = { 878 0x1c, 0xf2, 0x51, 0x57 // smmul pl r1 r12 r2 879 }; 880 const byte kInstruction_smmul_le_r14_r6_r6[] = { 881 0x16, 0xf6, 0x5e, 0xd7 // smmul le r14 r6 r6 882 }; 883 const byte kInstruction_smmul_ne_r3_r8_r8[] = { 884 0x18, 0xf8, 0x53, 0x17 // smmul ne r3 r8 r8 885 }; 886 const byte kInstruction_smmul_eq_r4_r12_r8[] = { 887 0x1c, 0xf8, 0x54, 0x07 // smmul eq r4 r12 r8 888 }; 889 const byte kInstruction_smmul_ge_r11_r2_r3[] = { 890 0x12, 0xf3, 0x5b, 0xa7 // smmul ge r11 r2 r3 891 }; 892 const byte kInstruction_smmul_hi_r12_r6_r11[] = { 893 0x16, 0xfb, 0x5c, 0x87 // smmul hi r12 r6 r11 894 }; 895 const byte kInstruction_smmul_cs_r4_r5_r10[] = { 896 0x15, 0xfa, 0x54, 0x27 // smmul cs r4 r5 r10 897 }; 898 const byte kInstruction_smmul_ge_r10_r2_r10[] = { 899 0x12, 0xfa, 0x5a, 0xa7 // smmul ge r10 r2 r10 900 }; 901 const byte kInstruction_smmul_ge_r5_r14_r6[] = { 902 0x1e, 0xf6, 0x55, 0xa7 // smmul ge r5 r14 r6 903 }; 904 const byte kInstruction_smmul_gt_r13_r7_r5[] = { 905 0x17, 0xf5, 0x5d, 0xc7 // smmul gt r13 r7 r5 906 }; 907 const byte kInstruction_smmul_ge_r13_r4_r12[] = { 908 0x14, 0xfc, 0x5d, 0xa7 // smmul ge r13 r4 r12 909 }; 910 const byte kInstruction_smmul_lt_r8_r10_r14[] = { 911 0x1a, 0xfe, 0x58, 0xb7 // smmul lt r8 r10 r14 912 }; 913 const byte kInstruction_smmul_le_r4_r3_r13[] = { 914 0x13, 0xfd, 0x54, 0xd7 // smmul le r4 r3 r13 915 }; 916 const byte kInstruction_smmul_pl_r0_r9_r0[] = { 917 0x19, 0xf0, 0x50, 0x57 // smmul pl r0 r9 r0 918 }; 919 const byte kInstruction_smmul_eq_r2_r3_r1[] = { 920 0x13, 0xf1, 0x52, 0x07 // smmul eq r2 r3 r1 921 }; 922 const byte kInstruction_smmul_vc_r0_r0_r3[] = { 923 0x10, 0xf3, 0x50, 0x77 // smmul vc r0 r0 r3 924 }; 925 const byte kInstruction_smmul_mi_r10_r8_r11[] = { 926 0x18, 0xfb, 0x5a, 0x47 // smmul mi r10 r8 r11 927 }; 928 const byte kInstruction_smmul_mi_r5_r14_r14[] = { 929 0x1e, 0xfe, 0x55, 0x47 // smmul mi r5 r14 r14 930 }; 931 const byte kInstruction_smmul_gt_r5_r11_r2[] = { 932 0x1b, 0xf2, 0x55, 0xc7 // smmul gt r5 r11 r2 933 }; 934 const byte kInstruction_smmul_al_r4_r7_r11[] = { 935 0x17, 0xfb, 0x54, 0xe7 // smmul al r4 r7 r11 936 }; 937 const TestResult kReferencesmmul[] = { 938 { 939 ARRAY_SIZE(kInstruction_smmul_hi_r1_r9_r5), 940 kInstruction_smmul_hi_r1_r9_r5, 941 }, 942 { 943 ARRAY_SIZE(kInstruction_smmul_pl_r8_r6_r2), 944 kInstruction_smmul_pl_r8_r6_r2, 945 }, 946 { 947 ARRAY_SIZE(kInstruction_smmul_hi_r5_r8_r2), 948 kInstruction_smmul_hi_r5_r8_r2, 949 }, 950 { 951 ARRAY_SIZE(kInstruction_smmul_vc_r9_r2_r7), 952 kInstruction_smmul_vc_r9_r2_r7, 953 }, 954 { 955 ARRAY_SIZE(kInstruction_smmul_lt_r4_r6_r3), 956 kInstruction_smmul_lt_r4_r6_r3, 957 }, 958 { 959 ARRAY_SIZE(kInstruction_smmul_le_r11_r6_r2), 960 kInstruction_smmul_le_r11_r6_r2, 961 }, 962 { 963 ARRAY_SIZE(kInstruction_smmul_cc_r8_r14_r4), 964 kInstruction_smmul_cc_r8_r14_r4, 965 }, 966 { 967 ARRAY_SIZE(kInstruction_smmul_le_r5_r14_r6), 968 kInstruction_smmul_le_r5_r14_r6, 969 }, 970 { 971 ARRAY_SIZE(kInstruction_smmul_lt_r6_r1_r0), 972 kInstruction_smmul_lt_r6_r1_r0, 973 }, 974 { 975 ARRAY_SIZE(kInstruction_smmul_lt_r5_r0_r9), 976 kInstruction_smmul_lt_r5_r0_r9, 977 }, 978 { 979 ARRAY_SIZE(kInstruction_smmul_le_r8_r12_r7), 980 kInstruction_smmul_le_r8_r12_r7, 981 }, 982 { 983 ARRAY_SIZE(kInstruction_smmul_eq_r7_r14_r6), 984 kInstruction_smmul_eq_r7_r14_r6, 985 }, 986 { 987 ARRAY_SIZE(kInstruction_smmul_cs_r7_r4_r6), 988 kInstruction_smmul_cs_r7_r4_r6, 989 }, 990 { 991 ARRAY_SIZE(kInstruction_smmul_gt_r9_r6_r9), 992 kInstruction_smmul_gt_r9_r6_r9, 993 }, 994 { 995 ARRAY_SIZE(kInstruction_smmul_ne_r13_r9_r1), 996 kInstruction_smmul_ne_r13_r9_r1, 997 }, 998 { 999 ARRAY_SIZE(kInstruction_smmul_ge_r13_r1_r13), 1000 kInstruction_smmul_ge_r13_r1_r13, 1001 }, 1002 { 1003 ARRAY_SIZE(kInstruction_smmul_ls_r8_r10_r2), 1004 kInstruction_smmul_ls_r8_r10_r2, 1005 }, 1006 { 1007 ARRAY_SIZE(kInstruction_smmul_hi_r0_r13_r5), 1008 kInstruction_smmul_hi_r0_r13_r5, 1009 }, 1010 { 1011 ARRAY_SIZE(kInstruction_smmul_pl_r13_r7_r8), 1012 kInstruction_smmul_pl_r13_r7_r8, 1013 }, 1014 { 1015 ARRAY_SIZE(kInstruction_smmul_ge_r4_r13_r11), 1016 kInstruction_smmul_ge_r4_r13_r11, 1017 }, 1018 { 1019 ARRAY_SIZE(kInstruction_smmul_cs_r5_r10_r5), 1020 kInstruction_smmul_cs_r5_r10_r5, 1021 }, 1022 { 1023 ARRAY_SIZE(kInstruction_smmul_cs_r5_r4_r3), 1024 kInstruction_smmul_cs_r5_r4_r3, 1025 }, 1026 { 1027 ARRAY_SIZE(kInstruction_smmul_ls_r6_r14_r8), 1028 kInstruction_smmul_ls_r6_r14_r8, 1029 }, 1030 { 1031 ARRAY_SIZE(kInstruction_smmul_vs_r3_r8_r6), 1032 kInstruction_smmul_vs_r3_r8_r6, 1033 }, 1034 { 1035 ARRAY_SIZE(kInstruction_smmul_vc_r7_r12_r3), 1036 kInstruction_smmul_vc_r7_r12_r3, 1037 }, 1038 { 1039 ARRAY_SIZE(kInstruction_smmul_ge_r1_r4_r1), 1040 kInstruction_smmul_ge_r1_r4_r1, 1041 }, 1042 { 1043 ARRAY_SIZE(kInstruction_smmul_cc_r4_r7_r10), 1044 kInstruction_smmul_cc_r4_r7_r10, 1045 }, 1046 { 1047 ARRAY_SIZE(kInstruction_smmul_cc_r2_r0_r13), 1048 kInstruction_smmul_cc_r2_r0_r13, 1049 }, 1050 { 1051 ARRAY_SIZE(kInstruction_smmul_vs_r9_r6_r8), 1052 kInstruction_smmul_vs_r9_r6_r8, 1053 }, 1054 { 1055 ARRAY_SIZE(kInstruction_smmul_cs_r14_r11_r13), 1056 kInstruction_smmul_cs_r14_r11_r13, 1057 }, 1058 { 1059 ARRAY_SIZE(kInstruction_smmul_pl_r5_r8_r4), 1060 kInstruction_smmul_pl_r5_r8_r4, 1061 }, 1062 { 1063 ARRAY_SIZE(kInstruction_smmul_pl_r2_r3_r7), 1064 kInstruction_smmul_pl_r2_r3_r7, 1065 }, 1066 { 1067 ARRAY_SIZE(kInstruction_smmul_cs_r7_r12_r14), 1068 kInstruction_smmul_cs_r7_r12_r14, 1069 }, 1070 { 1071 ARRAY_SIZE(kInstruction_smmul_hi_r6_r6_r1), 1072 kInstruction_smmul_hi_r6_r6_r1, 1073 }, 1074 { 1075 ARRAY_SIZE(kInstruction_smmul_cc_r6_r9_r6), 1076 kInstruction_smmul_cc_r6_r9_r6, 1077 }, 1078 { 1079 ARRAY_SIZE(kInstruction_smmul_ne_r12_r12_r0), 1080 kInstruction_smmul_ne_r12_r12_r0, 1081 }, 1082 { 1083 ARRAY_SIZE(kInstruction_smmul_cc_r9_r3_r8), 1084 kInstruction_smmul_cc_r9_r3_r8, 1085 }, 1086 { 1087 ARRAY_SIZE(kInstruction_smmul_mi_r13_r6_r1), 1088 kInstruction_smmul_mi_r13_r6_r1, 1089 }, 1090 { 1091 ARRAY_SIZE(kInstruction_smmul_lt_r4_r8_r6), 1092 kInstruction_smmul_lt_r4_r8_r6, 1093 }, 1094 { 1095 ARRAY_SIZE(kInstruction_smmul_hi_r11_r5_r9), 1096 kInstruction_smmul_hi_r11_r5_r9, 1097 }, 1098 { 1099 ARRAY_SIZE(kInstruction_smmul_cc_r6_r10_r6), 1100 kInstruction_smmul_cc_r6_r10_r6, 1101 }, 1102 { 1103 ARRAY_SIZE(kInstruction_smmul_eq_r10_r10_r5), 1104 kInstruction_smmul_eq_r10_r10_r5, 1105 }, 1106 { 1107 ARRAY_SIZE(kInstruction_smmul_al_r5_r4_r11), 1108 kInstruction_smmul_al_r5_r4_r11, 1109 }, 1110 { 1111 ARRAY_SIZE(kInstruction_smmul_pl_r11_r11_r2), 1112 kInstruction_smmul_pl_r11_r11_r2, 1113 }, 1114 { 1115 ARRAY_SIZE(kInstruction_smmul_ls_r6_r14_r12), 1116 kInstruction_smmul_ls_r6_r14_r12, 1117 }, 1118 { 1119 ARRAY_SIZE(kInstruction_smmul_vc_r7_r7_r2), 1120 kInstruction_smmul_vc_r7_r7_r2, 1121 }, 1122 { 1123 ARRAY_SIZE(kInstruction_smmul_eq_r10_r8_r4), 1124 kInstruction_smmul_eq_r10_r8_r4, 1125 }, 1126 { 1127 ARRAY_SIZE(kInstruction_smmul_al_r14_r7_r2), 1128 kInstruction_smmul_al_r14_r7_r2, 1129 }, 1130 { 1131 ARRAY_SIZE(kInstruction_smmul_cs_r3_r11_r10), 1132 kInstruction_smmul_cs_r3_r11_r10, 1133 }, 1134 { 1135 ARRAY_SIZE(kInstruction_smmul_ls_r11_r4_r0), 1136 kInstruction_smmul_ls_r11_r4_r0, 1137 }, 1138 { 1139 ARRAY_SIZE(kInstruction_smmul_hi_r11_r8_r9), 1140 kInstruction_smmul_hi_r11_r8_r9, 1141 }, 1142 { 1143 ARRAY_SIZE(kInstruction_smmul_vs_r2_r14_r13), 1144 kInstruction_smmul_vs_r2_r14_r13, 1145 }, 1146 { 1147 ARRAY_SIZE(kInstruction_smmul_al_r1_r13_r9), 1148 kInstruction_smmul_al_r1_r13_r9, 1149 }, 1150 { 1151 ARRAY_SIZE(kInstruction_smmul_eq_r3_r9_r13), 1152 kInstruction_smmul_eq_r3_r9_r13, 1153 }, 1154 { 1155 ARRAY_SIZE(kInstruction_smmul_ge_r10_r3_r13), 1156 kInstruction_smmul_ge_r10_r3_r13, 1157 }, 1158 { 1159 ARRAY_SIZE(kInstruction_smmul_pl_r8_r5_r10), 1160 kInstruction_smmul_pl_r8_r5_r10, 1161 }, 1162 { 1163 ARRAY_SIZE(kInstruction_smmul_vc_r8_r11_r6), 1164 kInstruction_smmul_vc_r8_r11_r6, 1165 }, 1166 { 1167 ARRAY_SIZE(kInstruction_smmul_eq_r0_r0_r5), 1168 kInstruction_smmul_eq_r0_r0_r5, 1169 }, 1170 { 1171 ARRAY_SIZE(kInstruction_smmul_ne_r6_r5_r8), 1172 kInstruction_smmul_ne_r6_r5_r8, 1173 }, 1174 { 1175 ARRAY_SIZE(kInstruction_smmul_hi_r5_r13_r3), 1176 kInstruction_smmul_hi_r5_r13_r3, 1177 }, 1178 { 1179 ARRAY_SIZE(kInstruction_smmul_ne_r11_r14_r14), 1180 kInstruction_smmul_ne_r11_r14_r14, 1181 }, 1182 { 1183 ARRAY_SIZE(kInstruction_smmul_mi_r1_r0_r6), 1184 kInstruction_smmul_mi_r1_r0_r6, 1185 }, 1186 { 1187 ARRAY_SIZE(kInstruction_smmul_le_r14_r8_r2), 1188 kInstruction_smmul_le_r14_r8_r2, 1189 }, 1190 { 1191 ARRAY_SIZE(kInstruction_smmul_eq_r9_r6_r5), 1192 kInstruction_smmul_eq_r9_r6_r5, 1193 }, 1194 { 1195 ARRAY_SIZE(kInstruction_smmul_eq_r11_r0_r13), 1196 kInstruction_smmul_eq_r11_r0_r13, 1197 }, 1198 { 1199 ARRAY_SIZE(kInstruction_smmul_pl_r4_r5_r14), 1200 kInstruction_smmul_pl_r4_r5_r14, 1201 }, 1202 { 1203 ARRAY_SIZE(kInstruction_smmul_cs_r13_r5_r13), 1204 kInstruction_smmul_cs_r13_r5_r13, 1205 }, 1206 { 1207 ARRAY_SIZE(kInstruction_smmul_mi_r0_r13_r8), 1208 kInstruction_smmul_mi_r0_r13_r8, 1209 }, 1210 { 1211 ARRAY_SIZE(kInstruction_smmul_lt_r2_r13_r3), 1212 kInstruction_smmul_lt_r2_r13_r3, 1213 }, 1214 { 1215 ARRAY_SIZE(kInstruction_smmul_ls_r8_r1_r11), 1216 kInstruction_smmul_ls_r8_r1_r11, 1217 }, 1218 { 1219 ARRAY_SIZE(kInstruction_smmul_vc_r14_r11_r8), 1220 kInstruction_smmul_vc_r14_r11_r8, 1221 }, 1222 { 1223 ARRAY_SIZE(kInstruction_smmul_lt_r4_r13_r12), 1224 kInstruction_smmul_lt_r4_r13_r12, 1225 }, 1226 { 1227 ARRAY_SIZE(kInstruction_smmul_eq_r2_r1_r14), 1228 kInstruction_smmul_eq_r2_r1_r14, 1229 }, 1230 { 1231 ARRAY_SIZE(kInstruction_smmul_eq_r9_r4_r14), 1232 kInstruction_smmul_eq_r9_r4_r14, 1233 }, 1234 { 1235 ARRAY_SIZE(kInstruction_smmul_hi_r10_r6_r13), 1236 kInstruction_smmul_hi_r10_r6_r13, 1237 }, 1238 { 1239 ARRAY_SIZE(kInstruction_smmul_ge_r12_r9_r4), 1240 kInstruction_smmul_ge_r12_r9_r4, 1241 }, 1242 { 1243 ARRAY_SIZE(kInstruction_smmul_le_r9_r11_r14), 1244 kInstruction_smmul_le_r9_r11_r14, 1245 }, 1246 { 1247 ARRAY_SIZE(kInstruction_smmul_ls_r0_r9_r5), 1248 kInstruction_smmul_ls_r0_r9_r5, 1249 }, 1250 { 1251 ARRAY_SIZE(kInstruction_smmul_mi_r2_r3_r8), 1252 kInstruction_smmul_mi_r2_r3_r8, 1253 }, 1254 { 1255 ARRAY_SIZE(kInstruction_smmul_ne_r14_r10_r14), 1256 kInstruction_smmul_ne_r14_r10_r14, 1257 }, 1258 { 1259 ARRAY_SIZE(kInstruction_smmul_eq_r6_r2_r10), 1260 kInstruction_smmul_eq_r6_r2_r10, 1261 }, 1262 { 1263 ARRAY_SIZE(kInstruction_smmul_lt_r11_r0_r12), 1264 kInstruction_smmul_lt_r11_r0_r12, 1265 }, 1266 { 1267 ARRAY_SIZE(kInstruction_smmul_ne_r1_r12_r10), 1268 kInstruction_smmul_ne_r1_r12_r10, 1269 }, 1270 { 1271 ARRAY_SIZE(kInstruction_smmul_cc_r1_r0_r2), 1272 kInstruction_smmul_cc_r1_r0_r2, 1273 }, 1274 { 1275 ARRAY_SIZE(kInstruction_smmul_al_r5_r5_r7), 1276 kInstruction_smmul_al_r5_r5_r7, 1277 }, 1278 { 1279 ARRAY_SIZE(kInstruction_smmul_hi_r7_r13_r1), 1280 kInstruction_smmul_hi_r7_r13_r1, 1281 }, 1282 { 1283 ARRAY_SIZE(kInstruction_smmul_cs_r4_r4_r9), 1284 kInstruction_smmul_cs_r4_r4_r9, 1285 }, 1286 { 1287 ARRAY_SIZE(kInstruction_smmul_eq_r14_r4_r14), 1288 kInstruction_smmul_eq_r14_r4_r14, 1289 }, 1290 { 1291 ARRAY_SIZE(kInstruction_smmul_vs_r10_r5_r14), 1292 kInstruction_smmul_vs_r10_r5_r14, 1293 }, 1294 { 1295 ARRAY_SIZE(kInstruction_smmul_gt_r4_r3_r11), 1296 kInstruction_smmul_gt_r4_r3_r11, 1297 }, 1298 { 1299 ARRAY_SIZE(kInstruction_smmul_ne_r14_r10_r12), 1300 kInstruction_smmul_ne_r14_r10_r12, 1301 }, 1302 { 1303 ARRAY_SIZE(kInstruction_smmul_vs_r2_r11_r0), 1304 kInstruction_smmul_vs_r2_r11_r0, 1305 }, 1306 { 1307 ARRAY_SIZE(kInstruction_smmul_ge_r5_r12_r7), 1308 kInstruction_smmul_ge_r5_r12_r7, 1309 }, 1310 { 1311 ARRAY_SIZE(kInstruction_smmul_mi_r7_r14_r6), 1312 kInstruction_smmul_mi_r7_r14_r6, 1313 }, 1314 { 1315 ARRAY_SIZE(kInstruction_smmul_gt_r8_r3_r8), 1316 kInstruction_smmul_gt_r8_r3_r8, 1317 }, 1318 { 1319 ARRAY_SIZE(kInstruction_smmul_hi_r9_r14_r3), 1320 kInstruction_smmul_hi_r9_r14_r3, 1321 }, 1322 { 1323 ARRAY_SIZE(kInstruction_smmul_vc_r2_r11_r2), 1324 kInstruction_smmul_vc_r2_r11_r2, 1325 }, 1326 { 1327 ARRAY_SIZE(kInstruction_smmul_hi_r11_r7_r12), 1328 kInstruction_smmul_hi_r11_r7_r12, 1329 }, 1330 { 1331 ARRAY_SIZE(kInstruction_smmul_cs_r6_r4_r11), 1332 kInstruction_smmul_cs_r6_r4_r11, 1333 }, 1334 { 1335 ARRAY_SIZE(kInstruction_smmul_cs_r12_r5_r9), 1336 kInstruction_smmul_cs_r12_r5_r9, 1337 }, 1338 { 1339 ARRAY_SIZE(kInstruction_smmul_ls_r5_r10_r5), 1340 kInstruction_smmul_ls_r5_r10_r5, 1341 }, 1342 { 1343 ARRAY_SIZE(kInstruction_smmul_ls_r0_r9_r13), 1344 kInstruction_smmul_ls_r0_r9_r13, 1345 }, 1346 { 1347 ARRAY_SIZE(kInstruction_smmul_lt_r3_r3_r5), 1348 kInstruction_smmul_lt_r3_r3_r5, 1349 }, 1350 { 1351 ARRAY_SIZE(kInstruction_smmul_mi_r0_r12_r8), 1352 kInstruction_smmul_mi_r0_r12_r8, 1353 }, 1354 { 1355 ARRAY_SIZE(kInstruction_smmul_pl_r3_r12_r12), 1356 kInstruction_smmul_pl_r3_r12_r12, 1357 }, 1358 { 1359 ARRAY_SIZE(kInstruction_smmul_eq_r8_r12_r5), 1360 kInstruction_smmul_eq_r8_r12_r5, 1361 }, 1362 { 1363 ARRAY_SIZE(kInstruction_smmul_cc_r7_r8_r1), 1364 kInstruction_smmul_cc_r7_r8_r1, 1365 }, 1366 { 1367 ARRAY_SIZE(kInstruction_smmul_hi_r2_r13_r10), 1368 kInstruction_smmul_hi_r2_r13_r10, 1369 }, 1370 { 1371 ARRAY_SIZE(kInstruction_smmul_al_r7_r10_r10), 1372 kInstruction_smmul_al_r7_r10_r10, 1373 }, 1374 { 1375 ARRAY_SIZE(kInstruction_smmul_vc_r1_r12_r2), 1376 kInstruction_smmul_vc_r1_r12_r2, 1377 }, 1378 { 1379 ARRAY_SIZE(kInstruction_smmul_cc_r8_r5_r8), 1380 kInstruction_smmul_cc_r8_r5_r8, 1381 }, 1382 { 1383 ARRAY_SIZE(kInstruction_smmul_ls_r3_r7_r9), 1384 kInstruction_smmul_ls_r3_r7_r9, 1385 }, 1386 { 1387 ARRAY_SIZE(kInstruction_smmul_al_r8_r10_r8), 1388 kInstruction_smmul_al_r8_r10_r8, 1389 }, 1390 { 1391 ARRAY_SIZE(kInstruction_smmul_lt_r4_r12_r10), 1392 kInstruction_smmul_lt_r4_r12_r10, 1393 }, 1394 { 1395 ARRAY_SIZE(kInstruction_smmul_ge_r10_r5_r11), 1396 kInstruction_smmul_ge_r10_r5_r11, 1397 }, 1398 { 1399 ARRAY_SIZE(kInstruction_smmul_ls_r3_r14_r4), 1400 kInstruction_smmul_ls_r3_r14_r4, 1401 }, 1402 { 1403 ARRAY_SIZE(kInstruction_smmul_hi_r3_r6_r12), 1404 kInstruction_smmul_hi_r3_r6_r12, 1405 }, 1406 { 1407 ARRAY_SIZE(kInstruction_smmul_hi_r6_r0_r4), 1408 kInstruction_smmul_hi_r6_r0_r4, 1409 }, 1410 { 1411 ARRAY_SIZE(kInstruction_smmul_al_r11_r6_r0), 1412 kInstruction_smmul_al_r11_r6_r0, 1413 }, 1414 { 1415 ARRAY_SIZE(kInstruction_smmul_mi_r3_r1_r9), 1416 kInstruction_smmul_mi_r3_r1_r9, 1417 }, 1418 { 1419 ARRAY_SIZE(kInstruction_smmul_mi_r12_r13_r0), 1420 kInstruction_smmul_mi_r12_r13_r0, 1421 }, 1422 { 1423 ARRAY_SIZE(kInstruction_smmul_le_r1_r2_r5), 1424 kInstruction_smmul_le_r1_r2_r5, 1425 }, 1426 { 1427 ARRAY_SIZE(kInstruction_smmul_hi_r4_r3_r14), 1428 kInstruction_smmul_hi_r4_r3_r14, 1429 }, 1430 { 1431 ARRAY_SIZE(kInstruction_smmul_eq_r6_r11_r11), 1432 kInstruction_smmul_eq_r6_r11_r11, 1433 }, 1434 { 1435 ARRAY_SIZE(kInstruction_smmul_cc_r14_r11_r14), 1436 kInstruction_smmul_cc_r14_r11_r14, 1437 }, 1438 { 1439 ARRAY_SIZE(kInstruction_smmul_hi_r4_r10_r0), 1440 kInstruction_smmul_hi_r4_r10_r0, 1441 }, 1442 { 1443 ARRAY_SIZE(kInstruction_smmul_cc_r7_r11_r1), 1444 kInstruction_smmul_cc_r7_r11_r1, 1445 }, 1446 { 1447 ARRAY_SIZE(kInstruction_smmul_mi_r14_r6_r10), 1448 kInstruction_smmul_mi_r14_r6_r10, 1449 }, 1450 { 1451 ARRAY_SIZE(kInstruction_smmul_eq_r2_r0_r11), 1452 kInstruction_smmul_eq_r2_r0_r11, 1453 }, 1454 { 1455 ARRAY_SIZE(kInstruction_smmul_mi_r13_r5_r12), 1456 kInstruction_smmul_mi_r13_r5_r12, 1457 }, 1458 { 1459 ARRAY_SIZE(kInstruction_smmul_eq_r2_r12_r5), 1460 kInstruction_smmul_eq_r2_r12_r5, 1461 }, 1462 { 1463 ARRAY_SIZE(kInstruction_smmul_le_r12_r0_r2), 1464 kInstruction_smmul_le_r12_r0_r2, 1465 }, 1466 { 1467 ARRAY_SIZE(kInstruction_smmul_vc_r10_r10_r9), 1468 kInstruction_smmul_vc_r10_r10_r9, 1469 }, 1470 { 1471 ARRAY_SIZE(kInstruction_smmul_ls_r11_r11_r8), 1472 kInstruction_smmul_ls_r11_r11_r8, 1473 }, 1474 { 1475 ARRAY_SIZE(kInstruction_smmul_hi_r10_r11_r9), 1476 kInstruction_smmul_hi_r10_r11_r9, 1477 }, 1478 { 1479 ARRAY_SIZE(kInstruction_smmul_vs_r7_r12_r14), 1480 kInstruction_smmul_vs_r7_r12_r14, 1481 }, 1482 { 1483 ARRAY_SIZE(kInstruction_smmul_gt_r11_r14_r12), 1484 kInstruction_smmul_gt_r11_r14_r12, 1485 }, 1486 { 1487 ARRAY_SIZE(kInstruction_smmul_vs_r0_r12_r8), 1488 kInstruction_smmul_vs_r0_r12_r8, 1489 }, 1490 { 1491 ARRAY_SIZE(kInstruction_smmul_al_r0_r5_r7), 1492 kInstruction_smmul_al_r0_r5_r7, 1493 }, 1494 { 1495 ARRAY_SIZE(kInstruction_smmul_hi_r5_r13_r8), 1496 kInstruction_smmul_hi_r5_r13_r8, 1497 }, 1498 { 1499 ARRAY_SIZE(kInstruction_smmul_le_r9_r9_r7), 1500 kInstruction_smmul_le_r9_r9_r7, 1501 }, 1502 { 1503 ARRAY_SIZE(kInstruction_smmul_cc_r4_r9_r5), 1504 kInstruction_smmul_cc_r4_r9_r5, 1505 }, 1506 { 1507 ARRAY_SIZE(kInstruction_smmul_vs_r8_r1_r3), 1508 kInstruction_smmul_vs_r8_r1_r3, 1509 }, 1510 { 1511 ARRAY_SIZE(kInstruction_smmul_cc_r0_r10_r12), 1512 kInstruction_smmul_cc_r0_r10_r12, 1513 }, 1514 { 1515 ARRAY_SIZE(kInstruction_smmul_eq_r7_r14_r0), 1516 kInstruction_smmul_eq_r7_r14_r0, 1517 }, 1518 { 1519 ARRAY_SIZE(kInstruction_smmul_vs_r12_r9_r11), 1520 kInstruction_smmul_vs_r12_r9_r11, 1521 }, 1522 { 1523 ARRAY_SIZE(kInstruction_smmul_gt_r5_r9_r11), 1524 kInstruction_smmul_gt_r5_r9_r11, 1525 }, 1526 { 1527 ARRAY_SIZE(kInstruction_smmul_cs_r14_r13_r7), 1528 kInstruction_smmul_cs_r14_r13_r7, 1529 }, 1530 { 1531 ARRAY_SIZE(kInstruction_smmul_mi_r11_r3_r10), 1532 kInstruction_smmul_mi_r11_r3_r10, 1533 }, 1534 { 1535 ARRAY_SIZE(kInstruction_smmul_hi_r11_r8_r12), 1536 kInstruction_smmul_hi_r11_r8_r12, 1537 }, 1538 { 1539 ARRAY_SIZE(kInstruction_smmul_cs_r3_r8_r13), 1540 kInstruction_smmul_cs_r3_r8_r13, 1541 }, 1542 { 1543 ARRAY_SIZE(kInstruction_smmul_pl_r10_r12_r6), 1544 kInstruction_smmul_pl_r10_r12_r6, 1545 }, 1546 { 1547 ARRAY_SIZE(kInstruction_smmul_vc_r7_r3_r2), 1548 kInstruction_smmul_vc_r7_r3_r2, 1549 }, 1550 { 1551 ARRAY_SIZE(kInstruction_smmul_mi_r9_r0_r8), 1552 kInstruction_smmul_mi_r9_r0_r8, 1553 }, 1554 { 1555 ARRAY_SIZE(kInstruction_smmul_eq_r2_r13_r7), 1556 kInstruction_smmul_eq_r2_r13_r7, 1557 }, 1558 { 1559 ARRAY_SIZE(kInstruction_smmul_ne_r2_r14_r0), 1560 kInstruction_smmul_ne_r2_r14_r0, 1561 }, 1562 { 1563 ARRAY_SIZE(kInstruction_smmul_vs_r4_r10_r0), 1564 kInstruction_smmul_vs_r4_r10_r0, 1565 }, 1566 { 1567 ARRAY_SIZE(kInstruction_smmul_ls_r0_r2_r2), 1568 kInstruction_smmul_ls_r0_r2_r2, 1569 }, 1570 { 1571 ARRAY_SIZE(kInstruction_smmul_cc_r1_r6_r0), 1572 kInstruction_smmul_cc_r1_r6_r0, 1573 }, 1574 { 1575 ARRAY_SIZE(kInstruction_smmul_lt_r12_r0_r8), 1576 kInstruction_smmul_lt_r12_r0_r8, 1577 }, 1578 { 1579 ARRAY_SIZE(kInstruction_smmul_cc_r9_r3_r14), 1580 kInstruction_smmul_cc_r9_r3_r14, 1581 }, 1582 { 1583 ARRAY_SIZE(kInstruction_smmul_vs_r7_r9_r1), 1584 kInstruction_smmul_vs_r7_r9_r1, 1585 }, 1586 { 1587 ARRAY_SIZE(kInstruction_smmul_eq_r11_r9_r14), 1588 kInstruction_smmul_eq_r11_r9_r14, 1589 }, 1590 { 1591 ARRAY_SIZE(kInstruction_smmul_pl_r6_r10_r4), 1592 kInstruction_smmul_pl_r6_r10_r4, 1593 }, 1594 { 1595 ARRAY_SIZE(kInstruction_smmul_ne_r8_r5_r6), 1596 kInstruction_smmul_ne_r8_r5_r6, 1597 }, 1598 { 1599 ARRAY_SIZE(kInstruction_smmul_cs_r0_r6_r2), 1600 kInstruction_smmul_cs_r0_r6_r2, 1601 }, 1602 { 1603 ARRAY_SIZE(kInstruction_smmul_eq_r11_r12_r4), 1604 kInstruction_smmul_eq_r11_r12_r4, 1605 }, 1606 { 1607 ARRAY_SIZE(kInstruction_smmul_lt_r14_r3_r14), 1608 kInstruction_smmul_lt_r14_r3_r14, 1609 }, 1610 { 1611 ARRAY_SIZE(kInstruction_smmul_le_r7_r12_r14), 1612 kInstruction_smmul_le_r7_r12_r14, 1613 }, 1614 { 1615 ARRAY_SIZE(kInstruction_smmul_hi_r2_r9_r9), 1616 kInstruction_smmul_hi_r2_r9_r9, 1617 }, 1618 { 1619 ARRAY_SIZE(kInstruction_smmul_ne_r8_r1_r0), 1620 kInstruction_smmul_ne_r8_r1_r0, 1621 }, 1622 { 1623 ARRAY_SIZE(kInstruction_smmul_cc_r5_r11_r2), 1624 kInstruction_smmul_cc_r5_r11_r2, 1625 }, 1626 { 1627 ARRAY_SIZE(kInstruction_smmul_hi_r0_r1_r2), 1628 kInstruction_smmul_hi_r0_r1_r2, 1629 }, 1630 { 1631 ARRAY_SIZE(kInstruction_smmul_al_r4_r9_r4), 1632 kInstruction_smmul_al_r4_r9_r4, 1633 }, 1634 { 1635 ARRAY_SIZE(kInstruction_smmul_cs_r12_r7_r14), 1636 kInstruction_smmul_cs_r12_r7_r14, 1637 }, 1638 { 1639 ARRAY_SIZE(kInstruction_smmul_cc_r4_r12_r10), 1640 kInstruction_smmul_cc_r4_r12_r10, 1641 }, 1642 { 1643 ARRAY_SIZE(kInstruction_smmul_al_r3_r5_r10), 1644 kInstruction_smmul_al_r3_r5_r10, 1645 }, 1646 { 1647 ARRAY_SIZE(kInstruction_smmul_mi_r5_r3_r7), 1648 kInstruction_smmul_mi_r5_r3_r7, 1649 }, 1650 { 1651 ARRAY_SIZE(kInstruction_smmul_ls_r10_r6_r2), 1652 kInstruction_smmul_ls_r10_r6_r2, 1653 }, 1654 { 1655 ARRAY_SIZE(kInstruction_smmul_mi_r0_r12_r11), 1656 kInstruction_smmul_mi_r0_r12_r11, 1657 }, 1658 { 1659 ARRAY_SIZE(kInstruction_smmul_vc_r12_r5_r6), 1660 kInstruction_smmul_vc_r12_r5_r6, 1661 }, 1662 { 1663 ARRAY_SIZE(kInstruction_smmul_cs_r3_r9_r4), 1664 kInstruction_smmul_cs_r3_r9_r4, 1665 }, 1666 { 1667 ARRAY_SIZE(kInstruction_smmul_ls_r4_r9_r11), 1668 kInstruction_smmul_ls_r4_r9_r11, 1669 }, 1670 { 1671 ARRAY_SIZE(kInstruction_smmul_le_r14_r8_r13), 1672 kInstruction_smmul_le_r14_r8_r13, 1673 }, 1674 { 1675 ARRAY_SIZE(kInstruction_smmul_gt_r4_r10_r8), 1676 kInstruction_smmul_gt_r4_r10_r8, 1677 }, 1678 { 1679 ARRAY_SIZE(kInstruction_smmul_al_r6_r9_r9), 1680 kInstruction_smmul_al_r6_r9_r9, 1681 }, 1682 { 1683 ARRAY_SIZE(kInstruction_smmul_ne_r8_r5_r12), 1684 kInstruction_smmul_ne_r8_r5_r12, 1685 }, 1686 { 1687 ARRAY_SIZE(kInstruction_smmul_ne_r0_r4_r8), 1688 kInstruction_smmul_ne_r0_r4_r8, 1689 }, 1690 { 1691 ARRAY_SIZE(kInstruction_smmul_mi_r7_r13_r3), 1692 kInstruction_smmul_mi_r7_r13_r3, 1693 }, 1694 { 1695 ARRAY_SIZE(kInstruction_smmul_cc_r11_r7_r0), 1696 kInstruction_smmul_cc_r11_r7_r0, 1697 }, 1698 { 1699 ARRAY_SIZE(kInstruction_smmul_hi_r1_r0_r12), 1700 kInstruction_smmul_hi_r1_r0_r12, 1701 }, 1702 { 1703 ARRAY_SIZE(kInstruction_smmul_lt_r8_r9_r3), 1704 kInstruction_smmul_lt_r8_r9_r3, 1705 }, 1706 { 1707 ARRAY_SIZE(kInstruction_smmul_al_r0_r2_r1), 1708 kInstruction_smmul_al_r0_r2_r1, 1709 }, 1710 { 1711 ARRAY_SIZE(kInstruction_smmul_vs_r4_r3_r14), 1712 kInstruction_smmul_vs_r4_r3_r14, 1713 }, 1714 { 1715 ARRAY_SIZE(kInstruction_smmul_ge_r2_r11_r1), 1716 kInstruction_smmul_ge_r2_r11_r1, 1717 }, 1718 { 1719 ARRAY_SIZE(kInstruction_smmul_lt_r12_r9_r6), 1720 kInstruction_smmul_lt_r12_r9_r6, 1721 }, 1722 { 1723 ARRAY_SIZE(kInstruction_smmul_ls_r8_r2_r7), 1724 kInstruction_smmul_ls_r8_r2_r7, 1725 }, 1726 { 1727 ARRAY_SIZE(kInstruction_smmul_le_r8_r13_r3), 1728 kInstruction_smmul_le_r8_r13_r3, 1729 }, 1730 { 1731 ARRAY_SIZE(kInstruction_smmul_eq_r11_r13_r14), 1732 kInstruction_smmul_eq_r11_r13_r14, 1733 }, 1734 { 1735 ARRAY_SIZE(kInstruction_smmul_lt_r1_r6_r13), 1736 kInstruction_smmul_lt_r1_r6_r13, 1737 }, 1738 { 1739 ARRAY_SIZE(kInstruction_smmul_cs_r3_r8_r11), 1740 kInstruction_smmul_cs_r3_r8_r11, 1741 }, 1742 { 1743 ARRAY_SIZE(kInstruction_smmul_pl_r12_r5_r4), 1744 kInstruction_smmul_pl_r12_r5_r4, 1745 }, 1746 { 1747 ARRAY_SIZE(kInstruction_smmul_eq_r8_r7_r2), 1748 kInstruction_smmul_eq_r8_r7_r2, 1749 }, 1750 { 1751 ARRAY_SIZE(kInstruction_smmul_ls_r2_r12_r2), 1752 kInstruction_smmul_ls_r2_r12_r2, 1753 }, 1754 { 1755 ARRAY_SIZE(kInstruction_smmul_le_r14_r2_r3), 1756 kInstruction_smmul_le_r14_r2_r3, 1757 }, 1758 { 1759 ARRAY_SIZE(kInstruction_smmul_ge_r10_r11_r6), 1760 kInstruction_smmul_ge_r10_r11_r6, 1761 }, 1762 { 1763 ARRAY_SIZE(kInstruction_smmul_hi_r0_r2_r2), 1764 kInstruction_smmul_hi_r0_r2_r2, 1765 }, 1766 { 1767 ARRAY_SIZE(kInstruction_smmul_ge_r2_r0_r2), 1768 kInstruction_smmul_ge_r2_r0_r2, 1769 }, 1770 { 1771 ARRAY_SIZE(kInstruction_smmul_vs_r11_r14_r0), 1772 kInstruction_smmul_vs_r11_r14_r0, 1773 }, 1774 { 1775 ARRAY_SIZE(kInstruction_smmul_lt_r2_r0_r1), 1776 kInstruction_smmul_lt_r2_r0_r1, 1777 }, 1778 { 1779 ARRAY_SIZE(kInstruction_smmul_cs_r2_r5_r11), 1780 kInstruction_smmul_cs_r2_r5_r11, 1781 }, 1782 { 1783 ARRAY_SIZE(kInstruction_smmul_ls_r7_r14_r5), 1784 kInstruction_smmul_ls_r7_r14_r5, 1785 }, 1786 { 1787 ARRAY_SIZE(kInstruction_smmul_pl_r0_r0_r3), 1788 kInstruction_smmul_pl_r0_r0_r3, 1789 }, 1790 { 1791 ARRAY_SIZE(kInstruction_smmul_ge_r6_r8_r8), 1792 kInstruction_smmul_ge_r6_r8_r8, 1793 }, 1794 { 1795 ARRAY_SIZE(kInstruction_smmul_le_r11_r1_r10), 1796 kInstruction_smmul_le_r11_r1_r10, 1797 }, 1798 { 1799 ARRAY_SIZE(kInstruction_smmul_vs_r5_r2_r7), 1800 kInstruction_smmul_vs_r5_r2_r7, 1801 }, 1802 { 1803 ARRAY_SIZE(kInstruction_smmul_ne_r4_r4_r8), 1804 kInstruction_smmul_ne_r4_r4_r8, 1805 }, 1806 { 1807 ARRAY_SIZE(kInstruction_smmul_cc_r9_r14_r13), 1808 kInstruction_smmul_cc_r9_r14_r13, 1809 }, 1810 { 1811 ARRAY_SIZE(kInstruction_smmul_hi_r14_r6_r3), 1812 kInstruction_smmul_hi_r14_r6_r3, 1813 }, 1814 { 1815 ARRAY_SIZE(kInstruction_smmul_al_r0_r8_r0), 1816 kInstruction_smmul_al_r0_r8_r0, 1817 }, 1818 { 1819 ARRAY_SIZE(kInstruction_smmul_lt_r6_r11_r1), 1820 kInstruction_smmul_lt_r6_r11_r1, 1821 }, 1822 { 1823 ARRAY_SIZE(kInstruction_smmul_ge_r7_r6_r12), 1824 kInstruction_smmul_ge_r7_r6_r12, 1825 }, 1826 { 1827 ARRAY_SIZE(kInstruction_smmul_cs_r4_r6_r14), 1828 kInstruction_smmul_cs_r4_r6_r14, 1829 }, 1830 { 1831 ARRAY_SIZE(kInstruction_smmul_cs_r7_r6_r7), 1832 kInstruction_smmul_cs_r7_r6_r7, 1833 }, 1834 { 1835 ARRAY_SIZE(kInstruction_smmul_cs_r3_r7_r10), 1836 kInstruction_smmul_cs_r3_r7_r10, 1837 }, 1838 { 1839 ARRAY_SIZE(kInstruction_smmul_ne_r0_r2_r1), 1840 kInstruction_smmul_ne_r0_r2_r1, 1841 }, 1842 { 1843 ARRAY_SIZE(kInstruction_smmul_vs_r9_r10_r13), 1844 kInstruction_smmul_vs_r9_r10_r13, 1845 }, 1846 { 1847 ARRAY_SIZE(kInstruction_smmul_vc_r11_r14_r12), 1848 kInstruction_smmul_vc_r11_r14_r12, 1849 }, 1850 { 1851 ARRAY_SIZE(kInstruction_smmul_ge_r14_r8_r7), 1852 kInstruction_smmul_ge_r14_r8_r7, 1853 }, 1854 { 1855 ARRAY_SIZE(kInstruction_smmul_lt_r13_r0_r11), 1856 kInstruction_smmul_lt_r13_r0_r11, 1857 }, 1858 { 1859 ARRAY_SIZE(kInstruction_smmul_lt_r14_r13_r4), 1860 kInstruction_smmul_lt_r14_r13_r4, 1861 }, 1862 { 1863 ARRAY_SIZE(kInstruction_smmul_al_r1_r10_r9), 1864 kInstruction_smmul_al_r1_r10_r9, 1865 }, 1866 { 1867 ARRAY_SIZE(kInstruction_smmul_ge_r11_r14_r11), 1868 kInstruction_smmul_ge_r11_r14_r11, 1869 }, 1870 { 1871 ARRAY_SIZE(kInstruction_smmul_cs_r11_r4_r11), 1872 kInstruction_smmul_cs_r11_r4_r11, 1873 }, 1874 { 1875 ARRAY_SIZE(kInstruction_smmul_ge_r0_r14_r7), 1876 kInstruction_smmul_ge_r0_r14_r7, 1877 }, 1878 { 1879 ARRAY_SIZE(kInstruction_smmul_mi_r1_r2_r9), 1880 kInstruction_smmul_mi_r1_r2_r9, 1881 }, 1882 { 1883 ARRAY_SIZE(kInstruction_smmul_eq_r5_r12_r3), 1884 kInstruction_smmul_eq_r5_r12_r3, 1885 }, 1886 { 1887 ARRAY_SIZE(kInstruction_smmul_ge_r1_r5_r12), 1888 kInstruction_smmul_ge_r1_r5_r12, 1889 }, 1890 { 1891 ARRAY_SIZE(kInstruction_smmul_lt_r10_r11_r4), 1892 kInstruction_smmul_lt_r10_r11_r4, 1893 }, 1894 { 1895 ARRAY_SIZE(kInstruction_smmul_le_r1_r1_r5), 1896 kInstruction_smmul_le_r1_r1_r5, 1897 }, 1898 { 1899 ARRAY_SIZE(kInstruction_smmul_al_r9_r1_r8), 1900 kInstruction_smmul_al_r9_r1_r8, 1901 }, 1902 { 1903 ARRAY_SIZE(kInstruction_smmul_ne_r6_r8_r4), 1904 kInstruction_smmul_ne_r6_r8_r4, 1905 }, 1906 { 1907 ARRAY_SIZE(kInstruction_smmul_ge_r12_r2_r9), 1908 kInstruction_smmul_ge_r12_r2_r9, 1909 }, 1910 { 1911 ARRAY_SIZE(kInstruction_smmul_pl_r4_r3_r10), 1912 kInstruction_smmul_pl_r4_r3_r10, 1913 }, 1914 { 1915 ARRAY_SIZE(kInstruction_smmul_eq_r14_r4_r11), 1916 kInstruction_smmul_eq_r14_r4_r11, 1917 }, 1918 { 1919 ARRAY_SIZE(kInstruction_smmul_cc_r9_r7_r6), 1920 kInstruction_smmul_cc_r9_r7_r6, 1921 }, 1922 { 1923 ARRAY_SIZE(kInstruction_smmul_ge_r12_r4_r5), 1924 kInstruction_smmul_ge_r12_r4_r5, 1925 }, 1926 { 1927 ARRAY_SIZE(kInstruction_smmul_hi_r2_r3_r4), 1928 kInstruction_smmul_hi_r2_r3_r4, 1929 }, 1930 { 1931 ARRAY_SIZE(kInstruction_smmul_cs_r0_r3_r1), 1932 kInstruction_smmul_cs_r0_r3_r1, 1933 }, 1934 { 1935 ARRAY_SIZE(kInstruction_smmul_hi_r6_r2_r8), 1936 kInstruction_smmul_hi_r6_r2_r8, 1937 }, 1938 { 1939 ARRAY_SIZE(kInstruction_smmul_cc_r3_r14_r13), 1940 kInstruction_smmul_cc_r3_r14_r13, 1941 }, 1942 { 1943 ARRAY_SIZE(kInstruction_smmul_gt_r11_r4_r7), 1944 kInstruction_smmul_gt_r11_r4_r7, 1945 }, 1946 { 1947 ARRAY_SIZE(kInstruction_smmul_hi_r5_r0_r12), 1948 kInstruction_smmul_hi_r5_r0_r12, 1949 }, 1950 { 1951 ARRAY_SIZE(kInstruction_smmul_gt_r0_r14_r14), 1952 kInstruction_smmul_gt_r0_r14_r14, 1953 }, 1954 { 1955 ARRAY_SIZE(kInstruction_smmul_hi_r9_r0_r10), 1956 kInstruction_smmul_hi_r9_r0_r10, 1957 }, 1958 { 1959 ARRAY_SIZE(kInstruction_smmul_vc_r7_r11_r8), 1960 kInstruction_smmul_vc_r7_r11_r8, 1961 }, 1962 { 1963 ARRAY_SIZE(kInstruction_smmul_pl_r11_r9_r6), 1964 kInstruction_smmul_pl_r11_r9_r6, 1965 }, 1966 { 1967 ARRAY_SIZE(kInstruction_smmul_al_r3_r3_r7), 1968 kInstruction_smmul_al_r3_r3_r7, 1969 }, 1970 { 1971 ARRAY_SIZE(kInstruction_smmul_mi_r5_r7_r9), 1972 kInstruction_smmul_mi_r5_r7_r9, 1973 }, 1974 { 1975 ARRAY_SIZE(kInstruction_smmul_cc_r11_r2_r4), 1976 kInstruction_smmul_cc_r11_r2_r4, 1977 }, 1978 { 1979 ARRAY_SIZE(kInstruction_smmul_cc_r9_r13_r10), 1980 kInstruction_smmul_cc_r9_r13_r10, 1981 }, 1982 { 1983 ARRAY_SIZE(kInstruction_smmul_al_r5_r2_r6), 1984 kInstruction_smmul_al_r5_r2_r6, 1985 }, 1986 { 1987 ARRAY_SIZE(kInstruction_smmul_ge_r9_r4_r6), 1988 kInstruction_smmul_ge_r9_r4_r6, 1989 }, 1990 { 1991 ARRAY_SIZE(kInstruction_smmul_ls_r3_r3_r4), 1992 kInstruction_smmul_ls_r3_r3_r4, 1993 }, 1994 { 1995 ARRAY_SIZE(kInstruction_smmul_ge_r14_r1_r8), 1996 kInstruction_smmul_ge_r14_r1_r8, 1997 }, 1998 { 1999 ARRAY_SIZE(kInstruction_smmul_ls_r7_r12_r7), 2000 kInstruction_smmul_ls_r7_r12_r7, 2001 }, 2002 { 2003 ARRAY_SIZE(kInstruction_smmul_al_r11_r10_r5), 2004 kInstruction_smmul_al_r11_r10_r5, 2005 }, 2006 { 2007 ARRAY_SIZE(kInstruction_smmul_al_r7_r4_r6), 2008 kInstruction_smmul_al_r7_r4_r6, 2009 }, 2010 { 2011 ARRAY_SIZE(kInstruction_smmul_vs_r12_r4_r10), 2012 kInstruction_smmul_vs_r12_r4_r10, 2013 }, 2014 { 2015 ARRAY_SIZE(kInstruction_smmul_eq_r4_r4_r4), 2016 kInstruction_smmul_eq_r4_r4_r4, 2017 }, 2018 { 2019 ARRAY_SIZE(kInstruction_smmul_vs_r6_r6_r12), 2020 kInstruction_smmul_vs_r6_r6_r12, 2021 }, 2022 { 2023 ARRAY_SIZE(kInstruction_smmul_pl_r9_r3_r5), 2024 kInstruction_smmul_pl_r9_r3_r5, 2025 }, 2026 { 2027 ARRAY_SIZE(kInstruction_smmul_eq_r6_r5_r13), 2028 kInstruction_smmul_eq_r6_r5_r13, 2029 }, 2030 { 2031 ARRAY_SIZE(kInstruction_smmul_cc_r8_r2_r12), 2032 kInstruction_smmul_cc_r8_r2_r12, 2033 }, 2034 { 2035 ARRAY_SIZE(kInstruction_smmul_le_r4_r2_r0), 2036 kInstruction_smmul_le_r4_r2_r0, 2037 }, 2038 { 2039 ARRAY_SIZE(kInstruction_smmul_lt_r7_r9_r8), 2040 kInstruction_smmul_lt_r7_r9_r8, 2041 }, 2042 { 2043 ARRAY_SIZE(kInstruction_smmul_le_r4_r7_r11), 2044 kInstruction_smmul_le_r4_r7_r11, 2045 }, 2046 { 2047 ARRAY_SIZE(kInstruction_smmul_eq_r5_r7_r5), 2048 kInstruction_smmul_eq_r5_r7_r5, 2049 }, 2050 { 2051 ARRAY_SIZE(kInstruction_smmul_vc_r10_r7_r12), 2052 kInstruction_smmul_vc_r10_r7_r12, 2053 }, 2054 { 2055 ARRAY_SIZE(kInstruction_smmul_eq_r7_r10_r6), 2056 kInstruction_smmul_eq_r7_r10_r6, 2057 }, 2058 { 2059 ARRAY_SIZE(kInstruction_smmul_pl_r1_r12_r2), 2060 kInstruction_smmul_pl_r1_r12_r2, 2061 }, 2062 { 2063 ARRAY_SIZE(kInstruction_smmul_le_r14_r6_r6), 2064 kInstruction_smmul_le_r14_r6_r6, 2065 }, 2066 { 2067 ARRAY_SIZE(kInstruction_smmul_ne_r3_r8_r8), 2068 kInstruction_smmul_ne_r3_r8_r8, 2069 }, 2070 { 2071 ARRAY_SIZE(kInstruction_smmul_eq_r4_r12_r8), 2072 kInstruction_smmul_eq_r4_r12_r8, 2073 }, 2074 { 2075 ARRAY_SIZE(kInstruction_smmul_ge_r11_r2_r3), 2076 kInstruction_smmul_ge_r11_r2_r3, 2077 }, 2078 { 2079 ARRAY_SIZE(kInstruction_smmul_hi_r12_r6_r11), 2080 kInstruction_smmul_hi_r12_r6_r11, 2081 }, 2082 { 2083 ARRAY_SIZE(kInstruction_smmul_cs_r4_r5_r10), 2084 kInstruction_smmul_cs_r4_r5_r10, 2085 }, 2086 { 2087 ARRAY_SIZE(kInstruction_smmul_ge_r10_r2_r10), 2088 kInstruction_smmul_ge_r10_r2_r10, 2089 }, 2090 { 2091 ARRAY_SIZE(kInstruction_smmul_ge_r5_r14_r6), 2092 kInstruction_smmul_ge_r5_r14_r6, 2093 }, 2094 { 2095 ARRAY_SIZE(kInstruction_smmul_gt_r13_r7_r5), 2096 kInstruction_smmul_gt_r13_r7_r5, 2097 }, 2098 { 2099 ARRAY_SIZE(kInstruction_smmul_ge_r13_r4_r12), 2100 kInstruction_smmul_ge_r13_r4_r12, 2101 }, 2102 { 2103 ARRAY_SIZE(kInstruction_smmul_lt_r8_r10_r14), 2104 kInstruction_smmul_lt_r8_r10_r14, 2105 }, 2106 { 2107 ARRAY_SIZE(kInstruction_smmul_le_r4_r3_r13), 2108 kInstruction_smmul_le_r4_r3_r13, 2109 }, 2110 { 2111 ARRAY_SIZE(kInstruction_smmul_pl_r0_r9_r0), 2112 kInstruction_smmul_pl_r0_r9_r0, 2113 }, 2114 { 2115 ARRAY_SIZE(kInstruction_smmul_eq_r2_r3_r1), 2116 kInstruction_smmul_eq_r2_r3_r1, 2117 }, 2118 { 2119 ARRAY_SIZE(kInstruction_smmul_vc_r0_r0_r3), 2120 kInstruction_smmul_vc_r0_r0_r3, 2121 }, 2122 { 2123 ARRAY_SIZE(kInstruction_smmul_mi_r10_r8_r11), 2124 kInstruction_smmul_mi_r10_r8_r11, 2125 }, 2126 { 2127 ARRAY_SIZE(kInstruction_smmul_mi_r5_r14_r14), 2128 kInstruction_smmul_mi_r5_r14_r14, 2129 }, 2130 { 2131 ARRAY_SIZE(kInstruction_smmul_gt_r5_r11_r2), 2132 kInstruction_smmul_gt_r5_r11_r2, 2133 }, 2134 { 2135 ARRAY_SIZE(kInstruction_smmul_al_r4_r7_r11), 2136 kInstruction_smmul_al_r4_r7_r11, 2137 }, 2138 }; 2139 2140 #endif // VIXL_ASSEMBLER_COND_RD_RN_RM_SMMUL_A32_H_ 2141