LCOV - code coverage report
Current view: top level - /mnt/build/buildbot/bld/build-lcov/gcc - insn-extract.cc (source / functions) Coverage Total Hit
Test: gcc.info Lines: 91.9 % 15368 14121
Test Date: 2026-05-30 15:37:04 Functions: 100.0 % 1 1
Legend: Lines:     hit not hit

            Line data    Source code
       1              : /* Generated automatically by the program `genextract'
       2              :    from the machine description file `md'.  */
       3              : 
       4              : #define IN_TARGET_CODE 1
       5              : #include "config.h"
       6              : #include "system.h"
       7              : #include "coretypes.h"
       8              : #include "tm.h"
       9              : #include "rtl.h"
      10              : #include "insn-config.h"
      11              : #include "recog.h"
      12              : #include "diagnostic-core.h"
      13              : 
      14              : /* This variable is used as the "location" of any missing operand
      15              :    whose numbers are skipped by a given pattern.  */
      16              : static rtx junk ATTRIBUTE_UNUSED;
      17              : 
      18              : void
      19   2249279443 : insn_extract (rtx_insn *insn)
      20              : {
      21   2249279443 :   rtx *ro = recog_data.operand;
      22   2249279443 :   rtx **ro_loc = recog_data.operand_loc;
      23   2249279443 :   rtx pat = PATTERN (insn);
      24   2249279443 :   int i ATTRIBUTE_UNUSED; /* only for peepholes */
      25              : 
      26   2249279443 :   if (flag_checking)
      27              :     {
      28   2249260884 :       memset (ro, 0xab, sizeof (*ro) * MAX_RECOG_OPERANDS);
      29   2249260884 :       memset (ro_loc, 0xab, sizeof (*ro_loc) * MAX_RECOG_OPERANDS);
      30              :     }
      31              : 
      32   2249279443 :   switch (INSN_CODE (insn))
      33              :     {
      34            0 :     default:
      35              :       /* Control reaches here if insn_extract has been called with an
      36              :          unrecognizable insn (code -1), or an insn whose INSN_CODE
      37              :          corresponds to a DEFINE_EXPAND in the machine description;
      38              :          either way, a bug.  */
      39            0 :       if (INSN_CODE (insn) < 0)
      40            0 :         fatal_insn ("unrecognizable insn:", insn);
      41              :       else
      42            0 :         fatal_insn ("insn with invalid code number:", insn);
      43              : 
      44         2139 :     case 11161:  /* cmpccxadd_di */
      45         2139 :     case 11160:  /* cmpccxadd_si */
      46         2139 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
      47         2139 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
      48         2139 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
      49         2139 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
      50         2139 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 3));
      51         2139 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0);
      52         2139 :       recog_data.dup_num[0] = 1;
      53         2139 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 1), 1);
      54         2139 :       recog_data.dup_num[1] = 2;
      55         2139 :       recog_data.dup_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0);
      56         2139 :       recog_data.dup_num[2] = 1;
      57         2139 :       break;
      58              : 
      59        35542 :     case 11159:  /* atomic_xor_fetch_cmp_0di_1 */
      60        35542 :     case 11158:  /* atomic_or_fetch_cmp_0di_1 */
      61        35542 :     case 11157:  /* atomic_and_fetch_cmp_0di_1 */
      62        35542 :     case 11156:  /* atomic_xor_fetch_cmp_0si_1 */
      63        35542 :     case 11155:  /* atomic_or_fetch_cmp_0si_1 */
      64        35542 :     case 11154:  /* atomic_and_fetch_cmp_0si_1 */
      65        35542 :     case 11153:  /* atomic_xor_fetch_cmp_0hi_1 */
      66        35542 :     case 11152:  /* atomic_or_fetch_cmp_0hi_1 */
      67        35542 :     case 11151:  /* atomic_and_fetch_cmp_0hi_1 */
      68        35542 :     case 11150:  /* atomic_xor_fetch_cmp_0qi_1 */
      69        35542 :     case 11149:  /* atomic_or_fetch_cmp_0qi_1 */
      70        35542 :     case 11148:  /* atomic_and_fetch_cmp_0qi_1 */
      71        35542 :     case 11147:  /* atomic_sub_fetch_cmp_0di_1 */
      72        35542 :     case 11146:  /* atomic_sub_fetch_cmp_0si_1 */
      73        35542 :     case 11145:  /* atomic_sub_fetch_cmp_0hi_1 */
      74        35542 :     case 11144:  /* atomic_sub_fetch_cmp_0qi_1 */
      75        35542 :     case 11143:  /* atomic_add_fetch_cmp_0di_1 */
      76        35542 :     case 11142:  /* atomic_add_fetch_cmp_0si_1 */
      77        35542 :     case 11141:  /* atomic_add_fetch_cmp_0hi_1 */
      78        35542 :     case 11140:  /* atomic_add_fetch_cmp_0qi_1 */
      79        35542 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0, 0));
      80        35542 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
      81        35542 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0, 1));
      82        35542 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0);
      83        35542 :       recog_data.dup_num[0] = 0;
      84        35542 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
      85        35542 :       recog_data.dup_num[1] = 0;
      86        35542 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
      87        35542 :       recog_data.dup_num[2] = 1;
      88        35542 :       break;
      89              : 
      90         2522 :     case 11136:  /* atomic_bit_test_and_complementdi_1 */
      91         2522 :     case 11135:  /* atomic_bit_test_and_complementsi_1 */
      92         2522 :     case 11134:  /* atomic_bit_test_and_complementhi_1 */
      93         2522 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 0));
      94         2522 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 0), 2));
      95         2522 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1));
      96         2522 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 0), 0);
      97         2522 :       recog_data.dup_num[0] = 0;
      98         2522 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
      99         2522 :       recog_data.dup_num[1] = 0;
     100         2522 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 2);
     101         2522 :       recog_data.dup_num[2] = 1;
     102         2522 :       break;
     103              : 
     104         4803 :     case 11139:  /* atomic_bit_test_and_resetdi_1 */
     105         4803 :     case 11138:  /* atomic_bit_test_and_resetsi_1 */
     106         4803 :     case 11137:  /* atomic_bit_test_and_resethi_1 */
     107         4803 :     case 11133:  /* atomic_bit_test_and_setdi_1 */
     108         4803 :     case 11132:  /* atomic_bit_test_and_setsi_1 */
     109         4803 :     case 11131:  /* atomic_bit_test_and_sethi_1 */
     110         4803 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 0));
     111         4803 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 0), 2));
     112         4803 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1));
     113         4803 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 0), 0);
     114         4803 :       recog_data.dup_num[0] = 0;
     115         4803 :       break;
     116              : 
     117       237409 :     case 11130:  /* atomic_xordi */
     118       237409 :     case 11129:  /* atomic_ordi */
     119       237409 :     case 11128:  /* atomic_anddi */
     120       237409 :     case 11127:  /* atomic_xorsi */
     121       237409 :     case 11126:  /* atomic_orsi */
     122       237409 :     case 11125:  /* atomic_andsi */
     123       237409 :     case 11124:  /* atomic_xorhi */
     124       237409 :     case 11123:  /* atomic_orhi */
     125       237409 :     case 11122:  /* atomic_andhi */
     126       237409 :     case 11121:  /* atomic_xorqi */
     127       237409 :     case 11120:  /* atomic_orqi */
     128       237409 :     case 11119:  /* atomic_andqi */
     129       237409 :     case 11118:  /* atomic_subdi */
     130       237409 :     case 11117:  /* atomic_subsi */
     131       237409 :     case 11116:  /* atomic_subhi */
     132       237409 :     case 11115:  /* atomic_subqi */
     133       237409 :     case 11114:  /* atomic_adddi */
     134       237409 :     case 11113:  /* atomic_addsi */
     135       237409 :     case 11112:  /* atomic_addhi */
     136       237409 :     case 11111:  /* atomic_addqi */
     137       237409 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     138       237409 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0), 1));
     139       237409 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     140       237409 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0), 0);
     141       237409 :       recog_data.dup_num[0] = 0;
     142       237409 :       break;
     143              : 
     144         2339 :     case 11110:  /* rao_aadddi */
     145         2339 :     case 11109:  /* rao_axordi */
     146         2339 :     case 11108:  /* rao_aordi */
     147         2339 :     case 11107:  /* rao_aanddi */
     148         2339 :     case 11106:  /* rao_aaddsi */
     149         2339 :     case 11105:  /* rao_axorsi */
     150         2339 :     case 11104:  /* rao_aorsi */
     151         2339 :     case 11103:  /* rao_aandsi */
     152         2339 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     153         2339 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
     154         2339 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0);
     155         2339 :       recog_data.dup_num[0] = 0;
     156         2339 :       break;
     157              : 
     158       265550 :     case 11102:  /* atomic_exchangedi */
     159       265550 :     case 11101:  /* atomic_exchangesi */
     160       265550 :     case 11100:  /* atomic_exchangehi */
     161       265550 :     case 11099:  /* atomic_exchangeqi */
     162       265550 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     163       265550 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
     164       265550 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 1));
     165       265550 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     166       265550 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0);
     167       265550 :       recog_data.dup_num[0] = 1;
     168       265550 :       break;
     169              : 
     170           16 :     case 11098:  /* *atomic_fetch_add_cmpdi */
     171           16 :     case 11097:  /* *atomic_fetch_add_cmpsi */
     172           16 :     case 11096:  /* *atomic_fetch_add_cmphi */
     173           16 :     case 11095:  /* *atomic_fetch_add_cmpqi */
     174           16 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 0));
     175           16 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
     176           16 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
     177           16 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1));
     178           16 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0);
     179           16 :       recog_data.dup_num[0] = 0;
     180           16 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
     181           16 :       recog_data.dup_num[1] = 0;
     182           16 :       break;
     183              : 
     184       256740 :     case 11094:  /* atomic_fetch_adddi */
     185       256740 :     case 11093:  /* atomic_fetch_addsi */
     186       256740 :     case 11092:  /* atomic_fetch_addhi */
     187       256740 :     case 11091:  /* atomic_fetch_addqi */
     188       256740 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     189       256740 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
     190       256740 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
     191       256740 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     192       256740 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0);
     193       256740 :       recog_data.dup_num[0] = 1;
     194       256740 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
     195       256740 :       recog_data.dup_num[1] = 1;
     196       256740 :       break;
     197              : 
     198       456501 :     case 11090:  /* atomic_compare_and_swapdi_1 */
     199       456501 :     case 11089:  /* atomic_compare_and_swapsi_1 */
     200       456501 :     case 11088:  /* atomic_compare_and_swaphi_1 */
     201       456501 :     case 11087:  /* atomic_compare_and_swapqi_1 */
     202       456501 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     203       456501 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
     204       456501 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     205       456501 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
     206       456501 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 3));
     207       456501 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0);
     208       456501 :       recog_data.dup_num[0] = 1;
     209       456501 :       break;
     210              : 
     211        21128 :     case 11086:  /* atomic_compare_and_swapti_doubleword */
     212        21128 :     case 11085:  /* atomic_compare_and_swapdi_doubleword */
     213        21128 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     214        21128 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
     215        21128 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     216        21128 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
     217        21128 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 3));
     218        21128 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 4));
     219        21128 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0);
     220        21128 :       recog_data.dup_num[0] = 1;
     221        21128 :       break;
     222              : 
     223         7006 :     case 11074:  /* mfence_nosse */
     224         7006 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     225         7006 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0);
     226         7006 :       recog_data.dup_num[0] = 0;
     227         7006 :       break;
     228              : 
     229         1876 :     case 10585:  /* *vcvtph2hf8sv8hf_mask */
     230         1876 :     case 10584:  /* *vcvtph2hf8v8hf_mask */
     231         1876 :     case 10583:  /* *vcvtph2bf8sv8hf_mask */
     232         1876 :     case 10582:  /* *vcvtph2bf8v8hf_mask */
     233         1876 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     234         1876 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
     235         1876 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
     236         1876 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
     237         1876 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
     238         1876 :       break;
     239              : 
     240         1676 :     case 10561:  /* *vcvtbiasph2hf8sv8hf_mask */
     241         1676 :     case 10560:  /* *vcvtbiasph2hf8v8hf_mask */
     242         1676 :     case 10559:  /* *vcvtbiasph2bf8sv8hf_mask */
     243         1676 :     case 10558:  /* *vcvtbiasph2bf8v8hf_mask */
     244         1676 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     245         1676 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
     246         1676 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
     247         1676 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
     248         1676 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
     249         1676 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 1));
     250         1676 :       break;
     251              : 
     252          622 :     case 10525:  /* avx10_2_cvt2ps2phx_v32hf_mask_round */
     253          622 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     254          622 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1), 0));
     255          622 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
     256          622 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
     257          622 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
     258          622 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
     259          622 :       break;
     260              : 
     261          217 :     case 10523:  /* avx10_2_cvt2ps2phx_v32hf_round */
     262          217 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     263          217 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1), 0));
     264          217 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
     265          217 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 1));
     266          217 :       break;
     267              : 
     268         8036 :     case 10661:  /* *vpdpwuuds_v4si_maskz */
     269         8036 :     case 10660:  /* *vpdpwuud_v4si_maskz */
     270         8036 :     case 10659:  /* *vpdpwsuds_v4si_maskz */
     271         8036 :     case 10658:  /* *vpdpwsud_v4si_maskz */
     272         8036 :     case 10657:  /* *vpdpwusds_v4si_maskz */
     273         8036 :     case 10656:  /* *vpdpwusd_v4si_maskz */
     274         8036 :     case 10655:  /* *vpdpwuuds_v8si_maskz */
     275         8036 :     case 10654:  /* *vpdpwuud_v8si_maskz */
     276         8036 :     case 10653:  /* *vpdpwsuds_v8si_maskz */
     277         8036 :     case 10652:  /* *vpdpwsud_v8si_maskz */
     278         8036 :     case 10651:  /* *vpdpwusds_v8si_maskz */
     279         8036 :     case 10650:  /* *vpdpwusd_v8si_maskz */
     280         8036 :     case 10649:  /* *vpdpwuuds_v16si_maskz */
     281         8036 :     case 10648:  /* *vpdpwuud_v16si_maskz */
     282         8036 :     case 10647:  /* *vpdpwsuds_v16si_maskz */
     283         8036 :     case 10646:  /* *vpdpwsud_v16si_maskz */
     284         8036 :     case 10645:  /* *vpdpwusds_v16si_maskz */
     285         8036 :     case 10644:  /* *vpdpwusd_v16si_maskz */
     286         8036 :     case 10509:  /* *vpdpbuuds_v4si_maskz */
     287         8036 :     case 10508:  /* *vpdpbuud_v4si_maskz */
     288         8036 :     case 10507:  /* *vpdpbsuds_v4si_maskz */
     289         8036 :     case 10506:  /* *vpdpbsud_v4si_maskz */
     290         8036 :     case 10505:  /* *vpdpbssds_v4si_maskz */
     291         8036 :     case 10504:  /* *vpdpbssd_v4si_maskz */
     292         8036 :     case 10503:  /* *vpdpbuuds_v8si_maskz */
     293         8036 :     case 10502:  /* *vpdpbuud_v8si_maskz */
     294         8036 :     case 10501:  /* *vpdpbsuds_v8si_maskz */
     295         8036 :     case 10500:  /* *vpdpbsud_v8si_maskz */
     296         8036 :     case 10499:  /* *vpdpbssds_v8si_maskz */
     297         8036 :     case 10498:  /* *vpdpbssd_v8si_maskz */
     298         8036 :     case 10497:  /* *vpdpbuuds_v16si_maskz */
     299         8036 :     case 10496:  /* *vpdpbuud_v16si_maskz */
     300         8036 :     case 10495:  /* *vpdpbsuds_v16si_maskz */
     301         8036 :     case 10494:  /* *vpdpbsud_v16si_maskz */
     302         8036 :     case 10493:  /* *vpdpbssds_v16si_maskz */
     303         8036 :     case 10492:  /* *vpdpbssd_v16si_maskz */
     304         8036 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     305         8036 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
     306         8036 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
     307         8036 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
     308         8036 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
     309         8036 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 1));
     310         8036 :       break;
     311              : 
     312          628 :     case 10455:  /* *aesencwide256klu8 */
     313          628 :     case 10454:  /* *aesencwide128klu8 */
     314          628 :     case 10453:  /* *aesdecwide256klu8 */
     315          628 :     case 10452:  /* *aesdecwide128klu8 */
     316          628 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
     317          628 :       ro[1] = *(ro_loc[1] = &PATTERN (insn));
     318          628 :       break;
     319              : 
     320          760 :     case 10451:  /* aesenc256klu8 */
     321          760 :     case 10450:  /* aesenc128klu8 */
     322          760 :     case 10449:  /* aesdec256klu8 */
     323          760 :     case 10448:  /* aesdec128klu8 */
     324          760 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     325          760 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
     326          760 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     327          760 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 1);
     328          760 :       recog_data.dup_num[0] = 2;
     329          760 :       recog_data.dup_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 0);
     330          760 :       recog_data.dup_num[1] = 1;
     331          760 :       break;
     332              : 
     333          344 :     case 10447:  /* *encodekey256u32 */
     334          344 :     case 10446:  /* *encodekey128u32 */
     335          344 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     336          344 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
     337          344 :       ro[2] = *(ro_loc[2] = &PATTERN (insn));
     338          344 :       break;
     339              : 
     340          209 :     case 10445:  /* loadiwkey */
     341          209 :       ro[0] = *(ro_loc[0] = &XVECEXP (XVECEXP (pat, 0, 0), 0, 0));
     342          209 :       ro[1] = *(ro_loc[1] = &XVECEXP (XVECEXP (pat, 0, 0), 0, 1));
     343          209 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (pat, 0, 0), 0, 2));
     344          209 :       ro[3] = *(ro_loc[3] = &XVECEXP (XVECEXP (pat, 0, 0), 0, 3));
     345          209 :       break;
     346              : 
     347         2352 :     case 10529:  /* avx10_2_cvt2ps2phx_v8hf_mask */
     348         2352 :     case 10527:  /* avx10_2_cvt2ps2phx_v16hf_mask */
     349         2352 :     case 10524:  /* avx10_2_cvt2ps2phx_v32hf_mask */
     350         2352 :     case 10428:  /* avx512f_cvtne2ps2bf16_v8bf_mask */
     351         2352 :     case 10426:  /* avx512f_cvtne2ps2bf16_v16bf_mask */
     352         2352 :     case 10424:  /* avx512f_cvtne2ps2bf16_v32bf_mask */
     353         2352 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     354         2352 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
     355         2352 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
     356         2352 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
     357         2352 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
     358         2352 :       break;
     359              : 
     360          744 :     case 10528:  /* avx10_2_cvt2ps2phx_v8hf */
     361          744 :     case 10526:  /* avx10_2_cvt2ps2phx_v16hf */
     362          744 :     case 10522:  /* avx10_2_cvt2ps2phx_v32hf */
     363          744 :     case 10427:  /* avx512f_cvtne2ps2bf16_v8bf */
     364          744 :     case 10425:  /* avx512f_cvtne2ps2bf16_v16bf */
     365          744 :     case 10423:  /* avx512f_cvtne2ps2bf16_v32bf */
     366          744 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     367          744 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
     368          744 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
     369          744 :       break;
     370              : 
     371         1638 :     case 10237:  /* *restore_multiple_leave_returndi */
     372         1638 :     case 10236:  /* *restore_multiple_leave_returnsi */
     373         1638 :     case 10235:  /* *restore_multiple_and_returndi */
     374         1638 :     case 10234:  /* *restore_multiple_and_returnsi */
     375         1638 :       ro[0] = *(ro_loc[0] = &PATTERN (insn));
     376         1638 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
     377         1638 :       break;
     378              : 
     379        22190 :     case 10233:  /* *restore_multipledi */
     380        22190 :     case 10232:  /* *restore_multiplesi */
     381        22190 :     case 10231:  /* *save_multipledi */
     382        22190 :     case 10230:  /* *save_multiplesi */
     383        22190 :       ro[0] = *(ro_loc[0] = &PATTERN (insn));
     384        22190 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 0));
     385        22190 :       break;
     386              : 
     387          504 :     case 10090:  /* avx512dq_vmfpclassv2df_mask */
     388          504 :     case 10088:  /* avx512dq_vmfpclassv4sf_mask */
     389          504 :     case 10086:  /* avx512dq_vmfpclassv8hf_mask */
     390          504 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     391          504 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
     392          504 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
     393          504 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
     394          504 :       break;
     395              : 
     396        17290 :     case 9970:  /* *avx512f_scatterdiv2df */
     397        17290 :     case 9969:  /* *avx512f_scatterdiv2di */
     398        17290 :     case 9968:  /* *avx512f_scatterdiv4sf */
     399        17290 :     case 9967:  /* *avx512f_scatterdiv4si */
     400        17290 :     case 9966:  /* *avx512f_scatterdiv4df */
     401        17290 :     case 9965:  /* *avx512f_scatterdiv4di */
     402        17290 :     case 9964:  /* *avx512f_scatterdiv8sf */
     403        17290 :     case 9963:  /* *avx512f_scatterdiv8si */
     404        17290 :     case 9962:  /* *avx512f_scatterdiv8df */
     405        17290 :     case 9961:  /* *avx512f_scatterdiv8di */
     406        17290 :     case 9960:  /* *avx512f_scatterdiv16sf */
     407        17290 :     case 9959:  /* *avx512f_scatterdiv16si */
     408        17290 :     case 9958:  /* *avx512f_scatterdiv2df */
     409        17290 :     case 9957:  /* *avx512f_scatterdiv2di */
     410        17290 :     case 9956:  /* *avx512f_scatterdiv4sf */
     411        17290 :     case 9955:  /* *avx512f_scatterdiv4si */
     412        17290 :     case 9954:  /* *avx512f_scatterdiv4df */
     413        17290 :     case 9953:  /* *avx512f_scatterdiv4di */
     414        17290 :     case 9952:  /* *avx512f_scatterdiv8sf */
     415        17290 :     case 9951:  /* *avx512f_scatterdiv8si */
     416        17290 :     case 9950:  /* *avx512f_scatterdiv8df */
     417        17290 :     case 9949:  /* *avx512f_scatterdiv8di */
     418        17290 :     case 9948:  /* *avx512f_scatterdiv16sf */
     419        17290 :     case 9947:  /* *avx512f_scatterdiv16si */
     420        17290 :     case 9946:  /* *avx512f_scattersiv2df */
     421        17290 :     case 9945:  /* *avx512f_scattersiv2di */
     422        17290 :     case 9944:  /* *avx512f_scattersiv4sf */
     423        17290 :     case 9943:  /* *avx512f_scattersiv4si */
     424        17290 :     case 9942:  /* *avx512f_scattersiv4df */
     425        17290 :     case 9941:  /* *avx512f_scattersiv4di */
     426        17290 :     case 9940:  /* *avx512f_scattersiv8sf */
     427        17290 :     case 9939:  /* *avx512f_scattersiv8si */
     428        17290 :     case 9938:  /* *avx512f_scattersiv8df */
     429        17290 :     case 9937:  /* *avx512f_scattersiv8di */
     430        17290 :     case 9936:  /* *avx512f_scattersiv16sf */
     431        17290 :     case 9935:  /* *avx512f_scattersiv16si */
     432        17290 :     case 9934:  /* *avx512f_scattersiv2df */
     433        17290 :     case 9933:  /* *avx512f_scattersiv2di */
     434        17290 :     case 9932:  /* *avx512f_scattersiv4sf */
     435        17290 :     case 9931:  /* *avx512f_scattersiv4si */
     436        17290 :     case 9930:  /* *avx512f_scattersiv4df */
     437        17290 :     case 9929:  /* *avx512f_scattersiv4di */
     438        17290 :     case 9928:  /* *avx512f_scattersiv8sf */
     439        17290 :     case 9927:  /* *avx512f_scattersiv8si */
     440        17290 :     case 9926:  /* *avx512f_scattersiv8df */
     441        17290 :     case 9925:  /* *avx512f_scattersiv8di */
     442        17290 :     case 9924:  /* *avx512f_scattersiv16sf */
     443        17290 :     case 9923:  /* *avx512f_scattersiv16si */
     444        17290 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0), 0, 0));
     445        17290 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
     446        17290 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0), 0, 1));
     447        17290 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     448        17290 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0), 0, 2));
     449        17290 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (pat, 0, 0), 0));
     450        17290 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0), 0, 3));
     451        17290 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0);
     452        17290 :       recog_data.dup_num[0] = 6;
     453        17290 :       break;
     454              : 
     455         5373 :     case 9922:  /* *avx512f_gatherdiv2df_2 */
     456         5373 :     case 9921:  /* *avx512f_gatherdiv2di_2 */
     457         5373 :     case 9920:  /* *avx512f_gatherdiv4sf_2 */
     458         5373 :     case 9919:  /* *avx512f_gatherdiv4si_2 */
     459         5373 :     case 9918:  /* *avx512f_gatherdiv4df_2 */
     460         5373 :     case 9917:  /* *avx512f_gatherdiv4di_2 */
     461         5373 :     case 9916:  /* *avx512f_gatherdiv8sf_2 */
     462         5373 :     case 9915:  /* *avx512f_gatherdiv8si_2 */
     463         5373 :     case 9914:  /* *avx512f_gatherdiv8df_2 */
     464         5373 :     case 9913:  /* *avx512f_gatherdiv8di_2 */
     465         5373 :     case 9912:  /* *avx512f_gatherdiv16sf_2 */
     466         5373 :     case 9911:  /* *avx512f_gatherdiv16si_2 */
     467         5373 :     case 9910:  /* *avx512f_gatherdiv2df_2 */
     468         5373 :     case 9909:  /* *avx512f_gatherdiv2di_2 */
     469         5373 :     case 9908:  /* *avx512f_gatherdiv4sf_2 */
     470         5373 :     case 9907:  /* *avx512f_gatherdiv4si_2 */
     471         5373 :     case 9906:  /* *avx512f_gatherdiv4df_2 */
     472         5373 :     case 9905:  /* *avx512f_gatherdiv4di_2 */
     473         5373 :     case 9904:  /* *avx512f_gatherdiv8sf_2 */
     474         5373 :     case 9903:  /* *avx512f_gatherdiv8si_2 */
     475         5373 :     case 9902:  /* *avx512f_gatherdiv8df_2 */
     476         5373 :     case 9901:  /* *avx512f_gatherdiv8di_2 */
     477         5373 :     case 9900:  /* *avx512f_gatherdiv16sf_2 */
     478         5373 :     case 9899:  /* *avx512f_gatherdiv16si_2 */
     479         5373 :     case 9874:  /* *avx512f_gathersiv2df_2 */
     480         5373 :     case 9873:  /* *avx512f_gathersiv2di_2 */
     481         5373 :     case 9872:  /* *avx512f_gathersiv4sf_2 */
     482         5373 :     case 9871:  /* *avx512f_gathersiv4si_2 */
     483         5373 :     case 9870:  /* *avx512f_gathersiv4df_2 */
     484         5373 :     case 9869:  /* *avx512f_gathersiv4di_2 */
     485         5373 :     case 9868:  /* *avx512f_gathersiv8sf_2 */
     486         5373 :     case 9867:  /* *avx512f_gathersiv8si_2 */
     487         5373 :     case 9866:  /* *avx512f_gathersiv8df_2 */
     488         5373 :     case 9865:  /* *avx512f_gathersiv8di_2 */
     489         5373 :     case 9864:  /* *avx512f_gathersiv16sf_2 */
     490         5373 :     case 9863:  /* *avx512f_gathersiv16si_2 */
     491         5373 :     case 9862:  /* *avx512f_gathersiv2df_2 */
     492         5373 :     case 9861:  /* *avx512f_gathersiv2di_2 */
     493         5373 :     case 9860:  /* *avx512f_gathersiv4sf_2 */
     494         5373 :     case 9859:  /* *avx512f_gathersiv4si_2 */
     495         5373 :     case 9858:  /* *avx512f_gathersiv4df_2 */
     496         5373 :     case 9857:  /* *avx512f_gathersiv4di_2 */
     497         5373 :     case 9856:  /* *avx512f_gathersiv8sf_2 */
     498         5373 :     case 9855:  /* *avx512f_gathersiv8si_2 */
     499         5373 :     case 9854:  /* *avx512f_gathersiv8df_2 */
     500         5373 :     case 9853:  /* *avx512f_gathersiv8di_2 */
     501         5373 :     case 9852:  /* *avx512f_gathersiv16sf_2 */
     502         5373 :     case 9851:  /* *avx512f_gathersiv16si_2 */
     503         5373 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     504         5373 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
     505         5373 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2), 0), 0, 1));
     506         5373 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2), 0), 0, 0));
     507         5373 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2), 0), 0, 2));
     508         5373 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
     509         5373 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     510         5373 :       break;
     511              : 
     512        10487 :     case 9898:  /* *avx512f_gatherdiv2df */
     513        10487 :     case 9897:  /* *avx512f_gatherdiv2di */
     514        10487 :     case 9896:  /* *avx512f_gatherdiv4sf */
     515        10487 :     case 9895:  /* *avx512f_gatherdiv4si */
     516        10487 :     case 9894:  /* *avx512f_gatherdiv4df */
     517        10487 :     case 9893:  /* *avx512f_gatherdiv4di */
     518        10487 :     case 9892:  /* *avx512f_gatherdiv8sf */
     519        10487 :     case 9891:  /* *avx512f_gatherdiv8si */
     520        10487 :     case 9890:  /* *avx512f_gatherdiv8df */
     521        10487 :     case 9889:  /* *avx512f_gatherdiv8di */
     522        10487 :     case 9888:  /* *avx512f_gatherdiv16sf */
     523        10487 :     case 9887:  /* *avx512f_gatherdiv16si */
     524        10487 :     case 9886:  /* *avx512f_gatherdiv2df */
     525        10487 :     case 9885:  /* *avx512f_gatherdiv2di */
     526        10487 :     case 9884:  /* *avx512f_gatherdiv4sf */
     527        10487 :     case 9883:  /* *avx512f_gatherdiv4si */
     528        10487 :     case 9882:  /* *avx512f_gatherdiv4df */
     529        10487 :     case 9881:  /* *avx512f_gatherdiv4di */
     530        10487 :     case 9880:  /* *avx512f_gatherdiv8sf */
     531        10487 :     case 9879:  /* *avx512f_gatherdiv8si */
     532        10487 :     case 9878:  /* *avx512f_gatherdiv8df */
     533        10487 :     case 9877:  /* *avx512f_gatherdiv8di */
     534        10487 :     case 9876:  /* *avx512f_gatherdiv16sf */
     535        10487 :     case 9875:  /* *avx512f_gatherdiv16si */
     536        10487 :     case 9850:  /* *avx512f_gathersiv2df */
     537        10487 :     case 9849:  /* *avx512f_gathersiv2di */
     538        10487 :     case 9848:  /* *avx512f_gathersiv4sf */
     539        10487 :     case 9847:  /* *avx512f_gathersiv4si */
     540        10487 :     case 9846:  /* *avx512f_gathersiv4df */
     541        10487 :     case 9845:  /* *avx512f_gathersiv4di */
     542        10487 :     case 9844:  /* *avx512f_gathersiv8sf */
     543        10487 :     case 9843:  /* *avx512f_gathersiv8si */
     544        10487 :     case 9842:  /* *avx512f_gathersiv8df */
     545        10487 :     case 9841:  /* *avx512f_gathersiv8di */
     546        10487 :     case 9840:  /* *avx512f_gathersiv16sf */
     547        10487 :     case 9839:  /* *avx512f_gathersiv16si */
     548        10487 :     case 9838:  /* *avx512f_gathersiv2df */
     549        10487 :     case 9837:  /* *avx512f_gathersiv2di */
     550        10487 :     case 9836:  /* *avx512f_gathersiv4sf */
     551        10487 :     case 9835:  /* *avx512f_gathersiv4si */
     552        10487 :     case 9834:  /* *avx512f_gathersiv4df */
     553        10487 :     case 9833:  /* *avx512f_gathersiv4di */
     554        10487 :     case 9832:  /* *avx512f_gathersiv8sf */
     555        10487 :     case 9831:  /* *avx512f_gathersiv8si */
     556        10487 :     case 9830:  /* *avx512f_gathersiv8df */
     557        10487 :     case 9829:  /* *avx512f_gathersiv8di */
     558        10487 :     case 9828:  /* *avx512f_gathersiv16sf */
     559        10487 :     case 9827:  /* *avx512f_gathersiv16si */
     560        10487 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     561        10487 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
     562        10487 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
     563        10487 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2), 0), 0, 1));
     564        10487 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2), 0), 0, 0));
     565        10487 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2), 0), 0, 2));
     566        10487 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
     567        10487 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     568        10487 :       break;
     569              : 
     570          389 :     case 9826:  /* *avx2_gatherdiv8sf_4 */
     571          389 :     case 9825:  /* *avx2_gatherdiv8si_4 */
     572          389 :     case 9824:  /* *avx2_gatherdiv8sf_4 */
     573          389 :     case 9823:  /* *avx2_gatherdiv8si_4 */
     574          389 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     575          389 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
     576          389 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1), 0), 0, 0));
     577          389 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1), 0), 0, 1));
     578          389 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 3));
     579          389 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1), 0), 0, 2));
     580          389 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1));
     581          389 :       break;
     582              : 
     583          446 :     case 9822:  /* *avx2_gatherdiv8sf_3 */
     584          446 :     case 9821:  /* *avx2_gatherdiv8si_3 */
     585          446 :     case 9820:  /* *avx2_gatherdiv8sf_3 */
     586          446 :     case 9819:  /* *avx2_gatherdiv8si_3 */
     587          446 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     588          446 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
     589          446 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 0));
     590          446 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1), 0), 0, 0));
     591          446 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1), 0), 0, 1));
     592          446 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 3));
     593          446 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1), 0), 0, 2));
     594          446 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1));
     595          446 :       break;
     596              : 
     597         5927 :     case 9818:  /* *avx2_gatherdiv8sf_2 */
     598         5927 :     case 9817:  /* *avx2_gatherdiv8si_2 */
     599         5927 :     case 9816:  /* *avx2_gatherdiv4sf_2 */
     600         5927 :     case 9815:  /* *avx2_gatherdiv4si_2 */
     601         5927 :     case 9814:  /* *avx2_gatherdiv4df_2 */
     602         5927 :     case 9813:  /* *avx2_gatherdiv4di_2 */
     603         5927 :     case 9812:  /* *avx2_gatherdiv2df_2 */
     604         5927 :     case 9811:  /* *avx2_gatherdiv2di_2 */
     605         5927 :     case 9810:  /* *avx2_gatherdiv8sf_2 */
     606         5927 :     case 9809:  /* *avx2_gatherdiv8si_2 */
     607         5927 :     case 9808:  /* *avx2_gatherdiv4sf_2 */
     608         5927 :     case 9807:  /* *avx2_gatherdiv4si_2 */
     609         5927 :     case 9806:  /* *avx2_gatherdiv4df_2 */
     610         5927 :     case 9805:  /* *avx2_gatherdiv4di_2 */
     611         5927 :     case 9804:  /* *avx2_gatherdiv2df_2 */
     612         5927 :     case 9803:  /* *avx2_gatherdiv2di_2 */
     613         5927 :     case 9786:  /* *avx2_gathersiv8sf_2 */
     614         5927 :     case 9785:  /* *avx2_gathersiv8si_2 */
     615         5927 :     case 9784:  /* *avx2_gathersiv4sf_2 */
     616         5927 :     case 9783:  /* *avx2_gathersiv4si_2 */
     617         5927 :     case 9782:  /* *avx2_gathersiv4df_2 */
     618         5927 :     case 9781:  /* *avx2_gathersiv4di_2 */
     619         5927 :     case 9780:  /* *avx2_gathersiv2df_2 */
     620         5927 :     case 9779:  /* *avx2_gathersiv2di_2 */
     621         5927 :     case 9778:  /* *avx2_gathersiv8sf_2 */
     622         5927 :     case 9777:  /* *avx2_gathersiv8si_2 */
     623         5927 :     case 9776:  /* *avx2_gathersiv4sf_2 */
     624         5927 :     case 9775:  /* *avx2_gathersiv4si_2 */
     625         5927 :     case 9774:  /* *avx2_gathersiv4df_2 */
     626         5927 :     case 9773:  /* *avx2_gathersiv4di_2 */
     627         5927 :     case 9772:  /* *avx2_gathersiv2df_2 */
     628         5927 :     case 9771:  /* *avx2_gathersiv2di_2 */
     629         5927 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     630         5927 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
     631         5927 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1), 0), 0, 0));
     632         5927 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1), 0), 0, 1));
     633         5927 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 3));
     634         5927 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1), 0), 0, 2));
     635         5927 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     636         5927 :       break;
     637              : 
     638         6573 :     case 9802:  /* *avx2_gatherdiv8sf */
     639         6573 :     case 9801:  /* *avx2_gatherdiv8si */
     640         6573 :     case 9800:  /* *avx2_gatherdiv4sf */
     641         6573 :     case 9799:  /* *avx2_gatherdiv4si */
     642         6573 :     case 9798:  /* *avx2_gatherdiv4df */
     643         6573 :     case 9797:  /* *avx2_gatherdiv4di */
     644         6573 :     case 9796:  /* *avx2_gatherdiv2df */
     645         6573 :     case 9795:  /* *avx2_gatherdiv2di */
     646         6573 :     case 9794:  /* *avx2_gatherdiv8sf */
     647         6573 :     case 9793:  /* *avx2_gatherdiv8si */
     648         6573 :     case 9792:  /* *avx2_gatherdiv4sf */
     649         6573 :     case 9791:  /* *avx2_gatherdiv4si */
     650         6573 :     case 9790:  /* *avx2_gatherdiv4df */
     651         6573 :     case 9789:  /* *avx2_gatherdiv4di */
     652         6573 :     case 9788:  /* *avx2_gatherdiv2df */
     653         6573 :     case 9787:  /* *avx2_gatherdiv2di */
     654         6573 :     case 9770:  /* *avx2_gathersiv8sf */
     655         6573 :     case 9769:  /* *avx2_gathersiv8si */
     656         6573 :     case 9768:  /* *avx2_gathersiv4sf */
     657         6573 :     case 9767:  /* *avx2_gathersiv4si */
     658         6573 :     case 9766:  /* *avx2_gathersiv4df */
     659         6573 :     case 9765:  /* *avx2_gathersiv4di */
     660         6573 :     case 9764:  /* *avx2_gathersiv2df */
     661         6573 :     case 9763:  /* *avx2_gathersiv2di */
     662         6573 :     case 9762:  /* *avx2_gathersiv8sf */
     663         6573 :     case 9761:  /* *avx2_gathersiv8si */
     664         6573 :     case 9760:  /* *avx2_gathersiv4sf */
     665         6573 :     case 9759:  /* *avx2_gathersiv4si */
     666         6573 :     case 9758:  /* *avx2_gathersiv4df */
     667         6573 :     case 9757:  /* *avx2_gathersiv4di */
     668         6573 :     case 9756:  /* *avx2_gathersiv2df */
     669         6573 :     case 9755:  /* *avx2_gathersiv2di */
     670         6573 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     671         6573 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
     672         6573 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
     673         6573 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1), 0), 0, 0));
     674         6573 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1), 0), 0, 1));
     675         6573 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 3));
     676         6573 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1), 0), 0, 2));
     677         6573 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     678         6573 :       break;
     679              : 
     680            0 :     case 9754:  /* *avx512f_vcvtps2ph512_merge_mask */
     681            0 :     case 9748:  /* *vcvtps2ph256_merge_mask */
     682            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     683            0 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
     684            0 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
     685            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
     686            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
     687            0 :       recog_data.dup_num[0] = 0;
     688            0 :       break;
     689              : 
     690          430 :     case 9743:  /* *vcvtps2ph_mask */
     691          430 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     692          430 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
     693          430 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
     694          430 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
     695          430 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
     696          430 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
     697          430 :       break;
     698              : 
     699          478 :     case 9733:  /* vcvtph2ps_mask */
     700          478 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     701          478 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
     702          478 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
     703          478 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
     704          478 :       break;
     705              : 
     706        24306 :     case 10006:  /* compressstorev8hi_mask */
     707        24306 :     case 10005:  /* compressstorev16hi_mask */
     708        24306 :     case 10004:  /* compressstorev32hi_mask */
     709        24306 :     case 10003:  /* compressstorev32qi_mask */
     710        24306 :     case 10002:  /* compressstorev16qi_mask */
     711        24306 :     case 10001:  /* compressstorev64qi_mask */
     712        24306 :     case 10000:  /* avx512vl_compressstorev2df_mask */
     713        24306 :     case 9999:  /* avx512vl_compressstorev2di_mask */
     714        24306 :     case 9998:  /* avx512vl_compressstorev4sf_mask */
     715        24306 :     case 9997:  /* avx512vl_compressstorev4si_mask */
     716        24306 :     case 9996:  /* avx512vl_compressstorev4df_mask */
     717        24306 :     case 9995:  /* avx512vl_compressstorev4di_mask */
     718        24306 :     case 9994:  /* avx512vl_compressstorev8sf_mask */
     719        24306 :     case 9993:  /* avx512vl_compressstorev8si_mask */
     720        24306 :     case 9992:  /* avx512f_compressstorev8df_mask */
     721        24306 :     case 9991:  /* avx512f_compressstorev8di_mask */
     722        24306 :     case 9990:  /* avx512f_compressstorev16sf_mask */
     723        24306 :     case 9989:  /* avx512f_compressstorev16si_mask */
     724        24306 :     case 9634:  /* *avx512vl_storev2df_mask_1 */
     725        24306 :     case 9633:  /* *avx512vl_storev4df_mask_1 */
     726        24306 :     case 9632:  /* *avx512f_storev8df_mask_1 */
     727        24306 :     case 9631:  /* *avx512vl_storev4sf_mask_1 */
     728        24306 :     case 9630:  /* *avx512vl_storev8sf_mask_1 */
     729        24306 :     case 9629:  /* *avx512f_storev16sf_mask_1 */
     730        24306 :     case 9628:  /* *avx512vl_storev8bf_mask_1 */
     731        24306 :     case 9627:  /* *avx512vl_storev16bf_mask_1 */
     732        24306 :     case 9626:  /* *avx512bw_storev32bf_mask_1 */
     733        24306 :     case 9625:  /* *avx512fp16_storev8hf_mask_1 */
     734        24306 :     case 9624:  /* *avx512vl_storev16hf_mask_1 */
     735        24306 :     case 9623:  /* *avx512bw_storev32hf_mask_1 */
     736        24306 :     case 9622:  /* *avx512vl_storev2di_mask_1 */
     737        24306 :     case 9621:  /* *avx512vl_storev4di_mask_1 */
     738        24306 :     case 9620:  /* *avx512f_storev8di_mask_1 */
     739        24306 :     case 9619:  /* *avx512vl_storev4si_mask_1 */
     740        24306 :     case 9618:  /* *avx512vl_storev8si_mask_1 */
     741        24306 :     case 9617:  /* *avx512f_storev16si_mask_1 */
     742        24306 :     case 9616:  /* *avx512vl_storev8hi_mask_1 */
     743        24306 :     case 9615:  /* *avx512vl_storev16hi_mask_1 */
     744        24306 :     case 9614:  /* *avx512bw_storev32hi_mask_1 */
     745        24306 :     case 9613:  /* *avx512vl_storev16qi_mask_1 */
     746        24306 :     case 9612:  /* *avx512vl_storev32qi_mask_1 */
     747        24306 :     case 9611:  /* *avx512bw_storev64qi_mask_1 */
     748        24306 :     case 9610:  /* avx512vl_storev8bf_mask */
     749        24306 :     case 9609:  /* avx512vl_storev16bf_mask */
     750        24306 :     case 9608:  /* avx512bw_storev32bf_mask */
     751        24306 :     case 9607:  /* avx512fp16_storev8hf_mask */
     752        24306 :     case 9606:  /* avx512vl_storev16hf_mask */
     753        24306 :     case 9605:  /* avx512bw_storev32hf_mask */
     754        24306 :     case 9604:  /* avx512vl_storev8hi_mask */
     755        24306 :     case 9603:  /* avx512vl_storev16hi_mask */
     756        24306 :     case 9602:  /* avx512bw_storev32hi_mask */
     757        24306 :     case 9601:  /* avx512vl_storev32qi_mask */
     758        24306 :     case 9600:  /* avx512vl_storev16qi_mask */
     759        24306 :     case 9599:  /* avx512bw_storev64qi_mask */
     760        24306 :     case 9598:  /* avx512vl_storev2df_mask */
     761        24306 :     case 9597:  /* avx512vl_storev4df_mask */
     762        24306 :     case 9596:  /* avx512f_storev8df_mask */
     763        24306 :     case 9595:  /* avx512vl_storev4sf_mask */
     764        24306 :     case 9594:  /* avx512vl_storev8sf_mask */
     765        24306 :     case 9593:  /* avx512f_storev16sf_mask */
     766        24306 :     case 9592:  /* avx512vl_storev2di_mask */
     767        24306 :     case 9591:  /* avx512vl_storev4di_mask */
     768        24306 :     case 9590:  /* avx512f_storev8di_mask */
     769        24306 :     case 9589:  /* avx512vl_storev4si_mask */
     770        24306 :     case 9588:  /* avx512vl_storev8si_mask */
     771        24306 :     case 9587:  /* avx512f_storev16si_mask */
     772        24306 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     773        24306 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
     774        24306 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 2));
     775        24306 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (pat, 1), 0, 1);
     776        24306 :       recog_data.dup_num[0] = 0;
     777        24306 :       break;
     778              : 
     779         6441 :     case 9586:  /* avx2_maskstored */
     780         6441 :     case 9585:  /* avx2_maskstored256 */
     781         6441 :     case 9584:  /* avx_maskstorepd256 */
     782         6441 :     case 9583:  /* avx_maskstoreps256 */
     783         6441 :     case 9582:  /* avx2_maskstoreq */
     784         6441 :     case 9581:  /* avx2_maskstoreq256 */
     785         6441 :     case 9580:  /* avx_maskstorepd */
     786         6441 :     case 9579:  /* avx_maskstoreps */
     787         6441 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     788         6441 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
     789         6441 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
     790         6441 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (pat, 1), 0, 2);
     791         6441 :       recog_data.dup_num[0] = 0;
     792         6441 :       break;
     793              : 
     794         9968 :     case 9578:  /* avx2_maskloadd */
     795         9968 :     case 9577:  /* avx2_maskloadd256 */
     796         9968 :     case 9576:  /* avx_maskloadpd256 */
     797         9968 :     case 9575:  /* avx_maskloadps256 */
     798         9968 :     case 9574:  /* avx2_maskloadq */
     799         9968 :     case 9573:  /* avx2_maskloadq256 */
     800         9968 :     case 9572:  /* avx_maskloadpd */
     801         9968 :     case 9571:  /* avx_maskloadps */
     802         9968 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     803         9968 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 1));
     804         9968 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 0));
     805         9968 :       break;
     806              : 
     807         5770 :     case 9532:  /* avx512vl_vpermt2varv16qi3_mask */
     808         5770 :     case 9531:  /* avx512vl_vpermt2varv32qi3_mask */
     809         5770 :     case 9530:  /* avx512bw_vpermt2varv64qi3_mask */
     810         5770 :     case 9529:  /* avx512vl_vpermt2varv8hi3_mask */
     811         5770 :     case 9528:  /* avx512vl_vpermt2varv16hi3_mask */
     812         5770 :     case 9527:  /* avx512bw_vpermt2varv32hi3_mask */
     813         5770 :     case 9526:  /* avx512vl_vpermt2varv2df3_mask */
     814         5770 :     case 9525:  /* avx512vl_vpermt2varv2di3_mask */
     815         5770 :     case 9524:  /* avx512vl_vpermt2varv4sf3_mask */
     816         5770 :     case 9523:  /* avx512vl_vpermt2varv4si3_mask */
     817         5770 :     case 9522:  /* avx512vl_vpermt2varv4df3_mask */
     818         5770 :     case 9521:  /* avx512vl_vpermt2varv4di3_mask */
     819         5770 :     case 9520:  /* avx512vl_vpermt2varv8sf3_mask */
     820         5770 :     case 9519:  /* avx512vl_vpermt2varv8si3_mask */
     821         5770 :     case 9518:  /* avx512f_vpermt2varv8df3_mask */
     822         5770 :     case 9517:  /* avx512f_vpermt2varv8di3_mask */
     823         5770 :     case 9516:  /* avx512f_vpermt2varv16sf3_mask */
     824         5770 :     case 9515:  /* avx512f_vpermt2varv16si3_mask */
     825         5770 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     826         5770 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
     827         5770 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
     828         5770 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
     829         5770 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
     830         5770 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
     831         5770 :       recog_data.dup_num[0] = 2;
     832         5770 :       break;
     833              : 
     834         1606 :     case 9466:  /* *avx512vl_vpermi2varv2df3_mask */
     835         1606 :     case 9465:  /* *avx512vl_vpermi2varv4df3_mask */
     836         1606 :     case 9464:  /* *avx512f_vpermi2varv8df3_mask */
     837         1606 :     case 9463:  /* *avx512vl_vpermi2varv4sf3_mask */
     838         1606 :     case 9462:  /* *avx512vl_vpermi2varv8sf3_mask */
     839         1606 :     case 9461:  /* *avx512f_vpermi2varv16sf3_mask */
     840         1606 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     841         1606 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
     842         1606 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
     843         1606 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
     844         1606 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
     845         1606 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 1), 0);
     846         1606 :       recog_data.dup_num[0] = 2;
     847         1606 :       break;
     848              : 
     849         3626 :     case 9460:  /* *avx512vl_vpermi2varv16qi3_mask */
     850         3626 :     case 9459:  /* *avx512vl_vpermi2varv32qi3_mask */
     851         3626 :     case 9458:  /* *avx512bw_vpermi2varv64qi3_mask */
     852         3626 :     case 9457:  /* *avx512vl_vpermi2varv8hi3_mask */
     853         3626 :     case 9456:  /* *avx512vl_vpermi2varv16hi3_mask */
     854         3626 :     case 9455:  /* *avx512bw_vpermi2varv32hi3_mask */
     855         3626 :     case 9454:  /* *avx512vl_vpermi2varv2di3_mask */
     856         3626 :     case 9453:  /* *avx512vl_vpermi2varv4di3_mask */
     857         3626 :     case 9452:  /* *avx512vl_vpermi2varv4si3_mask */
     858         3626 :     case 9451:  /* *avx512vl_vpermi2varv8si3_mask */
     859         3626 :     case 9450:  /* *avx512f_vpermi2varv8di3_mask */
     860         3626 :     case 9449:  /* *avx512f_vpermi2varv16si3_mask */
     861         3626 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     862         3626 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
     863         3626 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
     864         3626 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
     865         3626 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
     866         3626 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
     867         3626 :       recog_data.dup_num[0] = 2;
     868         3626 :       break;
     869              : 
     870            2 :     case 9374:  /* avx2_lddqu_inserti_to_bcasti */
     871            2 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     872            2 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
     873            2 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0, 0);
     874            2 :       recog_data.dup_num[0] = 1;
     875            2 :       break;
     876              : 
     877        20061 :     case 9396:  /* avx_vbroadcastf128_v16bf */
     878        20061 :     case 9395:  /* avx_vbroadcastf128_v16hf */
     879        20061 :     case 9394:  /* avx_vbroadcastf128_v4df */
     880        20061 :     case 9393:  /* avx_vbroadcastf128_v8sf */
     881        20061 :     case 9392:  /* avx_vbroadcastf128_v4di */
     882        20061 :     case 9391:  /* avx_vbroadcastf128_v8si */
     883        20061 :     case 9390:  /* avx_vbroadcastf128_v16hi */
     884        20061 :     case 9389:  /* avx_vbroadcastf128_v32qi */
     885        20061 :     case 9373:  /* avx2_vbroadcasti128_v4di */
     886        20061 :     case 9372:  /* avx2_vbroadcasti128_v8si */
     887        20061 :     case 9371:  /* avx2_vbroadcasti128_v16hi */
     888        20061 :     case 9370:  /* avx2_vbroadcasti128_v32qi */
     889        20061 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     890        20061 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
     891        20061 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
     892        20061 :       recog_data.dup_num[0] = 1;
     893        20061 :       break;
     894              : 
     895         2686 :     case 9246:  /* *avx_vpermilpv2df_mask */
     896         2686 :     case 9244:  /* *avx_vpermilpv4df_mask */
     897         2686 :     case 9242:  /* *avx512f_vpermilpv8df_mask */
     898         2686 :     case 9240:  /* *avx_vpermilpv4sf_mask */
     899         2686 :     case 9238:  /* *avx_vpermilpv8sf_mask */
     900         2686 :     case 9236:  /* *avx512f_vpermilpv16sf_mask */
     901         2686 :     case 9234:  /* *avx512vl_vpermilpv2di_mask */
     902         2686 :     case 9232:  /* *avx512vl_vpermilpv4di_mask */
     903         2686 :     case 9230:  /* *avx512f_vpermilpv8di_mask */
     904         2686 :     case 9228:  /* *sse2_vpermilpv4si_mask */
     905         2686 :     case 9226:  /* *avx_vpermilpv8si_mask */
     906         2686 :     case 9224:  /* *avx512f_vpermilpv16si_mask */
     907         2686 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     908         2686 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
     909         2686 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
     910         2686 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
     911         2686 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
     912         2686 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
     913         2686 :       break;
     914              : 
     915        96070 :     case 9546:  /* *ssse3_palignrv2df_perm */
     916        96070 :     case 9545:  /* *ssse3_palignrv4sf_perm */
     917        96070 :     case 9544:  /* *ssse3_palignrv2di_perm */
     918        96070 :     case 9543:  /* *ssse3_palignrv4si_perm */
     919        96070 :     case 9542:  /* *ssse3_palignrv8bf_perm */
     920        96070 :     case 9541:  /* *ssse3_palignrv8hf_perm */
     921        96070 :     case 9540:  /* *ssse3_palignrv8hi_perm */
     922        96070 :     case 9539:  /* *ssse3_palignrv16qi_perm */
     923        96070 :     case 9245:  /* *avx_vpermilpv2df */
     924        96070 :     case 9243:  /* *avx_vpermilpv4df */
     925        96070 :     case 9241:  /* *avx512f_vpermilpv8df */
     926        96070 :     case 9239:  /* *avx_vpermilpv4sf */
     927        96070 :     case 9237:  /* *avx_vpermilpv8sf */
     928        96070 :     case 9235:  /* *avx512f_vpermilpv16sf */
     929        96070 :     case 9233:  /* *avx512vl_vpermilpv2di */
     930        96070 :     case 9231:  /* *avx512vl_vpermilpv4di */
     931        96070 :     case 9229:  /* *avx512f_vpermilpv8di */
     932        96070 :     case 9227:  /* *sse2_vpermilpv4si */
     933        96070 :     case 9225:  /* *avx_vpermilpv8si */
     934        96070 :     case 9223:  /* *avx512f_vpermilpv16si */
     935        96070 :     case 9222:  /* *avx_vperm_broadcast_v4df */
     936        96070 :     case 9221:  /* *avx_vperm_broadcast_v8sf */
     937        96070 :     case 9220:  /* *avx_vperm_broadcast_v4sf */
     938        96070 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     939        96070 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
     940        96070 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
     941        96070 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
     942        96070 :       break;
     943              : 
     944         1841 :     case 9154:  /* *avx_vzeroall */
     945         1841 :       ro[0] = *(ro_loc[0] = &PATTERN (insn));
     946         1841 :       break;
     947              : 
     948         1036 :     case 9138:  /* xop_maskcmp_uns2v2di3 */
     949         1036 :     case 9137:  /* xop_maskcmp_uns2v4si3 */
     950         1036 :     case 9136:  /* xop_maskcmp_uns2v8hi3 */
     951         1036 :     case 9135:  /* xop_maskcmp_uns2v16qi3 */
     952         1036 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     953         1036 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
     954         1036 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
     955         1036 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
     956         1036 :       break;
     957              : 
     958        12689 :     case 9117:  /* xop_shlv2di3 */
     959        12689 :     case 9116:  /* xop_shlv4si3 */
     960        12689 :     case 9115:  /* xop_shlv8hi3 */
     961        12689 :     case 9114:  /* xop_shlv16qi3 */
     962        12689 :     case 9113:  /* xop_shav2di3 */
     963        12689 :     case 9112:  /* xop_shav4si3 */
     964        12689 :     case 9111:  /* xop_shav8hi3 */
     965        12689 :     case 9110:  /* xop_shav16qi3 */
     966        12689 :     case 9109:  /* xop_vrotlv2di3 */
     967        12689 :     case 9108:  /* xop_vrotlv4si3 */
     968        12689 :     case 9107:  /* xop_vrotlv8hi3 */
     969        12689 :     case 9106:  /* xop_vrotlv16qi3 */
     970        12689 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     971        12689 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
     972        12689 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
     973        12689 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 1), 1);
     974        12689 :       recog_data.dup_num[0] = 2;
     975        12689 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 2), 0);
     976        12689 :       recog_data.dup_num[1] = 1;
     977        12689 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 2), 1), 0);
     978        12689 :       recog_data.dup_num[2] = 2;
     979        12689 :       break;
     980              : 
     981            0 :     case 9097:  /* xop_pperm_pack_v8hi_v16qi */
     982            0 :     case 9096:  /* xop_pperm_pack_v4si_v8hi */
     983            0 :     case 9095:  /* xop_pperm_pack_v2di_v4si */
     984            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     985            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
     986            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
     987            0 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
     988            0 :       break;
     989              : 
     990          260 :     case 9084:  /* xop_phaddubq */
     991          260 :     case 9083:  /* xop_phaddbq */
     992          260 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     993          260 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0));
     994          260 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1), 0), 0);
     995          260 :       recog_data.dup_num[0] = 1;
     996          260 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0), 0), 0);
     997          260 :       recog_data.dup_num[1] = 1;
     998          260 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 1), 0), 0);
     999          260 :       recog_data.dup_num[2] = 1;
    1000          260 :       recog_data.dup_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 0), 0);
    1001          260 :       recog_data.dup_num[3] = 1;
    1002          260 :       recog_data.dup_loc[4] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1), 0), 0);
    1003          260 :       recog_data.dup_num[4] = 1;
    1004          260 :       recog_data.dup_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 0), 0), 0);
    1005          260 :       recog_data.dup_num[5] = 1;
    1006          260 :       recog_data.dup_loc[6] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 1), 0), 0);
    1007          260 :       recog_data.dup_num[6] = 1;
    1008          260 :       break;
    1009              : 
    1010          520 :     case 9088:  /* xop_phadduwq */
    1011          520 :     case 9087:  /* xop_phaddwq */
    1012          520 :     case 9082:  /* xop_phaddubd */
    1013          520 :     case 9081:  /* xop_phaddbd */
    1014          520 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1015          520 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    1016          520 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0), 0);
    1017          520 :       recog_data.dup_num[0] = 1;
    1018          520 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 0);
    1019          520 :       recog_data.dup_num[1] = 1;
    1020          520 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 0), 0);
    1021          520 :       recog_data.dup_num[2] = 1;
    1022          520 :       break;
    1023              : 
    1024         1332 :     case 9093:  /* xop_phsubdq */
    1025         1332 :     case 9092:  /* xop_phsubwd */
    1026         1332 :     case 9091:  /* xop_phsubbw */
    1027         1332 :     case 9090:  /* xop_phaddudq */
    1028         1332 :     case 9089:  /* xop_phadddq */
    1029         1332 :     case 9086:  /* xop_phadduwd */
    1030         1332 :     case 9085:  /* xop_phaddwd */
    1031         1332 :     case 9080:  /* xop_phaddubw */
    1032         1332 :     case 9079:  /* xop_phaddbw */
    1033         1332 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1034         1332 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    1035         1332 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0);
    1036         1332 :       recog_data.dup_num[0] = 1;
    1037         1332 :       break;
    1038              : 
    1039          416 :     case 9062:  /* xop_pmadcsswd */
    1040          416 :     case 9061:  /* xop_pmadcswd */
    1041          416 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1042          416 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0));
    1043          416 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1), 0), 0));
    1044          416 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    1045          416 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0), 0), 0);
    1046          416 :       recog_data.dup_num[0] = 1;
    1047          416 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 1), 0), 0);
    1048          416 :       recog_data.dup_num[1] = 2;
    1049          416 :       break;
    1050              : 
    1051         2849 :     case 9060:  /* xop_pmacsswd */
    1052         2849 :     case 9059:  /* xop_pmacswd */
    1053         2849 :     case 9058:  /* xop_pmacssdqh */
    1054         2849 :     case 9057:  /* xop_pmacsdqh */
    1055         2849 :     case 9056:  /* xop_pmacssdql */
    1056         2849 :     case 9055:  /* xop_pmacsdql */
    1057         2849 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1058         2849 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    1059         2849 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0), 0));
    1060         2849 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    1061         2849 :       break;
    1062              : 
    1063         1774 :     case 9050:  /* sse4_2_pcmpistr_cconly */
    1064         1774 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    1065         1774 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 2), 0));
    1066         1774 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    1067         1774 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    1068         1774 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
    1069         1774 :       break;
    1070              : 
    1071         1976 :     case 9049:  /* sse4_2_pcmpistrm */
    1072         1976 :     case 9048:  /* sse4_2_pcmpistri */
    1073         1976 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    1074         1976 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    1075         1976 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    1076         1976 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
    1077         1976 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 2);
    1078         1976 :       recog_data.dup_num[0] = 3;
    1079         1976 :       recog_data.dup_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 1);
    1080         1976 :       recog_data.dup_num[1] = 2;
    1081         1976 :       recog_data.dup_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 0);
    1082         1976 :       recog_data.dup_num[2] = 1;
    1083         1976 :       break;
    1084              : 
    1085         1287 :     case 9047:  /* sse4_2_pcmpistr */
    1086         1287 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    1087         1287 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
    1088         1287 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    1089         1287 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    1090         1287 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
    1091         1287 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0, 2);
    1092         1287 :       recog_data.dup_num[0] = 4;
    1093         1287 :       recog_data.dup_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0, 1);
    1094         1287 :       recog_data.dup_num[1] = 3;
    1095         1287 :       recog_data.dup_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0, 0);
    1096         1287 :       recog_data.dup_num[2] = 2;
    1097         1287 :       recog_data.dup_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 2);
    1098         1287 :       recog_data.dup_num[3] = 4;
    1099         1287 :       recog_data.dup_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 1);
    1100         1287 :       recog_data.dup_num[4] = 3;
    1101         1287 :       recog_data.dup_loc[5] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 0);
    1102         1287 :       recog_data.dup_num[5] = 2;
    1103         1287 :       break;
    1104              : 
    1105         1336 :     case 9046:  /* sse4_2_pcmpestr_cconly */
    1106         1336 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    1107         1336 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 2), 0));
    1108         1336 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    1109         1336 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    1110         1336 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
    1111         1336 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 3));
    1112         1336 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 4));
    1113         1336 :       break;
    1114              : 
    1115         1810 :     case 9045:  /* sse4_2_pcmpestrm */
    1116         1810 :     case 9044:  /* sse4_2_pcmpestri */
    1117         1810 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    1118         1810 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    1119         1810 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    1120         1810 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
    1121         1810 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 3));
    1122         1810 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 4));
    1123         1810 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 4);
    1124         1810 :       recog_data.dup_num[0] = 5;
    1125         1810 :       recog_data.dup_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 3);
    1126         1810 :       recog_data.dup_num[1] = 4;
    1127         1810 :       recog_data.dup_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 2);
    1128         1810 :       recog_data.dup_num[2] = 3;
    1129         1810 :       recog_data.dup_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 1);
    1130         1810 :       recog_data.dup_num[3] = 2;
    1131         1810 :       recog_data.dup_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 0);
    1132         1810 :       recog_data.dup_num[4] = 1;
    1133         1810 :       break;
    1134              : 
    1135         1225 :     case 9043:  /* sse4_2_pcmpestr */
    1136         1225 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    1137         1225 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
    1138         1225 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    1139         1225 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    1140         1225 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
    1141         1225 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 3));
    1142         1225 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 4));
    1143         1225 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0, 4);
    1144         1225 :       recog_data.dup_num[0] = 6;
    1145         1225 :       recog_data.dup_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0, 3);
    1146         1225 :       recog_data.dup_num[1] = 5;
    1147         1225 :       recog_data.dup_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0, 2);
    1148         1225 :       recog_data.dup_num[2] = 4;
    1149         1225 :       recog_data.dup_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0, 1);
    1150         1225 :       recog_data.dup_num[3] = 3;
    1151         1225 :       recog_data.dup_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0, 0);
    1152         1225 :       recog_data.dup_num[4] = 2;
    1153         1225 :       recog_data.dup_loc[5] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 4);
    1154         1225 :       recog_data.dup_num[5] = 6;
    1155         1225 :       recog_data.dup_loc[6] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 3);
    1156         1225 :       recog_data.dup_num[6] = 5;
    1157         1225 :       recog_data.dup_loc[7] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 2);
    1158         1225 :       recog_data.dup_num[7] = 4;
    1159         1225 :       recog_data.dup_loc[8] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 1);
    1160         1225 :       recog_data.dup_num[8] = 3;
    1161         1225 :       recog_data.dup_loc[9] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 0);
    1162         1225 :       recog_data.dup_num[9] = 2;
    1163         1225 :       break;
    1164              : 
    1165           12 :     case 9032:  /* *ptestv2di_ccz */
    1166           12 :     case 9031:  /* *ptestv4di_ccz */
    1167           12 :     case 9030:  /* *ptestv4si_ccz */
    1168           12 :     case 9029:  /* *ptestv8si_ccz */
    1169           12 :     case 9028:  /* *ptestv8hi_ccz */
    1170           12 :     case 9027:  /* *ptestv16hi_ccz */
    1171           12 :     case 9026:  /* *ptestv16qi_ccz */
    1172           12 :     case 9025:  /* *ptestv32qi_ccz */
    1173           12 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    1174           12 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    1175           12 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    1176           12 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 1), 0), 0);
    1177           12 :       recog_data.dup_num[0] = 0;
    1178           12 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 1), 0), 1);
    1179           12 :       recog_data.dup_num[1] = 1;
    1180           12 :       recog_data.dup_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 1), 1);
    1181           12 :       recog_data.dup_num[2] = 2;
    1182           12 :       break;
    1183              : 
    1184            7 :     case 9024:  /* *ptestv4df_and */
    1185            7 :     case 9023:  /* *ptestv8sf_and */
    1186            7 :     case 9022:  /* *ptestv2ti_and */
    1187            7 :     case 9021:  /* *ptestv4di_and */
    1188            7 :     case 9020:  /* *ptestv8si_and */
    1189            7 :     case 9019:  /* *ptestv16hi_and */
    1190            7 :     case 9018:  /* *ptestv32qi_and */
    1191            7 :     case 9017:  /* *ptestv2df_and */
    1192            7 :     case 9016:  /* *ptestv4sf_and */
    1193            7 :     case 9015:  /* *ptestv1ti_and */
    1194            7 :     case 9014:  /* *ptestv2di_and */
    1195            7 :     case 9013:  /* *ptestv4si_and */
    1196            7 :     case 9012:  /* *ptestv8hi_and */
    1197            7 :     case 9011:  /* *ptestv16qi_and */
    1198            7 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
    1199            7 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    1200            7 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 1), 0);
    1201            7 :       recog_data.dup_num[0] = 0;
    1202            7 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 1), 1);
    1203            7 :       recog_data.dup_num[1] = 1;
    1204            7 :       break;
    1205              : 
    1206           39 :     case 8991:  /* *sse4_1_zero_extendv2siv2di2_4 */
    1207           39 :     case 8977:  /* *avx2_zero_extendv4siv4di2_2 */
    1208           39 :     case 8971:  /* *avx512f_zero_extendv8siv8di2_2 */
    1209           39 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1210           39 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    1211           39 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    1212           39 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    1213           39 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    1214           39 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    1215           39 :       break;
    1216              : 
    1217           10 :     case 8937:  /* *sse4_1_zero_extendv2qiv2di2_2 */
    1218           10 :     case 8936:  /* *sse4_1_zero_extendv2qiv2di2_2 */
    1219           10 :     case 8935:  /* *sse4_1_zero_extendv2qiv2di2_2 */
    1220           10 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1221           10 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0));
    1222           10 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 1));
    1223           10 :       break;
    1224              : 
    1225           27 :     case 8965:  /* *avx512vl_zero_extendv2hiv2di2_mask_2 */
    1226           27 :     case 8964:  /* *avx512vl_sign_extendv2hiv2di2_mask_2 */
    1227           27 :     case 8926:  /* *avx512vl_zero_extendv4qiv4di2_mask_2 */
    1228           27 :     case 8925:  /* *avx512vl_sign_extendv4qiv4di2_mask_2 */
    1229           27 :     case 8870:  /* *avx512vl_zero_extendv4qiv4si2_mask_2 */
    1230           27 :     case 8869:  /* *avx512vl_sign_extendv4qiv4si2_mask_2 */
    1231           27 :     case 8868:  /* *sse4_1_zero_extendv4qiv4si2_2 */
    1232           27 :     case 8866:  /* *sse4_1_sign_extendv4qiv4si2_2 */
    1233           27 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1234           27 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0), 0));
    1235           27 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    1236           27 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    1237           27 :       break;
    1238              : 
    1239           20 :     case 8963:  /* *sse4_1_zero_extendv2hiv2di2_2 */
    1240           20 :     case 8962:  /* *sse4_1_sign_extendv2hiv2di2_2 */
    1241           20 :     case 8924:  /* *avx2_zero_extendv4qiv4di2_2 */
    1242           20 :     case 8923:  /* *avx2_sign_extendv4qiv4di2_2 */
    1243           20 :     case 8867:  /* *sse4_1_zero_extendv4qiv4si2_2 */
    1244           20 :     case 8865:  /* *sse4_1_sign_extendv4qiv4si2_2 */
    1245           20 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1246           20 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0));
    1247           20 :       break;
    1248              : 
    1249           54 :     case 8989:  /* *avx512vl_zero_extendv2siv2di2_mask_2 */
    1250           54 :     case 8988:  /* *avx512vl_sign_extendv2siv2di2_mask_2 */
    1251           54 :     case 8953:  /* *avx512vl_zero_extendv4hiv4di2_mask_2 */
    1252           54 :     case 8952:  /* *avx512vl_sign_extendv4hiv4di2_mask_2 */
    1253           54 :     case 8914:  /* *avx512f_zero_extendv8qiv8di2_mask_2 */
    1254           54 :     case 8913:  /* *avx512f_sign_extendv8qiv8di2_mask_2 */
    1255           54 :     case 8898:  /* *avx512vl_zero_extendv4hiv4si2_mask_2 */
    1256           54 :     case 8897:  /* *avx512vl_sign_extendv4hiv4si2_mask_2 */
    1257           54 :     case 8856:  /* *avx512vl_zero_extendv8qiv8si2_mask_2 */
    1258           54 :     case 8855:  /* *avx512vl_sign_extendv8qiv8si2_mask_2 */
    1259           54 :     case 8836:  /* *avx512vl_zero_extendv8qiv8hi2_mask_2 */
    1260           54 :     case 8835:  /* *avx512vl_sign_extendv8qiv8hi2_mask_2 */
    1261           54 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1262           54 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0));
    1263           54 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    1264           54 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    1265           54 :       break;
    1266              : 
    1267           36 :     case 8987:  /* *sse4_1_zero_extendv2siv2di2_2 */
    1268           36 :     case 8986:  /* *sse4_1_sign_extendv2siv2di2_2 */
    1269           36 :     case 8951:  /* *avx2_zero_extendv4hiv4di2_2 */
    1270           36 :     case 8950:  /* *avx2_sign_extendv4hiv4di2_2 */
    1271           36 :     case 8912:  /* *avx512f_zero_extendv8qiv8di2_2 */
    1272           36 :     case 8911:  /* *avx512f_sign_extendv8qiv8di2_2 */
    1273           36 :     case 8896:  /* *sse4_1_zero_extendv4hiv4si2_2 */
    1274           36 :     case 8895:  /* *sse4_1_sign_extendv4hiv4si2_2 */
    1275           36 :     case 8854:  /* *avx2_zero_extendv8qiv8si2_2 */
    1276           36 :     case 8853:  /* *avx2_sign_extendv8qiv8si2_2 */
    1277           36 :     case 8834:  /* *sse4_1_zero_extendv8qiv8hi2_2 */
    1278           36 :     case 8833:  /* *sse4_1_sign_extendv8qiv8hi2_2 */
    1279           36 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1280           36 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    1281           36 :       break;
    1282              : 
    1283          114 :     case 8902:  /* *sse4_1_zero_extendv4hiv4si2_4 */
    1284          114 :     case 8901:  /* *sse4_1_zero_extendv4hiv4si2_4 */
    1285          114 :     case 8900:  /* *sse4_1_zero_extendv4hiv4si2_4 */
    1286          114 :     case 8886:  /* *avx2_zero_extendv8hiv8si2_2 */
    1287          114 :     case 8885:  /* *avx2_zero_extendv8hiv8si2_2 */
    1288          114 :     case 8884:  /* *avx2_zero_extendv8hiv8si2_2 */
    1289          114 :     case 8878:  /* *avx512f_zero_extendv16hiv16si2_2 */
    1290          114 :     case 8877:  /* *avx512f_zero_extendv16hiv16si2_2 */
    1291          114 :     case 8876:  /* *avx512f_zero_extendv16hiv16si2_2 */
    1292          114 :     case 8840:  /* *sse4_1_zero_extendv8qiv8hi2_4 */
    1293          114 :     case 8839:  /* *sse4_1_zero_extendv8qiv8hi2_4 */
    1294          114 :     case 8838:  /* *sse4_1_zero_extendv8qiv8hi2_4 */
    1295          114 :     case 8824:  /* *avx512bw_zero_extendv32qiv32hi2_2 */
    1296          114 :     case 8823:  /* *avx512bw_zero_extendv32qiv32hi2_2 */
    1297          114 :     case 8822:  /* *avx512bw_zero_extendv32qiv32hi2_2 */
    1298          114 :     case 8816:  /* *avx2_zero_extendv16qiv16hi2_2 */
    1299          114 :     case 8815:  /* *avx2_zero_extendv16qiv16hi2_2 */
    1300          114 :     case 8814:  /* *avx2_zero_extendv16qiv16hi2_2 */
    1301          114 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1302          114 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    1303          114 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 1));
    1304          114 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    1305          114 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    1306          114 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    1307          114 :       break;
    1308              : 
    1309        33952 :     case 9731:  /* *vec_concatv2df_0_1 */
    1310        33952 :     case 9730:  /* *vec_concatv4df_0_1 */
    1311        33952 :     case 9729:  /* *vec_concatv8df_0_1 */
    1312        33952 :     case 9728:  /* *vec_concatv4sf_0_1 */
    1313        33952 :     case 9727:  /* *vec_concatv8sf_0_1 */
    1314        33952 :     case 9726:  /* *vec_concatv16sf_0_1 */
    1315        33952 :     case 9725:  /* *vec_concatv8bf_0_1 */
    1316        33952 :     case 9724:  /* *vec_concatv16bf_0_1 */
    1317        33952 :     case 9723:  /* *vec_concatv32bf_0_1 */
    1318        33952 :     case 9722:  /* *vec_concatv8hf_0_1 */
    1319        33952 :     case 9721:  /* *vec_concatv16hf_0_1 */
    1320        33952 :     case 9720:  /* *vec_concatv32hf_0_1 */
    1321        33952 :     case 9719:  /* *vec_concatv2di_0_1 */
    1322        33952 :     case 9718:  /* *vec_concatv4di_0_1 */
    1323        33952 :     case 9717:  /* *vec_concatv8di_0_1 */
    1324        33952 :     case 9716:  /* *vec_concatv4si_0_1 */
    1325        33952 :     case 9715:  /* *vec_concatv8si_0_1 */
    1326        33952 :     case 9714:  /* *vec_concatv16si_0_1 */
    1327        33952 :     case 9713:  /* *vec_concatv8hi_0_1 */
    1328        33952 :     case 9712:  /* *vec_concatv16hi_0_1 */
    1329        33952 :     case 9711:  /* *vec_concatv32hi_0_1 */
    1330        33952 :     case 9710:  /* *vec_concatv16qi_0_1 */
    1331        33952 :     case 9709:  /* *vec_concatv32qi_0_1 */
    1332        33952 :     case 9708:  /* *vec_concatv64qi_0_1 */
    1333        33952 :     case 9538:  /* *avx_vperm2f128v4df_nozero */
    1334        33952 :     case 9537:  /* *avx_vperm2f128v8sf_nozero */
    1335        33952 :     case 9536:  /* *avx_vperm2f128v8si_nozero */
    1336        33952 :     case 9404:  /* *avx_vbroadcastf128_v16bf_perm */
    1337        33952 :     case 9403:  /* *avx_vbroadcastf128_v16hf_perm */
    1338        33952 :     case 9402:  /* *avx_vbroadcastf128_v4df_perm */
    1339        33952 :     case 9401:  /* *avx_vbroadcastf128_v8sf_perm */
    1340        33952 :     case 9400:  /* *avx_vbroadcastf128_v4di_perm */
    1341        33952 :     case 9399:  /* *avx_vbroadcastf128_v8si_perm */
    1342        33952 :     case 9398:  /* *avx_vbroadcastf128_v16hi_perm */
    1343        33952 :     case 9397:  /* *avx_vbroadcastf128_v32qi_perm */
    1344        33952 :     case 8990:  /* *sse4_1_zero_extendv2siv2di2_3 */
    1345        33952 :     case 8976:  /* *avx2_zero_extendv4siv4di2_1 */
    1346        33952 :     case 8970:  /* *avx512f_zero_extendv8siv8di2_1 */
    1347        33952 :     case 8899:  /* *sse4_1_zero_extendv4hiv4si2_3 */
    1348        33952 :     case 8883:  /* avx2_zero_extendv8hiv8si2_1 */
    1349        33952 :     case 8875:  /* avx512f_zero_extendv16hiv16si2_1 */
    1350        33952 :     case 8837:  /* *sse4_1_zero_extendv8qiv8hi2_3 */
    1351        33952 :     case 8821:  /* *avx512bw_zero_extendv32qiv32hi2_1 */
    1352        33952 :     case 8813:  /* *avx2_zero_extendv16qiv16hi2_1 */
    1353        33952 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1354        33952 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    1355        33952 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    1356        33952 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    1357        33952 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    1358        33952 :       break;
    1359              : 
    1360            8 :     case 8799:  /* *sse4_1_pblendvb_gt_subreg_not */
    1361            8 :     case 8798:  /* *avx2_pblendvb_gt_subreg_not */
    1362            8 :     case 8797:  /* *sse4_1_pblendvb_lt_subreg_not */
    1363            8 :     case 8796:  /* *avx2_pblendvb_lt_subreg_not */
    1364            8 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1365            8 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 1));
    1366            8 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 0));
    1367            8 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0), 0), 0));
    1368            8 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 1));
    1369            8 :       break;
    1370              : 
    1371           24 :     case 8768:  /* *avx_blendvpd256_not_gtint */
    1372           24 :     case 8767:  /* *avx_blendvps256_not_gtint */
    1373           24 :     case 8766:  /* *sse4_1_blendvpd_not_gtint */
    1374           24 :     case 8765:  /* *sse4_1_blendvps_not_gtint */
    1375           24 :     case 8764:  /* *avx_blendvpd256_not_ltint */
    1376           24 :     case 8763:  /* *avx_blendvps256_not_ltint */
    1377           24 :     case 8762:  /* *sse4_1_blendvpd_not_ltint */
    1378           24 :     case 8761:  /* *sse4_1_blendvps_not_ltint */
    1379           24 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1380           24 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
    1381           24 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    1382           24 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0), 0), 0), 0));
    1383           24 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0), 1));
    1384           24 :       break;
    1385              : 
    1386          813 :     case 8760:  /* *avx_blendvpd256_gtint */
    1387          813 :     case 8759:  /* *avx_blendvps256_gtint */
    1388          813 :     case 8758:  /* *sse4_1_blendvpd_gtint */
    1389          813 :     case 8757:  /* *sse4_1_blendvps_gtint */
    1390          813 :     case 8756:  /* *avx_blendvpd256_ltint */
    1391          813 :     case 8755:  /* *avx_blendvps256_ltint */
    1392          813 :     case 8754:  /* *sse4_1_blendvpd_ltint */
    1393          813 :     case 8753:  /* *sse4_1_blendvps_ltint */
    1394          813 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1395          813 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
    1396          813 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    1397          813 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0), 0));
    1398          813 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0), 1));
    1399          813 :       break;
    1400              : 
    1401          306 :     case 8686:  /* *ssse3_pshufbv8qi3 */
    1402          306 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    1403          306 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    1404          306 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    1405          306 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
    1406          306 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
    1407          306 :       break;
    1408              : 
    1409          959 :     case 8677:  /* *ssse3_pmulhrswv8hi3_mask */
    1410          959 :     case 8675:  /* *avx2_pmulhrswv16hi3_mask */
    1411          959 :     case 8673:  /* *avx512bw_pmulhrswv32hi3_mask */
    1412          959 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1413          959 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0), 0), 0));
    1414          959 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0), 1), 0));
    1415          959 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 1));
    1416          959 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    1417          959 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
    1418          959 :       break;
    1419              : 
    1420          965 :     case 8679:  /* *smulhrsv2hi3 */
    1421          965 :     case 8678:  /* *ssse3_pmulhrswv4hi3 */
    1422          965 :     case 8676:  /* *ssse3_pmulhrswv8hi3 */
    1423          965 :     case 8674:  /* *avx2_pmulhrswv16hi3 */
    1424          965 :     case 8672:  /* *avx512bw_pmulhrswv32hi3 */
    1425          965 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1426          965 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0), 0));
    1427          965 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 1), 0));
    1428          965 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    1429          965 :       break;
    1430              : 
    1431          986 :     case 8669:  /* avx512bw_umulhrswv32hi3_mask */
    1432          986 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1433          986 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0), 0), 0));
    1434          986 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0), 1), 0));
    1435          986 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    1436          986 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    1437          986 :       break;
    1438              : 
    1439          135 :     case 8668:  /* avx512bw_umulhrswv32hi3 */
    1440          135 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1441          135 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0), 0));
    1442          135 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 1), 0));
    1443          135 :       break;
    1444              : 
    1445         5032 :     case 8660:  /* ssse3_phsubdv2si3 */
    1446         5032 :     case 8659:  /* ssse3_phadddv2si3 */
    1447         5032 :     case 8658:  /* ssse3_phsubdv4si3 */
    1448         5032 :     case 8657:  /* ssse3_phadddv4si3 */
    1449         5032 :     case 8656:  /* avx2_phsubdv8si3 */
    1450         5032 :     case 8655:  /* avx2_phadddv8si3 */
    1451         5032 :     case 8654:  /* ssse3_phsubswv4hi3 */
    1452         5032 :     case 8653:  /* ssse3_phsubwv4hi3 */
    1453         5032 :     case 8652:  /* ssse3_phaddswv4hi3 */
    1454         5032 :     case 8651:  /* ssse3_phaddwv4hi3 */
    1455         5032 :     case 8650:  /* ssse3_phsubswv8hi3 */
    1456         5032 :     case 8649:  /* ssse3_phsubwv8hi3 */
    1457         5032 :     case 8648:  /* ssse3_phaddswv8hi3 */
    1458         5032 :     case 8647:  /* ssse3_phaddwv8hi3 */
    1459         5032 :     case 8646:  /* avx2_phsubswv16hi3 */
    1460         5032 :     case 8645:  /* avx2_phsubwv16hi3 */
    1461         5032 :     case 8644:  /* avx2_phaddswv16hi3 */
    1462         5032 :     case 8643:  /* avx2_phaddwv16hi3 */
    1463         5032 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1464         5032 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    1465         5032 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    1466         5032 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0);
    1467         5032 :       recog_data.dup_num[0] = 1;
    1468         5032 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1);
    1469         5032 :       recog_data.dup_num[1] = 2;
    1470         5032 :       break;
    1471              : 
    1472            2 :     case 8634:  /* *pmovsk_ptest_v16qi_avx512 */
    1473            2 :     case 8633:  /* *pmovsk_ptest_v32qi_avx512 */
    1474            2 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 2), 0, 0));
    1475            2 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 2), 0, 1));
    1476            2 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    1477            2 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 0));
    1478            2 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 1));
    1479            2 :       break;
    1480              : 
    1481            0 :     case 8632:  /* *pmovsk_mask_cmp_v16qi_avx512 */
    1482            0 :     case 8631:  /* *pmovsk_mask_cmp_v32qi_avx512 */
    1483            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 0));
    1484            0 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 2));
    1485            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    1486            0 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 1));
    1487            0 :       break;
    1488              : 
    1489            0 :     case 8630:  /* *pmovsk_mask_v32qi_avx512 */
    1490            0 :     case 8629:  /* *pmovsk_kmask_v16qi_avx512 */
    1491            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1492            0 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    1493            0 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
    1494            0 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    1495            0 :       break;
    1496              : 
    1497            0 :     case 8628:  /* *sse2_pmovmskb_ext_lt_avx512 */
    1498            0 :     case 8627:  /* *sse2_pmovmskb_ext_lt_avx512 */
    1499            0 :     case 8625:  /* *sse2_pmovmskb_zext_lt_avx512 */
    1500            0 :     case 8624:  /* *avx2_pmovmskb_zext_lt_avx512 */
    1501            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1502            0 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 2), 0, 0));
    1503            0 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 2), 0, 1));
    1504            0 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 0));
    1505            0 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 1));
    1506            0 :       break;
    1507              : 
    1508            0 :     case 8621:  /* *sse2_pmovmskb_lt_avx512 */
    1509            0 :     case 8620:  /* *avx2_pmovmskb_lt_avx512 */
    1510            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1511            0 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2), 0, 0));
    1512            0 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2), 0, 1));
    1513            0 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
    1514            0 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    1515            0 :       break;
    1516              : 
    1517            8 :     case 8617:  /* *sse2_pmovskb_zexthisi */
    1518            8 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1519            8 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    1520            8 :       break;
    1521              : 
    1522           26 :     case 8611:  /* *sse2_movmskpd_uext_shift */
    1523           26 :     case 8610:  /* *sse2_movmskpd_ext_shift */
    1524           26 :     case 8609:  /* *avx_movmskpd256_uext_shift */
    1525           26 :     case 8608:  /* *avx_movmskpd256_ext_shift */
    1526           26 :     case 8607:  /* *sse_movmskps_uext_shift */
    1527           26 :     case 8606:  /* *sse_movmskps_ext_shift */
    1528           26 :     case 8605:  /* *avx_movmskps256_uext_shift */
    1529           26 :     case 8604:  /* *avx_movmskps256_ext_shift */
    1530           26 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1531           26 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 0), 0));
    1532           26 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 0), 1));
    1533           26 :       break;
    1534              : 
    1535          134 :     case 8603:  /* *sse2_movmskpd_shift */
    1536          134 :     case 8602:  /* *avx_movmskpd256_shift */
    1537          134 :     case 8601:  /* *sse_movmskps_shift */
    1538          134 :     case 8600:  /* *avx_movmskps256_shift */
    1539          134 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1540          134 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    1541          134 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    1542          134 :       break;
    1543              : 
    1544            0 :     case 8599:  /* *sse2_movmskpd_uext_lt_avx512 */
    1545            0 :     case 8598:  /* *sse2_movmskpd_ext_lt_avx512 */
    1546            0 :     case 8597:  /* *avx_movmskpd256_uext_lt_avx512 */
    1547            0 :     case 8596:  /* *avx_movmskpd256_ext_lt_avx512 */
    1548            0 :     case 8595:  /* *sse_movmskps_uext_lt_avx512 */
    1549            0 :     case 8594:  /* *sse_movmskps_ext_lt_avx512 */
    1550            0 :     case 8593:  /* *avx_movmskps256_uext_lt_avx512 */
    1551            0 :     case 8592:  /* *avx_movmskps256_ext_lt_avx512 */
    1552            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1553            0 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 0), 2), 0, 0));
    1554            0 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 0), 2), 0, 1));
    1555            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 0), 0));
    1556            0 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 0), 1));
    1557            0 :       break;
    1558              : 
    1559           24 :     case 8626:  /* *sse2_pmovmskb_ext_lt */
    1560           24 :     case 8623:  /* *sse2_pmovmskb_zext_lt */
    1561           24 :     case 8622:  /* *avx2_pmovmskb_zext_lt */
    1562           24 :     case 8591:  /* *sse2_movmskpd_uext_lt */
    1563           24 :     case 8590:  /* *sse2_movmskpd_ext_lt */
    1564           24 :     case 8589:  /* *avx_movmskpd256_uext_lt */
    1565           24 :     case 8588:  /* *avx_movmskpd256_ext_lt */
    1566           24 :     case 8587:  /* *sse_movmskps_uext_lt */
    1567           24 :     case 8586:  /* *sse_movmskps_ext_lt */
    1568           24 :     case 8585:  /* *avx_movmskps256_uext_lt */
    1569           24 :     case 8584:  /* *avx_movmskps256_ext_lt */
    1570           24 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1571           24 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 0));
    1572           24 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 1));
    1573           24 :       break;
    1574              : 
    1575            0 :     case 8583:  /* *sse2_movmskpd_lt_avx512 */
    1576            0 :     case 8582:  /* *avx_movmskpd256_lt_avx512 */
    1577            0 :     case 8581:  /* *sse_movmskps_lt_avx512 */
    1578            0 :     case 8580:  /* *avx_movmskps256_lt_avx512 */
    1579            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1580            0 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0, 0));
    1581            0 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0, 1));
    1582            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    1583            0 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    1584            0 :       break;
    1585              : 
    1586         3113 :     case 8560:  /* *sse2_uavgv8hi3_mask */
    1587         3113 :     case 8558:  /* *avx2_uavgv16hi3_mask */
    1588         3113 :     case 8556:  /* *avx512bw_uavgv32hi3_mask */
    1589         3113 :     case 8554:  /* *sse2_uavgv16qi3_mask */
    1590         3113 :     case 8552:  /* *avx2_uavgv32qi3_mask */
    1591         3113 :     case 8550:  /* *avx512bw_uavgv64qi3_mask */
    1592         3113 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1593         3113 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0), 0));
    1594         3113 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 1), 0));
    1595         3113 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    1596         3113 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    1597         3113 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 1));
    1598         3113 :       break;
    1599              : 
    1600         1754 :     case 8559:  /* *sse2_uavgv8hi3 */
    1601         1754 :     case 8557:  /* *avx2_uavgv16hi3 */
    1602         1754 :     case 8555:  /* *avx512bw_uavgv32hi3 */
    1603         1754 :     case 8553:  /* *sse2_uavgv16qi3 */
    1604         1754 :     case 8551:  /* *avx2_uavgv32qi3 */
    1605         1754 :     case 8549:  /* *avx512bw_uavgv64qi3 */
    1606         1754 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1607         1754 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0));
    1608         1754 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 1), 0));
    1609         1754 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    1610         1754 :       break;
    1611              : 
    1612            2 :     case 8541:  /* *vec_concatv8hi_permt2 */
    1613            2 :     case 8540:  /* *vec_concatv16qi_permt2 */
    1614            2 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1615            2 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 1));
    1616            2 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 2));
    1617            2 :       break;
    1618              : 
    1619          394 :     case 8510:  /* sse2_pshufhw_1_mask */
    1620          394 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1621          394 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    1622          394 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 4));
    1623          394 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 5));
    1624          394 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 6));
    1625          394 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 7));
    1626          394 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (pat, 1), 1));
    1627          394 :       ro[7] = *(ro_loc[7] = &XEXP (XEXP (pat, 1), 2));
    1628          394 :       break;
    1629              : 
    1630         4960 :     case 8509:  /* sse2_pshufhw_1 */
    1631         4960 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1632         4960 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    1633         4960 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 4));
    1634         4960 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 5));
    1635         4960 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 6));
    1636         4960 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 7));
    1637         4960 :       break;
    1638              : 
    1639          436 :     case 8508:  /* avx2_pshufhw_1_mask */
    1640          436 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1641          436 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    1642          436 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 4));
    1643          436 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 5));
    1644          436 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 6));
    1645          436 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 7));
    1646          436 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 12));
    1647          436 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 13));
    1648          436 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 14));
    1649          436 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 15));
    1650          436 :       ro[10] = *(ro_loc[10] = &XEXP (XEXP (pat, 1), 1));
    1651          436 :       ro[11] = *(ro_loc[11] = &XEXP (XEXP (pat, 1), 2));
    1652          436 :       break;
    1653              : 
    1654          246 :     case 8507:  /* avx2_pshufhw_1 */
    1655          246 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1656          246 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    1657          246 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 4));
    1658          246 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 5));
    1659          246 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 6));
    1660          246 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 7));
    1661          246 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 12));
    1662          246 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 13));
    1663          246 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 14));
    1664          246 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 15));
    1665          246 :       break;
    1666              : 
    1667          436 :     case 8502:  /* avx2_pshuflw_1_mask */
    1668          436 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1669          436 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    1670          436 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
    1671          436 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 1));
    1672          436 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 2));
    1673          436 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 3));
    1674          436 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 8));
    1675          436 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 9));
    1676          436 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 10));
    1677          436 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 11));
    1678          436 :       ro[10] = *(ro_loc[10] = &XEXP (XEXP (pat, 1), 1));
    1679          436 :       ro[11] = *(ro_loc[11] = &XEXP (XEXP (pat, 1), 2));
    1680          436 :       break;
    1681              : 
    1682          273 :     case 8501:  /* avx2_pshuflw_1 */
    1683          273 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1684          273 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    1685          273 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    1686          273 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    1687          273 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 2));
    1688          273 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 3));
    1689          273 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 8));
    1690          273 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 9));
    1691          273 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 10));
    1692          273 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 11));
    1693          273 :       break;
    1694              : 
    1695          507 :     case 8494:  /* avx512f_pshufd_1_mask */
    1696          507 :     case 8492:  /* *avx512f_shuf_i32x4_1_mask_1 */
    1697          507 :     case 8490:  /* *avx512f_shuf_f32x4_1_mask_1 */
    1698          507 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1699          507 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    1700          507 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
    1701          507 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 1));
    1702          507 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 2));
    1703          507 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 3));
    1704          507 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 4));
    1705          507 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 5));
    1706          507 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 6));
    1707          507 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 7));
    1708          507 :       ro[10] = *(ro_loc[10] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 8));
    1709          507 :       ro[11] = *(ro_loc[11] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 9));
    1710          507 :       ro[12] = *(ro_loc[12] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 10));
    1711          507 :       ro[13] = *(ro_loc[13] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 11));
    1712          507 :       ro[14] = *(ro_loc[14] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 12));
    1713          507 :       ro[15] = *(ro_loc[15] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 13));
    1714          507 :       ro[16] = *(ro_loc[16] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 14));
    1715          507 :       ro[17] = *(ro_loc[17] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 15));
    1716          507 :       ro[18] = *(ro_loc[18] = &XEXP (XEXP (pat, 1), 1));
    1717          507 :       ro[19] = *(ro_loc[19] = &XEXP (XEXP (pat, 1), 2));
    1718          507 :       break;
    1719              : 
    1720         1363 :     case 8493:  /* avx512f_pshufd_1 */
    1721         1363 :     case 8491:  /* *avx512f_shuf_i32x4_1_1 */
    1722         1363 :     case 8489:  /* *avx512f_shuf_f32x4_1_1 */
    1723         1363 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1724         1363 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    1725         1363 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    1726         1363 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    1727         1363 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 2));
    1728         1363 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 3));
    1729         1363 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 4));
    1730         1363 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 5));
    1731         1363 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 6));
    1732         1363 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 7));
    1733         1363 :       ro[10] = *(ro_loc[10] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 8));
    1734         1363 :       ro[11] = *(ro_loc[11] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 9));
    1735         1363 :       ro[12] = *(ro_loc[12] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 10));
    1736         1363 :       ro[13] = *(ro_loc[13] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 11));
    1737         1363 :       ro[14] = *(ro_loc[14] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 12));
    1738         1363 :       ro[15] = *(ro_loc[15] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 13));
    1739         1363 :       ro[16] = *(ro_loc[16] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 14));
    1740         1363 :       ro[17] = *(ro_loc[17] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 15));
    1741         1363 :       break;
    1742              : 
    1743         1658 :     case 9254:  /* avx512f_permv8di_1_mask */
    1744         1658 :     case 9252:  /* avx512f_permv8df_1_mask */
    1745         1658 :     case 8496:  /* avx2_pshufd_1_mask */
    1746         1658 :     case 8480:  /* *avx512f_shuf_i64x2_1_mask_1 */
    1747         1658 :     case 8478:  /* *avx512f_shuf_f64x2_1_mask_1 */
    1748         1658 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1749         1658 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    1750         1658 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
    1751         1658 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 1));
    1752         1658 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 2));
    1753         1658 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 3));
    1754         1658 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 4));
    1755         1658 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 5));
    1756         1658 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 6));
    1757         1658 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 7));
    1758         1658 :       ro[10] = *(ro_loc[10] = &XEXP (XEXP (pat, 1), 1));
    1759         1658 :       ro[11] = *(ro_loc[11] = &XEXP (XEXP (pat, 1), 2));
    1760         1658 :       break;
    1761              : 
    1762        15100 :     case 9253:  /* avx512f_permv8di_1 */
    1763        15100 :     case 9251:  /* avx512f_permv8df_1 */
    1764        15100 :     case 8495:  /* avx2_pshufd_1 */
    1765        15100 :     case 8479:  /* *avx512f_shuf_i64x2_1_1 */
    1766        15100 :     case 8477:  /* *avx512f_shuf_f64x2_1_1 */
    1767        15100 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1768        15100 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    1769        15100 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    1770        15100 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    1771        15100 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 2));
    1772        15100 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 3));
    1773        15100 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 4));
    1774        15100 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 5));
    1775        15100 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 6));
    1776        15100 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 7));
    1777        15100 :       break;
    1778              : 
    1779          321 :     case 9558:  /* vec_set_lo_v8sf_mask */
    1780          321 :     case 9556:  /* vec_set_lo_v8si_mask */
    1781          321 :     case 9550:  /* vec_set_lo_v4df_mask */
    1782          321 :     case 9548:  /* vec_set_lo_v4di_mask */
    1783          321 :     case 8464:  /* vec_set_lo_v8di_mask */
    1784          321 :     case 8462:  /* vec_set_lo_v8df_mask */
    1785          321 :     case 8456:  /* vec_set_lo_v16si_mask */
    1786          321 :     case 8454:  /* vec_set_lo_v16sf_mask */
    1787          321 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1788          321 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
    1789          321 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    1790          321 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    1791          321 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    1792          321 :       break;
    1793              : 
    1794         1973 :     case 8452:  /* avx512f_vinserti32x4_1_mask */
    1795         1973 :     case 8450:  /* avx512f_vinsertf32x4_1_mask */
    1796         1973 :     case 8448:  /* avx512dq_vinserti64x2_1_mask */
    1797         1973 :     case 8446:  /* avx512dq_vinsertf64x2_1_mask */
    1798         1973 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1799         1973 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    1800         1973 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
    1801         1973 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    1802         1973 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    1803         1973 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
    1804         1973 :       break;
    1805              : 
    1806          965 :     case 8451:  /* *avx512f_vinserti32x4_1 */
    1807          965 :     case 8449:  /* *avx512f_vinsertf32x4_1 */
    1808          965 :     case 8447:  /* *avx512dq_vinserti64x2_1 */
    1809          965 :     case 8445:  /* *avx512dq_vinsertf64x2_1 */
    1810          965 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1811          965 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    1812          965 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    1813          965 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    1814          965 :       break;
    1815              : 
    1816         2293 :     case 8368:  /* avx512bw_packssdw_mask */
    1817         2293 :     case 8366:  /* avx2_packssdw_mask */
    1818         2293 :     case 8362:  /* avx512bw_packsswb_mask */
    1819         2293 :     case 8360:  /* avx2_packsswb_mask */
    1820         2293 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1821         2293 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    1822         2293 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1), 0));
    1823         2293 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    1824         2293 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    1825         2293 :       break;
    1826              : 
    1827          928 :     case 8367:  /* avx512bw_packssdw */
    1828          928 :     case 8365:  /* avx2_packssdw */
    1829          928 :     case 8361:  /* avx512bw_packsswb */
    1830          928 :     case 8359:  /* avx2_packsswb */
    1831          928 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1832          928 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    1833          928 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
    1834          928 :       break;
    1835              : 
    1836          984 :     case 8364:  /* sse2_packssdw_mask */
    1837          984 :     case 8358:  /* sse2_packsswb_mask */
    1838          984 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1839          984 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    1840          984 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
    1841          984 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    1842          984 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    1843          984 :       break;
    1844              : 
    1845            0 :     case 8356:  /* *avx512vl_testnmv2di3_zext_mask */
    1846            0 :     case 8355:  /* *avx512vl_testnmv2di3_zext_mask */
    1847            0 :     case 8354:  /* *avx512vl_testnmv2di3_zext_mask */
    1848            0 :     case 8353:  /* *avx512vl_testnmv4di3_zext_mask */
    1849            0 :     case 8352:  /* *avx512vl_testnmv4di3_zext_mask */
    1850            0 :     case 8351:  /* *avx512vl_testnmv4di3_zext_mask */
    1851            0 :     case 8350:  /* *avx512f_testnmv8di3_zext_mask */
    1852            0 :     case 8349:  /* *avx512f_testnmv8di3_zext_mask */
    1853            0 :     case 8348:  /* *avx512f_testnmv8di3_zext_mask */
    1854            0 :     case 8347:  /* *avx512vl_testnmv4si3_zext_mask */
    1855            0 :     case 8346:  /* *avx512vl_testnmv4si3_zext_mask */
    1856            0 :     case 8345:  /* *avx512vl_testnmv4si3_zext_mask */
    1857            0 :     case 8344:  /* *avx512vl_testnmv8si3_zext_mask */
    1858            0 :     case 8343:  /* *avx512vl_testnmv8si3_zext_mask */
    1859            0 :     case 8342:  /* *avx512vl_testnmv8si3_zext_mask */
    1860            0 :     case 8341:  /* *avx512f_testnmv16si3_zext_mask */
    1861            0 :     case 8340:  /* *avx512f_testnmv16si3_zext_mask */
    1862            0 :     case 8339:  /* *avx512f_testnmv16si3_zext_mask */
    1863            0 :     case 8338:  /* *avx512vl_testnmv8hi3_zext_mask */
    1864            0 :     case 8337:  /* *avx512vl_testnmv8hi3_zext_mask */
    1865            0 :     case 8336:  /* *avx512vl_testnmv8hi3_zext_mask */
    1866            0 :     case 8335:  /* *avx512vl_testnmv16hi3_zext_mask */
    1867            0 :     case 8334:  /* *avx512vl_testnmv16hi3_zext_mask */
    1868            0 :     case 8333:  /* *avx512vl_testnmv16hi3_zext_mask */
    1869            0 :     case 8332:  /* *avx512bw_testnmv32hi3_zext_mask */
    1870            0 :     case 8331:  /* *avx512bw_testnmv32hi3_zext_mask */
    1871            0 :     case 8330:  /* *avx512bw_testnmv32hi3_zext_mask */
    1872            0 :     case 8329:  /* *avx512vl_testnmv16qi3_zext_mask */
    1873            0 :     case 8328:  /* *avx512vl_testnmv16qi3_zext_mask */
    1874            0 :     case 8327:  /* *avx512vl_testnmv16qi3_zext_mask */
    1875            0 :     case 8326:  /* *avx512vl_testnmv32qi3_zext_mask */
    1876            0 :     case 8325:  /* *avx512vl_testnmv32qi3_zext_mask */
    1877            0 :     case 8324:  /* *avx512vl_testnmv32qi3_zext_mask */
    1878            0 :     case 8323:  /* *avx512bw_testnmv64qi3_zext_mask */
    1879            0 :     case 8322:  /* *avx512bw_testnmv64qi3_zext_mask */
    1880            0 :     case 8321:  /* *avx512bw_testnmv64qi3_zext_mask */
    1881            0 :     case 8284:  /* *avx512vl_testmv2di3_zext_mask */
    1882            0 :     case 8283:  /* *avx512vl_testmv2di3_zext_mask */
    1883            0 :     case 8282:  /* *avx512vl_testmv2di3_zext_mask */
    1884            0 :     case 8281:  /* *avx512vl_testmv4di3_zext_mask */
    1885            0 :     case 8280:  /* *avx512vl_testmv4di3_zext_mask */
    1886            0 :     case 8279:  /* *avx512vl_testmv4di3_zext_mask */
    1887            0 :     case 8278:  /* *avx512f_testmv8di3_zext_mask */
    1888            0 :     case 8277:  /* *avx512f_testmv8di3_zext_mask */
    1889            0 :     case 8276:  /* *avx512f_testmv8di3_zext_mask */
    1890            0 :     case 8275:  /* *avx512vl_testmv4si3_zext_mask */
    1891            0 :     case 8274:  /* *avx512vl_testmv4si3_zext_mask */
    1892            0 :     case 8273:  /* *avx512vl_testmv4si3_zext_mask */
    1893            0 :     case 8272:  /* *avx512vl_testmv8si3_zext_mask */
    1894            0 :     case 8271:  /* *avx512vl_testmv8si3_zext_mask */
    1895            0 :     case 8270:  /* *avx512vl_testmv8si3_zext_mask */
    1896            0 :     case 8269:  /* *avx512f_testmv16si3_zext_mask */
    1897            0 :     case 8268:  /* *avx512f_testmv16si3_zext_mask */
    1898            0 :     case 8267:  /* *avx512f_testmv16si3_zext_mask */
    1899            0 :     case 8266:  /* *avx512vl_testmv8hi3_zext_mask */
    1900            0 :     case 8265:  /* *avx512vl_testmv8hi3_zext_mask */
    1901            0 :     case 8264:  /* *avx512vl_testmv8hi3_zext_mask */
    1902            0 :     case 8263:  /* *avx512vl_testmv16hi3_zext_mask */
    1903            0 :     case 8262:  /* *avx512vl_testmv16hi3_zext_mask */
    1904            0 :     case 8261:  /* *avx512vl_testmv16hi3_zext_mask */
    1905            0 :     case 8260:  /* *avx512bw_testmv32hi3_zext_mask */
    1906            0 :     case 8259:  /* *avx512bw_testmv32hi3_zext_mask */
    1907            0 :     case 8258:  /* *avx512bw_testmv32hi3_zext_mask */
    1908            0 :     case 8257:  /* *avx512vl_testmv16qi3_zext_mask */
    1909            0 :     case 8256:  /* *avx512vl_testmv16qi3_zext_mask */
    1910            0 :     case 8255:  /* *avx512vl_testmv16qi3_zext_mask */
    1911            0 :     case 8254:  /* *avx512vl_testmv32qi3_zext_mask */
    1912            0 :     case 8253:  /* *avx512vl_testmv32qi3_zext_mask */
    1913            0 :     case 8252:  /* *avx512vl_testmv32qi3_zext_mask */
    1914            0 :     case 8251:  /* *avx512bw_testmv64qi3_zext_mask */
    1915            0 :     case 8250:  /* *avx512bw_testmv64qi3_zext_mask */
    1916            0 :     case 8249:  /* *avx512bw_testmv64qi3_zext_mask */
    1917            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1918            0 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    1919            0 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
    1920            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    1921            0 :       break;
    1922              : 
    1923           21 :     case 8041:  /* *one_cmplv2di2_pternlog_false_dep */
    1924           21 :     case 8040:  /* *one_cmplv4di2_pternlog_false_dep */
    1925           21 :     case 8039:  /* *one_cmplv4si2_pternlog_false_dep */
    1926           21 :     case 8038:  /* *one_cmplv8si2_pternlog_false_dep */
    1927           21 :     case 8037:  /* *one_cmplv8hi2_pternlog_false_dep */
    1928           21 :     case 8036:  /* *one_cmplv16hi2_pternlog_false_dep */
    1929           21 :     case 8035:  /* *one_cmplv32hi2_pternlog_false_dep */
    1930           21 :     case 8034:  /* *one_cmplv16qi2_pternlog_false_dep */
    1931           21 :     case 8033:  /* *one_cmplv32qi2_pternlog_false_dep */
    1932           21 :     case 8032:  /* *one_cmplv64qi2_pternlog_false_dep */
    1933           21 :     case 8031:  /* *one_cmplv8di2_pternlog_false_dep */
    1934           21 :     case 8030:  /* *one_cmplv16si2_pternlog_false_dep */
    1935           21 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    1936           21 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    1937           21 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    1938           21 :       ro[3] = *(ro_loc[3] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    1939           21 :       break;
    1940              : 
    1941            0 :     case 7967:  /* *avx2_pcmpv16qi3_5 */
    1942            0 :     case 7966:  /* *avx2_pcmpv32qi3_5 */
    1943            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1944            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    1945            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    1946            0 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 0), 0));
    1947            0 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 1));
    1948            0 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 2));
    1949            0 :       break;
    1950              : 
    1951            0 :     case 7690:  /* *avx512_ashrv2di3_1 */
    1952            0 :     case 7689:  /* *avx512_ashrv4di3_1 */
    1953            0 :     case 7688:  /* *avx512_ashrv8di3_1 */
    1954            0 :     case 7687:  /* *avx512_ashrv4si3_1 */
    1955            0 :     case 7686:  /* *avx512_ashrv8si3_1 */
    1956            0 :     case 7685:  /* *avx512_ashrv16si3_1 */
    1957            0 :     case 7684:  /* *avx512_ashrv8hi3_1 */
    1958            0 :     case 7683:  /* *avx512_ashrv16hi3_1 */
    1959            0 :     case 7682:  /* *avx512_ashrv32hi3_1 */
    1960            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1961            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    1962            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    1963            0 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 0));
    1964            0 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 1));
    1965            0 :       break;
    1966              : 
    1967         3028 :     case 7635:  /* *sse4_1_mulv2siv2di3_mask */
    1968         3028 :     case 7633:  /* *vec_widen_smult_even_v8si_mask */
    1969         3028 :     case 7631:  /* *vec_widen_smult_even_v16si_mask */
    1970         3028 :     case 7629:  /* *vec_widen_umult_even_v4si_mask */
    1971         3028 :     case 7627:  /* *vec_widen_umult_even_v8si_mask */
    1972         3028 :     case 7625:  /* *vec_widen_umult_even_v16si_mask */
    1973         3028 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1974         3028 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    1975         3028 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0), 0));
    1976         3028 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    1977         3028 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    1978         3028 :       break;
    1979              : 
    1980         3004 :     case 7623:  /* *umulv8hi3_highpart_mask */
    1981         3004 :     case 7621:  /* *smulv8hi3_highpart_mask */
    1982         3004 :     case 7619:  /* *umulv16hi3_highpart_mask */
    1983         3004 :     case 7617:  /* *smulv16hi3_highpart_mask */
    1984         3004 :     case 7615:  /* *umulv32hi3_highpart_mask */
    1985         3004 :     case 7613:  /* *smulv32hi3_highpart_mask */
    1986         3004 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1987         3004 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0));
    1988         3004 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 1), 0));
    1989         3004 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    1990         3004 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    1991         3004 :       break;
    1992              : 
    1993         7654 :     case 7485:  /* avx512f_us_truncatev8div16qi2_mask_store_1 */
    1994         7654 :     case 7484:  /* avx512f_truncatev8div16qi2_mask_store_1 */
    1995         7654 :     case 7483:  /* avx512f_ss_truncatev8div16qi2_mask_store_1 */
    1996         7654 :     case 7467:  /* avx512vl_us_truncatev2div2si2_mask_store_1 */
    1997         7654 :     case 7466:  /* avx512vl_truncatev2div2si2_mask_store_1 */
    1998         7654 :     case 7465:  /* avx512vl_ss_truncatev2div2si2_mask_store_1 */
    1999         7654 :     case 7448:  /* avx512vl_us_truncatev2div2hi2_mask_store_1 */
    2000         7654 :     case 7447:  /* avx512vl_truncatev2div2hi2_mask_store_1 */
    2001         7654 :     case 7446:  /* avx512vl_ss_truncatev2div2hi2_mask_store_1 */
    2002         7654 :     case 7433:  /* avx512vl_us_truncatev4div4hi2_mask_store_1 */
    2003         7654 :     case 7432:  /* avx512vl_truncatev4div4hi2_mask_store_1 */
    2004         7654 :     case 7431:  /* avx512vl_ss_truncatev4div4hi2_mask_store_1 */
    2005         7654 :     case 7430:  /* avx512vl_us_truncatev4siv4hi2_mask_store_1 */
    2006         7654 :     case 7429:  /* avx512vl_truncatev4siv4hi2_mask_store_1 */
    2007         7654 :     case 7428:  /* avx512vl_ss_truncatev4siv4hi2_mask_store_1 */
    2008         7654 :     case 7393:  /* avx512vl_us_truncatev8siv8qi2_mask_store_1 */
    2009         7654 :     case 7392:  /* avx512vl_truncatev8siv8qi2_mask_store_1 */
    2010         7654 :     case 7391:  /* avx512vl_ss_truncatev8siv8qi2_mask_store_1 */
    2011         7654 :     case 7390:  /* avx512vl_us_truncatev8hiv8qi2_mask_store_1 */
    2012         7654 :     case 7389:  /* avx512vl_truncatev8hiv8qi2_mask_store_1 */
    2013         7654 :     case 7388:  /* avx512vl_ss_truncatev8hiv8qi2_mask_store_1 */
    2014         7654 :     case 7363:  /* avx512vl_us_truncatev4div4qi2_mask_store_1 */
    2015         7654 :     case 7362:  /* avx512vl_truncatev4div4qi2_mask_store_1 */
    2016         7654 :     case 7361:  /* avx512vl_ss_truncatev4div4qi2_mask_store_1 */
    2017         7654 :     case 7360:  /* avx512vl_us_truncatev4siv4qi2_mask_store_1 */
    2018         7654 :     case 7359:  /* avx512vl_truncatev4siv4qi2_mask_store_1 */
    2019         7654 :     case 7358:  /* avx512vl_ss_truncatev4siv4qi2_mask_store_1 */
    2020         7654 :     case 7333:  /* avx512vl_us_truncatev2div2qi2_mask_store_1 */
    2021         7654 :     case 7332:  /* avx512vl_truncatev2div2qi2_mask_store_1 */
    2022         7654 :     case 7331:  /* avx512vl_ss_truncatev2div2qi2_mask_store_1 */
    2023         7654 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2024         7654 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    2025         7654 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 2));
    2026         7654 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    2027         7654 :       recog_data.dup_num[0] = 0;
    2028         7654 :       break;
    2029              : 
    2030           18 :     case 7403:  /* *avx512f_pshufb_truncv4siv4hi_1 */
    2031           18 :     case 7318:  /* *avx512f_pshufb_truncv8hiv8qi_1 */
    2032           18 :     case 7262:  /* *avx512f_permvar_truncv8siv8hi_1_hf */
    2033           18 :     case 7260:  /* *avx512bw_permvar_truncv16siv16hi_1_hf */
    2034           18 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2035           18 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    2036           18 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
    2037           18 :       break;
    2038              : 
    2039          396 :     case 7219:  /* sse2_shufpd_v2df_mask */
    2040          396 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2041          396 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    2042          396 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    2043          396 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
    2044          396 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 1));
    2045          396 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 1));
    2046          396 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (pat, 1), 2));
    2047          396 :       break;
    2048              : 
    2049         1576 :     case 8488:  /* avx512f_shuf_i32x4_1_mask */
    2050         1576 :     case 8486:  /* avx512f_shuf_f32x4_1_mask */
    2051         1576 :     case 7214:  /* avx512f_shufps512_1_mask */
    2052         1576 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2053         1576 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    2054         1576 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    2055         1576 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
    2056         1576 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 1));
    2057         1576 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 2));
    2058         1576 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 3));
    2059         1576 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 4));
    2060         1576 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 5));
    2061         1576 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 6));
    2062         1576 :       ro[10] = *(ro_loc[10] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 7));
    2063         1576 :       ro[11] = *(ro_loc[11] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 8));
    2064         1576 :       ro[12] = *(ro_loc[12] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 9));
    2065         1576 :       ro[13] = *(ro_loc[13] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 10));
    2066         1576 :       ro[14] = *(ro_loc[14] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 11));
    2067         1576 :       ro[15] = *(ro_loc[15] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 12));
    2068         1576 :       ro[16] = *(ro_loc[16] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 13));
    2069         1576 :       ro[17] = *(ro_loc[17] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 14));
    2070         1576 :       ro[18] = *(ro_loc[18] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 15));
    2071         1576 :       ro[19] = *(ro_loc[19] = &XEXP (XEXP (pat, 1), 1));
    2072         1576 :       ro[20] = *(ro_loc[20] = &XEXP (XEXP (pat, 1), 2));
    2073         1576 :       break;
    2074              : 
    2075         1842 :     case 8487:  /* avx512f_shuf_i32x4_1 */
    2076         1842 :     case 8485:  /* avx512f_shuf_f32x4_1 */
    2077         1842 :     case 7213:  /* avx512f_shufps512_1 */
    2078         1842 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2079         1842 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    2080         1842 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    2081         1842 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    2082         1842 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    2083         1842 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 2));
    2084         1842 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 3));
    2085         1842 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 4));
    2086         1842 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 5));
    2087         1842 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 6));
    2088         1842 :       ro[10] = *(ro_loc[10] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 7));
    2089         1842 :       ro[11] = *(ro_loc[11] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 8));
    2090         1842 :       ro[12] = *(ro_loc[12] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 9));
    2091         1842 :       ro[13] = *(ro_loc[13] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 10));
    2092         1842 :       ro[14] = *(ro_loc[14] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 11));
    2093         1842 :       ro[15] = *(ro_loc[15] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 12));
    2094         1842 :       ro[16] = *(ro_loc[16] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 13));
    2095         1842 :       ro[17] = *(ro_loc[17] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 14));
    2096         1842 :       ro[18] = *(ro_loc[18] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 15));
    2097         1842 :       break;
    2098              : 
    2099            0 :     case 7212:  /* *avx512f_rndscalev2df_round */
    2100            0 :     case 7210:  /* *avx512f_rndscalev4sf_round */
    2101            0 :     case 7208:  /* *avx512f_rndscalev8hf_round */
    2102            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2103            0 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    2104            0 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 0));
    2105            0 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 1));
    2106            0 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    2107            0 :       break;
    2108              : 
    2109          387 :     case 9042:  /* *sse4_1_roundsd */
    2110          387 :     case 9041:  /* *sse4_1_roundss */
    2111          387 :     case 9040:  /* *sse4_1_roundsh */
    2112          387 :     case 7211:  /* *avx512f_rndscalev2df */
    2113          387 :     case 7209:  /* *avx512f_rndscalev4sf */
    2114          387 :     case 7207:  /* *avx512f_rndscalev8hf */
    2115          387 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2116          387 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    2117          387 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    2118          387 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
    2119          387 :       break;
    2120              : 
    2121          827 :     case 7206:  /* avx512f_rndscalev2df_mask_round */
    2122          827 :     case 7202:  /* avx512f_rndscalev4sf_mask_round */
    2123          827 :     case 7198:  /* avx512f_rndscalev8hf_mask_round */
    2124          827 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2125          827 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    2126          827 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 0));
    2127          827 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 1));
    2128          827 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    2129          827 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    2130          827 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    2131          827 :       break;
    2132              : 
    2133          313 :     case 7205:  /* avx512f_rndscalev2df_round */
    2134          313 :     case 7201:  /* avx512f_rndscalev4sf_round */
    2135          313 :     case 7197:  /* avx512f_rndscalev8hf_round */
    2136          313 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2137          313 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    2138          313 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    2139          313 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    2140          313 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    2141          313 :       break;
    2142              : 
    2143         1391 :     case 7204:  /* avx512f_rndscalev2df_mask */
    2144         1391 :     case 7200:  /* avx512f_rndscalev4sf_mask */
    2145         1391 :     case 7196:  /* avx512f_rndscalev8hf_mask */
    2146         1391 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2147         1391 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    2148         1391 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    2149         1391 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
    2150         1391 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    2151         1391 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    2152         1391 :       break;
    2153              : 
    2154         1743 :     case 9039:  /* sse4_1_roundsd */
    2155         1743 :     case 9038:  /* sse4_1_roundss */
    2156         1743 :     case 9037:  /* sse4_1_roundsh */
    2157         1743 :     case 7203:  /* avx512f_rndscalev2df */
    2158         1743 :     case 7199:  /* avx512f_rndscalev4sf */
    2159         1743 :     case 7195:  /* avx512f_rndscalev8hf */
    2160         1743 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2161         1743 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    2162         1743 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    2163         1743 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    2164         1743 :       break;
    2165              : 
    2166          756 :     case 7158:  /* avx512f_sfixupimmv2df_mask_round */
    2167          756 :     case 7156:  /* avx512f_sfixupimmv4sf_mask_round */
    2168          756 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2169          756 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 0));
    2170          756 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 1));
    2171          756 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 2));
    2172          756 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 3));
    2173          756 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    2174          756 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    2175          756 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1);
    2176          756 :       recog_data.dup_num[0] = 2;
    2177          756 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    2178          756 :       recog_data.dup_num[1] = 1;
    2179          756 :       break;
    2180              : 
    2181          136 :     case 7157:  /* avx512f_sfixupimmv2df_mask */
    2182          136 :     case 7155:  /* avx512f_sfixupimmv4sf_mask */
    2183          136 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2184          136 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    2185          136 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
    2186          136 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 2));
    2187          136 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 3));
    2188          136 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
    2189          136 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 1);
    2190          136 :       recog_data.dup_num[0] = 2;
    2191          136 :       recog_data.dup_loc[1] = &XEXP (XEXP (pat, 1), 1);
    2192          136 :       recog_data.dup_num[1] = 1;
    2193          136 :       break;
    2194              : 
    2195          656 :     case 7154:  /* avx512f_sfixupimmv2df_maskz_1_round */
    2196          656 :     case 7150:  /* avx512f_sfixupimmv4sf_maskz_1_round */
    2197          656 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2198          656 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 0));
    2199          656 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 1));
    2200          656 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 2));
    2201          656 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 3));
    2202          656 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    2203          656 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    2204          656 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (pat, 1), 0, 1));
    2205          656 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    2206          656 :       recog_data.dup_num[0] = 2;
    2207          656 :       break;
    2208              : 
    2209           48 :     case 7153:  /* avx512f_sfixupimmv2df_maskz_1 */
    2210           48 :     case 7149:  /* avx512f_sfixupimmv4sf_maskz_1 */
    2211           48 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2212           48 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    2213           48 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
    2214           48 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 2));
    2215           48 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 3));
    2216           48 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    2217           48 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    2218           48 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    2219           48 :       recog_data.dup_num[0] = 2;
    2220           48 :       break;
    2221              : 
    2222          482 :     case 7152:  /* avx512f_sfixupimmv2df_round */
    2223          482 :     case 7148:  /* avx512f_sfixupimmv4sf_round */
    2224          482 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2225          482 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    2226          482 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    2227          482 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    2228          482 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 3));
    2229          482 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    2230          482 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    2231          482 :       recog_data.dup_num[0] = 2;
    2232          482 :       break;
    2233              : 
    2234          162 :     case 7151:  /* avx512f_sfixupimmv2df */
    2235          162 :     case 7147:  /* avx512f_sfixupimmv4sf */
    2236          162 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2237          162 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    2238          162 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    2239          162 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    2240          162 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 3));
    2241          162 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    2242          162 :       recog_data.dup_num[0] = 2;
    2243          162 :       break;
    2244              : 
    2245          717 :     case 7146:  /* avx512vl_fixupimmv2df_mask_round */
    2246          717 :     case 7144:  /* avx512vl_fixupimmv4df_mask_round */
    2247          717 :     case 7142:  /* avx512f_fixupimmv8df_mask_round */
    2248          717 :     case 7140:  /* avx512vl_fixupimmv4sf_mask_round */
    2249          717 :     case 7138:  /* avx512vl_fixupimmv8sf_mask_round */
    2250          717 :     case 7136:  /* avx512f_fixupimmv16sf_mask_round */
    2251          717 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2252          717 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    2253          717 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    2254          717 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    2255          717 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 3));
    2256          717 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    2257          717 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    2258          717 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    2259          717 :       recog_data.dup_num[0] = 1;
    2260          717 :       break;
    2261              : 
    2262          656 :     case 7134:  /* avx512vl_fixupimmv2df_maskz_1_round */
    2263          656 :     case 7130:  /* avx512vl_fixupimmv4df_maskz_1_round */
    2264          656 :     case 7126:  /* avx512f_fixupimmv8df_maskz_1_round */
    2265          656 :     case 7122:  /* avx512vl_fixupimmv4sf_maskz_1_round */
    2266          656 :     case 7118:  /* avx512vl_fixupimmv8sf_maskz_1_round */
    2267          656 :     case 7114:  /* avx512f_fixupimmv16sf_maskz_1_round */
    2268          656 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2269          656 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    2270          656 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    2271          656 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    2272          656 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 3));
    2273          656 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    2274          656 :       ro[6] = *(ro_loc[6] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    2275          656 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (pat, 1), 0, 1));
    2276          656 :       break;
    2277              : 
    2278          482 :     case 7132:  /* avx512vl_fixupimmv2df_round */
    2279          482 :     case 7128:  /* avx512vl_fixupimmv4df_round */
    2280          482 :     case 7124:  /* avx512f_fixupimmv8df_round */
    2281          482 :     case 7120:  /* avx512vl_fixupimmv4sf_round */
    2282          482 :     case 7116:  /* avx512vl_fixupimmv8sf_round */
    2283          482 :     case 7112:  /* avx512f_fixupimmv16sf_round */
    2284          482 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2285          482 :       ro[1] = *(ro_loc[1] = &XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0));
    2286          482 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 1));
    2287          482 :       ro[3] = *(ro_loc[3] = &XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 2));
    2288          482 :       ro[4] = *(ro_loc[4] = &XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 3));
    2289          482 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    2290          482 :       break;
    2291              : 
    2292         2374 :     case 7145:  /* avx512vl_fixupimmv2df_mask */
    2293         2374 :     case 7143:  /* avx512vl_fixupimmv4df_mask */
    2294         2374 :     case 7141:  /* avx512f_fixupimmv8df_mask */
    2295         2374 :     case 7139:  /* avx512vl_fixupimmv4sf_mask */
    2296         2374 :     case 7137:  /* avx512vl_fixupimmv8sf_mask */
    2297         2374 :     case 7135:  /* avx512f_fixupimmv16sf_mask */
    2298         2374 :     case 7042:  /* *avx512vl_vternlogv2di_mask */
    2299         2374 :     case 7041:  /* *avx512vl_vternlogv4di_mask */
    2300         2374 :     case 7040:  /* *avx512f_vternlogv8di_mask */
    2301         2374 :     case 7039:  /* *avx512vl_vternlogv4si_mask */
    2302         2374 :     case 7038:  /* *avx512vl_vternlogv8si_mask */
    2303         2374 :     case 7037:  /* *avx512f_vternlogv16si_mask */
    2304         2374 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2305         2374 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    2306         2374 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    2307         2374 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    2308         2374 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 3));
    2309         2374 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
    2310         2374 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    2311         2374 :       recog_data.dup_num[0] = 1;
    2312         2374 :       break;
    2313              : 
    2314            0 :     case 6172:  /* *avx512vl_vpternlogv2df_1 */
    2315            0 :     case 6171:  /* *avx512vl_vpternlogv2df_1 */
    2316            0 :     case 6170:  /* *avx512vl_vpternlogv2df_1 */
    2317            0 :     case 6169:  /* *avx512vl_vpternlogv2df_1 */
    2318            0 :     case 6168:  /* *avx512vl_vpternlogv2df_1 */
    2319            0 :     case 6167:  /* *avx512vl_vpternlogv2df_1 */
    2320            0 :     case 6166:  /* *avx512vl_vpternlogv2df_1 */
    2321            0 :     case 6165:  /* *avx512vl_vpternlogv2df_1 */
    2322            0 :     case 6164:  /* *avx512vl_vpternlogv2df_1 */
    2323            0 :     case 6163:  /* *avx512vl_vpternlogv2df_1 */
    2324            0 :     case 6162:  /* *avx512vl_vpternlogv2df_1 */
    2325            0 :     case 6161:  /* *avx512vl_vpternlogv2df_1 */
    2326            0 :     case 6160:  /* *avx512vl_vpternlogv2df_1 */
    2327            0 :     case 6159:  /* *avx512vl_vpternlogv2df_1 */
    2328            0 :     case 6158:  /* *avx512vl_vpternlogv2df_1 */
    2329            0 :     case 6157:  /* *avx512vl_vpternlogv2df_1 */
    2330            0 :     case 6156:  /* *avx512vl_vpternlogv2df_1 */
    2331            0 :     case 6155:  /* *avx512vl_vpternlogv2df_1 */
    2332            0 :     case 6154:  /* *avx512vl_vpternlogv2df_1 */
    2333            0 :     case 6153:  /* *avx512vl_vpternlogv2df_1 */
    2334            0 :     case 6152:  /* *avx512vl_vpternlogv2df_1 */
    2335            0 :     case 6151:  /* *avx512vl_vpternlogv2df_1 */
    2336            0 :     case 6150:  /* *avx512vl_vpternlogv2df_1 */
    2337            0 :     case 6149:  /* *avx512vl_vpternlogv2df_1 */
    2338            0 :     case 6148:  /* *avx512vl_vpternlogv2df_1 */
    2339            0 :     case 6147:  /* *avx512vl_vpternlogv2df_1 */
    2340            0 :     case 6146:  /* *avx512vl_vpternlogv2df_1 */
    2341            0 :     case 6145:  /* *avx512vl_vpternlogv4df_1 */
    2342            0 :     case 6144:  /* *avx512vl_vpternlogv4df_1 */
    2343            0 :     case 6143:  /* *avx512vl_vpternlogv4df_1 */
    2344            0 :     case 6142:  /* *avx512vl_vpternlogv4df_1 */
    2345            0 :     case 6141:  /* *avx512vl_vpternlogv4df_1 */
    2346            0 :     case 6140:  /* *avx512vl_vpternlogv4df_1 */
    2347            0 :     case 6139:  /* *avx512vl_vpternlogv4df_1 */
    2348            0 :     case 6138:  /* *avx512vl_vpternlogv4df_1 */
    2349            0 :     case 6137:  /* *avx512vl_vpternlogv4df_1 */
    2350            0 :     case 6136:  /* *avx512vl_vpternlogv4df_1 */
    2351            0 :     case 6135:  /* *avx512vl_vpternlogv4df_1 */
    2352            0 :     case 6134:  /* *avx512vl_vpternlogv4df_1 */
    2353            0 :     case 6133:  /* *avx512vl_vpternlogv4df_1 */
    2354            0 :     case 6132:  /* *avx512vl_vpternlogv4df_1 */
    2355            0 :     case 6131:  /* *avx512vl_vpternlogv4df_1 */
    2356            0 :     case 6130:  /* *avx512vl_vpternlogv4df_1 */
    2357            0 :     case 6129:  /* *avx512vl_vpternlogv4df_1 */
    2358            0 :     case 6128:  /* *avx512vl_vpternlogv4df_1 */
    2359            0 :     case 6127:  /* *avx512vl_vpternlogv4df_1 */
    2360            0 :     case 6126:  /* *avx512vl_vpternlogv4df_1 */
    2361            0 :     case 6125:  /* *avx512vl_vpternlogv4df_1 */
    2362            0 :     case 6124:  /* *avx512vl_vpternlogv4df_1 */
    2363            0 :     case 6123:  /* *avx512vl_vpternlogv4df_1 */
    2364            0 :     case 6122:  /* *avx512vl_vpternlogv4df_1 */
    2365            0 :     case 6121:  /* *avx512vl_vpternlogv4df_1 */
    2366            0 :     case 6120:  /* *avx512vl_vpternlogv4df_1 */
    2367            0 :     case 6119:  /* *avx512vl_vpternlogv4df_1 */
    2368            0 :     case 6118:  /* *avx512f_vpternlogv8df_1 */
    2369            0 :     case 6117:  /* *avx512f_vpternlogv8df_1 */
    2370            0 :     case 6116:  /* *avx512f_vpternlogv8df_1 */
    2371            0 :     case 6115:  /* *avx512f_vpternlogv8df_1 */
    2372            0 :     case 6114:  /* *avx512f_vpternlogv8df_1 */
    2373            0 :     case 6113:  /* *avx512f_vpternlogv8df_1 */
    2374            0 :     case 6112:  /* *avx512f_vpternlogv8df_1 */
    2375            0 :     case 6111:  /* *avx512f_vpternlogv8df_1 */
    2376            0 :     case 6110:  /* *avx512f_vpternlogv8df_1 */
    2377            0 :     case 6109:  /* *avx512f_vpternlogv8df_1 */
    2378            0 :     case 6108:  /* *avx512f_vpternlogv8df_1 */
    2379            0 :     case 6107:  /* *avx512f_vpternlogv8df_1 */
    2380            0 :     case 6106:  /* *avx512f_vpternlogv8df_1 */
    2381            0 :     case 6105:  /* *avx512f_vpternlogv8df_1 */
    2382            0 :     case 6104:  /* *avx512f_vpternlogv8df_1 */
    2383            0 :     case 6103:  /* *avx512f_vpternlogv8df_1 */
    2384            0 :     case 6102:  /* *avx512f_vpternlogv8df_1 */
    2385            0 :     case 6101:  /* *avx512f_vpternlogv8df_1 */
    2386            0 :     case 6100:  /* *avx512f_vpternlogv8df_1 */
    2387            0 :     case 6099:  /* *avx512f_vpternlogv8df_1 */
    2388            0 :     case 6098:  /* *avx512f_vpternlogv8df_1 */
    2389            0 :     case 6097:  /* *avx512f_vpternlogv8df_1 */
    2390            0 :     case 6096:  /* *avx512f_vpternlogv8df_1 */
    2391            0 :     case 6095:  /* *avx512f_vpternlogv8df_1 */
    2392            0 :     case 6094:  /* *avx512f_vpternlogv8df_1 */
    2393            0 :     case 6093:  /* *avx512f_vpternlogv8df_1 */
    2394            0 :     case 6092:  /* *avx512f_vpternlogv8df_1 */
    2395            0 :     case 6091:  /* *avx512vl_vpternlogv4sf_1 */
    2396            0 :     case 6090:  /* *avx512vl_vpternlogv4sf_1 */
    2397            0 :     case 6089:  /* *avx512vl_vpternlogv4sf_1 */
    2398            0 :     case 6088:  /* *avx512vl_vpternlogv4sf_1 */
    2399            0 :     case 6087:  /* *avx512vl_vpternlogv4sf_1 */
    2400            0 :     case 6086:  /* *avx512vl_vpternlogv4sf_1 */
    2401            0 :     case 6085:  /* *avx512vl_vpternlogv4sf_1 */
    2402            0 :     case 6084:  /* *avx512vl_vpternlogv4sf_1 */
    2403            0 :     case 6083:  /* *avx512vl_vpternlogv4sf_1 */
    2404            0 :     case 6082:  /* *avx512vl_vpternlogv4sf_1 */
    2405            0 :     case 6081:  /* *avx512vl_vpternlogv4sf_1 */
    2406            0 :     case 6080:  /* *avx512vl_vpternlogv4sf_1 */
    2407            0 :     case 6079:  /* *avx512vl_vpternlogv4sf_1 */
    2408            0 :     case 6078:  /* *avx512vl_vpternlogv4sf_1 */
    2409            0 :     case 6077:  /* *avx512vl_vpternlogv4sf_1 */
    2410            0 :     case 6076:  /* *avx512vl_vpternlogv4sf_1 */
    2411            0 :     case 6075:  /* *avx512vl_vpternlogv4sf_1 */
    2412            0 :     case 6074:  /* *avx512vl_vpternlogv4sf_1 */
    2413            0 :     case 6073:  /* *avx512vl_vpternlogv4sf_1 */
    2414            0 :     case 6072:  /* *avx512vl_vpternlogv4sf_1 */
    2415            0 :     case 6071:  /* *avx512vl_vpternlogv4sf_1 */
    2416            0 :     case 6070:  /* *avx512vl_vpternlogv4sf_1 */
    2417            0 :     case 6069:  /* *avx512vl_vpternlogv4sf_1 */
    2418            0 :     case 6068:  /* *avx512vl_vpternlogv4sf_1 */
    2419            0 :     case 6067:  /* *avx512vl_vpternlogv4sf_1 */
    2420            0 :     case 6066:  /* *avx512vl_vpternlogv4sf_1 */
    2421            0 :     case 6065:  /* *avx512vl_vpternlogv4sf_1 */
    2422            0 :     case 6064:  /* *avx512vl_vpternlogv8sf_1 */
    2423            0 :     case 6063:  /* *avx512vl_vpternlogv8sf_1 */
    2424            0 :     case 6062:  /* *avx512vl_vpternlogv8sf_1 */
    2425            0 :     case 6061:  /* *avx512vl_vpternlogv8sf_1 */
    2426            0 :     case 6060:  /* *avx512vl_vpternlogv8sf_1 */
    2427            0 :     case 6059:  /* *avx512vl_vpternlogv8sf_1 */
    2428            0 :     case 6058:  /* *avx512vl_vpternlogv8sf_1 */
    2429            0 :     case 6057:  /* *avx512vl_vpternlogv8sf_1 */
    2430            0 :     case 6056:  /* *avx512vl_vpternlogv8sf_1 */
    2431            0 :     case 6055:  /* *avx512vl_vpternlogv8sf_1 */
    2432            0 :     case 6054:  /* *avx512vl_vpternlogv8sf_1 */
    2433            0 :     case 6053:  /* *avx512vl_vpternlogv8sf_1 */
    2434            0 :     case 6052:  /* *avx512vl_vpternlogv8sf_1 */
    2435            0 :     case 6051:  /* *avx512vl_vpternlogv8sf_1 */
    2436            0 :     case 6050:  /* *avx512vl_vpternlogv8sf_1 */
    2437            0 :     case 6049:  /* *avx512vl_vpternlogv8sf_1 */
    2438            0 :     case 6048:  /* *avx512vl_vpternlogv8sf_1 */
    2439            0 :     case 6047:  /* *avx512vl_vpternlogv8sf_1 */
    2440            0 :     case 6046:  /* *avx512vl_vpternlogv8sf_1 */
    2441            0 :     case 6045:  /* *avx512vl_vpternlogv8sf_1 */
    2442            0 :     case 6044:  /* *avx512vl_vpternlogv8sf_1 */
    2443            0 :     case 6043:  /* *avx512vl_vpternlogv8sf_1 */
    2444            0 :     case 6042:  /* *avx512vl_vpternlogv8sf_1 */
    2445            0 :     case 6041:  /* *avx512vl_vpternlogv8sf_1 */
    2446            0 :     case 6040:  /* *avx512vl_vpternlogv8sf_1 */
    2447            0 :     case 6039:  /* *avx512vl_vpternlogv8sf_1 */
    2448            0 :     case 6038:  /* *avx512vl_vpternlogv8sf_1 */
    2449            0 :     case 6037:  /* *avx512f_vpternlogv16sf_1 */
    2450            0 :     case 6036:  /* *avx512f_vpternlogv16sf_1 */
    2451            0 :     case 6035:  /* *avx512f_vpternlogv16sf_1 */
    2452            0 :     case 6034:  /* *avx512f_vpternlogv16sf_1 */
    2453            0 :     case 6033:  /* *avx512f_vpternlogv16sf_1 */
    2454            0 :     case 6032:  /* *avx512f_vpternlogv16sf_1 */
    2455            0 :     case 6031:  /* *avx512f_vpternlogv16sf_1 */
    2456            0 :     case 6030:  /* *avx512f_vpternlogv16sf_1 */
    2457            0 :     case 6029:  /* *avx512f_vpternlogv16sf_1 */
    2458            0 :     case 6028:  /* *avx512f_vpternlogv16sf_1 */
    2459            0 :     case 6027:  /* *avx512f_vpternlogv16sf_1 */
    2460            0 :     case 6026:  /* *avx512f_vpternlogv16sf_1 */
    2461            0 :     case 6025:  /* *avx512f_vpternlogv16sf_1 */
    2462            0 :     case 6024:  /* *avx512f_vpternlogv16sf_1 */
    2463            0 :     case 6023:  /* *avx512f_vpternlogv16sf_1 */
    2464            0 :     case 6022:  /* *avx512f_vpternlogv16sf_1 */
    2465            0 :     case 6021:  /* *avx512f_vpternlogv16sf_1 */
    2466            0 :     case 6020:  /* *avx512f_vpternlogv16sf_1 */
    2467            0 :     case 6019:  /* *avx512f_vpternlogv16sf_1 */
    2468            0 :     case 6018:  /* *avx512f_vpternlogv16sf_1 */
    2469            0 :     case 6017:  /* *avx512f_vpternlogv16sf_1 */
    2470            0 :     case 6016:  /* *avx512f_vpternlogv16sf_1 */
    2471            0 :     case 6015:  /* *avx512f_vpternlogv16sf_1 */
    2472            0 :     case 6014:  /* *avx512f_vpternlogv16sf_1 */
    2473            0 :     case 6013:  /* *avx512f_vpternlogv16sf_1 */
    2474            0 :     case 6012:  /* *avx512f_vpternlogv16sf_1 */
    2475            0 :     case 6011:  /* *avx512f_vpternlogv16sf_1 */
    2476            0 :     case 6010:  /* *avx512vl_vpternlogv8bf_1 */
    2477            0 :     case 6009:  /* *avx512vl_vpternlogv8bf_1 */
    2478            0 :     case 6008:  /* *avx512vl_vpternlogv8bf_1 */
    2479            0 :     case 6007:  /* *avx512vl_vpternlogv8bf_1 */
    2480            0 :     case 6006:  /* *avx512vl_vpternlogv8bf_1 */
    2481            0 :     case 6005:  /* *avx512vl_vpternlogv8bf_1 */
    2482            0 :     case 6004:  /* *avx512vl_vpternlogv8bf_1 */
    2483            0 :     case 6003:  /* *avx512vl_vpternlogv8bf_1 */
    2484            0 :     case 6002:  /* *avx512vl_vpternlogv8bf_1 */
    2485            0 :     case 6001:  /* *avx512vl_vpternlogv8bf_1 */
    2486            0 :     case 6000:  /* *avx512vl_vpternlogv8bf_1 */
    2487            0 :     case 5999:  /* *avx512vl_vpternlogv8bf_1 */
    2488            0 :     case 5998:  /* *avx512vl_vpternlogv8bf_1 */
    2489            0 :     case 5997:  /* *avx512vl_vpternlogv8bf_1 */
    2490            0 :     case 5996:  /* *avx512vl_vpternlogv8bf_1 */
    2491            0 :     case 5995:  /* *avx512vl_vpternlogv8bf_1 */
    2492            0 :     case 5994:  /* *avx512vl_vpternlogv8bf_1 */
    2493            0 :     case 5993:  /* *avx512vl_vpternlogv8bf_1 */
    2494            0 :     case 5992:  /* *avx512vl_vpternlogv8bf_1 */
    2495            0 :     case 5991:  /* *avx512vl_vpternlogv8bf_1 */
    2496            0 :     case 5990:  /* *avx512vl_vpternlogv8bf_1 */
    2497            0 :     case 5989:  /* *avx512vl_vpternlogv8bf_1 */
    2498            0 :     case 5988:  /* *avx512vl_vpternlogv8bf_1 */
    2499            0 :     case 5987:  /* *avx512vl_vpternlogv8bf_1 */
    2500            0 :     case 5986:  /* *avx512vl_vpternlogv8bf_1 */
    2501            0 :     case 5985:  /* *avx512vl_vpternlogv8bf_1 */
    2502            0 :     case 5984:  /* *avx512vl_vpternlogv8bf_1 */
    2503            0 :     case 5983:  /* *avx512vl_vpternlogv16bf_1 */
    2504            0 :     case 5982:  /* *avx512vl_vpternlogv16bf_1 */
    2505            0 :     case 5981:  /* *avx512vl_vpternlogv16bf_1 */
    2506            0 :     case 5980:  /* *avx512vl_vpternlogv16bf_1 */
    2507            0 :     case 5979:  /* *avx512vl_vpternlogv16bf_1 */
    2508            0 :     case 5978:  /* *avx512vl_vpternlogv16bf_1 */
    2509            0 :     case 5977:  /* *avx512vl_vpternlogv16bf_1 */
    2510            0 :     case 5976:  /* *avx512vl_vpternlogv16bf_1 */
    2511            0 :     case 5975:  /* *avx512vl_vpternlogv16bf_1 */
    2512            0 :     case 5974:  /* *avx512vl_vpternlogv16bf_1 */
    2513            0 :     case 5973:  /* *avx512vl_vpternlogv16bf_1 */
    2514            0 :     case 5972:  /* *avx512vl_vpternlogv16bf_1 */
    2515            0 :     case 5971:  /* *avx512vl_vpternlogv16bf_1 */
    2516            0 :     case 5970:  /* *avx512vl_vpternlogv16bf_1 */
    2517            0 :     case 5969:  /* *avx512vl_vpternlogv16bf_1 */
    2518            0 :     case 5968:  /* *avx512vl_vpternlogv16bf_1 */
    2519            0 :     case 5967:  /* *avx512vl_vpternlogv16bf_1 */
    2520            0 :     case 5966:  /* *avx512vl_vpternlogv16bf_1 */
    2521            0 :     case 5965:  /* *avx512vl_vpternlogv16bf_1 */
    2522            0 :     case 5964:  /* *avx512vl_vpternlogv16bf_1 */
    2523            0 :     case 5963:  /* *avx512vl_vpternlogv16bf_1 */
    2524            0 :     case 5962:  /* *avx512vl_vpternlogv16bf_1 */
    2525            0 :     case 5961:  /* *avx512vl_vpternlogv16bf_1 */
    2526            0 :     case 5960:  /* *avx512vl_vpternlogv16bf_1 */
    2527            0 :     case 5959:  /* *avx512vl_vpternlogv16bf_1 */
    2528            0 :     case 5958:  /* *avx512vl_vpternlogv16bf_1 */
    2529            0 :     case 5957:  /* *avx512vl_vpternlogv16bf_1 */
    2530            0 :     case 5956:  /* *avx512bw_vpternlogv32bf_1 */
    2531            0 :     case 5955:  /* *avx512bw_vpternlogv32bf_1 */
    2532            0 :     case 5954:  /* *avx512bw_vpternlogv32bf_1 */
    2533            0 :     case 5953:  /* *avx512bw_vpternlogv32bf_1 */
    2534            0 :     case 5952:  /* *avx512bw_vpternlogv32bf_1 */
    2535            0 :     case 5951:  /* *avx512bw_vpternlogv32bf_1 */
    2536            0 :     case 5950:  /* *avx512bw_vpternlogv32bf_1 */
    2537            0 :     case 5949:  /* *avx512bw_vpternlogv32bf_1 */
    2538            0 :     case 5948:  /* *avx512bw_vpternlogv32bf_1 */
    2539            0 :     case 5947:  /* *avx512bw_vpternlogv32bf_1 */
    2540            0 :     case 5946:  /* *avx512bw_vpternlogv32bf_1 */
    2541            0 :     case 5945:  /* *avx512bw_vpternlogv32bf_1 */
    2542            0 :     case 5944:  /* *avx512bw_vpternlogv32bf_1 */
    2543            0 :     case 5943:  /* *avx512bw_vpternlogv32bf_1 */
    2544            0 :     case 5942:  /* *avx512bw_vpternlogv32bf_1 */
    2545            0 :     case 5941:  /* *avx512bw_vpternlogv32bf_1 */
    2546            0 :     case 5940:  /* *avx512bw_vpternlogv32bf_1 */
    2547            0 :     case 5939:  /* *avx512bw_vpternlogv32bf_1 */
    2548            0 :     case 5938:  /* *avx512bw_vpternlogv32bf_1 */
    2549            0 :     case 5937:  /* *avx512bw_vpternlogv32bf_1 */
    2550            0 :     case 5936:  /* *avx512bw_vpternlogv32bf_1 */
    2551            0 :     case 5935:  /* *avx512bw_vpternlogv32bf_1 */
    2552            0 :     case 5934:  /* *avx512bw_vpternlogv32bf_1 */
    2553            0 :     case 5933:  /* *avx512bw_vpternlogv32bf_1 */
    2554            0 :     case 5932:  /* *avx512bw_vpternlogv32bf_1 */
    2555            0 :     case 5931:  /* *avx512bw_vpternlogv32bf_1 */
    2556            0 :     case 5930:  /* *avx512bw_vpternlogv32bf_1 */
    2557            0 :     case 5929:  /* *avx512fp16_vpternlogv8hf_1 */
    2558            0 :     case 5928:  /* *avx512fp16_vpternlogv8hf_1 */
    2559            0 :     case 5927:  /* *avx512fp16_vpternlogv8hf_1 */
    2560            0 :     case 5926:  /* *avx512fp16_vpternlogv8hf_1 */
    2561            0 :     case 5925:  /* *avx512fp16_vpternlogv8hf_1 */
    2562            0 :     case 5924:  /* *avx512fp16_vpternlogv8hf_1 */
    2563            0 :     case 5923:  /* *avx512fp16_vpternlogv8hf_1 */
    2564            0 :     case 5922:  /* *avx512fp16_vpternlogv8hf_1 */
    2565            0 :     case 5921:  /* *avx512fp16_vpternlogv8hf_1 */
    2566            0 :     case 5920:  /* *avx512fp16_vpternlogv8hf_1 */
    2567            0 :     case 5919:  /* *avx512fp16_vpternlogv8hf_1 */
    2568            0 :     case 5918:  /* *avx512fp16_vpternlogv8hf_1 */
    2569            0 :     case 5917:  /* *avx512fp16_vpternlogv8hf_1 */
    2570            0 :     case 5916:  /* *avx512fp16_vpternlogv8hf_1 */
    2571            0 :     case 5915:  /* *avx512fp16_vpternlogv8hf_1 */
    2572            0 :     case 5914:  /* *avx512fp16_vpternlogv8hf_1 */
    2573            0 :     case 5913:  /* *avx512fp16_vpternlogv8hf_1 */
    2574            0 :     case 5912:  /* *avx512fp16_vpternlogv8hf_1 */
    2575            0 :     case 5911:  /* *avx512fp16_vpternlogv8hf_1 */
    2576            0 :     case 5910:  /* *avx512fp16_vpternlogv8hf_1 */
    2577            0 :     case 5909:  /* *avx512fp16_vpternlogv8hf_1 */
    2578            0 :     case 5908:  /* *avx512fp16_vpternlogv8hf_1 */
    2579            0 :     case 5907:  /* *avx512fp16_vpternlogv8hf_1 */
    2580            0 :     case 5906:  /* *avx512fp16_vpternlogv8hf_1 */
    2581            0 :     case 5905:  /* *avx512fp16_vpternlogv8hf_1 */
    2582            0 :     case 5904:  /* *avx512fp16_vpternlogv8hf_1 */
    2583            0 :     case 5903:  /* *avx512fp16_vpternlogv8hf_1 */
    2584            0 :     case 5902:  /* *avx512vl_vpternlogv16hf_1 */
    2585            0 :     case 5901:  /* *avx512vl_vpternlogv16hf_1 */
    2586            0 :     case 5900:  /* *avx512vl_vpternlogv16hf_1 */
    2587            0 :     case 5899:  /* *avx512vl_vpternlogv16hf_1 */
    2588            0 :     case 5898:  /* *avx512vl_vpternlogv16hf_1 */
    2589            0 :     case 5897:  /* *avx512vl_vpternlogv16hf_1 */
    2590            0 :     case 5896:  /* *avx512vl_vpternlogv16hf_1 */
    2591            0 :     case 5895:  /* *avx512vl_vpternlogv16hf_1 */
    2592            0 :     case 5894:  /* *avx512vl_vpternlogv16hf_1 */
    2593            0 :     case 5893:  /* *avx512vl_vpternlogv16hf_1 */
    2594            0 :     case 5892:  /* *avx512vl_vpternlogv16hf_1 */
    2595            0 :     case 5891:  /* *avx512vl_vpternlogv16hf_1 */
    2596            0 :     case 5890:  /* *avx512vl_vpternlogv16hf_1 */
    2597            0 :     case 5889:  /* *avx512vl_vpternlogv16hf_1 */
    2598            0 :     case 5888:  /* *avx512vl_vpternlogv16hf_1 */
    2599            0 :     case 5887:  /* *avx512vl_vpternlogv16hf_1 */
    2600            0 :     case 5886:  /* *avx512vl_vpternlogv16hf_1 */
    2601            0 :     case 5885:  /* *avx512vl_vpternlogv16hf_1 */
    2602            0 :     case 5884:  /* *avx512vl_vpternlogv16hf_1 */
    2603            0 :     case 5883:  /* *avx512vl_vpternlogv16hf_1 */
    2604            0 :     case 5882:  /* *avx512vl_vpternlogv16hf_1 */
    2605            0 :     case 5881:  /* *avx512vl_vpternlogv16hf_1 */
    2606            0 :     case 5880:  /* *avx512vl_vpternlogv16hf_1 */
    2607            0 :     case 5879:  /* *avx512vl_vpternlogv16hf_1 */
    2608            0 :     case 5878:  /* *avx512vl_vpternlogv16hf_1 */
    2609            0 :     case 5877:  /* *avx512vl_vpternlogv16hf_1 */
    2610            0 :     case 5876:  /* *avx512vl_vpternlogv16hf_1 */
    2611            0 :     case 5875:  /* *avx512bw_vpternlogv32hf_1 */
    2612            0 :     case 5874:  /* *avx512bw_vpternlogv32hf_1 */
    2613            0 :     case 5873:  /* *avx512bw_vpternlogv32hf_1 */
    2614            0 :     case 5872:  /* *avx512bw_vpternlogv32hf_1 */
    2615            0 :     case 5871:  /* *avx512bw_vpternlogv32hf_1 */
    2616            0 :     case 5870:  /* *avx512bw_vpternlogv32hf_1 */
    2617            0 :     case 5869:  /* *avx512bw_vpternlogv32hf_1 */
    2618            0 :     case 5868:  /* *avx512bw_vpternlogv32hf_1 */
    2619            0 :     case 5867:  /* *avx512bw_vpternlogv32hf_1 */
    2620            0 :     case 5866:  /* *avx512bw_vpternlogv32hf_1 */
    2621            0 :     case 5865:  /* *avx512bw_vpternlogv32hf_1 */
    2622            0 :     case 5864:  /* *avx512bw_vpternlogv32hf_1 */
    2623            0 :     case 5863:  /* *avx512bw_vpternlogv32hf_1 */
    2624            0 :     case 5862:  /* *avx512bw_vpternlogv32hf_1 */
    2625            0 :     case 5861:  /* *avx512bw_vpternlogv32hf_1 */
    2626            0 :     case 5860:  /* *avx512bw_vpternlogv32hf_1 */
    2627            0 :     case 5859:  /* *avx512bw_vpternlogv32hf_1 */
    2628            0 :     case 5858:  /* *avx512bw_vpternlogv32hf_1 */
    2629            0 :     case 5857:  /* *avx512bw_vpternlogv32hf_1 */
    2630            0 :     case 5856:  /* *avx512bw_vpternlogv32hf_1 */
    2631            0 :     case 5855:  /* *avx512bw_vpternlogv32hf_1 */
    2632            0 :     case 5854:  /* *avx512bw_vpternlogv32hf_1 */
    2633            0 :     case 5853:  /* *avx512bw_vpternlogv32hf_1 */
    2634            0 :     case 5852:  /* *avx512bw_vpternlogv32hf_1 */
    2635            0 :     case 5851:  /* *avx512bw_vpternlogv32hf_1 */
    2636            0 :     case 5850:  /* *avx512bw_vpternlogv32hf_1 */
    2637            0 :     case 5849:  /* *avx512bw_vpternlogv32hf_1 */
    2638            0 :     case 5848:  /* *avx512vl_vpternlogv2di_1 */
    2639            0 :     case 5847:  /* *avx512vl_vpternlogv2di_1 */
    2640            0 :     case 5846:  /* *avx512vl_vpternlogv2di_1 */
    2641            0 :     case 5845:  /* *avx512vl_vpternlogv2di_1 */
    2642            0 :     case 5844:  /* *avx512vl_vpternlogv2di_1 */
    2643            0 :     case 5843:  /* *avx512vl_vpternlogv2di_1 */
    2644            0 :     case 5842:  /* *avx512vl_vpternlogv2di_1 */
    2645            0 :     case 5841:  /* *avx512vl_vpternlogv2di_1 */
    2646            0 :     case 5840:  /* *avx512vl_vpternlogv2di_1 */
    2647            0 :     case 5839:  /* *avx512vl_vpternlogv2di_1 */
    2648            0 :     case 5838:  /* *avx512vl_vpternlogv2di_1 */
    2649            0 :     case 5837:  /* *avx512vl_vpternlogv2di_1 */
    2650            0 :     case 5836:  /* *avx512vl_vpternlogv2di_1 */
    2651            0 :     case 5835:  /* *avx512vl_vpternlogv2di_1 */
    2652            0 :     case 5834:  /* *avx512vl_vpternlogv2di_1 */
    2653            0 :     case 5833:  /* *avx512vl_vpternlogv2di_1 */
    2654            0 :     case 5832:  /* *avx512vl_vpternlogv2di_1 */
    2655            0 :     case 5831:  /* *avx512vl_vpternlogv2di_1 */
    2656            0 :     case 5830:  /* *avx512vl_vpternlogv2di_1 */
    2657            0 :     case 5829:  /* *avx512vl_vpternlogv2di_1 */
    2658            0 :     case 5828:  /* *avx512vl_vpternlogv2di_1 */
    2659            0 :     case 5827:  /* *avx512vl_vpternlogv2di_1 */
    2660            0 :     case 5826:  /* *avx512vl_vpternlogv2di_1 */
    2661            0 :     case 5825:  /* *avx512vl_vpternlogv2di_1 */
    2662            0 :     case 5824:  /* *avx512vl_vpternlogv2di_1 */
    2663            0 :     case 5823:  /* *avx512vl_vpternlogv2di_1 */
    2664            0 :     case 5822:  /* *avx512vl_vpternlogv2di_1 */
    2665            0 :     case 5821:  /* *avx512vl_vpternlogv4di_1 */
    2666            0 :     case 5820:  /* *avx512vl_vpternlogv4di_1 */
    2667            0 :     case 5819:  /* *avx512vl_vpternlogv4di_1 */
    2668            0 :     case 5818:  /* *avx512vl_vpternlogv4di_1 */
    2669            0 :     case 5817:  /* *avx512vl_vpternlogv4di_1 */
    2670            0 :     case 5816:  /* *avx512vl_vpternlogv4di_1 */
    2671            0 :     case 5815:  /* *avx512vl_vpternlogv4di_1 */
    2672            0 :     case 5814:  /* *avx512vl_vpternlogv4di_1 */
    2673            0 :     case 5813:  /* *avx512vl_vpternlogv4di_1 */
    2674            0 :     case 5812:  /* *avx512vl_vpternlogv4di_1 */
    2675            0 :     case 5811:  /* *avx512vl_vpternlogv4di_1 */
    2676            0 :     case 5810:  /* *avx512vl_vpternlogv4di_1 */
    2677            0 :     case 5809:  /* *avx512vl_vpternlogv4di_1 */
    2678            0 :     case 5808:  /* *avx512vl_vpternlogv4di_1 */
    2679            0 :     case 5807:  /* *avx512vl_vpternlogv4di_1 */
    2680            0 :     case 5806:  /* *avx512vl_vpternlogv4di_1 */
    2681            0 :     case 5805:  /* *avx512vl_vpternlogv4di_1 */
    2682            0 :     case 5804:  /* *avx512vl_vpternlogv4di_1 */
    2683            0 :     case 5803:  /* *avx512vl_vpternlogv4di_1 */
    2684            0 :     case 5802:  /* *avx512vl_vpternlogv4di_1 */
    2685            0 :     case 5801:  /* *avx512vl_vpternlogv4di_1 */
    2686            0 :     case 5800:  /* *avx512vl_vpternlogv4di_1 */
    2687            0 :     case 5799:  /* *avx512vl_vpternlogv4di_1 */
    2688            0 :     case 5798:  /* *avx512vl_vpternlogv4di_1 */
    2689            0 :     case 5797:  /* *avx512vl_vpternlogv4di_1 */
    2690            0 :     case 5796:  /* *avx512vl_vpternlogv4di_1 */
    2691            0 :     case 5795:  /* *avx512vl_vpternlogv4di_1 */
    2692            0 :     case 5794:  /* *avx512f_vpternlogv8di_1 */
    2693            0 :     case 5793:  /* *avx512f_vpternlogv8di_1 */
    2694            0 :     case 5792:  /* *avx512f_vpternlogv8di_1 */
    2695            0 :     case 5791:  /* *avx512f_vpternlogv8di_1 */
    2696            0 :     case 5790:  /* *avx512f_vpternlogv8di_1 */
    2697            0 :     case 5789:  /* *avx512f_vpternlogv8di_1 */
    2698            0 :     case 5788:  /* *avx512f_vpternlogv8di_1 */
    2699            0 :     case 5787:  /* *avx512f_vpternlogv8di_1 */
    2700            0 :     case 5786:  /* *avx512f_vpternlogv8di_1 */
    2701            0 :     case 5785:  /* *avx512f_vpternlogv8di_1 */
    2702            0 :     case 5784:  /* *avx512f_vpternlogv8di_1 */
    2703            0 :     case 5783:  /* *avx512f_vpternlogv8di_1 */
    2704            0 :     case 5782:  /* *avx512f_vpternlogv8di_1 */
    2705            0 :     case 5781:  /* *avx512f_vpternlogv8di_1 */
    2706            0 :     case 5780:  /* *avx512f_vpternlogv8di_1 */
    2707            0 :     case 5779:  /* *avx512f_vpternlogv8di_1 */
    2708            0 :     case 5778:  /* *avx512f_vpternlogv8di_1 */
    2709            0 :     case 5777:  /* *avx512f_vpternlogv8di_1 */
    2710            0 :     case 5776:  /* *avx512f_vpternlogv8di_1 */
    2711            0 :     case 5775:  /* *avx512f_vpternlogv8di_1 */
    2712            0 :     case 5774:  /* *avx512f_vpternlogv8di_1 */
    2713            0 :     case 5773:  /* *avx512f_vpternlogv8di_1 */
    2714            0 :     case 5772:  /* *avx512f_vpternlogv8di_1 */
    2715            0 :     case 5771:  /* *avx512f_vpternlogv8di_1 */
    2716            0 :     case 5770:  /* *avx512f_vpternlogv8di_1 */
    2717            0 :     case 5769:  /* *avx512f_vpternlogv8di_1 */
    2718            0 :     case 5768:  /* *avx512f_vpternlogv8di_1 */
    2719            0 :     case 5767:  /* *avx512vl_vpternlogv4si_1 */
    2720            0 :     case 5766:  /* *avx512vl_vpternlogv4si_1 */
    2721            0 :     case 5765:  /* *avx512vl_vpternlogv4si_1 */
    2722            0 :     case 5764:  /* *avx512vl_vpternlogv4si_1 */
    2723            0 :     case 5763:  /* *avx512vl_vpternlogv4si_1 */
    2724            0 :     case 5762:  /* *avx512vl_vpternlogv4si_1 */
    2725            0 :     case 5761:  /* *avx512vl_vpternlogv4si_1 */
    2726            0 :     case 5760:  /* *avx512vl_vpternlogv4si_1 */
    2727            0 :     case 5759:  /* *avx512vl_vpternlogv4si_1 */
    2728            0 :     case 5758:  /* *avx512vl_vpternlogv4si_1 */
    2729            0 :     case 5757:  /* *avx512vl_vpternlogv4si_1 */
    2730            0 :     case 5756:  /* *avx512vl_vpternlogv4si_1 */
    2731            0 :     case 5755:  /* *avx512vl_vpternlogv4si_1 */
    2732            0 :     case 5754:  /* *avx512vl_vpternlogv4si_1 */
    2733            0 :     case 5753:  /* *avx512vl_vpternlogv4si_1 */
    2734            0 :     case 5752:  /* *avx512vl_vpternlogv4si_1 */
    2735            0 :     case 5751:  /* *avx512vl_vpternlogv4si_1 */
    2736            0 :     case 5750:  /* *avx512vl_vpternlogv4si_1 */
    2737            0 :     case 5749:  /* *avx512vl_vpternlogv4si_1 */
    2738            0 :     case 5748:  /* *avx512vl_vpternlogv4si_1 */
    2739            0 :     case 5747:  /* *avx512vl_vpternlogv4si_1 */
    2740            0 :     case 5746:  /* *avx512vl_vpternlogv4si_1 */
    2741            0 :     case 5745:  /* *avx512vl_vpternlogv4si_1 */
    2742            0 :     case 5744:  /* *avx512vl_vpternlogv4si_1 */
    2743            0 :     case 5743:  /* *avx512vl_vpternlogv4si_1 */
    2744            0 :     case 5742:  /* *avx512vl_vpternlogv4si_1 */
    2745            0 :     case 5741:  /* *avx512vl_vpternlogv4si_1 */
    2746            0 :     case 5740:  /* *avx512vl_vpternlogv8si_1 */
    2747            0 :     case 5739:  /* *avx512vl_vpternlogv8si_1 */
    2748            0 :     case 5738:  /* *avx512vl_vpternlogv8si_1 */
    2749            0 :     case 5737:  /* *avx512vl_vpternlogv8si_1 */
    2750            0 :     case 5736:  /* *avx512vl_vpternlogv8si_1 */
    2751            0 :     case 5735:  /* *avx512vl_vpternlogv8si_1 */
    2752            0 :     case 5734:  /* *avx512vl_vpternlogv8si_1 */
    2753            0 :     case 5733:  /* *avx512vl_vpternlogv8si_1 */
    2754            0 :     case 5732:  /* *avx512vl_vpternlogv8si_1 */
    2755            0 :     case 5731:  /* *avx512vl_vpternlogv8si_1 */
    2756            0 :     case 5730:  /* *avx512vl_vpternlogv8si_1 */
    2757            0 :     case 5729:  /* *avx512vl_vpternlogv8si_1 */
    2758            0 :     case 5728:  /* *avx512vl_vpternlogv8si_1 */
    2759            0 :     case 5727:  /* *avx512vl_vpternlogv8si_1 */
    2760            0 :     case 5726:  /* *avx512vl_vpternlogv8si_1 */
    2761            0 :     case 5725:  /* *avx512vl_vpternlogv8si_1 */
    2762            0 :     case 5724:  /* *avx512vl_vpternlogv8si_1 */
    2763            0 :     case 5723:  /* *avx512vl_vpternlogv8si_1 */
    2764            0 :     case 5722:  /* *avx512vl_vpternlogv8si_1 */
    2765            0 :     case 5721:  /* *avx512vl_vpternlogv8si_1 */
    2766            0 :     case 5720:  /* *avx512vl_vpternlogv8si_1 */
    2767            0 :     case 5719:  /* *avx512vl_vpternlogv8si_1 */
    2768            0 :     case 5718:  /* *avx512vl_vpternlogv8si_1 */
    2769            0 :     case 5717:  /* *avx512vl_vpternlogv8si_1 */
    2770            0 :     case 5716:  /* *avx512vl_vpternlogv8si_1 */
    2771            0 :     case 5715:  /* *avx512vl_vpternlogv8si_1 */
    2772            0 :     case 5714:  /* *avx512vl_vpternlogv8si_1 */
    2773            0 :     case 5713:  /* *avx512f_vpternlogv16si_1 */
    2774            0 :     case 5712:  /* *avx512f_vpternlogv16si_1 */
    2775            0 :     case 5711:  /* *avx512f_vpternlogv16si_1 */
    2776            0 :     case 5710:  /* *avx512f_vpternlogv16si_1 */
    2777            0 :     case 5709:  /* *avx512f_vpternlogv16si_1 */
    2778            0 :     case 5708:  /* *avx512f_vpternlogv16si_1 */
    2779            0 :     case 5707:  /* *avx512f_vpternlogv16si_1 */
    2780            0 :     case 5706:  /* *avx512f_vpternlogv16si_1 */
    2781            0 :     case 5705:  /* *avx512f_vpternlogv16si_1 */
    2782            0 :     case 5704:  /* *avx512f_vpternlogv16si_1 */
    2783            0 :     case 5703:  /* *avx512f_vpternlogv16si_1 */
    2784            0 :     case 5702:  /* *avx512f_vpternlogv16si_1 */
    2785            0 :     case 5701:  /* *avx512f_vpternlogv16si_1 */
    2786            0 :     case 5700:  /* *avx512f_vpternlogv16si_1 */
    2787            0 :     case 5699:  /* *avx512f_vpternlogv16si_1 */
    2788            0 :     case 5698:  /* *avx512f_vpternlogv16si_1 */
    2789            0 :     case 5697:  /* *avx512f_vpternlogv16si_1 */
    2790            0 :     case 5696:  /* *avx512f_vpternlogv16si_1 */
    2791            0 :     case 5695:  /* *avx512f_vpternlogv16si_1 */
    2792            0 :     case 5694:  /* *avx512f_vpternlogv16si_1 */
    2793            0 :     case 5693:  /* *avx512f_vpternlogv16si_1 */
    2794            0 :     case 5692:  /* *avx512f_vpternlogv16si_1 */
    2795            0 :     case 5691:  /* *avx512f_vpternlogv16si_1 */
    2796            0 :     case 5690:  /* *avx512f_vpternlogv16si_1 */
    2797            0 :     case 5689:  /* *avx512f_vpternlogv16si_1 */
    2798            0 :     case 5688:  /* *avx512f_vpternlogv16si_1 */
    2799            0 :     case 5687:  /* *avx512f_vpternlogv16si_1 */
    2800            0 :     case 5686:  /* *avx512vl_vpternlogv8hi_1 */
    2801            0 :     case 5685:  /* *avx512vl_vpternlogv8hi_1 */
    2802            0 :     case 5684:  /* *avx512vl_vpternlogv8hi_1 */
    2803            0 :     case 5683:  /* *avx512vl_vpternlogv8hi_1 */
    2804            0 :     case 5682:  /* *avx512vl_vpternlogv8hi_1 */
    2805            0 :     case 5681:  /* *avx512vl_vpternlogv8hi_1 */
    2806            0 :     case 5680:  /* *avx512vl_vpternlogv8hi_1 */
    2807            0 :     case 5679:  /* *avx512vl_vpternlogv8hi_1 */
    2808            0 :     case 5678:  /* *avx512vl_vpternlogv8hi_1 */
    2809            0 :     case 5677:  /* *avx512vl_vpternlogv8hi_1 */
    2810            0 :     case 5676:  /* *avx512vl_vpternlogv8hi_1 */
    2811            0 :     case 5675:  /* *avx512vl_vpternlogv8hi_1 */
    2812            0 :     case 5674:  /* *avx512vl_vpternlogv8hi_1 */
    2813            0 :     case 5673:  /* *avx512vl_vpternlogv8hi_1 */
    2814            0 :     case 5672:  /* *avx512vl_vpternlogv8hi_1 */
    2815            0 :     case 5671:  /* *avx512vl_vpternlogv8hi_1 */
    2816            0 :     case 5670:  /* *avx512vl_vpternlogv8hi_1 */
    2817            0 :     case 5669:  /* *avx512vl_vpternlogv8hi_1 */
    2818            0 :     case 5668:  /* *avx512vl_vpternlogv8hi_1 */
    2819            0 :     case 5667:  /* *avx512vl_vpternlogv8hi_1 */
    2820            0 :     case 5666:  /* *avx512vl_vpternlogv8hi_1 */
    2821            0 :     case 5665:  /* *avx512vl_vpternlogv8hi_1 */
    2822            0 :     case 5664:  /* *avx512vl_vpternlogv8hi_1 */
    2823            0 :     case 5663:  /* *avx512vl_vpternlogv8hi_1 */
    2824            0 :     case 5662:  /* *avx512vl_vpternlogv8hi_1 */
    2825            0 :     case 5661:  /* *avx512vl_vpternlogv8hi_1 */
    2826            0 :     case 5660:  /* *avx512vl_vpternlogv8hi_1 */
    2827            0 :     case 5659:  /* *avx512vl_vpternlogv16hi_1 */
    2828            0 :     case 5658:  /* *avx512vl_vpternlogv16hi_1 */
    2829            0 :     case 5657:  /* *avx512vl_vpternlogv16hi_1 */
    2830            0 :     case 5656:  /* *avx512vl_vpternlogv16hi_1 */
    2831            0 :     case 5655:  /* *avx512vl_vpternlogv16hi_1 */
    2832            0 :     case 5654:  /* *avx512vl_vpternlogv16hi_1 */
    2833            0 :     case 5653:  /* *avx512vl_vpternlogv16hi_1 */
    2834            0 :     case 5652:  /* *avx512vl_vpternlogv16hi_1 */
    2835            0 :     case 5651:  /* *avx512vl_vpternlogv16hi_1 */
    2836            0 :     case 5650:  /* *avx512vl_vpternlogv16hi_1 */
    2837            0 :     case 5649:  /* *avx512vl_vpternlogv16hi_1 */
    2838            0 :     case 5648:  /* *avx512vl_vpternlogv16hi_1 */
    2839            0 :     case 5647:  /* *avx512vl_vpternlogv16hi_1 */
    2840            0 :     case 5646:  /* *avx512vl_vpternlogv16hi_1 */
    2841            0 :     case 5645:  /* *avx512vl_vpternlogv16hi_1 */
    2842            0 :     case 5644:  /* *avx512vl_vpternlogv16hi_1 */
    2843            0 :     case 5643:  /* *avx512vl_vpternlogv16hi_1 */
    2844            0 :     case 5642:  /* *avx512vl_vpternlogv16hi_1 */
    2845            0 :     case 5641:  /* *avx512vl_vpternlogv16hi_1 */
    2846            0 :     case 5640:  /* *avx512vl_vpternlogv16hi_1 */
    2847            0 :     case 5639:  /* *avx512vl_vpternlogv16hi_1 */
    2848            0 :     case 5638:  /* *avx512vl_vpternlogv16hi_1 */
    2849            0 :     case 5637:  /* *avx512vl_vpternlogv16hi_1 */
    2850            0 :     case 5636:  /* *avx512vl_vpternlogv16hi_1 */
    2851            0 :     case 5635:  /* *avx512vl_vpternlogv16hi_1 */
    2852            0 :     case 5634:  /* *avx512vl_vpternlogv16hi_1 */
    2853            0 :     case 5633:  /* *avx512vl_vpternlogv16hi_1 */
    2854            0 :     case 5632:  /* *avx512bw_vpternlogv32hi_1 */
    2855            0 :     case 5631:  /* *avx512bw_vpternlogv32hi_1 */
    2856            0 :     case 5630:  /* *avx512bw_vpternlogv32hi_1 */
    2857            0 :     case 5629:  /* *avx512bw_vpternlogv32hi_1 */
    2858            0 :     case 5628:  /* *avx512bw_vpternlogv32hi_1 */
    2859            0 :     case 5627:  /* *avx512bw_vpternlogv32hi_1 */
    2860            0 :     case 5626:  /* *avx512bw_vpternlogv32hi_1 */
    2861            0 :     case 5625:  /* *avx512bw_vpternlogv32hi_1 */
    2862            0 :     case 5624:  /* *avx512bw_vpternlogv32hi_1 */
    2863            0 :     case 5623:  /* *avx512bw_vpternlogv32hi_1 */
    2864            0 :     case 5622:  /* *avx512bw_vpternlogv32hi_1 */
    2865            0 :     case 5621:  /* *avx512bw_vpternlogv32hi_1 */
    2866            0 :     case 5620:  /* *avx512bw_vpternlogv32hi_1 */
    2867            0 :     case 5619:  /* *avx512bw_vpternlogv32hi_1 */
    2868            0 :     case 5618:  /* *avx512bw_vpternlogv32hi_1 */
    2869            0 :     case 5617:  /* *avx512bw_vpternlogv32hi_1 */
    2870            0 :     case 5616:  /* *avx512bw_vpternlogv32hi_1 */
    2871            0 :     case 5615:  /* *avx512bw_vpternlogv32hi_1 */
    2872            0 :     case 5614:  /* *avx512bw_vpternlogv32hi_1 */
    2873            0 :     case 5613:  /* *avx512bw_vpternlogv32hi_1 */
    2874            0 :     case 5612:  /* *avx512bw_vpternlogv32hi_1 */
    2875            0 :     case 5611:  /* *avx512bw_vpternlogv32hi_1 */
    2876            0 :     case 5610:  /* *avx512bw_vpternlogv32hi_1 */
    2877            0 :     case 5609:  /* *avx512bw_vpternlogv32hi_1 */
    2878            0 :     case 5608:  /* *avx512bw_vpternlogv32hi_1 */
    2879            0 :     case 5607:  /* *avx512bw_vpternlogv32hi_1 */
    2880            0 :     case 5606:  /* *avx512bw_vpternlogv32hi_1 */
    2881            0 :     case 5605:  /* *avx512vl_vpternlogv16qi_1 */
    2882            0 :     case 5604:  /* *avx512vl_vpternlogv16qi_1 */
    2883            0 :     case 5603:  /* *avx512vl_vpternlogv16qi_1 */
    2884            0 :     case 5602:  /* *avx512vl_vpternlogv16qi_1 */
    2885            0 :     case 5601:  /* *avx512vl_vpternlogv16qi_1 */
    2886            0 :     case 5600:  /* *avx512vl_vpternlogv16qi_1 */
    2887            0 :     case 5599:  /* *avx512vl_vpternlogv16qi_1 */
    2888            0 :     case 5598:  /* *avx512vl_vpternlogv16qi_1 */
    2889            0 :     case 5597:  /* *avx512vl_vpternlogv16qi_1 */
    2890            0 :     case 5596:  /* *avx512vl_vpternlogv16qi_1 */
    2891            0 :     case 5595:  /* *avx512vl_vpternlogv16qi_1 */
    2892            0 :     case 5594:  /* *avx512vl_vpternlogv16qi_1 */
    2893            0 :     case 5593:  /* *avx512vl_vpternlogv16qi_1 */
    2894            0 :     case 5592:  /* *avx512vl_vpternlogv16qi_1 */
    2895            0 :     case 5591:  /* *avx512vl_vpternlogv16qi_1 */
    2896            0 :     case 5590:  /* *avx512vl_vpternlogv16qi_1 */
    2897            0 :     case 5589:  /* *avx512vl_vpternlogv16qi_1 */
    2898            0 :     case 5588:  /* *avx512vl_vpternlogv16qi_1 */
    2899            0 :     case 5587:  /* *avx512vl_vpternlogv16qi_1 */
    2900            0 :     case 5586:  /* *avx512vl_vpternlogv16qi_1 */
    2901            0 :     case 5585:  /* *avx512vl_vpternlogv16qi_1 */
    2902            0 :     case 5584:  /* *avx512vl_vpternlogv16qi_1 */
    2903            0 :     case 5583:  /* *avx512vl_vpternlogv16qi_1 */
    2904            0 :     case 5582:  /* *avx512vl_vpternlogv16qi_1 */
    2905            0 :     case 5581:  /* *avx512vl_vpternlogv16qi_1 */
    2906            0 :     case 5580:  /* *avx512vl_vpternlogv16qi_1 */
    2907            0 :     case 5579:  /* *avx512vl_vpternlogv16qi_1 */
    2908            0 :     case 5578:  /* *avx512vl_vpternlogv32qi_1 */
    2909            0 :     case 5577:  /* *avx512vl_vpternlogv32qi_1 */
    2910            0 :     case 5576:  /* *avx512vl_vpternlogv32qi_1 */
    2911            0 :     case 5575:  /* *avx512vl_vpternlogv32qi_1 */
    2912            0 :     case 5574:  /* *avx512vl_vpternlogv32qi_1 */
    2913            0 :     case 5573:  /* *avx512vl_vpternlogv32qi_1 */
    2914            0 :     case 5572:  /* *avx512vl_vpternlogv32qi_1 */
    2915            0 :     case 5571:  /* *avx512vl_vpternlogv32qi_1 */
    2916            0 :     case 5570:  /* *avx512vl_vpternlogv32qi_1 */
    2917            0 :     case 5569:  /* *avx512vl_vpternlogv32qi_1 */
    2918            0 :     case 5568:  /* *avx512vl_vpternlogv32qi_1 */
    2919            0 :     case 5567:  /* *avx512vl_vpternlogv32qi_1 */
    2920            0 :     case 5566:  /* *avx512vl_vpternlogv32qi_1 */
    2921            0 :     case 5565:  /* *avx512vl_vpternlogv32qi_1 */
    2922            0 :     case 5564:  /* *avx512vl_vpternlogv32qi_1 */
    2923            0 :     case 5563:  /* *avx512vl_vpternlogv32qi_1 */
    2924            0 :     case 5562:  /* *avx512vl_vpternlogv32qi_1 */
    2925            0 :     case 5561:  /* *avx512vl_vpternlogv32qi_1 */
    2926            0 :     case 5560:  /* *avx512vl_vpternlogv32qi_1 */
    2927            0 :     case 5559:  /* *avx512vl_vpternlogv32qi_1 */
    2928            0 :     case 5558:  /* *avx512vl_vpternlogv32qi_1 */
    2929            0 :     case 5557:  /* *avx512vl_vpternlogv32qi_1 */
    2930            0 :     case 5556:  /* *avx512vl_vpternlogv32qi_1 */
    2931            0 :     case 5555:  /* *avx512vl_vpternlogv32qi_1 */
    2932            0 :     case 5554:  /* *avx512vl_vpternlogv32qi_1 */
    2933            0 :     case 5553:  /* *avx512vl_vpternlogv32qi_1 */
    2934            0 :     case 5552:  /* *avx512vl_vpternlogv32qi_1 */
    2935            0 :     case 5551:  /* *avx512bw_vpternlogv64qi_1 */
    2936            0 :     case 5550:  /* *avx512bw_vpternlogv64qi_1 */
    2937            0 :     case 5549:  /* *avx512bw_vpternlogv64qi_1 */
    2938            0 :     case 5548:  /* *avx512bw_vpternlogv64qi_1 */
    2939            0 :     case 5547:  /* *avx512bw_vpternlogv64qi_1 */
    2940            0 :     case 5546:  /* *avx512bw_vpternlogv64qi_1 */
    2941            0 :     case 5545:  /* *avx512bw_vpternlogv64qi_1 */
    2942            0 :     case 5544:  /* *avx512bw_vpternlogv64qi_1 */
    2943            0 :     case 5543:  /* *avx512bw_vpternlogv64qi_1 */
    2944            0 :     case 5542:  /* *avx512bw_vpternlogv64qi_1 */
    2945            0 :     case 5541:  /* *avx512bw_vpternlogv64qi_1 */
    2946            0 :     case 5540:  /* *avx512bw_vpternlogv64qi_1 */
    2947            0 :     case 5539:  /* *avx512bw_vpternlogv64qi_1 */
    2948            0 :     case 5538:  /* *avx512bw_vpternlogv64qi_1 */
    2949            0 :     case 5537:  /* *avx512bw_vpternlogv64qi_1 */
    2950            0 :     case 5536:  /* *avx512bw_vpternlogv64qi_1 */
    2951            0 :     case 5535:  /* *avx512bw_vpternlogv64qi_1 */
    2952            0 :     case 5534:  /* *avx512bw_vpternlogv64qi_1 */
    2953            0 :     case 5533:  /* *avx512bw_vpternlogv64qi_1 */
    2954            0 :     case 5532:  /* *avx512bw_vpternlogv64qi_1 */
    2955            0 :     case 5531:  /* *avx512bw_vpternlogv64qi_1 */
    2956            0 :     case 5530:  /* *avx512bw_vpternlogv64qi_1 */
    2957            0 :     case 5529:  /* *avx512bw_vpternlogv64qi_1 */
    2958            0 :     case 5528:  /* *avx512bw_vpternlogv64qi_1 */
    2959            0 :     case 5527:  /* *avx512bw_vpternlogv64qi_1 */
    2960            0 :     case 5526:  /* *avx512bw_vpternlogv64qi_1 */
    2961            0 :     case 5525:  /* *avx512bw_vpternlogv64qi_1 */
    2962            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2963            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    2964            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    2965            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    2966            0 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 1), 1));
    2967            0 :       break;
    2968              : 
    2969         2289 :     case 7133:  /* avx512vl_fixupimmv2df_maskz_1 */
    2970         2289 :     case 7129:  /* avx512vl_fixupimmv4df_maskz_1 */
    2971         2289 :     case 7125:  /* avx512f_fixupimmv8df_maskz_1 */
    2972         2289 :     case 7121:  /* avx512vl_fixupimmv4sf_maskz_1 */
    2973         2289 :     case 7117:  /* avx512vl_fixupimmv8sf_maskz_1 */
    2974         2289 :     case 7113:  /* avx512f_fixupimmv16sf_maskz_1 */
    2975         2289 :     case 5476:  /* avx512vl_vternlogv2di_maskz_1 */
    2976         2289 :     case 5474:  /* avx512vl_vternlogv4di_maskz_1 */
    2977         2289 :     case 5472:  /* avx512f_vternlogv8di_maskz_1 */
    2978         2289 :     case 5470:  /* avx512vl_vternlogv4si_maskz_1 */
    2979         2289 :     case 5468:  /* avx512vl_vternlogv8si_maskz_1 */
    2980         2289 :     case 5466:  /* avx512f_vternlogv16si_maskz_1 */
    2981         2289 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2982         2289 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    2983         2289 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    2984         2289 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    2985         2289 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 3));
    2986         2289 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 1));
    2987         2289 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (pat, 1), 2));
    2988         2289 :       break;
    2989              : 
    2990        41436 :     case 10178:  /* vsm3rnds2 */
    2991        41436 :     case 9146:  /* xop_vpermil2v2df3 */
    2992        41436 :     case 9145:  /* xop_vpermil2v4df3 */
    2993        41436 :     case 9144:  /* xop_vpermil2v4sf3 */
    2994        41436 :     case 9143:  /* xop_vpermil2v8sf3 */
    2995        41436 :     case 8733:  /* sse4a_insertqi */
    2996        41436 :     case 7131:  /* avx512vl_fixupimmv2df */
    2997        41436 :     case 7127:  /* avx512vl_fixupimmv4df */
    2998        41436 :     case 7123:  /* avx512f_fixupimmv8df */
    2999        41436 :     case 7119:  /* avx512vl_fixupimmv4sf */
    3000        41436 :     case 7115:  /* avx512vl_fixupimmv8sf */
    3001        41436 :     case 7111:  /* avx512f_fixupimmv16sf */
    3002        41436 :     case 5500:  /* *avx512vl_vternlogv2df_all */
    3003        41436 :     case 5499:  /* *avx512vl_vternlogv4df_all */
    3004        41436 :     case 5498:  /* *avx512f_vternlogv8df_all */
    3005        41436 :     case 5497:  /* *avx512vl_vternlogv4sf_all */
    3006        41436 :     case 5496:  /* *avx512vl_vternlogv8sf_all */
    3007        41436 :     case 5495:  /* *avx512f_vternlogv16sf_all */
    3008        41436 :     case 5494:  /* *avx512vl_vternlogv8bf_all */
    3009        41436 :     case 5493:  /* *avx512vl_vternlogv16bf_all */
    3010        41436 :     case 5492:  /* *avx512bw_vternlogv32bf_all */
    3011        41436 :     case 5491:  /* *avx512fp16_vternlogv8hf_all */
    3012        41436 :     case 5490:  /* *avx512vl_vternlogv16hf_all */
    3013        41436 :     case 5489:  /* *avx512bw_vternlogv32hf_all */
    3014        41436 :     case 5488:  /* *avx512vl_vternlogv2di_all */
    3015        41436 :     case 5487:  /* *avx512vl_vternlogv4di_all */
    3016        41436 :     case 5486:  /* *avx512f_vternlogv8di_all */
    3017        41436 :     case 5485:  /* *avx512vl_vternlogv4si_all */
    3018        41436 :     case 5484:  /* *avx512vl_vternlogv8si_all */
    3019        41436 :     case 5483:  /* *avx512f_vternlogv16si_all */
    3020        41436 :     case 5482:  /* *avx512vl_vternlogv8hi_all */
    3021        41436 :     case 5481:  /* *avx512vl_vternlogv16hi_all */
    3022        41436 :     case 5480:  /* *avx512bw_vternlogv32hi_all */
    3023        41436 :     case 5479:  /* *avx512vl_vternlogv16qi_all */
    3024        41436 :     case 5478:  /* *avx512vl_vternlogv32qi_all */
    3025        41436 :     case 5477:  /* *avx512bw_vternlogv64qi_all */
    3026        41436 :     case 5475:  /* avx512vl_vternlogv2di */
    3027        41436 :     case 5473:  /* avx512vl_vternlogv4di */
    3028        41436 :     case 5471:  /* avx512f_vternlogv8di */
    3029        41436 :     case 5469:  /* avx512vl_vternlogv4si */
    3030        41436 :     case 5467:  /* avx512vl_vternlogv8si */
    3031        41436 :     case 5465:  /* avx512f_vternlogv16si */
    3032        41436 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3033        41436 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
    3034        41436 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3035        41436 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 2));
    3036        41436 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 3));
    3037        41436 :       break;
    3038              : 
    3039         2829 :     case 9250:  /* avx2_permv4df_1_mask */
    3040         2829 :     case 9248:  /* avx2_permv4di_1_mask */
    3041         2829 :     case 8504:  /* sse2_pshuflw_1_mask */
    3042         2829 :     case 8498:  /* sse2_pshufd_1_mask */
    3043         2829 :     case 5342:  /* avx512f_vextracti32x4_1_mask */
    3044         2829 :     case 5341:  /* avx512f_vextractf32x4_1_mask */
    3045         2829 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3046         2829 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    3047         2829 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
    3048         2829 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 1));
    3049         2829 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 2));
    3050         2829 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 3));
    3051         2829 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (pat, 1), 1));
    3052         2829 :       ro[7] = *(ro_loc[7] = &XEXP (XEXP (pat, 1), 2));
    3053         2829 :       break;
    3054              : 
    3055          726 :     case 5338:  /* avx512dq_vextracti64x2_1_mask */
    3056          726 :     case 5337:  /* avx512dq_vextractf64x2_1_mask */
    3057          726 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3058          726 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    3059          726 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
    3060          726 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 1));
    3061          726 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    3062          726 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
    3063          726 :       break;
    3064              : 
    3065       629490 :     case 8548:  /* vec_setv4di_0 */
    3066       629490 :     case 8547:  /* vec_setv8di_0 */
    3067       629490 :     case 8511:  /* sse2_loadld */
    3068       629490 :     case 7246:  /* vec_setv4df_0 */
    3069       629490 :     case 7245:  /* vec_setv8df_0 */
    3070       629490 :     case 5333:  /* vec_setv2df_0 */
    3071       629490 :     case 5326:  /* vec_setv16sf_0 */
    3072       629490 :     case 5325:  /* vec_setv16si_0 */
    3073       629490 :     case 5324:  /* vec_setv8sf_0 */
    3074       629490 :     case 5323:  /* vec_setv8si_0 */
    3075       629490 :     case 5311:  /* vec_setv32bf_0 */
    3076       629490 :     case 5310:  /* vec_setv16bf_0 */
    3077       629490 :     case 5309:  /* vec_setv32hf_0 */
    3078       629490 :     case 5308:  /* vec_setv16hf_0 */
    3079       629490 :     case 5307:  /* vec_setv32hi_0 */
    3080       629490 :     case 5306:  /* vec_setv16hi_0 */
    3081       629490 :     case 5302:  /* vec_setv8bf_0 */
    3082       629490 :     case 5301:  /* vec_setv8hf_0 */
    3083       629490 :     case 5300:  /* vec_setv8hi_0 */
    3084       629490 :     case 5299:  /* vec_setv4sf_0 */
    3085       629490 :     case 5298:  /* vec_setv4si_0 */
    3086       629490 :     case 5297:  /* *vec_concatv8hi_movss */
    3087       629490 :     case 5296:  /* *vec_concatv8bf_movss */
    3088       629490 :     case 5295:  /* *vec_concatv8hf_movss */
    3089       629490 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3090       629490 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    3091       629490 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    3092       629490 :       break;
    3093              : 
    3094         2028 :     case 9569:  /* vec_set_lo_v32qi */
    3095         2028 :     case 9565:  /* vec_set_lo_v16bf */
    3096         2028 :     case 9564:  /* vec_set_lo_v16hf */
    3097         2028 :     case 9563:  /* vec_set_lo_v16hi */
    3098         2028 :     case 9557:  /* vec_set_lo_v8sf */
    3099         2028 :     case 9555:  /* vec_set_lo_v8si */
    3100         2028 :     case 9549:  /* vec_set_lo_v4df */
    3101         2028 :     case 9547:  /* vec_set_lo_v4di */
    3102         2028 :     case 8463:  /* vec_set_lo_v8di */
    3103         2028 :     case 8461:  /* vec_set_lo_v8df */
    3104         2028 :     case 8455:  /* vec_set_lo_v16si */
    3105         2028 :     case 8453:  /* vec_set_lo_v16sf */
    3106         2028 :     case 7239:  /* sse2_loadlpd */
    3107         2028 :     case 5279:  /* sse_loadlps */
    3108         2028 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3109         2028 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    3110         2028 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
    3111         2028 :       break;
    3112              : 
    3113      1000468 :     case 8471:  /* *avx512dq_shuf_f64x2_1 */
    3114      1000468 :     case 8469:  /* *avx512dq_shuf_i64x2_1 */
    3115      1000468 :     case 7217:  /* avx_shufpd256_1 */
    3116      1000468 :     case 5275:  /* sse_shufps_v4sf */
    3117      1000468 :     case 5274:  /* sse_shufps_v4si */
    3118      1000468 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3119      1000468 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    3120      1000468 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    3121      1000468 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    3122      1000468 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    3123      1000468 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 2));
    3124      1000468 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 3));
    3125      1000468 :       break;
    3126              : 
    3127         1768 :     case 8472:  /* avx512dq_shuf_f64x2_1_mask */
    3128         1768 :     case 8470:  /* avx512dq_shuf_i64x2_1_mask */
    3129         1768 :     case 7218:  /* avx_shufpd256_1_mask */
    3130         1768 :     case 5273:  /* sse_shufps_v4sf_mask */
    3131         1768 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3132         1768 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    3133         1768 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    3134         1768 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
    3135         1768 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 1));
    3136         1768 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 2));
    3137         1768 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 3));
    3138         1768 :       ro[7] = *(ro_loc[7] = &XEXP (XEXP (pat, 1), 1));
    3139         1768 :       ro[8] = *(ro_loc[8] = &XEXP (XEXP (pat, 1), 2));
    3140         1768 :       break;
    3141              : 
    3142         3396 :     case 8484:  /* avx512vl_shuf_f32x4_1_mask */
    3143         3396 :     case 8482:  /* avx512vl_shuf_i32x4_1_mask */
    3144         3396 :     case 8476:  /* avx512f_shuf_i64x2_1_mask */
    3145         3396 :     case 8474:  /* avx512f_shuf_f64x2_1_mask */
    3146         3396 :     case 7216:  /* avx512f_shufpd512_1_mask */
    3147         3396 :     case 5272:  /* avx_shufps256_1_mask */
    3148         3396 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3149         3396 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    3150         3396 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    3151         3396 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
    3152         3396 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 1));
    3153         3396 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 2));
    3154         3396 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 3));
    3155         3396 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 4));
    3156         3396 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 5));
    3157         3396 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 6));
    3158         3396 :       ro[10] = *(ro_loc[10] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 7));
    3159         3396 :       ro[11] = *(ro_loc[11] = &XEXP (XEXP (pat, 1), 1));
    3160         3396 :       ro[12] = *(ro_loc[12] = &XEXP (XEXP (pat, 1), 2));
    3161         3396 :       break;
    3162              : 
    3163        27632 :     case 8483:  /* avx512vl_shuf_f32x4_1 */
    3164        27632 :     case 8481:  /* avx512vl_shuf_i32x4_1 */
    3165        27632 :     case 8475:  /* avx512f_shuf_i64x2_1 */
    3166        27632 :     case 8473:  /* avx512f_shuf_f64x2_1 */
    3167        27632 :     case 7215:  /* avx512f_shufpd512_1 */
    3168        27632 :     case 5271:  /* avx_shufps256_1 */
    3169        27632 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3170        27632 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    3171        27632 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    3172        27632 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    3173        27632 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    3174        27632 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 2));
    3175        27632 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 3));
    3176        27632 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 4));
    3177        27632 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 5));
    3178        27632 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 6));
    3179        27632 :       ro[10] = *(ro_loc[10] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 7));
    3180        27632 :       break;
    3181              : 
    3182         4233 :     case 5412:  /* avx_movddup256_mask */
    3183         4233 :     case 5408:  /* avx512f_movddup512_mask */
    3184         4233 :     case 5270:  /* avx512f_movsldup512_mask */
    3185         4233 :     case 5268:  /* sse3_movsldup_mask */
    3186         4233 :     case 5266:  /* avx_movsldup256_mask */
    3187         4233 :     case 5264:  /* avx512f_movshdup512_mask */
    3188         4233 :     case 5262:  /* sse3_movshdup_mask */
    3189         4233 :     case 5260:  /* avx_movshdup256_mask */
    3190         4233 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3191         4233 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    3192         4233 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    3193         4233 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    3194         4233 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1);
    3195         4233 :       recog_data.dup_num[0] = 1;
    3196         4233 :       break;
    3197              : 
    3198         2272 :     case 5411:  /* avx_movddup256 */
    3199         2272 :     case 5407:  /* avx512f_movddup512 */
    3200         2272 :     case 5269:  /* *avx512f_movsldup512 */
    3201         2272 :     case 5267:  /* sse3_movsldup */
    3202         2272 :     case 5265:  /* avx_movsldup256 */
    3203         2272 :     case 5263:  /* *avx512f_movshdup512 */
    3204         2272 :     case 5261:  /* sse3_movshdup */
    3205         2272 :     case 5259:  /* avx_movshdup256 */
    3206         2272 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3207         2272 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    3208         2272 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 1);
    3209         2272 :       recog_data.dup_num[0] = 1;
    3210         2272 :       break;
    3211              : 
    3212        19600 :     case 8434:  /* vec_interleave_lowv4si_mask */
    3213        19600 :     case 8432:  /* avx512f_interleave_lowv16si_mask */
    3214        19600 :     case 8430:  /* avx2_interleave_lowv8si_mask */
    3215        19600 :     case 8428:  /* vec_interleave_highv4si_mask */
    3216        19600 :     case 8426:  /* avx512f_interleave_highv16si_mask */
    3217        19600 :     case 8424:  /* avx2_interleave_highv8si_mask */
    3218        19600 :     case 8422:  /* vec_interleave_lowv8bf_mask */
    3219        19600 :     case 8420:  /* vec_interleave_lowv8hf_mask */
    3220        19600 :     case 8418:  /* vec_interleave_lowv8hi_mask */
    3221        19600 :     case 8416:  /* avx2_interleave_lowv16bf_mask */
    3222        19600 :     case 8414:  /* avx2_interleave_lowv16hf_mask */
    3223        19600 :     case 8412:  /* avx2_interleave_lowv16hi_mask */
    3224        19600 :     case 8410:  /* avx512bw_interleave_lowv32bf_mask */
    3225        19600 :     case 8408:  /* avx512bw_interleave_lowv32hf_mask */
    3226        19600 :     case 8406:  /* avx512bw_interleave_lowv32hi_mask */
    3227        19600 :     case 8404:  /* vec_interleave_highv8bf_mask */
    3228        19600 :     case 8402:  /* vec_interleave_highv8hf_mask */
    3229        19600 :     case 8400:  /* vec_interleave_highv8hi_mask */
    3230        19600 :     case 8398:  /* avx2_interleave_highv16bf_mask */
    3231        19600 :     case 8396:  /* avx2_interleave_highv16hf_mask */
    3232        19600 :     case 8394:  /* avx2_interleave_highv16hi_mask */
    3233        19600 :     case 8392:  /* avx512bw_interleave_highv32bf_mask */
    3234        19600 :     case 8390:  /* avx512bw_interleave_highv32hf_mask */
    3235        19600 :     case 8388:  /* avx512bw_interleave_highv32hi_mask */
    3236        19600 :     case 8386:  /* vec_interleave_lowv16qi_mask */
    3237        19600 :     case 8384:  /* avx2_interleave_lowv32qi_mask */
    3238        19600 :     case 8382:  /* avx512bw_interleave_lowv64qi_mask */
    3239        19600 :     case 8380:  /* vec_interleave_highv16qi_mask */
    3240        19600 :     case 8378:  /* avx2_interleave_highv32qi_mask */
    3241        19600 :     case 8376:  /* avx512bw_interleave_highv64qi_mask */
    3242        19600 :     case 7231:  /* vec_interleave_lowv2di_mask */
    3243        19600 :     case 7229:  /* avx512f_interleave_lowv8di_mask */
    3244        19600 :     case 7227:  /* avx2_interleave_lowv4di_mask */
    3245        19600 :     case 7225:  /* vec_interleave_highv2di_mask */
    3246        19600 :     case 7223:  /* avx512f_interleave_highv8di_mask */
    3247        19600 :     case 7221:  /* avx2_interleave_highv4di_mask */
    3248        19600 :     case 5415:  /* avx512vl_unpcklpd128_mask */
    3249        19600 :     case 5414:  /* avx_unpcklpd256_mask */
    3250        19600 :     case 5410:  /* avx512f_unpcklpd512_mask */
    3251        19600 :     case 5405:  /* avx512vl_unpckhpd128_mask */
    3252        19600 :     case 5404:  /* avx_unpckhpd256_mask */
    3253        19600 :     case 5402:  /* avx512f_unpckhpd512_mask */
    3254        19600 :     case 5257:  /* unpcklps128_mask */
    3255        19600 :     case 5256:  /* avx_unpcklps256_mask */
    3256        19600 :     case 5254:  /* avx512f_unpcklps512_mask */
    3257        19600 :     case 5252:  /* vec_interleave_highv4sf_mask */
    3258        19600 :     case 5250:  /* avx_unpckhps256_mask */
    3259        19600 :     case 5248:  /* avx512f_unpckhps512_mask */
    3260        19600 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3261        19600 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    3262        19600 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    3263        19600 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    3264        19600 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    3265        19600 :       break;
    3266              : 
    3267          247 :     case 5237:  /* *avx512vl_cvtmask2qv2di_pternlog_false_dep */
    3268          247 :     case 5236:  /* *avx512vl_cvtmask2qv4di_pternlog_false_dep */
    3269          247 :     case 5235:  /* *avx512f_cvtmask2qv8di_pternlog_false_dep */
    3270          247 :     case 5234:  /* *avx512vl_cvtmask2dv4si_pternlog_false_dep */
    3271          247 :     case 5233:  /* *avx512vl_cvtmask2dv8si_pternlog_false_dep */
    3272          247 :     case 5232:  /* *avx512f_cvtmask2dv16si_pternlog_false_dep */
    3273          247 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    3274          247 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 2));
    3275          247 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    3276          247 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    3277          247 :       ro[4] = *(ro_loc[4] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    3278          247 :       break;
    3279              : 
    3280         6986 :     case 5231:  /* *avx512vl_cvtmask2qv2di_not */
    3281         6986 :     case 5230:  /* *avx512vl_cvtmask2qv4di_not */
    3282         6986 :     case 5229:  /* *avx512f_cvtmask2qv8di_not */
    3283         6986 :     case 5228:  /* *avx512vl_cvtmask2dv4si_not */
    3284         6986 :     case 5227:  /* *avx512vl_cvtmask2dv8si_not */
    3285         6986 :     case 5226:  /* *avx512f_cvtmask2dv16si_not */
    3286         6986 :     case 5225:  /* *avx512vl_cvtmask2wv8hi_not */
    3287         6986 :     case 5224:  /* *avx512vl_cvtmask2wv16hi_not */
    3288         6986 :     case 5223:  /* *avx512bw_cvtmask2wv32hi_not */
    3289         6986 :     case 5222:  /* *avx512vl_cvtmask2bv16qi_not */
    3290         6986 :     case 5221:  /* *avx512vl_cvtmask2bv32qi_not */
    3291         6986 :     case 5220:  /* *avx512bw_cvtmask2bv64qi_not */
    3292         6986 :     case 5219:  /* *avx512vl_cvtmask2qv2di */
    3293         6986 :     case 5218:  /* *avx512vl_cvtmask2qv4di */
    3294         6986 :     case 5217:  /* *avx512f_cvtmask2qv8di */
    3295         6986 :     case 5216:  /* *avx512vl_cvtmask2dv4si */
    3296         6986 :     case 5215:  /* *avx512vl_cvtmask2dv8si */
    3297         6986 :     case 5214:  /* *avx512f_cvtmask2dv16si */
    3298         6986 :     case 5213:  /* *avx512vl_cvtmask2wv8hi */
    3299         6986 :     case 5212:  /* *avx512vl_cvtmask2wv16hi */
    3300         6986 :     case 5211:  /* *avx512bw_cvtmask2wv32hi */
    3301         6986 :     case 5210:  /* *avx512vl_cvtmask2bv32qi */
    3302         6986 :     case 5209:  /* *avx512vl_cvtmask2bv16qi */
    3303         6986 :     case 5208:  /* *avx512bw_cvtmask2bv64qi */
    3304         6986 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3305         6986 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 2));
    3306         6986 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
    3307         6986 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    3308         6986 :       break;
    3309              : 
    3310          800 :     case 5176:  /* sse2_cvtss2sd_mask_round */
    3311          800 :     case 5171:  /* sse2_cvtsd2ss_mask_round */
    3312          800 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3313          800 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    3314          800 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0), 0));
    3315          800 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    3316          800 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    3317          800 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3318          800 :       break;
    3319              : 
    3320           92 :     case 5175:  /* sse2_cvtss2sd_mask */
    3321           92 :     case 5170:  /* sse2_cvtsd2ss_mask */
    3322           92 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3323           92 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    3324           92 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    3325           92 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    3326           92 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    3327           92 :       break;
    3328              : 
    3329         5070 :     case 7482:  /* *avx512f_us_truncatev8div16qi2_mask_1 */
    3330         5070 :     case 7481:  /* *avx512f_truncatev8div16qi2_mask_1 */
    3331         5070 :     case 7480:  /* *avx512f_ss_truncatev8div16qi2_mask_1 */
    3332         5070 :     case 7464:  /* *avx512vl_us_truncatev2div2si2_mask_1 */
    3333         5070 :     case 7463:  /* *avx512vl_truncatev2div2si2_mask_1 */
    3334         5070 :     case 7462:  /* *avx512vl_ss_truncatev2div2si2_mask_1 */
    3335         5070 :     case 7445:  /* *avx512vl_us_truncatev2div2hi2_mask_1 */
    3336         5070 :     case 7444:  /* *avx512vl_truncatev2div2hi2_mask_1 */
    3337         5070 :     case 7443:  /* *avx512vl_ss_truncatev2div2hi2_mask_1 */
    3338         5070 :     case 7427:  /* *avx512vl_us_truncatev4div4hi2_mask_1 */
    3339         5070 :     case 7426:  /* *avx512vl_truncatev4div4hi2_mask_1 */
    3340         5070 :     case 7425:  /* *avx512vl_ss_truncatev4div4hi2_mask_1 */
    3341         5070 :     case 7424:  /* *avx512vl_us_truncatev4siv4hi2_mask_1 */
    3342         5070 :     case 7423:  /* *avx512vl_truncatev4siv4hi2_mask_1 */
    3343         5070 :     case 7422:  /* *avx512vl_ss_truncatev4siv4hi2_mask_1 */
    3344         5070 :     case 7387:  /* *avx512vl_us_truncatev8siv8qi2_mask_1 */
    3345         5070 :     case 7386:  /* *avx512vl_truncatev8siv8qi2_mask_1 */
    3346         5070 :     case 7385:  /* *avx512vl_ss_truncatev8siv8qi2_mask_1 */
    3347         5070 :     case 7384:  /* *avx512vl_us_truncatev8hiv8qi2_mask_1 */
    3348         5070 :     case 7383:  /* *avx512vl_truncatev8hiv8qi2_mask_1 */
    3349         5070 :     case 7382:  /* *avx512vl_ss_truncatev8hiv8qi2_mask_1 */
    3350         5070 :     case 7357:  /* *avx512vl_us_truncatev4div4qi2_mask_1 */
    3351         5070 :     case 7356:  /* *avx512vl_truncatev4div4qi2_mask_1 */
    3352         5070 :     case 7355:  /* *avx512vl_ss_truncatev4div4qi2_mask_1 */
    3353         5070 :     case 7354:  /* *avx512vl_us_truncatev4siv4qi2_mask_1 */
    3354         5070 :     case 7353:  /* *avx512vl_truncatev4siv4qi2_mask_1 */
    3355         5070 :     case 7352:  /* *avx512vl_ss_truncatev4siv4qi2_mask_1 */
    3356         5070 :     case 7330:  /* *avx512vl_us_truncatev2div2qi2_mask_1 */
    3357         5070 :     case 7329:  /* *avx512vl_truncatev2div2qi2_mask_1 */
    3358         5070 :     case 7328:  /* *avx512vl_ss_truncatev2div2qi2_mask_1 */
    3359         5070 :     case 5167:  /* *sse2_cvttpd2dq_mask_1 */
    3360         5070 :     case 5066:  /* *fixuns_truncv2dfv2si2_mask_1 */
    3361         5070 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3362         5070 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    3363         5070 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    3364         5070 :       break;
    3365              : 
    3366        11101 :     case 7479:  /* avx512f_us_truncatev8div16qi2_mask */
    3367        11101 :     case 7478:  /* avx512f_truncatev8div16qi2_mask */
    3368        11101 :     case 7477:  /* avx512f_ss_truncatev8div16qi2_mask */
    3369        11101 :     case 7461:  /* avx512vl_us_truncatev2div2si2_mask */
    3370        11101 :     case 7460:  /* avx512vl_truncatev2div2si2_mask */
    3371        11101 :     case 7459:  /* avx512vl_ss_truncatev2div2si2_mask */
    3372        11101 :     case 7442:  /* avx512vl_us_truncatev2div2hi2_mask */
    3373        11101 :     case 7441:  /* avx512vl_truncatev2div2hi2_mask */
    3374        11101 :     case 7440:  /* avx512vl_ss_truncatev2div2hi2_mask */
    3375        11101 :     case 7421:  /* avx512vl_us_truncatev4div4hi2_mask */
    3376        11101 :     case 7420:  /* avx512vl_truncatev4div4hi2_mask */
    3377        11101 :     case 7419:  /* avx512vl_ss_truncatev4div4hi2_mask */
    3378        11101 :     case 7418:  /* avx512vl_us_truncatev4siv4hi2_mask */
    3379        11101 :     case 7417:  /* avx512vl_truncatev4siv4hi2_mask */
    3380        11101 :     case 7416:  /* avx512vl_ss_truncatev4siv4hi2_mask */
    3381        11101 :     case 7381:  /* avx512vl_us_truncatev8siv8qi2_mask */
    3382        11101 :     case 7380:  /* avx512vl_truncatev8siv8qi2_mask */
    3383        11101 :     case 7379:  /* avx512vl_ss_truncatev8siv8qi2_mask */
    3384        11101 :     case 7378:  /* avx512vl_us_truncatev8hiv8qi2_mask */
    3385        11101 :     case 7377:  /* avx512vl_truncatev8hiv8qi2_mask */
    3386        11101 :     case 7376:  /* avx512vl_ss_truncatev8hiv8qi2_mask */
    3387        11101 :     case 7351:  /* avx512vl_us_truncatev4div4qi2_mask */
    3388        11101 :     case 7350:  /* avx512vl_truncatev4div4qi2_mask */
    3389        11101 :     case 7349:  /* avx512vl_ss_truncatev4div4qi2_mask */
    3390        11101 :     case 7348:  /* avx512vl_us_truncatev4siv4qi2_mask */
    3391        11101 :     case 7347:  /* avx512vl_truncatev4siv4qi2_mask */
    3392        11101 :     case 7346:  /* avx512vl_ss_truncatev4siv4qi2_mask */
    3393        11101 :     case 7327:  /* avx512vl_us_truncatev2div2qi2_mask */
    3394        11101 :     case 7326:  /* avx512vl_truncatev2div2qi2_mask */
    3395        11101 :     case 7325:  /* avx512vl_ss_truncatev2div2qi2_mask */
    3396        11101 :     case 5166:  /* sse2_cvttpd2dq_mask */
    3397        11101 :     case 5065:  /* fixuns_truncv2dfv2si2_mask */
    3398        11101 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3399        11101 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    3400        11101 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
    3401        11101 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    3402        11101 :       break;
    3403              : 
    3404          312 :     case 5045:  /* *fixuns_notruncv2dfv2si2_mask_1 */
    3405          312 :     case 5034:  /* *sse2_cvtpd2dq_mask_1 */
    3406          312 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3407          312 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    3408          312 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    3409          312 :       break;
    3410              : 
    3411         1272 :     case 5064:  /* unspec_fixuns_truncv2dfv2si2_mask */
    3412         1272 :     case 5044:  /* fixuns_notruncv2dfv2si2_mask */
    3413         1272 :     case 5033:  /* sse2_cvtpd2dq_mask */
    3414         1272 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3415         1272 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    3416         1272 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
    3417         1272 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    3418         1272 :       break;
    3419              : 
    3420         1128 :     case 4896:  /* avx512dq_cvtps2uqqv2di_mask */
    3421         1128 :     case 4888:  /* avx512dq_cvtps2qqv2di_mask */
    3422         1128 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3423         1128 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0), 0));
    3424         1128 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    3425         1128 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    3426         1128 :       break;
    3427              : 
    3428         2327 :     case 9732:  /* vcvtph2ps */
    3429         2327 :     case 8616:  /* *sse2_pmovmskb_ext */
    3430         2327 :     case 8615:  /* *sse2_pmovmskb_zext */
    3431         2327 :     case 8614:  /* *avx2_pmovmskb_zext */
    3432         2327 :     case 8575:  /* *sse2_movmskpd_uext */
    3433         2327 :     case 8574:  /* *sse2_movmskpd_ext */
    3434         2327 :     case 8573:  /* *avx_movmskpd256_uext */
    3435         2327 :     case 8572:  /* *avx_movmskpd256_ext */
    3436         2327 :     case 8571:  /* *sse_movmskps_uext */
    3437         2327 :     case 8570:  /* *sse_movmskps_ext */
    3438         2327 :     case 8569:  /* *avx_movmskps256_uext */
    3439         2327 :     case 8568:  /* *avx_movmskps256_ext */
    3440         2327 :     case 5062:  /* *unspec_fixuns_truncv2dfv2si2 */
    3441         2327 :     case 5043:  /* fixuns_notruncv2dfv2si2 */
    3442         2327 :     case 5032:  /* sse2_cvtpd2dq */
    3443         2327 :     case 4813:  /* sse_cvtps2pi */
    3444         2327 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3445         2327 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    3446         2327 :       break;
    3447              : 
    3448         1722 :     case 4812:  /* sse_cvtpi2ps */
    3449         1722 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    3450         1722 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    3451         1722 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
    3452         1722 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
    3453         1722 :       break;
    3454              : 
    3455         3274 :     case 4807:  /* avx512fp16_vcvtss2sh_mask_round */
    3456         3274 :     case 4803:  /* avx512fp16_vcvtsd2sh_mask_round */
    3457         3274 :     case 4795:  /* avx512fp16_vcvtsh2ss_mask_round */
    3458         3274 :     case 4791:  /* avx512fp16_vcvtsh2sd_mask_round */
    3459         3274 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3460         3274 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0), 0), 0));
    3461         3274 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    3462         3274 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    3463         3274 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    3464         3274 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3465         3274 :       break;
    3466              : 
    3467         1044 :     case 4805:  /* avx512fp16_vcvtss2sh_round */
    3468         1044 :     case 4801:  /* avx512fp16_vcvtsd2sh_round */
    3469         1044 :     case 4794:  /* avx512fp16_vcvtsh2ss_round */
    3470         1044 :     case 4790:  /* avx512fp16_vcvtsh2sd_round */
    3471         1044 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3472         1044 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0), 0));
    3473         1044 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    3474         1044 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3475         1044 :       break;
    3476              : 
    3477          758 :     case 4806:  /* avx512fp16_vcvtss2sh_mask */
    3478          758 :     case 4802:  /* avx512fp16_vcvtsd2sh_mask */
    3479          758 :     case 4793:  /* avx512fp16_vcvtsh2ss_mask */
    3480          758 :     case 4789:  /* avx512fp16_vcvtsh2sd_mask */
    3481          758 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3482          758 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0));
    3483          758 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    3484          758 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    3485          758 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    3486          758 :       break;
    3487              : 
    3488          255 :     case 4804:  /* avx512fp16_vcvtss2sh */
    3489          255 :     case 4800:  /* avx512fp16_vcvtsd2sh */
    3490          255 :     case 4792:  /* avx512fp16_vcvtsh2ss */
    3491          255 :     case 4788:  /* avx512fp16_vcvtsh2sd */
    3492          255 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3493          255 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    3494          255 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    3495          255 :       break;
    3496              : 
    3497            0 :     case 4968:  /* sse2_cvttsd2siq_round */
    3498            0 :     case 4966:  /* sse2_cvttsd2si_round */
    3499            0 :     case 4954:  /* avx512f_vcvttsd2usiq_round */
    3500            0 :     case 4952:  /* avx512f_vcvttsd2usi_round */
    3501            0 :     case 4942:  /* avx512f_vcvttss2usiq_round */
    3502            0 :     case 4940:  /* avx512f_vcvttss2usi_round */
    3503            0 :     case 4833:  /* sse_cvttss2siq_round */
    3504            0 :     case 4831:  /* sse_cvttss2si_round */
    3505            0 :     case 4738:  /* avx512fp16_fixuns_truncdi2_round */
    3506            0 :     case 4736:  /* avx512fp16_fix_truncdi2_round */
    3507            0 :     case 4734:  /* avx512fp16_fixuns_truncsi2_round */
    3508            0 :     case 4732:  /* avx512fp16_fix_truncsi2_round */
    3509            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3510            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    3511            0 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3512            0 :       break;
    3513              : 
    3514        24866 :     case 9414:  /* avx512dq_broadcastv8sf_mask */
    3515        24866 :     case 9412:  /* avx512dq_broadcastv16sf_mask */
    3516        24866 :     case 9410:  /* avx512dq_broadcastv4si_mask */
    3517        24866 :     case 9408:  /* avx512dq_broadcastv8si_mask */
    3518        24866 :     case 9406:  /* avx512dq_broadcastv16si_mask */
    3519        24866 :     case 9310:  /* avx512vl_vec_dupv8bf_mask */
    3520        24866 :     case 9308:  /* avx512vl_vec_dupv16bf_mask */
    3521        24866 :     case 9306:  /* avx512bw_vec_dupv32bf_mask */
    3522        24866 :     case 9304:  /* avx512fp16_vec_dupv8hf_mask */
    3523        24866 :     case 9302:  /* avx512vl_vec_dupv16hf_mask */
    3524        24866 :     case 9300:  /* avx512bw_vec_dupv32hf_mask */
    3525        24866 :     case 9298:  /* avx512vl_vec_dupv8hi_mask */
    3526        24866 :     case 9296:  /* avx512vl_vec_dupv16hi_mask */
    3527        24866 :     case 9294:  /* avx512bw_vec_dupv32hi_mask */
    3528        24866 :     case 9292:  /* avx512vl_vec_dupv32qi_mask */
    3529        24866 :     case 9290:  /* avx512vl_vec_dupv16qi_mask */
    3530        24866 :     case 9288:  /* avx512bw_vec_dupv64qi_mask */
    3531        24866 :     case 9286:  /* avx512vl_vec_dupv2df_mask */
    3532        24866 :     case 9284:  /* avx512vl_vec_dupv4df_mask */
    3533        24866 :     case 9282:  /* avx512f_vec_dupv8df_mask */
    3534        24866 :     case 9280:  /* avx512vl_vec_dupv4sf_mask */
    3535        24866 :     case 9278:  /* avx512vl_vec_dupv8sf_mask */
    3536        24866 :     case 9276:  /* avx512f_vec_dupv16sf_mask */
    3537        24866 :     case 9274:  /* avx512vl_vec_dupv2di_mask */
    3538        24866 :     case 9272:  /* avx512vl_vec_dupv4di_mask */
    3539        24866 :     case 9270:  /* avx512f_vec_dupv8di_mask */
    3540        24866 :     case 9268:  /* avx512vl_vec_dupv4si_mask */
    3541        24866 :     case 9266:  /* avx512vl_vec_dupv8si_mask */
    3542        24866 :     case 9264:  /* avx512f_vec_dupv16si_mask */
    3543        24866 :     case 8981:  /* sse4_1_zero_extendv2siv2di2_mask */
    3544        24866 :     case 8979:  /* sse4_1_sign_extendv2siv2di2_mask */
    3545        24866 :     case 8957:  /* sse4_1_zero_extendv2hiv2di2_mask */
    3546        24866 :     case 8955:  /* sse4_1_sign_extendv2hiv2di2_mask */
    3547        24866 :     case 8945:  /* avx2_zero_extendv4hiv4di2_mask */
    3548        24866 :     case 8943:  /* avx2_sign_extendv4hiv4di2_mask */
    3549        24866 :     case 8930:  /* sse4_1_zero_extendv2qiv2di2_mask */
    3550        24866 :     case 8928:  /* sse4_1_sign_extendv2qiv2di2_mask */
    3551        24866 :     case 8918:  /* avx2_zero_extendv4qiv4di2_mask */
    3552        24866 :     case 8916:  /* avx2_sign_extendv4qiv4di2_mask */
    3553        24866 :     case 8906:  /* avx512f_zero_extendv8qiv8di2_mask */
    3554        24866 :     case 8904:  /* avx512f_sign_extendv8qiv8di2_mask */
    3555        24866 :     case 8890:  /* sse4_1_zero_extendv4hiv4si2_mask */
    3556        24866 :     case 8888:  /* sse4_1_sign_extendv4hiv4si2_mask */
    3557        24866 :     case 8860:  /* sse4_1_zero_extendv4qiv4si2_mask */
    3558        24866 :     case 8858:  /* sse4_1_sign_extendv4qiv4si2_mask */
    3559        24866 :     case 8848:  /* avx2_zero_extendv8qiv8si2_mask */
    3560        24866 :     case 8846:  /* avx2_sign_extendv8qiv8si2_mask */
    3561        24866 :     case 8828:  /* sse4_1_zero_extendv8qiv8hi2_mask */
    3562        24866 :     case 8826:  /* sse4_1_sign_extendv8qiv8hi2_mask */
    3563        24866 :     case 5239:  /* sse2_cvtps2pd_mask */
    3564        24866 :     case 5154:  /* avx512dq_fixuns_truncv2sfv2di2_mask */
    3565        24866 :     case 5152:  /* avx512dq_fix_truncv2sfv2di2_mask */
    3566        24866 :     case 5024:  /* sse2_cvtdq2pd_mask */
    3567        24866 :     case 5020:  /* floatunsv2siv2df2_mask */
    3568        24866 :     case 4764:  /* avx512fp16_float_extend_phv2df2_mask */
    3569        24866 :     case 4758:  /* avx512fp16_float_extend_phv4sf2_mask */
    3570        24866 :     case 4756:  /* avx512fp16_float_extend_phv4df2_mask */
    3571        24866 :     case 4718:  /* avx512fp16_fixuns_truncv2di2_mask */
    3572        24866 :     case 4716:  /* avx512fp16_fix_truncv2di2_mask */
    3573        24866 :     case 4702:  /* avx512fp16_fixuns_truncv4di2_mask */
    3574        24866 :     case 4700:  /* avx512fp16_fix_truncv4di2_mask */
    3575        24866 :     case 4698:  /* avx512fp16_fixuns_truncv4si2_mask */
    3576        24866 :     case 4696:  /* avx512fp16_fix_truncv4si2_mask */
    3577        24866 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3578        24866 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    3579        24866 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    3580        24866 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    3581        24866 :       break;
    3582              : 
    3583         3296 :     case 5174:  /* sse2_cvtss2sd_round */
    3584         3296 :     case 5169:  /* sse2_cvtsd2ss_round */
    3585         3296 :     case 4930:  /* sse2_cvtsi2sdq_round */
    3586         3296 :     case 4840:  /* cvtusi2sd64_round */
    3587         3296 :     case 4838:  /* cvtusi2ss64_round */
    3588         3296 :     case 4835:  /* cvtusi2ss32_round */
    3589         3296 :     case 4819:  /* sse_cvtsi2ssq_round */
    3590         3296 :     case 4817:  /* sse_cvtsi2ss_round */
    3591         3296 :     case 4590:  /* avx512fp16_vcvtusi2shq_round */
    3592         3296 :     case 4588:  /* avx512fp16_vcvtsi2shq_round */
    3593         3296 :     case 4586:  /* avx512fp16_vcvtusi2sh_round */
    3594         3296 :     case 4584:  /* avx512fp16_vcvtsi2sh_round */
    3595         3296 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3596         3296 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    3597         3296 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    3598         3296 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3599         3296 :       break;
    3600              : 
    3601      1155354 :     case 5305:  /* *vec_setv8bf_0_1 */
    3602      1155354 :     case 5304:  /* *vec_setv8hf_0_1 */
    3603      1155354 :     case 5303:  /* *vec_setv8hi_0_1 */
    3604      1155354 :     case 5177:  /* *sse2_vd_cvtss2sd */
    3605      1155354 :     case 5173:  /* sse2_cvtss2sd */
    3606      1155354 :     case 5172:  /* *sse2_vd_cvtsd2ss */
    3607      1155354 :     case 5168:  /* sse2_cvtsd2ss */
    3608      1155354 :     case 4929:  /* sse2_cvtsi2sdq */
    3609      1155354 :     case 4928:  /* sse2_cvtsi2sd */
    3610      1155354 :     case 4839:  /* cvtusi2sd64 */
    3611      1155354 :     case 4837:  /* cvtusi2ss64 */
    3612      1155354 :     case 4836:  /* cvtusi2sd32 */
    3613      1155354 :     case 4834:  /* cvtusi2ss32 */
    3614      1155354 :     case 4818:  /* sse_cvtsi2ssq */
    3615      1155354 :     case 4816:  /* sse_cvtsi2ss */
    3616      1155354 :     case 4589:  /* avx512fp16_vcvtusi2shq */
    3617      1155354 :     case 4587:  /* avx512fp16_vcvtsi2shq */
    3618      1155354 :     case 4585:  /* avx512fp16_vcvtusi2sh */
    3619      1155354 :     case 4583:  /* avx512fp16_vcvtsi2sh */
    3620      1155354 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3621      1155354 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    3622      1155354 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    3623      1155354 :       break;
    3624              : 
    3625         5524 :     case 10982:  /* avx10_2_vcvttss2usisdi_round */
    3626         5524 :     case 10980:  /* avx10_2_vcvttss2sisdi_round */
    3627         5524 :     case 10978:  /* avx10_2_vcvttss2usissi_round */
    3628         5524 :     case 10976:  /* avx10_2_vcvttss2sissi_round */
    3629         5524 :     case 10974:  /* avx10_2_vcvttsd2usisdi_round */
    3630         5524 :     case 10972:  /* avx10_2_vcvttsd2sisdi_round */
    3631         5524 :     case 10970:  /* avx10_2_vcvttsd2usissi_round */
    3632         5524 :     case 10968:  /* avx10_2_vcvttsd2sissi_round */
    3633         5524 :     case 4958:  /* sse2_cvtsd2siq_round */
    3634         5524 :     case 4956:  /* sse2_cvtsd2si_round */
    3635         5524 :     case 4946:  /* avx512f_vcvtsd2usiq_round */
    3636         5524 :     case 4944:  /* avx512f_vcvtsd2usi_round */
    3637         5524 :     case 4934:  /* avx512f_vcvtss2usiq_round */
    3638         5524 :     case 4932:  /* avx512f_vcvtss2usi_round */
    3639         5524 :     case 4823:  /* sse_cvtss2siq_round */
    3640         5524 :     case 4821:  /* sse_cvtss2si_round */
    3641         5524 :     case 4578:  /* avx512fp16_vcvtsh2siq_round */
    3642         5524 :     case 4576:  /* avx512fp16_vcvtsh2usiq_round */
    3643         5524 :     case 4574:  /* avx512fp16_vcvtsh2si_round */
    3644         5524 :     case 4572:  /* avx512fp16_vcvtsh2usi_round */
    3645         5524 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3646         5524 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 0));
    3647         5524 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3648         5524 :       break;
    3649              : 
    3650         1728 :     case 5187:  /* *sse2_cvtpd2ps_mask_1 */
    3651         1728 :     case 5014:  /* *floatunsv2div2sf2_mask_1 */
    3652         1728 :     case 5013:  /* *floatv2div2sf2_mask_1 */
    3653         1728 :     case 4787:  /* *avx512fp16_vcvtpd2ph_v2df_mask_1 */
    3654         1728 :     case 4784:  /* *avx512fp16_vcvtps2ph_v4sf_mask_1 */
    3655         1728 :     case 4783:  /* *avx512fp16_vcvtpd2ph_v4df_mask_1 */
    3656         1728 :     case 4570:  /* *avx512fp16_vcvtuqq2ph_v2di_mask_1 */
    3657         1728 :     case 4569:  /* *avx512fp16_vcvtqq2ph_v2di_mask_1 */
    3658         1728 :     case 4564:  /* *avx512fp16_vcvtuqq2ph_v4di_mask_1 */
    3659         1728 :     case 4563:  /* *avx512fp16_vcvtqq2ph_v4di_mask_1 */
    3660         1728 :     case 4562:  /* *avx512fp16_vcvtudq2ph_v4si_mask_1 */
    3661         1728 :     case 4561:  /* *avx512fp16_vcvtdq2ph_v4si_mask_1 */
    3662         1728 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3663         1728 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    3664         1728 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    3665         1728 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    3666         1728 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    3667         1728 :       break;
    3668              : 
    3669         5021 :     case 10430:  /* avx512f_cvtneps2bf16_v4sf_mask_1 */
    3670         5021 :     case 5186:  /* *sse2_cvtpd2ps_mask */
    3671         5021 :     case 5012:  /* *floatunsv2div2sf2_mask */
    3672         5021 :     case 5011:  /* *floatv2div2sf2_mask */
    3673         5021 :     case 4786:  /* *avx512fp16_vcvtpd2ph_v2df_mask */
    3674         5021 :     case 4782:  /* *avx512fp16_vcvtps2ph_v4sf_mask */
    3675         5021 :     case 4781:  /* *avx512fp16_vcvtpd2ph_v4df_mask */
    3676         5021 :     case 4568:  /* *avx512fp16_vcvtuqq2ph_v2di_mask */
    3677         5021 :     case 4567:  /* *avx512fp16_vcvtqq2ph_v2di_mask */
    3678         5021 :     case 4560:  /* *avx512fp16_vcvtuqq2ph_v4di_mask */
    3679         5021 :     case 4559:  /* *avx512fp16_vcvtqq2ph_v4di_mask */
    3680         5021 :     case 4558:  /* *avx512fp16_vcvtudq2ph_v4si_mask */
    3681         5021 :     case 4557:  /* *avx512fp16_vcvtdq2ph_v4si_mask */
    3682         5021 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3683         5021 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    3684         5021 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
    3685         5021 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    3686         5021 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    3687         5021 :       break;
    3688              : 
    3689        32203 :     case 10958:  /* avx10_2_vcvttps2uqqsv8di_mask_round */
    3690        32203 :     case 10954:  /* avx10_2_vcvttps2qqsv8di_mask_round */
    3691        32203 :     case 10942:  /* avx10_2_vcvttpd2uqqsv8df_mask_round */
    3692        32203 :     case 10938:  /* avx10_2_vcvttpd2qqsv8df_mask_round */
    3693        32203 :     case 10926:  /* avx10_2_vcvttpd2udqsv8df_mask_round */
    3694        32203 :     case 10922:  /* avx10_2_vcvttpd2dqsv8df_mask_round */
    3695        32203 :     case 10910:  /* avx10_2_vcvttps2udqsv16sf_mask_round */
    3696        32203 :     case 10906:  /* avx10_2_vcvttps2dqsv16sf_mask_round */
    3697        32203 :     case 10894:  /* avx10_2_cvttps2iubsv16sf_mask_round */
    3698        32203 :     case 10890:  /* avx10_2_cvttps2ibsv16sf_mask_round */
    3699        32203 :     case 10878:  /* avx10_2_cvtps2iubsv16sf_mask_round */
    3700        32203 :     case 10874:  /* avx10_2_cvtps2ibsv16sf_mask_round */
    3701        32203 :     case 10862:  /* avx10_2_cvttph2iubsv32hf_mask_round */
    3702        32203 :     case 10858:  /* avx10_2_cvttph2ibsv32hf_mask_round */
    3703        32203 :     case 10846:  /* avx10_2_cvtph2iubsv32hf_mask_round */
    3704        32203 :     case 10842:  /* avx10_2_cvtph2ibsv32hf_mask_round */
    3705        32203 :     case 9741:  /* avx512f_vcvtph2ps512_mask_round */
    3706        32203 :     case 7078:  /* avx512vl_getexpv2df_mask_round */
    3707        32203 :     case 7074:  /* avx512vl_getexpv4df_mask_round */
    3708        32203 :     case 7070:  /* avx512f_getexpv8df_mask_round */
    3709        32203 :     case 7066:  /* avx512vl_getexpv4sf_mask_round */
    3710        32203 :     case 7062:  /* avx512vl_getexpv8sf_mask_round */
    3711        32203 :     case 7058:  /* avx512f_getexpv16sf_mask_round */
    3712        32203 :     case 7054:  /* avx512fp16_getexpv8hf_mask_round */
    3713        32203 :     case 7050:  /* avx512vl_getexpv16hf_mask_round */
    3714        32203 :     case 7046:  /* avx512bw_getexpv32hf_mask_round */
    3715        32203 :     case 5130:  /* unspec_fixuns_truncv8sfv8di2_mask_round */
    3716        32203 :     case 5126:  /* unspec_fix_truncv8sfv8di2_mask_round */
    3717        32203 :     case 5118:  /* fixuns_notruncv8dfv8di2_mask_round */
    3718        32203 :     case 5110:  /* fix_notruncv8dfv8di2_mask_round */
    3719        32203 :     case 5082:  /* unspec_fixuns_truncv8dfv8di2_mask_round */
    3720        32203 :     case 5078:  /* unspec_fix_truncv8dfv8di2_mask_round */
    3721        32203 :     case 5053:  /* unspec_fixuns_truncv8dfv8si2_mask_round */
    3722        32203 :     case 5049:  /* unspec_fix_truncv8dfv8si2_mask_round */
    3723        32203 :     case 5042:  /* fixuns_notruncv4dfv4si2_mask_round */
    3724        32203 :     case 5038:  /* fixuns_notruncv8dfv8si2_mask_round */
    3725        32203 :     case 5028:  /* avx512f_cvtpd2dq512_mask_round */
    3726        32203 :     case 4904:  /* unspec_fixuns_truncv16sfv16si2_mask_round */
    3727        32203 :     case 4900:  /* unspec_fix_truncv16sfv16si2_mask_round */
    3728        32203 :     case 4892:  /* avx512dq_cvtps2uqqv8di_mask_round */
    3729        32203 :     case 4884:  /* avx512dq_cvtps2qqv8di_mask_round */
    3730        32203 :     case 4880:  /* avx512vl_fixuns_notruncv4sfv4si_mask_round */
    3731        32203 :     case 4876:  /* avx512vl_fixuns_notruncv8sfv8si_mask_round */
    3732        32203 :     case 4872:  /* avx512f_fixuns_notruncv16sfv16si_mask_round */
    3733        32203 :     case 4868:  /* avx512f_fix_notruncv16sfv16si_mask_round */
    3734        32203 :     case 4638:  /* unspec_avx512fp16_fixuns_truncv8di2_mask_round */
    3735        32203 :     case 4634:  /* unspec_avx512fp16_fix_truncv8di2_mask_round */
    3736        32203 :     case 4630:  /* unspec_avx512fp16_fixuns_truncv16si2_mask_round */
    3737        32203 :     case 4626:  /* unspec_avx512fp16_fix_truncv16si2_mask_round */
    3738        32203 :     case 4622:  /* unspec_avx512fp16_fixuns_truncv8si2_mask_round */
    3739        32203 :     case 4618:  /* unspec_avx512fp16_fix_truncv8si2_mask_round */
    3740        32203 :     case 4614:  /* unspec_avx512fp16_fixuns_truncv32hi2_mask_round */
    3741        32203 :     case 4610:  /* unspec_avx512fp16_fix_truncv32hi2_mask_round */
    3742        32203 :     case 4606:  /* unspec_avx512fp16_fixuns_truncv16hi2_mask_round */
    3743        32203 :     case 4602:  /* unspec_avx512fp16_fix_truncv16hi2_mask_round */
    3744        32203 :     case 4598:  /* unspec_avx512fp16_fixuns_truncv8hi2_mask_round */
    3745        32203 :     case 4594:  /* unspec_avx512fp16_fix_truncv8hi2_mask_round */
    3746        32203 :     case 4504:  /* avx512fp16_vcvtph2qq_v2di_mask_round */
    3747        32203 :     case 4500:  /* avx512fp16_vcvtph2uqq_v2di_mask_round */
    3748        32203 :     case 4496:  /* avx512fp16_vcvtph2dq_v4si_mask_round */
    3749        32203 :     case 4492:  /* avx512fp16_vcvtph2udq_v4si_mask_round */
    3750        32203 :     case 4488:  /* avx512fp16_vcvtph2w_v8hi_mask_round */
    3751        32203 :     case 4484:  /* avx512fp16_vcvtph2uw_v8hi_mask_round */
    3752        32203 :     case 4480:  /* avx512fp16_vcvtph2qq_v4di_mask_round */
    3753        32203 :     case 4476:  /* avx512fp16_vcvtph2uqq_v4di_mask_round */
    3754        32203 :     case 4472:  /* avx512fp16_vcvtph2dq_v8si_mask_round */
    3755        32203 :     case 4468:  /* avx512fp16_vcvtph2udq_v8si_mask_round */
    3756        32203 :     case 4464:  /* avx512fp16_vcvtph2w_v16hi_mask_round */
    3757        32203 :     case 4460:  /* avx512fp16_vcvtph2uw_v16hi_mask_round */
    3758        32203 :     case 4456:  /* avx512fp16_vcvtph2qq_v8di_mask_round */
    3759        32203 :     case 4452:  /* avx512fp16_vcvtph2uqq_v8di_mask_round */
    3760        32203 :     case 4448:  /* avx512fp16_vcvtph2dq_v16si_mask_round */
    3761        32203 :     case 4444:  /* avx512fp16_vcvtph2udq_v16si_mask_round */
    3762        32203 :     case 4440:  /* avx512fp16_vcvtph2w_v32hi_mask_round */
    3763        32203 :     case 4436:  /* avx512fp16_vcvtph2uw_v32hi_mask_round */
    3764        32203 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3765        32203 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    3766        32203 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    3767        32203 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    3768        32203 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3769        32203 :       break;
    3770              : 
    3771        13153 :     case 10956:  /* avx10_2_vcvttps2uqqsv8di_round */
    3772        13153 :     case 10952:  /* avx10_2_vcvttps2qqsv8di_round */
    3773        13153 :     case 10940:  /* avx10_2_vcvttpd2uqqsv8df_round */
    3774        13153 :     case 10936:  /* avx10_2_vcvttpd2qqsv8df_round */
    3775        13153 :     case 10924:  /* avx10_2_vcvttpd2udqsv8df_round */
    3776        13153 :     case 10920:  /* avx10_2_vcvttpd2dqsv8df_round */
    3777        13153 :     case 10908:  /* avx10_2_vcvttps2udqsv16sf_round */
    3778        13153 :     case 10904:  /* avx10_2_vcvttps2dqsv16sf_round */
    3779        13153 :     case 10892:  /* avx10_2_cvttps2iubsv16sf_round */
    3780        13153 :     case 10888:  /* avx10_2_cvttps2ibsv16sf_round */
    3781        13153 :     case 10876:  /* avx10_2_cvtps2iubsv16sf_round */
    3782        13153 :     case 10872:  /* avx10_2_cvtps2ibsv16sf_round */
    3783        13153 :     case 10860:  /* avx10_2_cvttph2iubsv32hf_round */
    3784        13153 :     case 10856:  /* avx10_2_cvttph2ibsv32hf_round */
    3785        13153 :     case 10844:  /* avx10_2_cvtph2iubsv32hf_round */
    3786        13153 :     case 10840:  /* avx10_2_cvtph2ibsv32hf_round */
    3787        13153 :     case 9739:  /* *avx512f_vcvtph2ps512_round */
    3788        13153 :     case 7076:  /* avx512vl_getexpv2df_round */
    3789        13153 :     case 7072:  /* avx512vl_getexpv4df_round */
    3790        13153 :     case 7068:  /* avx512f_getexpv8df_round */
    3791        13153 :     case 7064:  /* avx512vl_getexpv4sf_round */
    3792        13153 :     case 7060:  /* avx512vl_getexpv8sf_round */
    3793        13153 :     case 7056:  /* avx512f_getexpv16sf_round */
    3794        13153 :     case 7052:  /* avx512fp16_getexpv8hf_round */
    3795        13153 :     case 7048:  /* avx512vl_getexpv16hf_round */
    3796        13153 :     case 7044:  /* avx512bw_getexpv32hf_round */
    3797        13153 :     case 5128:  /* unspec_fixuns_truncv8sfv8di2_round */
    3798        13153 :     case 5124:  /* unspec_fix_truncv8sfv8di2_round */
    3799        13153 :     case 5116:  /* fixuns_notruncv8dfv8di2_round */
    3800        13153 :     case 5108:  /* fix_notruncv8dfv8di2_round */
    3801        13153 :     case 5080:  /* unspec_fixuns_truncv8dfv8di2_round */
    3802        13153 :     case 5076:  /* unspec_fix_truncv8dfv8di2_round */
    3803        13153 :     case 5051:  /* unspec_fixuns_truncv8dfv8si2_round */
    3804        13153 :     case 5047:  /* unspec_fix_truncv8dfv8si2_round */
    3805        13153 :     case 5040:  /* fixuns_notruncv4dfv4si2_round */
    3806        13153 :     case 5036:  /* fixuns_notruncv8dfv8si2_round */
    3807        13153 :     case 5026:  /* avx512f_cvtpd2dq512_round */
    3808        13153 :     case 4964:  /* unspec_sse2_cvttsd2siq_round */
    3809        13153 :     case 4962:  /* unspec_sse2_cvttsd2si_round */
    3810        13153 :     case 4950:  /* unspec_avx512f_vcvttsd2usiq_round */
    3811        13153 :     case 4948:  /* unspec_avx512f_vcvttsd2usi_round */
    3812        13153 :     case 4938:  /* unspec_avx512f_vcvttss2usiq_round */
    3813        13153 :     case 4936:  /* unspec_avx512f_vcvttss2usi_round */
    3814        13153 :     case 4902:  /* unspec_fixuns_truncv16sfv16si2_round */
    3815        13153 :     case 4898:  /* unspec_fix_truncv16sfv16si2_round */
    3816        13153 :     case 4890:  /* *avx512dq_cvtps2uqqv8di_round */
    3817        13153 :     case 4882:  /* *avx512dq_cvtps2qqv8di_round */
    3818        13153 :     case 4878:  /* *avx512vl_fixuns_notruncv4sfv4si_round */
    3819        13153 :     case 4874:  /* *avx512vl_fixuns_notruncv8sfv8si_round */
    3820        13153 :     case 4870:  /* *avx512f_fixuns_notruncv16sfv16si_round */
    3821        13153 :     case 4866:  /* avx512f_fix_notruncv16sfv16si_round */
    3822        13153 :     case 4829:  /* unspec_sse_cvttss2siq_round */
    3823        13153 :     case 4827:  /* unspec_sse_cvttss2si_round */
    3824        13153 :     case 4730:  /* unspec_avx512fp16_fixuns_truncdi2_round */
    3825        13153 :     case 4728:  /* unspec_avx512fp16_fix_truncdi2_round */
    3826        13153 :     case 4726:  /* unspec_avx512fp16_fixuns_truncsi2_round */
    3827        13153 :     case 4724:  /* unspec_avx512fp16_fix_truncsi2_round */
    3828        13153 :     case 4636:  /* unspec_avx512fp16_fixuns_truncv8di2_round */
    3829        13153 :     case 4632:  /* unspec_avx512fp16_fix_truncv8di2_round */
    3830        13153 :     case 4628:  /* unspec_avx512fp16_fixuns_truncv16si2_round */
    3831        13153 :     case 4624:  /* unspec_avx512fp16_fix_truncv16si2_round */
    3832        13153 :     case 4620:  /* unspec_avx512fp16_fixuns_truncv8si2_round */
    3833        13153 :     case 4616:  /* unspec_avx512fp16_fix_truncv8si2_round */
    3834        13153 :     case 4612:  /* unspec_avx512fp16_fixuns_truncv32hi2_round */
    3835        13153 :     case 4608:  /* unspec_avx512fp16_fix_truncv32hi2_round */
    3836        13153 :     case 4604:  /* unspec_avx512fp16_fixuns_truncv16hi2_round */
    3837        13153 :     case 4600:  /* unspec_avx512fp16_fix_truncv16hi2_round */
    3838        13153 :     case 4596:  /* unspec_avx512fp16_fixuns_truncv8hi2_round */
    3839        13153 :     case 4592:  /* unspec_avx512fp16_fix_truncv8hi2_round */
    3840        13153 :     case 4502:  /* avx512fp16_vcvtph2qq_v2di_round */
    3841        13153 :     case 4498:  /* avx512fp16_vcvtph2uqq_v2di_round */
    3842        13153 :     case 4494:  /* avx512fp16_vcvtph2dq_v4si_round */
    3843        13153 :     case 4490:  /* avx512fp16_vcvtph2udq_v4si_round */
    3844        13153 :     case 4486:  /* avx512fp16_vcvtph2w_v8hi_round */
    3845        13153 :     case 4482:  /* avx512fp16_vcvtph2uw_v8hi_round */
    3846        13153 :     case 4478:  /* avx512fp16_vcvtph2qq_v4di_round */
    3847        13153 :     case 4474:  /* avx512fp16_vcvtph2uqq_v4di_round */
    3848        13153 :     case 4470:  /* avx512fp16_vcvtph2dq_v8si_round */
    3849        13153 :     case 4466:  /* avx512fp16_vcvtph2udq_v8si_round */
    3850        13153 :     case 4462:  /* avx512fp16_vcvtph2w_v16hi_round */
    3851        13153 :     case 4458:  /* avx512fp16_vcvtph2uw_v16hi_round */
    3852        13153 :     case 4454:  /* avx512fp16_vcvtph2qq_v8di_round */
    3853        13153 :     case 4450:  /* avx512fp16_vcvtph2uqq_v8di_round */
    3854        13153 :     case 4446:  /* avx512fp16_vcvtph2dq_v16si_round */
    3855        13153 :     case 4442:  /* avx512fp16_vcvtph2udq_v16si_round */
    3856        13153 :     case 4438:  /* avx512fp16_vcvtph2w_v32hi_round */
    3857        13153 :     case 4434:  /* avx512fp16_vcvtph2uw_v32hi_round */
    3858        13153 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3859        13153 :       ro[1] = *(ro_loc[1] = &XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0));
    3860        13153 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3861        13153 :       break;
    3862              : 
    3863         1892 :     case 4432:  /* avx512fp16_fcmulcsh_v8hf_mask_round */
    3864         1892 :     case 4428:  /* avx512fp16_fmulcsh_v8hf_mask_round */
    3865         1892 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3866         1892 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 0));
    3867         1892 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 1));
    3868         1892 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    3869         1892 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0, 0));
    3870         1892 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3871         1892 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    3872         1892 :       recog_data.dup_num[0] = 1;
    3873         1892 :       break;
    3874              : 
    3875          436 :     case 4431:  /* avx512fp16_fcmulcsh_v8hf_mask */
    3876          436 :     case 4427:  /* avx512fp16_fmulcsh_v8hf_mask */
    3877          436 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3878          436 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    3879          436 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
    3880          436 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    3881          436 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0, 0));
    3882          436 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    3883          436 :       recog_data.dup_num[0] = 1;
    3884          436 :       break;
    3885              : 
    3886         1696 :     case 4424:  /* avx512fp16_fcmaddcsh_v8hf_mask_round */
    3887         1696 :     case 4422:  /* avx512fp16_fmaddcsh_v8hf_mask_round */
    3888         1696 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3889         1696 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 0));
    3890         1696 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 1));
    3891         1696 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 2));
    3892         1696 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0, 0));
    3893         1696 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3894         1696 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1);
    3895         1696 :       recog_data.dup_num[0] = 1;
    3896         1696 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    3897         1696 :       recog_data.dup_num[1] = 2;
    3898         1696 :       break;
    3899              : 
    3900          242 :     case 4423:  /* avx512fp16_fcmaddcsh_v8hf_mask */
    3901          242 :     case 4421:  /* avx512fp16_fmaddcsh_v8hf_mask */
    3902          242 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3903          242 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    3904          242 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
    3905          242 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 2));
    3906          242 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0, 0));
    3907          242 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 1);
    3908          242 :       recog_data.dup_num[0] = 1;
    3909          242 :       recog_data.dup_loc[1] = &XEXP (XEXP (pat, 1), 1);
    3910          242 :       recog_data.dup_num[1] = 2;
    3911          242 :       break;
    3912              : 
    3913          852 :     case 4420:  /* avx512fp16_fma_fcmaddcsh_v8hf_maskz_round */
    3914          852 :     case 4416:  /* avx512fp16_fma_fmaddcsh_v8hf_maskz_round */
    3915          852 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3916          852 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 0));
    3917          852 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 1));
    3918          852 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 2));
    3919          852 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    3920          852 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0, 0));
    3921          852 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3922          852 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    3923          852 :       recog_data.dup_num[0] = 2;
    3924          852 :       break;
    3925              : 
    3926          776 :     case 4419:  /* avx512fp16_fma_fcmaddcsh_v8hf_round */
    3927          776 :     case 4415:  /* avx512fp16_fma_fmaddcsh_v8hf_round */
    3928          776 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3929          776 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    3930          776 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    3931          776 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    3932          776 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3933          776 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    3934          776 :       recog_data.dup_num[0] = 2;
    3935          776 :       break;
    3936              : 
    3937          118 :     case 4418:  /* avx512fp16_fma_fcmaddcsh_v8hf_maskz */
    3938          118 :     case 4414:  /* avx512fp16_fma_fmaddcsh_v8hf_maskz */
    3939          118 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3940          118 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    3941          118 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
    3942          118 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 2));
    3943          118 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    3944          118 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0, 0));
    3945          118 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    3946          118 :       recog_data.dup_num[0] = 2;
    3947          118 :       break;
    3948              : 
    3949          149 :     case 4417:  /* avx512fp16_fma_fcmaddcsh_v8hf */
    3950          149 :     case 4413:  /* avx512fp16_fma_fmaddcsh_v8hf */
    3951          149 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3952          149 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    3953          149 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    3954          149 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    3955          149 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    3956          149 :       recog_data.dup_num[0] = 2;
    3957          149 :       break;
    3958              : 
    3959         1863 :     case 4404:  /* avx512bw_fcmulc_v32hf_mask_round */
    3960         1863 :     case 4400:  /* avx512bw_fmulc_v32hf_mask_round */
    3961         1863 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3962         1863 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    3963         1863 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    3964         1863 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    3965         1863 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2), 0, 0));
    3966         1863 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3967         1863 :       break;
    3968              : 
    3969         3050 :     case 4412:  /* avx512fp16_fcmulc_v8hf_mask */
    3970         3050 :     case 4410:  /* avx512fp16_fmulc_v8hf_mask */
    3971         3050 :     case 4408:  /* avx512vl_fcmulc_v16hf_mask */
    3972         3050 :     case 4406:  /* avx512vl_fmulc_v16hf_mask */
    3973         3050 :     case 4402:  /* avx512bw_fcmulc_v32hf_mask */
    3974         3050 :     case 4398:  /* avx512bw_fmulc_v32hf_mask */
    3975         3050 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3976         3050 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    3977         3050 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    3978         3050 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    3979         3050 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 0));
    3980         3050 :       break;
    3981              : 
    3982         1654 :     case 4392:  /* avx512bw_fcmaddc_v32hf_mask_round */
    3983         1654 :     case 4390:  /* avx512bw_fmaddc_v32hf_mask_round */
    3984         1654 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3985         1654 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    3986         1654 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    3987         1654 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    3988         1654 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2), 0, 0));
    3989         1654 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3990         1654 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    3991         1654 :       recog_data.dup_num[0] = 1;
    3992         1654 :       break;
    3993              : 
    3994         2650 :     case 4396:  /* avx512fp16_fcmaddc_v8hf_mask */
    3995         2650 :     case 4395:  /* avx512fp16_fmaddc_v8hf_mask */
    3996         2650 :     case 4394:  /* avx512vl_fcmaddc_v16hf_mask */
    3997         2650 :     case 4393:  /* avx512vl_fmaddc_v16hf_mask */
    3998         2650 :     case 4391:  /* avx512bw_fcmaddc_v32hf_mask */
    3999         2650 :     case 4389:  /* avx512bw_fmaddc_v32hf_mask */
    4000         2650 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4001         2650 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    4002         2650 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    4003         2650 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    4004         2650 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 0));
    4005         2650 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4006         2650 :       recog_data.dup_num[0] = 1;
    4007         2650 :       break;
    4008              : 
    4009           12 :     case 4388:  /* fma_v8hf_fcmaddc_bcst */
    4010           12 :     case 4387:  /* fma_v16hf_fcmaddc_bcst */
    4011           12 :     case 4386:  /* fma_v32hf_fcmaddc_bcst */
    4012           12 :     case 4385:  /* fma_v8hf_fmaddc_bcst */
    4013           12 :     case 4384:  /* fma_v16hf_fmaddc_bcst */
    4014           12 :     case 4383:  /* fma_v32hf_fmaddc_bcst */
    4015           12 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4016           12 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
    4017           12 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 1), 0));
    4018           12 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 2));
    4019           12 :       break;
    4020              : 
    4021          850 :     case 4356:  /* fma_fcmaddc_v32hf_maskz_1_round */
    4022          850 :     case 4352:  /* fma_fmaddc_v32hf_maskz_1_round */
    4023          850 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4024          850 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    4025          850 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    4026          850 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    4027          850 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    4028          850 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2), 0, 0));
    4029          850 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4030          850 :       break;
    4031              : 
    4032         1278 :     case 4364:  /* fma_fcmaddc_v8hf_maskz_1 */
    4033         1278 :     case 4362:  /* fma_fmaddc_v8hf_maskz_1 */
    4034         1278 :     case 4360:  /* fma_fcmaddc_v16hf_maskz_1 */
    4035         1278 :     case 4358:  /* fma_fmaddc_v16hf_maskz_1 */
    4036         1278 :     case 4355:  /* fma_fcmaddc_v32hf_maskz_1 */
    4037         1278 :     case 4351:  /* fma_fmaddc_v32hf_maskz_1 */
    4038         1278 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4039         1278 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    4040         1278 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    4041         1278 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    4042         1278 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    4043         1278 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 0));
    4044         1278 :       break;
    4045              : 
    4046          140 :     case 4348:  /* *fma4i_vmfnmsub_v2df */
    4047          140 :     case 4347:  /* *fma4i_vmfnmsub_v4sf */
    4048          140 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4049          140 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    4050          140 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    4051          140 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0));
    4052          140 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    4053          140 :       break;
    4054              : 
    4055          180 :     case 4344:  /* *fma4i_vmfmsub_v2df */
    4056          180 :     case 4343:  /* *fma4i_vmfmsub_v4sf */
    4057          180 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4058          180 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    4059          180 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    4060          180 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0));
    4061          180 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    4062          180 :       break;
    4063              : 
    4064          744 :     case 4342:  /* *fma4i_vmfmadd_v2df */
    4065          744 :     case 4341:  /* *fma4i_vmfmadd_v4sf */
    4066          744 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4067          744 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    4068          744 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    4069          744 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4070          744 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    4071          744 :       break;
    4072              : 
    4073          714 :     case 4340:  /* *avx512f_vmfnmsub_v2df_maskz_1_round */
    4074          714 :     case 4338:  /* *avx512f_vmfnmsub_v4sf_maskz_1_round */
    4075          714 :     case 4336:  /* *avx512f_vmfnmsub_v8hf_maskz_1_round */
    4076          714 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4077          714 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    4078          714 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0), 0));
    4079          714 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 2), 0));
    4080          714 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    4081          714 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4082          714 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4083          714 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4084          714 :       recog_data.dup_num[0] = 1;
    4085          714 :       break;
    4086              : 
    4087           66 :     case 4339:  /* *avx512f_vmfnmsub_v2df_maskz_1 */
    4088           66 :     case 4337:  /* *avx512f_vmfnmsub_v4sf_maskz_1 */
    4089           66 :     case 4335:  /* *avx512f_vmfnmsub_v8hf_maskz_1 */
    4090           66 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4091           66 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    4092           66 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    4093           66 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 2), 0));
    4094           66 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    4095           66 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4096           66 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4097           66 :       recog_data.dup_num[0] = 1;
    4098           66 :       break;
    4099              : 
    4100          930 :     case 4334:  /* *avx512f_vmfnmsub_v2df_mask3_round */
    4101          930 :     case 4332:  /* *avx512f_vmfnmsub_v4sf_mask3_round */
    4102          930 :     case 4330:  /* *avx512f_vmfnmsub_v8hf_mask3_round */
    4103          930 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4104          930 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    4105          930 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0), 0));
    4106          930 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 2), 0));
    4107          930 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4108          930 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4109          930 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1);
    4110          930 :       recog_data.dup_num[0] = 3;
    4111          930 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4112          930 :       recog_data.dup_num[1] = 3;
    4113          930 :       break;
    4114              : 
    4115          121 :     case 4333:  /* *avx512f_vmfnmsub_v2df_mask3 */
    4116          121 :     case 4331:  /* *avx512f_vmfnmsub_v4sf_mask3 */
    4117          121 :     case 4329:  /* *avx512f_vmfnmsub_v8hf_mask3 */
    4118          121 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4119          121 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    4120          121 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    4121          121 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 2), 0));
    4122          121 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4123          121 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 1);
    4124          121 :       recog_data.dup_num[0] = 3;
    4125          121 :       recog_data.dup_loc[1] = &XEXP (XEXP (pat, 1), 1);
    4126          121 :       recog_data.dup_num[1] = 3;
    4127          121 :       break;
    4128              : 
    4129          726 :     case 4328:  /* *avx512f_vmfnmsub_v2df_mask_round */
    4130          726 :     case 4326:  /* *avx512f_vmfnmsub_v4sf_mask_round */
    4131          726 :     case 4324:  /* *avx512f_vmfnmsub_v8hf_mask_round */
    4132          726 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4133          726 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0), 0));
    4134          726 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    4135          726 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 2), 0));
    4136          726 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4137          726 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4138          726 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1);
    4139          726 :       recog_data.dup_num[0] = 1;
    4140          726 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4141          726 :       recog_data.dup_num[1] = 1;
    4142          726 :       break;
    4143              : 
    4144           78 :     case 4327:  /* *avx512f_vmfnmsub_v2df_mask */
    4145           78 :     case 4325:  /* *avx512f_vmfnmsub_v4sf_mask */
    4146           78 :     case 4323:  /* *avx512f_vmfnmsub_v8hf_mask */
    4147           78 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4148           78 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    4149           78 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    4150           78 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 2), 0));
    4151           78 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4152           78 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 1);
    4153           78 :       recog_data.dup_num[0] = 1;
    4154           78 :       recog_data.dup_loc[1] = &XEXP (XEXP (pat, 1), 1);
    4155           78 :       recog_data.dup_num[1] = 1;
    4156           78 :       break;
    4157              : 
    4158          983 :     case 4322:  /* avx512f_vmfnmadd_v2df_maskz_1_round */
    4159          983 :     case 4320:  /* avx512f_vmfnmadd_v4sf_maskz_1_round */
    4160          983 :     case 4318:  /* avx512f_vmfnmadd_v8hf_maskz_1_round */
    4161          983 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4162          983 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    4163          983 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0), 0));
    4164          983 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 2));
    4165          983 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    4166          983 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4167          983 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4168          983 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4169          983 :       recog_data.dup_num[0] = 1;
    4170          983 :       break;
    4171              : 
    4172          148 :     case 4321:  /* avx512f_vmfnmadd_v2df_maskz_1 */
    4173          148 :     case 4319:  /* avx512f_vmfnmadd_v4sf_maskz_1 */
    4174          148 :     case 4317:  /* avx512f_vmfnmadd_v8hf_maskz_1 */
    4175          148 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4176          148 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    4177          148 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    4178          148 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 2));
    4179          148 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    4180          148 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4181          148 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4182          148 :       recog_data.dup_num[0] = 1;
    4183          148 :       break;
    4184              : 
    4185         1040 :     case 4316:  /* avx512f_vmfnmadd_v2df_mask3_round */
    4186         1040 :     case 4314:  /* avx512f_vmfnmadd_v4sf_mask3_round */
    4187         1040 :     case 4312:  /* avx512f_vmfnmadd_v8hf_mask3_round */
    4188         1040 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4189         1040 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    4190         1040 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0), 0));
    4191         1040 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 2));
    4192         1040 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4193         1040 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4194         1040 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1);
    4195         1040 :       recog_data.dup_num[0] = 3;
    4196         1040 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4197         1040 :       recog_data.dup_num[1] = 3;
    4198         1040 :       break;
    4199              : 
    4200          174 :     case 4315:  /* avx512f_vmfnmadd_v2df_mask3 */
    4201          174 :     case 4313:  /* avx512f_vmfnmadd_v4sf_mask3 */
    4202          174 :     case 4311:  /* avx512f_vmfnmadd_v8hf_mask3 */
    4203          174 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4204          174 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    4205          174 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    4206          174 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 2));
    4207          174 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4208          174 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 1);
    4209          174 :       recog_data.dup_num[0] = 3;
    4210          174 :       recog_data.dup_loc[1] = &XEXP (XEXP (pat, 1), 1);
    4211          174 :       recog_data.dup_num[1] = 3;
    4212          174 :       break;
    4213              : 
    4214         1035 :     case 4310:  /* avx512f_vmfnmadd_v2df_mask_round */
    4215         1035 :     case 4308:  /* avx512f_vmfnmadd_v4sf_mask_round */
    4216         1035 :     case 4306:  /* avx512f_vmfnmadd_v8hf_mask_round */
    4217         1035 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4218         1035 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0), 0));
    4219         1035 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    4220         1035 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 2));
    4221         1035 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4222         1035 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4223         1035 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1);
    4224         1035 :       recog_data.dup_num[0] = 1;
    4225         1035 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4226         1035 :       recog_data.dup_num[1] = 1;
    4227         1035 :       break;
    4228              : 
    4229          179 :     case 4309:  /* avx512f_vmfnmadd_v2df_mask */
    4230          179 :     case 4307:  /* avx512f_vmfnmadd_v4sf_mask */
    4231          179 :     case 4305:  /* avx512f_vmfnmadd_v8hf_mask */
    4232          179 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4233          179 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    4234          179 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    4235          179 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 2));
    4236          179 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4237          179 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 1);
    4238          179 :       recog_data.dup_num[0] = 1;
    4239          179 :       recog_data.dup_loc[1] = &XEXP (XEXP (pat, 1), 1);
    4240          179 :       recog_data.dup_num[1] = 1;
    4241          179 :       break;
    4242              : 
    4243         1002 :     case 4304:  /* *avx512f_vmfmsub_v2df_maskz_1_round */
    4244         1002 :     case 4302:  /* *avx512f_vmfmsub_v4sf_maskz_1_round */
    4245         1002 :     case 4300:  /* *avx512f_vmfmsub_v8hf_maskz_1_round */
    4246         1002 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4247         1002 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    4248         1002 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    4249         1002 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 2), 0));
    4250         1002 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    4251         1002 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4252         1002 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4253         1002 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4254         1002 :       recog_data.dup_num[0] = 1;
    4255         1002 :       break;
    4256              : 
    4257           66 :     case 4303:  /* *avx512f_vmfmsub_v2df_maskz_1 */
    4258           66 :     case 4301:  /* *avx512f_vmfmsub_v4sf_maskz_1 */
    4259           66 :     case 4299:  /* *avx512f_vmfmsub_v8hf_maskz_1 */
    4260           66 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4261           66 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    4262           66 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    4263           66 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 2), 0));
    4264           66 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    4265           66 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4266           66 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4267           66 :       recog_data.dup_num[0] = 1;
    4268           66 :       break;
    4269              : 
    4270         1695 :     case 4298:  /* avx512f_vmfmsub_v2df_mask3_round */
    4271         1695 :     case 4296:  /* avx512f_vmfmsub_v4sf_mask3_round */
    4272         1695 :     case 4294:  /* avx512f_vmfmsub_v8hf_mask3_round */
    4273         1695 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4274         1695 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    4275         1695 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    4276         1695 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 2), 0));
    4277         1695 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4278         1695 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4279         1695 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1);
    4280         1695 :       recog_data.dup_num[0] = 3;
    4281         1695 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4282         1695 :       recog_data.dup_num[1] = 3;
    4283         1695 :       break;
    4284              : 
    4285          593 :     case 4297:  /* avx512f_vmfmsub_v2df_mask3 */
    4286          593 :     case 4295:  /* avx512f_vmfmsub_v4sf_mask3 */
    4287          593 :     case 4293:  /* avx512f_vmfmsub_v8hf_mask3 */
    4288          593 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4289          593 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    4290          593 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    4291          593 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 2), 0));
    4292          593 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4293          593 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 1);
    4294          593 :       recog_data.dup_num[0] = 3;
    4295          593 :       recog_data.dup_loc[1] = &XEXP (XEXP (pat, 1), 1);
    4296          593 :       recog_data.dup_num[1] = 3;
    4297          593 :       break;
    4298              : 
    4299         1014 :     case 4292:  /* *avx512f_vmfmsub_v2df_mask_round */
    4300         1014 :     case 4290:  /* *avx512f_vmfmsub_v4sf_mask_round */
    4301         1014 :     case 4288:  /* *avx512f_vmfmsub_v8hf_mask_round */
    4302         1014 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4303         1014 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    4304         1014 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    4305         1014 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 2), 0));
    4306         1014 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4307         1014 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4308         1014 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1);
    4309         1014 :       recog_data.dup_num[0] = 1;
    4310         1014 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4311         1014 :       recog_data.dup_num[1] = 1;
    4312         1014 :       break;
    4313              : 
    4314           78 :     case 4291:  /* *avx512f_vmfmsub_v2df_mask */
    4315           78 :     case 4289:  /* *avx512f_vmfmsub_v4sf_mask */
    4316           78 :     case 4287:  /* *avx512f_vmfmsub_v8hf_mask */
    4317           78 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4318           78 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    4319           78 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    4320           78 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 2), 0));
    4321           78 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4322           78 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 1);
    4323           78 :       recog_data.dup_num[0] = 1;
    4324           78 :       recog_data.dup_loc[1] = &XEXP (XEXP (pat, 1), 1);
    4325           78 :       recog_data.dup_num[1] = 1;
    4326           78 :       break;
    4327              : 
    4328         1958 :     case 4286:  /* avx512f_vmfmadd_v2df_maskz_1_round */
    4329         1958 :     case 4284:  /* avx512f_vmfmadd_v4sf_maskz_1_round */
    4330         1958 :     case 4282:  /* avx512f_vmfmadd_v8hf_maskz_1_round */
    4331         1958 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4332         1958 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    4333         1958 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    4334         1958 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 2));
    4335         1958 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    4336         1958 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4337         1958 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4338         1958 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4339         1958 :       recog_data.dup_num[0] = 1;
    4340         1958 :       break;
    4341              : 
    4342          602 :     case 4285:  /* avx512f_vmfmadd_v2df_maskz_1 */
    4343          602 :     case 4283:  /* avx512f_vmfmadd_v4sf_maskz_1 */
    4344          602 :     case 4281:  /* avx512f_vmfmadd_v8hf_maskz_1 */
    4345          602 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4346          602 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    4347          602 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    4348          602 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 2));
    4349          602 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    4350          602 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4351          602 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4352          602 :       recog_data.dup_num[0] = 1;
    4353          602 :       break;
    4354              : 
    4355         1620 :     case 4280:  /* avx512f_vmfmadd_v2df_mask3_round */
    4356         1620 :     case 4278:  /* avx512f_vmfmadd_v4sf_mask3_round */
    4357         1620 :     case 4276:  /* avx512f_vmfmadd_v8hf_mask3_round */
    4358         1620 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4359         1620 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    4360         1620 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    4361         1620 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 2));
    4362         1620 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4363         1620 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4364         1620 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1);
    4365         1620 :       recog_data.dup_num[0] = 3;
    4366         1620 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4367         1620 :       recog_data.dup_num[1] = 3;
    4368         1620 :       break;
    4369              : 
    4370          542 :     case 4279:  /* avx512f_vmfmadd_v2df_mask3 */
    4371          542 :     case 4277:  /* avx512f_vmfmadd_v4sf_mask3 */
    4372          542 :     case 4275:  /* avx512f_vmfmadd_v8hf_mask3 */
    4373          542 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4374          542 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    4375          542 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    4376          542 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 2));
    4377          542 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4378          542 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 1);
    4379          542 :       recog_data.dup_num[0] = 3;
    4380          542 :       recog_data.dup_loc[1] = &XEXP (XEXP (pat, 1), 1);
    4381          542 :       recog_data.dup_num[1] = 3;
    4382          542 :       break;
    4383              : 
    4384         2235 :     case 4274:  /* avx512f_vmfmadd_v2df_mask_round */
    4385         2235 :     case 4272:  /* avx512f_vmfmadd_v4sf_mask_round */
    4386         2235 :     case 4270:  /* avx512f_vmfmadd_v8hf_mask_round */
    4387         2235 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4388         2235 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    4389         2235 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    4390         2235 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 2));
    4391         2235 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4392         2235 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4393         2235 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1);
    4394         2235 :       recog_data.dup_num[0] = 1;
    4395         2235 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4396         2235 :       recog_data.dup_num[1] = 1;
    4397         2235 :       break;
    4398              : 
    4399          875 :     case 4273:  /* avx512f_vmfmadd_v2df_mask */
    4400          875 :     case 4271:  /* avx512f_vmfmadd_v4sf_mask */
    4401          875 :     case 4269:  /* avx512f_vmfmadd_v8hf_mask */
    4402          875 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4403          875 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    4404          875 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    4405          875 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 2));
    4406          875 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4407          875 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 1);
    4408          875 :       recog_data.dup_num[0] = 1;
    4409          875 :       recog_data.dup_loc[1] = &XEXP (XEXP (pat, 1), 1);
    4410          875 :       recog_data.dup_num[1] = 1;
    4411          875 :       break;
    4412              : 
    4413          408 :     case 4268:  /* *fmai_fnmsub_v2df_round */
    4414          408 :     case 4266:  /* *fmai_fnmsub_v4sf_round */
    4415          408 :     case 4264:  /* *fmai_fnmsub_v8hf_round */
    4416          408 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4417          408 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    4418          408 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    4419          408 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0));
    4420          408 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4421          408 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4422          408 :       recog_data.dup_num[0] = 1;
    4423          408 :       break;
    4424              : 
    4425          578 :     case 4267:  /* *fmai_fnmsub_v2df */
    4426          578 :     case 4265:  /* *fmai_fnmsub_v4sf */
    4427          578 :     case 4263:  /* *fmai_fnmsub_v8hf */
    4428          578 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4429          578 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    4430          578 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    4431          578 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0));
    4432          578 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4433          578 :       recog_data.dup_num[0] = 1;
    4434          578 :       break;
    4435              : 
    4436          547 :     case 4262:  /* *fmai_fnmadd_v2df_round */
    4437          547 :     case 4260:  /* *fmai_fnmadd_v4sf_round */
    4438          547 :     case 4258:  /* *fmai_fnmadd_v8hf_round */
    4439          547 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4440          547 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    4441          547 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    4442          547 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4443          547 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4444          547 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4445          547 :       recog_data.dup_num[0] = 1;
    4446          547 :       break;
    4447              : 
    4448          566 :     case 4261:  /* *fmai_fnmadd_v2df */
    4449          566 :     case 4259:  /* *fmai_fnmadd_v4sf */
    4450          566 :     case 4257:  /* *fmai_fnmadd_v8hf */
    4451          566 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4452          566 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    4453          566 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    4454          566 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4455          566 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4456          566 :       recog_data.dup_num[0] = 1;
    4457          566 :       break;
    4458              : 
    4459          662 :     case 4256:  /* *fmai_fmsub_v2df */
    4460          662 :     case 4254:  /* *fmai_fmsub_v4sf */
    4461          662 :     case 4252:  /* *fmai_fmsub_v8hf */
    4462          662 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4463          662 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    4464          662 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    4465          662 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0));
    4466          662 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4467          662 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4468          662 :       recog_data.dup_num[0] = 1;
    4469          662 :       break;
    4470              : 
    4471          582 :     case 4255:  /* *fmai_fmsub_v2df */
    4472          582 :     case 4253:  /* *fmai_fmsub_v4sf */
    4473          582 :     case 4251:  /* *fmai_fmsub_v8hf */
    4474          582 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4475          582 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    4476          582 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    4477          582 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0));
    4478          582 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4479          582 :       recog_data.dup_num[0] = 1;
    4480          582 :       break;
    4481              : 
    4482         1342 :     case 4250:  /* *fmai_fmadd_v2df */
    4483         1342 :     case 4248:  /* *fmai_fmadd_v4sf */
    4484         1342 :     case 4246:  /* *fmai_fmadd_v8hf */
    4485         1342 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4486         1342 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    4487         1342 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    4488         1342 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    4489         1342 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4490         1342 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4491         1342 :       recog_data.dup_num[0] = 1;
    4492         1342 :       break;
    4493              : 
    4494          852 :     case 4249:  /* *fmai_fmadd_v2df */
    4495          852 :     case 4247:  /* *fmai_fmadd_v4sf */
    4496          852 :     case 4245:  /* *fmai_fmadd_v8hf */
    4497          852 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4498          852 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    4499          852 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    4500          852 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    4501          852 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4502          852 :       recog_data.dup_num[0] = 1;
    4503          852 :       break;
    4504              : 
    4505         1280 :     case 4244:  /* avx512vl_fmsubadd_v2df_mask3_round */
    4506         1280 :     case 4242:  /* avx512vl_fmsubadd_v4df_mask3_round */
    4507         1280 :     case 4240:  /* avx512f_fmsubadd_v8df_mask3_round */
    4508         1280 :     case 4238:  /* avx512vl_fmsubadd_v4sf_mask3_round */
    4509         1280 :     case 4236:  /* avx512vl_fmsubadd_v8sf_mask3_round */
    4510         1280 :     case 4234:  /* avx512f_fmsubadd_v16sf_mask3_round */
    4511         1280 :     case 4232:  /* avx512fp16_fmsubadd_v8hf_mask3_round */
    4512         1280 :     case 4230:  /* avx512vl_fmsubadd_v16hf_mask3_round */
    4513         1280 :     case 4228:  /* avx512bw_fmsubadd_v32hf_mask3_round */
    4514         1280 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4515         1280 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    4516         1280 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    4517         1280 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2), 0));
    4518         1280 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    4519         1280 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4520         1280 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4521         1280 :       recog_data.dup_num[0] = 3;
    4522         1280 :       break;
    4523              : 
    4524         2078 :     case 4243:  /* avx512vl_fmsubadd_v2df_mask3 */
    4525         2078 :     case 4241:  /* avx512vl_fmsubadd_v4df_mask3 */
    4526         2078 :     case 4239:  /* avx512f_fmsubadd_v8df_mask3 */
    4527         2078 :     case 4237:  /* avx512vl_fmsubadd_v4sf_mask3 */
    4528         2078 :     case 4235:  /* avx512vl_fmsubadd_v8sf_mask3 */
    4529         2078 :     case 4233:  /* avx512f_fmsubadd_v16sf_mask3 */
    4530         2078 :     case 4231:  /* avx512fp16_fmsubadd_v8hf_mask3 */
    4531         2078 :     case 4229:  /* avx512vl_fmsubadd_v16hf_mask3 */
    4532         2078 :     case 4227:  /* avx512bw_fmsubadd_v32hf_mask3 */
    4533         2078 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4534         2078 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    4535         2078 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    4536         2078 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2), 0));
    4537         2078 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    4538         2078 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4539         2078 :       recog_data.dup_num[0] = 3;
    4540         2078 :       break;
    4541              : 
    4542         1059 :     case 4226:  /* avx512vl_fmsubadd_v2df_mask_round */
    4543         1059 :     case 4224:  /* avx512vl_fmsubadd_v4df_mask_round */
    4544         1059 :     case 4222:  /* avx512f_fmsubadd_v8df_mask_round */
    4545         1059 :     case 4220:  /* avx512vl_fmsubadd_v4sf_mask_round */
    4546         1059 :     case 4218:  /* avx512vl_fmsubadd_v8sf_mask_round */
    4547         1059 :     case 4216:  /* avx512f_fmsubadd_v16sf_mask_round */
    4548         1059 :     case 4214:  /* avx512fp16_fmsubadd_v8hf_mask_round */
    4549         1059 :     case 4212:  /* avx512vl_fmsubadd_v16hf_mask_round */
    4550         1059 :     case 4210:  /* avx512bw_fmsubadd_v32hf_mask_round */
    4551         1059 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4552         1059 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    4553         1059 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    4554         1059 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2), 0));
    4555         1059 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    4556         1059 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4557         1059 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4558         1059 :       recog_data.dup_num[0] = 1;
    4559         1059 :       break;
    4560              : 
    4561         1504 :     case 4225:  /* avx512vl_fmsubadd_v2df_mask */
    4562         1504 :     case 4223:  /* avx512vl_fmsubadd_v4df_mask */
    4563         1504 :     case 4221:  /* avx512f_fmsubadd_v8df_mask */
    4564         1504 :     case 4219:  /* avx512vl_fmsubadd_v4sf_mask */
    4565         1504 :     case 4217:  /* avx512vl_fmsubadd_v8sf_mask */
    4566         1504 :     case 4215:  /* avx512f_fmsubadd_v16sf_mask */
    4567         1504 :     case 4213:  /* avx512fp16_fmsubadd_v8hf_mask */
    4568         1504 :     case 4211:  /* avx512vl_fmsubadd_v16hf_mask */
    4569         1504 :     case 4209:  /* avx512bw_fmsubadd_v32hf_mask */
    4570         1504 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4571         1504 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    4572         1504 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    4573         1504 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2), 0));
    4574         1504 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    4575         1504 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4576         1504 :       recog_data.dup_num[0] = 1;
    4577         1504 :       break;
    4578              : 
    4579          974 :     case 4204:  /* fma_fmsubadd_v8df_maskz_1_round */
    4580          974 :     case 4196:  /* fma_fmsubadd_v16sf_maskz_1_round */
    4581          974 :     case 4188:  /* fma_fmsubadd_v32hf_maskz_1_round */
    4582          974 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4583          974 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    4584          974 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    4585          974 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2), 0));
    4586          974 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    4587          974 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    4588          974 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4589          974 :       break;
    4590              : 
    4591          694 :     case 4203:  /* *fma_fmsubadd_v8df_round */
    4592          694 :     case 4195:  /* *fma_fmsubadd_v16sf_round */
    4593          694 :     case 4187:  /* *fma_fmsubadd_v32hf_round */
    4594          694 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4595          694 :       ro[1] = *(ro_loc[1] = &XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0));
    4596          694 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 1));
    4597          694 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 2), 0));
    4598          694 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4599          694 :       break;
    4600              : 
    4601         1286 :     case 4208:  /* fma_fmsubadd_v2df_maskz_1 */
    4602         1286 :     case 4206:  /* fma_fmsubadd_v4df_maskz_1 */
    4603         1286 :     case 4202:  /* fma_fmsubadd_v8df_maskz_1 */
    4604         1286 :     case 4200:  /* fma_fmsubadd_v4sf_maskz_1 */
    4605         1286 :     case 4198:  /* fma_fmsubadd_v8sf_maskz_1 */
    4606         1286 :     case 4194:  /* fma_fmsubadd_v16sf_maskz_1 */
    4607         1286 :     case 4192:  /* fma_fmsubadd_v8hf_maskz_1 */
    4608         1286 :     case 4190:  /* fma_fmsubadd_v16hf_maskz_1 */
    4609         1286 :     case 4186:  /* fma_fmsubadd_v32hf_maskz_1 */
    4610         1286 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4611         1286 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    4612         1286 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    4613         1286 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2), 0));
    4614         1286 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    4615         1286 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
    4616         1286 :       break;
    4617              : 
    4618         1737 :     case 4207:  /* *fma_fmsubadd_v2df */
    4619         1737 :     case 4205:  /* *fma_fmsubadd_v4df */
    4620         1737 :     case 4201:  /* *fma_fmsubadd_v8df */
    4621         1737 :     case 4199:  /* *fma_fmsubadd_v4sf */
    4622         1737 :     case 4197:  /* *fma_fmsubadd_v8sf */
    4623         1737 :     case 4193:  /* *fma_fmsubadd_v16sf */
    4624         1737 :     case 4191:  /* *fma_fmsubadd_v8hf */
    4625         1737 :     case 4189:  /* *fma_fmsubadd_v16hf */
    4626         1737 :     case 4185:  /* *fma_fmsubadd_v32hf */
    4627         1737 :     case 4184:  /* *fma_fmsubadd_v2df */
    4628         1737 :     case 4183:  /* *fma_fmsubadd_v4df */
    4629         1737 :     case 4182:  /* *fma_fmsubadd_v4sf */
    4630         1737 :     case 4181:  /* *fma_fmsubadd_v8sf */
    4631         1737 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4632         1737 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
    4633         1737 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4634         1737 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0));
    4635         1737 :       break;
    4636              : 
    4637         1280 :     case 4180:  /* avx512vl_fmaddsub_v2df_mask3_round */
    4638         1280 :     case 4178:  /* avx512vl_fmaddsub_v4df_mask3_round */
    4639         1280 :     case 4176:  /* avx512f_fmaddsub_v8df_mask3_round */
    4640         1280 :     case 4174:  /* avx512vl_fmaddsub_v4sf_mask3_round */
    4641         1280 :     case 4172:  /* avx512vl_fmaddsub_v8sf_mask3_round */
    4642         1280 :     case 4170:  /* avx512f_fmaddsub_v16sf_mask3_round */
    4643         1280 :     case 4168:  /* avx512fp16_fmaddsub_v8hf_mask3_round */
    4644         1280 :     case 4166:  /* avx512vl_fmaddsub_v16hf_mask3_round */
    4645         1280 :     case 4164:  /* avx512bw_fmaddsub_v32hf_mask3_round */
    4646         1280 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4647         1280 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    4648         1280 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    4649         1280 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    4650         1280 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    4651         1280 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4652         1280 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4653         1280 :       recog_data.dup_num[0] = 3;
    4654         1280 :       break;
    4655              : 
    4656         2064 :     case 4179:  /* avx512vl_fmaddsub_v2df_mask3 */
    4657         2064 :     case 4177:  /* avx512vl_fmaddsub_v4df_mask3 */
    4658         2064 :     case 4175:  /* avx512f_fmaddsub_v8df_mask3 */
    4659         2064 :     case 4173:  /* avx512vl_fmaddsub_v4sf_mask3 */
    4660         2064 :     case 4171:  /* avx512vl_fmaddsub_v8sf_mask3 */
    4661         2064 :     case 4169:  /* avx512f_fmaddsub_v16sf_mask3 */
    4662         2064 :     case 4167:  /* avx512fp16_fmaddsub_v8hf_mask3 */
    4663         2064 :     case 4165:  /* avx512vl_fmaddsub_v16hf_mask3 */
    4664         2064 :     case 4163:  /* avx512bw_fmaddsub_v32hf_mask3 */
    4665         2064 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4666         2064 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    4667         2064 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    4668         2064 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    4669         2064 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    4670         2064 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4671         2064 :       recog_data.dup_num[0] = 3;
    4672         2064 :       break;
    4673              : 
    4674         1599 :     case 4162:  /* avx512vl_fmaddsub_v2df_mask_round */
    4675         1599 :     case 4160:  /* avx512vl_fmaddsub_v4df_mask_round */
    4676         1599 :     case 4158:  /* avx512f_fmaddsub_v8df_mask_round */
    4677         1599 :     case 4156:  /* avx512vl_fmaddsub_v4sf_mask_round */
    4678         1599 :     case 4154:  /* avx512vl_fmaddsub_v8sf_mask_round */
    4679         1599 :     case 4152:  /* avx512f_fmaddsub_v16sf_mask_round */
    4680         1599 :     case 4150:  /* avx512fp16_fmaddsub_v8hf_mask_round */
    4681         1599 :     case 4148:  /* avx512vl_fmaddsub_v16hf_mask_round */
    4682         1599 :     case 4146:  /* avx512bw_fmaddsub_v32hf_mask_round */
    4683         1599 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4684         1599 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    4685         1599 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    4686         1599 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    4687         1599 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    4688         1599 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4689         1599 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4690         1599 :       recog_data.dup_num[0] = 1;
    4691         1599 :       break;
    4692              : 
    4693        20647 :     case 10667:  /* vdpphps_v4sf_mask */
    4694        20647 :     case 10666:  /* vdpphps_v8sf_mask */
    4695        20647 :     case 10665:  /* vdpphps_v16sf_mask */
    4696        20647 :     case 10643:  /* vpdpwuuds_v4si_mask */
    4697        20647 :     case 10642:  /* vpdpwuud_v4si_mask */
    4698        20647 :     case 10641:  /* vpdpwsuds_v4si_mask */
    4699        20647 :     case 10640:  /* vpdpwsud_v4si_mask */
    4700        20647 :     case 10639:  /* vpdpwusds_v4si_mask */
    4701        20647 :     case 10638:  /* vpdpwusd_v4si_mask */
    4702        20647 :     case 10637:  /* vpdpwuuds_v8si_mask */
    4703        20647 :     case 10636:  /* vpdpwuud_v8si_mask */
    4704        20647 :     case 10635:  /* vpdpwsuds_v8si_mask */
    4705        20647 :     case 10634:  /* vpdpwsud_v8si_mask */
    4706        20647 :     case 10633:  /* vpdpwusds_v8si_mask */
    4707        20647 :     case 10632:  /* vpdpwusd_v8si_mask */
    4708        20647 :     case 10631:  /* vpdpwuuds_v16si_mask */
    4709        20647 :     case 10630:  /* vpdpwuud_v16si_mask */
    4710        20647 :     case 10629:  /* vpdpwsuds_v16si_mask */
    4711        20647 :     case 10628:  /* vpdpwsud_v16si_mask */
    4712        20647 :     case 10627:  /* vpdpwusds_v16si_mask */
    4713        20647 :     case 10626:  /* vpdpwusd_v16si_mask */
    4714        20647 :     case 10491:  /* vpdpbuuds_v4si_mask */
    4715        20647 :     case 10490:  /* vpdpbuud_v4si_mask */
    4716        20647 :     case 10489:  /* vpdpbsuds_v4si_mask */
    4717        20647 :     case 10488:  /* vpdpbsud_v4si_mask */
    4718        20647 :     case 10487:  /* vpdpbssds_v4si_mask */
    4719        20647 :     case 10486:  /* vpdpbssd_v4si_mask */
    4720        20647 :     case 10485:  /* vpdpbuuds_v8si_mask */
    4721        20647 :     case 10484:  /* vpdpbuud_v8si_mask */
    4722        20647 :     case 10483:  /* vpdpbsuds_v8si_mask */
    4723        20647 :     case 10482:  /* vpdpbsud_v8si_mask */
    4724        20647 :     case 10481:  /* vpdpbssds_v8si_mask */
    4725        20647 :     case 10480:  /* vpdpbssd_v8si_mask */
    4726        20647 :     case 10479:  /* vpdpbuuds_v16si_mask */
    4727        20647 :     case 10478:  /* vpdpbuud_v16si_mask */
    4728        20647 :     case 10477:  /* vpdpbsuds_v16si_mask */
    4729        20647 :     case 10476:  /* vpdpbsud_v16si_mask */
    4730        20647 :     case 10475:  /* vpdpbssds_v16si_mask */
    4731        20647 :     case 10474:  /* vpdpbssd_v16si_mask */
    4732        20647 :     case 10444:  /* avx512f_dpbf16ps_v4sf_mask */
    4733        20647 :     case 10443:  /* avx512f_dpbf16ps_v8sf_mask */
    4734        20647 :     case 10442:  /* avx512f_dpbf16ps_v16sf_mask */
    4735        20647 :     case 10390:  /* vpdpwssds_v4si_mask */
    4736        20647 :     case 10389:  /* vpdpwssds_v8si_mask */
    4737        20647 :     case 10388:  /* vpdpwssds_v16si_mask */
    4738        20647 :     case 10381:  /* vpdpwssd_v4si_mask */
    4739        20647 :     case 10380:  /* vpdpwssd_v8si_mask */
    4740        20647 :     case 10379:  /* vpdpwssd_v16si_mask */
    4741        20647 :     case 10372:  /* vpdpbusds_v4si_mask */
    4742        20647 :     case 10371:  /* vpdpbusds_v8si_mask */
    4743        20647 :     case 10370:  /* vpdpbusds_v16si_mask */
    4744        20647 :     case 10363:  /* vpdpbusd_v4si_mask */
    4745        20647 :     case 10362:  /* vpdpbusd_v8si_mask */
    4746        20647 :     case 10361:  /* vpdpbusd_v16si_mask */
    4747        20647 :     case 10348:  /* vpshldv_v2di_mask */
    4748        20647 :     case 10347:  /* vpshldv_v4si_mask */
    4749        20647 :     case 10346:  /* vpshldv_v8hi_mask */
    4750        20647 :     case 10345:  /* vpshldv_v4di_mask */
    4751        20647 :     case 10344:  /* vpshldv_v8si_mask */
    4752        20647 :     case 10343:  /* vpshldv_v16hi_mask */
    4753        20647 :     case 10342:  /* vpshldv_v8di_mask */
    4754        20647 :     case 10341:  /* vpshldv_v16si_mask */
    4755        20647 :     case 10340:  /* vpshldv_v32hi_mask */
    4756        20647 :     case 10321:  /* vpshrdv_v2di_mask */
    4757        20647 :     case 10320:  /* vpshrdv_v4si_mask */
    4758        20647 :     case 10319:  /* vpshrdv_v8hi_mask */
    4759        20647 :     case 10318:  /* vpshrdv_v4di_mask */
    4760        20647 :     case 10317:  /* vpshrdv_v8si_mask */
    4761        20647 :     case 10316:  /* vpshrdv_v16hi_mask */
    4762        20647 :     case 10315:  /* vpshrdv_v8di_mask */
    4763        20647 :     case 10314:  /* vpshrdv_v16si_mask */
    4764        20647 :     case 10313:  /* vpshrdv_v32hi_mask */
    4765        20647 :     case 10211:  /* vpmadd52huqv2di_mask */
    4766        20647 :     case 10210:  /* vpmadd52luqv2di_mask */
    4767        20647 :     case 10209:  /* vpmadd52huqv4di_mask */
    4768        20647 :     case 10208:  /* vpmadd52luqv4di_mask */
    4769        20647 :     case 10207:  /* vpmadd52huqv8di_mask */
    4770        20647 :     case 10206:  /* vpmadd52luqv8di_mask */
    4771        20647 :     case 4161:  /* avx512vl_fmaddsub_v2df_mask */
    4772        20647 :     case 4159:  /* avx512vl_fmaddsub_v4df_mask */
    4773        20647 :     case 4157:  /* avx512f_fmaddsub_v8df_mask */
    4774        20647 :     case 4155:  /* avx512vl_fmaddsub_v4sf_mask */
    4775        20647 :     case 4153:  /* avx512vl_fmaddsub_v8sf_mask */
    4776        20647 :     case 4151:  /* avx512f_fmaddsub_v16sf_mask */
    4777        20647 :     case 4149:  /* avx512fp16_fmaddsub_v8hf_mask */
    4778        20647 :     case 4147:  /* avx512vl_fmaddsub_v16hf_mask */
    4779        20647 :     case 4145:  /* avx512bw_fmaddsub_v32hf_mask */
    4780        20647 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4781        20647 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    4782        20647 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    4783        20647 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    4784        20647 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    4785        20647 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4786        20647 :       recog_data.dup_num[0] = 1;
    4787        20647 :       break;
    4788              : 
    4789         2840 :     case 11024:  /* avx10_2_minmaxpv2df_mask_round */
    4790         2840 :     case 11020:  /* avx10_2_minmaxpv4df_mask_round */
    4791         2840 :     case 11016:  /* avx10_2_minmaxpv8df_mask_round */
    4792         2840 :     case 11012:  /* avx10_2_minmaxpv4sf_mask_round */
    4793         2840 :     case 11008:  /* avx10_2_minmaxpv8sf_mask_round */
    4794         2840 :     case 11004:  /* avx10_2_minmaxpv16sf_mask_round */
    4795         2840 :     case 11000:  /* avx10_2_minmaxpv8hf_mask_round */
    4796         2840 :     case 10996:  /* avx10_2_minmaxpv16hf_mask_round */
    4797         2840 :     case 10992:  /* avx10_2_minmaxpv32hf_mask_round */
    4798         2840 :     case 10054:  /* avx512dq_rangepv8df_mask_round */
    4799         2840 :     case 10046:  /* avx512dq_rangepv16sf_mask_round */
    4800         2840 :     case 4140:  /* fma_fmaddsub_v8df_maskz_1_round */
    4801         2840 :     case 4132:  /* fma_fmaddsub_v16sf_maskz_1_round */
    4802         2840 :     case 4124:  /* fma_fmaddsub_v32hf_maskz_1_round */
    4803         2840 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4804         2840 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    4805         2840 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    4806         2840 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    4807         2840 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    4808         2840 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    4809         2840 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4810         2840 :       break;
    4811              : 
    4812        44720 :     case 11023:  /* avx10_2_minmaxpv2df_mask */
    4813        44720 :     case 11019:  /* avx10_2_minmaxpv4df_mask */
    4814        44720 :     case 11015:  /* avx10_2_minmaxpv8df_mask */
    4815        44720 :     case 11011:  /* avx10_2_minmaxpv4sf_mask */
    4816        44720 :     case 11007:  /* avx10_2_minmaxpv8sf_mask */
    4817        44720 :     case 11003:  /* avx10_2_minmaxpv16sf_mask */
    4818        44720 :     case 10999:  /* avx10_2_minmaxpv8hf_mask */
    4819        44720 :     case 10995:  /* avx10_2_minmaxpv16hf_mask */
    4820        44720 :     case 10991:  /* avx10_2_minmaxpv32hf_mask */
    4821        44720 :     case 10988:  /* avx10_2_minmaxbf16_v8bf_mask */
    4822        44720 :     case 10986:  /* avx10_2_minmaxbf16_v16bf_mask */
    4823        44720 :     case 10984:  /* avx10_2_minmaxbf16_v32bf_mask */
    4824        44720 :     case 10670:  /* vdpphps_v4sf_maskz_1 */
    4825        44720 :     case 10669:  /* vdpphps_v8sf_maskz_1 */
    4826        44720 :     case 10668:  /* vdpphps_v16sf_maskz_1 */
    4827        44720 :     case 10441:  /* avx512f_dpbf16ps_v4sf_maskz_1 */
    4828        44720 :     case 10439:  /* avx512f_dpbf16ps_v8sf_maskz_1 */
    4829        44720 :     case 10437:  /* avx512f_dpbf16ps_v16sf_maskz_1 */
    4830        44720 :     case 10393:  /* vpdpwssds_v4si_maskz_1 */
    4831        44720 :     case 10392:  /* vpdpwssds_v8si_maskz_1 */
    4832        44720 :     case 10391:  /* vpdpwssds_v16si_maskz_1 */
    4833        44720 :     case 10384:  /* vpdpwssd_v4si_maskz_1 */
    4834        44720 :     case 10383:  /* vpdpwssd_v8si_maskz_1 */
    4835        44720 :     case 10382:  /* vpdpwssd_v16si_maskz_1 */
    4836        44720 :     case 10375:  /* vpdpbusds_v4si_maskz_1 */
    4837        44720 :     case 10374:  /* vpdpbusds_v8si_maskz_1 */
    4838        44720 :     case 10373:  /* vpdpbusds_v16si_maskz_1 */
    4839        44720 :     case 10366:  /* vpdpbusd_v4si_maskz_1 */
    4840        44720 :     case 10365:  /* vpdpbusd_v8si_maskz_1 */
    4841        44720 :     case 10364:  /* vpdpbusd_v16si_maskz_1 */
    4842        44720 :     case 10357:  /* vpshldv_v2di_maskz_1 */
    4843        44720 :     case 10356:  /* vpshldv_v4si_maskz_1 */
    4844        44720 :     case 10355:  /* vpshldv_v8hi_maskz_1 */
    4845        44720 :     case 10354:  /* vpshldv_v4di_maskz_1 */
    4846        44720 :     case 10353:  /* vpshldv_v8si_maskz_1 */
    4847        44720 :     case 10352:  /* vpshldv_v16hi_maskz_1 */
    4848        44720 :     case 10351:  /* vpshldv_v8di_maskz_1 */
    4849        44720 :     case 10350:  /* vpshldv_v16si_maskz_1 */
    4850        44720 :     case 10349:  /* vpshldv_v32hi_maskz_1 */
    4851        44720 :     case 10330:  /* vpshrdv_v2di_maskz_1 */
    4852        44720 :     case 10329:  /* vpshrdv_v4si_maskz_1 */
    4853        44720 :     case 10328:  /* vpshrdv_v8hi_maskz_1 */
    4854        44720 :     case 10327:  /* vpshrdv_v4di_maskz_1 */
    4855        44720 :     case 10326:  /* vpshrdv_v8si_maskz_1 */
    4856        44720 :     case 10325:  /* vpshrdv_v16hi_maskz_1 */
    4857        44720 :     case 10324:  /* vpshrdv_v8di_maskz_1 */
    4858        44720 :     case 10323:  /* vpshrdv_v16si_maskz_1 */
    4859        44720 :     case 10322:  /* vpshrdv_v32hi_maskz_1 */
    4860        44720 :     case 10303:  /* vpshld_v2di_mask */
    4861        44720 :     case 10301:  /* vpshld_v4si_mask */
    4862        44720 :     case 10299:  /* vpshld_v8hi_mask */
    4863        44720 :     case 10297:  /* vpshld_v4di_mask */
    4864        44720 :     case 10295:  /* vpshld_v8si_mask */
    4865        44720 :     case 10293:  /* vpshld_v16hi_mask */
    4866        44720 :     case 10291:  /* vpshld_v8di_mask */
    4867        44720 :     case 10289:  /* vpshld_v16si_mask */
    4868        44720 :     case 10287:  /* vpshld_v32hi_mask */
    4869        44720 :     case 10285:  /* vpshrd_v2di_mask */
    4870        44720 :     case 10283:  /* vpshrd_v4si_mask */
    4871        44720 :     case 10281:  /* vpshrd_v8hi_mask */
    4872        44720 :     case 10279:  /* vpshrd_v4di_mask */
    4873        44720 :     case 10277:  /* vpshrd_v8si_mask */
    4874        44720 :     case 10275:  /* vpshrd_v16hi_mask */
    4875        44720 :     case 10273:  /* vpshrd_v8di_mask */
    4876        44720 :     case 10271:  /* vpshrd_v16si_mask */
    4877        44720 :     case 10269:  /* vpshrd_v32hi_mask */
    4878        44720 :     case 10261:  /* vgf2p8affineqb_v16qi_mask */
    4879        44720 :     case 10259:  /* vgf2p8affineqb_v32qi_mask */
    4880        44720 :     case 10257:  /* vgf2p8affineqb_v64qi_mask */
    4881        44720 :     case 10255:  /* vgf2p8affineinvqb_v16qi_mask */
    4882        44720 :     case 10253:  /* vgf2p8affineinvqb_v32qi_mask */
    4883        44720 :     case 10251:  /* vgf2p8affineinvqb_v64qi_mask */
    4884        44720 :     case 10205:  /* vpmadd52huqv2di_maskz_1 */
    4885        44720 :     case 10204:  /* vpmadd52luqv2di_maskz_1 */
    4886        44720 :     case 10203:  /* vpmadd52huqv4di_maskz_1 */
    4887        44720 :     case 10202:  /* vpmadd52luqv4di_maskz_1 */
    4888        44720 :     case 10201:  /* vpmadd52huqv8di_maskz_1 */
    4889        44720 :     case 10200:  /* vpmadd52luqv8di_maskz_1 */
    4890        44720 :     case 10144:  /* avx512bw_dbpsadbwv32hi_mask */
    4891        44720 :     case 10142:  /* avx512bw_dbpsadbwv16hi_mask */
    4892        44720 :     case 10140:  /* avx512bw_dbpsadbwv8hi_mask */
    4893        44720 :     case 10058:  /* avx512dq_rangepv2df_mask */
    4894        44720 :     case 10056:  /* avx512dq_rangepv4df_mask */
    4895        44720 :     case 10053:  /* avx512dq_rangepv8df_mask */
    4896        44720 :     case 10050:  /* avx512dq_rangepv4sf_mask */
    4897        44720 :     case 10048:  /* avx512dq_rangepv8sf_mask */
    4898        44720 :     case 10045:  /* avx512dq_rangepv16sf_mask */
    4899        44720 :     case 9514:  /* avx512vl_vpermt2varv8bf3_maskz_1 */
    4900        44720 :     case 9512:  /* avx512vl_vpermt2varv16bf3_maskz_1 */
    4901        44720 :     case 9510:  /* avx512bw_vpermt2varv32bf3_maskz_1 */
    4902        44720 :     case 9508:  /* avx512fp16_vpermt2varv8hf3_maskz_1 */
    4903        44720 :     case 9506:  /* avx512vl_vpermt2varv16hf3_maskz_1 */
    4904        44720 :     case 9504:  /* avx512bw_vpermt2varv32hf3_maskz_1 */
    4905        44720 :     case 9502:  /* avx512vl_vpermt2varv16qi3_maskz_1 */
    4906        44720 :     case 9500:  /* avx512vl_vpermt2varv32qi3_maskz_1 */
    4907        44720 :     case 9498:  /* avx512bw_vpermt2varv64qi3_maskz_1 */
    4908        44720 :     case 9496:  /* avx512vl_vpermt2varv8hi3_maskz_1 */
    4909        44720 :     case 9494:  /* avx512vl_vpermt2varv16hi3_maskz_1 */
    4910        44720 :     case 9492:  /* avx512bw_vpermt2varv32hi3_maskz_1 */
    4911        44720 :     case 9490:  /* avx512vl_vpermt2varv2df3_maskz_1 */
    4912        44720 :     case 9488:  /* avx512vl_vpermt2varv2di3_maskz_1 */
    4913        44720 :     case 9486:  /* avx512vl_vpermt2varv4sf3_maskz_1 */
    4914        44720 :     case 9484:  /* avx512vl_vpermt2varv4si3_maskz_1 */
    4915        44720 :     case 9482:  /* avx512vl_vpermt2varv4df3_maskz_1 */
    4916        44720 :     case 9480:  /* avx512vl_vpermt2varv4di3_maskz_1 */
    4917        44720 :     case 9478:  /* avx512vl_vpermt2varv8sf3_maskz_1 */
    4918        44720 :     case 9476:  /* avx512vl_vpermt2varv8si3_maskz_1 */
    4919        44720 :     case 9474:  /* avx512f_vpermt2varv8df3_maskz_1 */
    4920        44720 :     case 9472:  /* avx512f_vpermt2varv8di3_maskz_1 */
    4921        44720 :     case 9470:  /* avx512f_vpermt2varv16sf3_maskz_1 */
    4922        44720 :     case 9468:  /* avx512f_vpermt2varv16si3_maskz_1 */
    4923        44720 :     case 8783:  /* sse4_1_mpsadbw_mask */
    4924        44720 :     case 8781:  /* avx2_mpsadbw_mask */
    4925        44720 :     case 8779:  /* avx10_2_mpsadbw_mask */
    4926        44720 :     case 8698:  /* ssse3_palignrv16qi_mask */
    4927        44720 :     case 8697:  /* avx2_palignrv32qi_mask */
    4928        44720 :     case 8696:  /* avx512bw_palignrv64qi_mask */
    4929        44720 :     case 7102:  /* avx512vl_alignv2di_mask */
    4930        44720 :     case 7100:  /* avx512vl_alignv4di_mask */
    4931        44720 :     case 7098:  /* avx512f_alignv8di_mask */
    4932        44720 :     case 7096:  /* avx512vl_alignv4si_mask */
    4933        44720 :     case 7094:  /* avx512vl_alignv8si_mask */
    4934        44720 :     case 7092:  /* avx512f_alignv16si_mask */
    4935        44720 :     case 4144:  /* fma_fmaddsub_v2df_maskz_1 */
    4936        44720 :     case 4142:  /* fma_fmaddsub_v4df_maskz_1 */
    4937        44720 :     case 4138:  /* fma_fmaddsub_v8df_maskz_1 */
    4938        44720 :     case 4136:  /* fma_fmaddsub_v4sf_maskz_1 */
    4939        44720 :     case 4134:  /* fma_fmaddsub_v8sf_maskz_1 */
    4940        44720 :     case 4130:  /* fma_fmaddsub_v16sf_maskz_1 */
    4941        44720 :     case 4128:  /* fma_fmaddsub_v8hf_maskz_1 */
    4942        44720 :     case 4126:  /* fma_fmaddsub_v16hf_maskz_1 */
    4943        44720 :     case 4122:  /* fma_fmaddsub_v32hf_maskz_1 */
    4944        44720 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4945        44720 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    4946        44720 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    4947        44720 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    4948        44720 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    4949        44720 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
    4950        44720 :       break;
    4951              : 
    4952         1213 :     case 4116:  /* avx512vl_fnmsub_v2df_mask3_round */
    4953         1213 :     case 4114:  /* avx512vl_fnmsub_v4df_mask3_round */
    4954         1213 :     case 4112:  /* avx512f_fnmsub_v8df_mask3_round */
    4955         1213 :     case 4110:  /* avx512vl_fnmsub_v4sf_mask3_round */
    4956         1213 :     case 4108:  /* avx512vl_fnmsub_v8sf_mask3_round */
    4957         1213 :     case 4106:  /* avx512f_fnmsub_v16sf_mask3_round */
    4958         1213 :     case 4104:  /* avx512fp16_fnmsub_v8hf_mask3_round */
    4959         1213 :     case 4102:  /* avx512vl_fnmsub_v16hf_mask3_round */
    4960         1213 :     case 4100:  /* avx512bw_fnmsub_v32hf_mask3_round */
    4961         1213 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4962         1213 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    4963         1213 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    4964         1213 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0));
    4965         1213 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    4966         1213 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4967         1213 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    4968         1213 :       recog_data.dup_num[0] = 3;
    4969         1213 :       break;
    4970              : 
    4971         3147 :     case 10760:  /* avx10_2_fnmsubbf16_v8bf_mask3 */
    4972         3147 :     case 10759:  /* avx10_2_fnmsubbf16_v16bf_mask3 */
    4973         3147 :     case 10758:  /* avx10_2_fnmsubbf16_v32bf_mask3 */
    4974         3147 :     case 4115:  /* avx512vl_fnmsub_v2df_mask3 */
    4975         3147 :     case 4113:  /* avx512vl_fnmsub_v4df_mask3 */
    4976         3147 :     case 4111:  /* avx512f_fnmsub_v8df_mask3 */
    4977         3147 :     case 4109:  /* avx512vl_fnmsub_v4sf_mask3 */
    4978         3147 :     case 4107:  /* avx512vl_fnmsub_v8sf_mask3 */
    4979         3147 :     case 4105:  /* avx512f_fnmsub_v16sf_mask3 */
    4980         3147 :     case 4103:  /* avx512fp16_fnmsub_v8hf_mask3 */
    4981         3147 :     case 4101:  /* avx512vl_fnmsub_v16hf_mask3 */
    4982         3147 :     case 4099:  /* avx512bw_fnmsub_v32hf_mask3 */
    4983         3147 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4984         3147 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    4985         3147 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    4986         3147 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0));
    4987         3147 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    4988         3147 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4989         3147 :       recog_data.dup_num[0] = 3;
    4990         3147 :       break;
    4991              : 
    4992         1373 :     case 4096:  /* avx512f_fnmsub_v8df_mask_round */
    4993         1373 :     case 4092:  /* avx512f_fnmsub_v16sf_mask_round */
    4994         1373 :     case 4088:  /* avx512bw_fnmsub_v32hf_mask_round */
    4995         1373 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4996         1373 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    4997         1373 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    4998         1373 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0));
    4999         1373 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    5000         1373 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5001         1373 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    5002         1373 :       recog_data.dup_num[0] = 1;
    5003         1373 :       break;
    5004              : 
    5005         3588 :     case 10757:  /* avx10_2_fnmsubbf16_v8bf_mask */
    5006         3588 :     case 10756:  /* avx10_2_fnmsubbf16_v16bf_mask */
    5007         3588 :     case 10755:  /* avx10_2_fnmsubbf16_v32bf_mask */
    5008         3588 :     case 4098:  /* avx512vl_fnmsub_v2df_mask */
    5009         3588 :     case 4097:  /* avx512vl_fnmsub_v4df_mask */
    5010         3588 :     case 4095:  /* avx512f_fnmsub_v8df_mask */
    5011         3588 :     case 4094:  /* avx512vl_fnmsub_v4sf_mask */
    5012         3588 :     case 4093:  /* avx512vl_fnmsub_v8sf_mask */
    5013         3588 :     case 4091:  /* avx512f_fnmsub_v16sf_mask */
    5014         3588 :     case 4090:  /* avx512fp16_fnmsub_v8hf_mask */
    5015         3588 :     case 4089:  /* avx512vl_fnmsub_v16hf_mask */
    5016         3588 :     case 4087:  /* avx512bw_fnmsub_v32hf_mask */
    5017         3588 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5018         3588 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    5019         3588 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    5020         3588 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0));
    5021         3588 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    5022         3588 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    5023         3588 :       recog_data.dup_num[0] = 1;
    5024         3588 :       break;
    5025              : 
    5026         1150 :     case 4082:  /* fma_fnmsub_v8df_maskz_1_round */
    5027         1150 :     case 4073:  /* fma_fnmsub_v16sf_maskz_1_round */
    5028         1150 :     case 4063:  /* fma_fnmsub_v32hf_maskz_1_round */
    5029         1150 :     case 4059:  /* *fma_fnmsub_v4df */
    5030         1150 :     case 4055:  /* *fma_fnmsub_v8sf */
    5031         1150 :     case 4051:  /* *fma_fnmsub_v2df */
    5032         1150 :     case 4047:  /* *fma_fnmsub_v4sf */
    5033         1150 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5034         1150 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    5035         1150 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    5036         1150 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0));
    5037         1150 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    5038         1150 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    5039         1150 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5040         1150 :       break;
    5041              : 
    5042         3392 :     case 10754:  /* avx10_2_fnmsubbf16_v8bf_maskz_1 */
    5043         3392 :     case 10752:  /* avx10_2_fnmsubbf16_v16bf_maskz_1 */
    5044         3392 :     case 10750:  /* avx10_2_fnmsubbf16_v32bf_maskz_1 */
    5045         3392 :     case 4086:  /* fma_fnmsub_v2df_maskz_1 */
    5046         3392 :     case 4084:  /* fma_fnmsub_v4df_maskz_1 */
    5047         3392 :     case 4080:  /* fma_fnmsub_v8df_maskz_1 */
    5048         3392 :     case 4077:  /* fma_fnmsub_v4sf_maskz_1 */
    5049         3392 :     case 4075:  /* fma_fnmsub_v8sf_maskz_1 */
    5050         3392 :     case 4071:  /* fma_fnmsub_v16sf_maskz_1 */
    5051         3392 :     case 4067:  /* fma_fnmsub_v8hf_maskz_1 */
    5052         3392 :     case 4065:  /* fma_fnmsub_v16hf_maskz_1 */
    5053         3392 :     case 4061:  /* fma_fnmsub_v32hf_maskz_1 */
    5054         3392 :     case 4057:  /* *fma_fnmsub_v4df */
    5055         3392 :     case 4053:  /* *fma_fnmsub_v8sf */
    5056         3392 :     case 4049:  /* *fma_fnmsub_v2df */
    5057         3392 :     case 4045:  /* *fma_fnmsub_v4sf */
    5058         3392 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5059         3392 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    5060         3392 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    5061         3392 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0));
    5062         3392 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    5063         3392 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
    5064         3392 :       break;
    5065              : 
    5066          764 :     case 4081:  /* *fma_fnmsub_v8df_round */
    5067          764 :     case 4072:  /* *fma_fnmsub_v16sf_round */
    5068          764 :     case 4062:  /* *fma_fnmsub_v32hf_round */
    5069          764 :     case 4058:  /* *fma_fnmsub_v4df */
    5070          764 :     case 4054:  /* *fma_fnmsub_v8sf */
    5071          764 :     case 4050:  /* *fma_fnmsub_v2df */
    5072          764 :     case 4046:  /* *fma_fnmsub_v4sf */
    5073          764 :     case 4043:  /* *fma_fnmsub_df */
    5074          764 :     case 4041:  /* *fma_fnmsub_sf */
    5075          764 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5076          764 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    5077          764 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    5078          764 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2), 0));
    5079          764 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5080          764 :       break;
    5081              : 
    5082        20458 :     case 10753:  /* avx10_2_fnmsubbf16_v8bf */
    5083        20458 :     case 10751:  /* avx10_2_fnmsubbf16_v16bf */
    5084        20458 :     case 10749:  /* avx10_2_fnmsubbf16_v32bf */
    5085        20458 :     case 4085:  /* *fma_fnmsub_v2df */
    5086        20458 :     case 4083:  /* *fma_fnmsub_v4df */
    5087        20458 :     case 4079:  /* *fma_fnmsub_v8df */
    5088        20458 :     case 4078:  /* *fma_fnmsub_df */
    5089        20458 :     case 4076:  /* *fma_fnmsub_v4sf */
    5090        20458 :     case 4074:  /* *fma_fnmsub_v8sf */
    5091        20458 :     case 4070:  /* *fma_fnmsub_v16sf */
    5092        20458 :     case 4069:  /* *fma_fnmsub_sf */
    5093        20458 :     case 4068:  /* *fma_fnmsub_hf */
    5094        20458 :     case 4066:  /* *fma_fnmsub_v8hf */
    5095        20458 :     case 4064:  /* *fma_fnmsub_v16hf */
    5096        20458 :     case 4060:  /* *fma_fnmsub_v32hf */
    5097        20458 :     case 4056:  /* *fma_fnmsub_v4df */
    5098        20458 :     case 4052:  /* *fma_fnmsub_v8sf */
    5099        20458 :     case 4048:  /* *fma_fnmsub_v2df */
    5100        20458 :     case 4044:  /* *fma_fnmsub_v4sf */
    5101        20458 :     case 4042:  /* *fma_fnmsub_df */
    5102        20458 :     case 4040:  /* *fma_fnmsub_sf */
    5103        20458 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5104        20458 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    5105        20458 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    5106        20458 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 2), 0));
    5107        20458 :       break;
    5108              : 
    5109         1213 :     case 4037:  /* avx512f_fnmadd_v8df_mask3_round */
    5110         1213 :     case 4033:  /* avx512f_fnmadd_v16sf_mask3_round */
    5111         1213 :     case 4029:  /* avx512bw_fnmadd_v32hf_mask3_round */
    5112         1213 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5113         1213 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    5114         1213 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    5115         1213 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    5116         1213 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    5117         1213 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5118         1213 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    5119         1213 :       recog_data.dup_num[0] = 3;
    5120         1213 :       break;
    5121              : 
    5122         3147 :     case 10736:  /* avx10_2_fnmaddbf16_v8bf_mask3 */
    5123         3147 :     case 10735:  /* avx10_2_fnmaddbf16_v16bf_mask3 */
    5124         3147 :     case 10734:  /* avx10_2_fnmaddbf16_v32bf_mask3 */
    5125         3147 :     case 4039:  /* avx512vl_fnmadd_v2df_mask3 */
    5126         3147 :     case 4038:  /* avx512vl_fnmadd_v4df_mask3 */
    5127         3147 :     case 4036:  /* avx512f_fnmadd_v8df_mask3 */
    5128         3147 :     case 4035:  /* avx512vl_fnmadd_v4sf_mask3 */
    5129         3147 :     case 4034:  /* avx512vl_fnmadd_v8sf_mask3 */
    5130         3147 :     case 4032:  /* avx512f_fnmadd_v16sf_mask3 */
    5131         3147 :     case 4031:  /* avx512fp16_fnmadd_v8hf_mask3 */
    5132         3147 :     case 4030:  /* avx512vl_fnmadd_v16hf_mask3 */
    5133         3147 :     case 4028:  /* avx512bw_fnmadd_v32hf_mask3 */
    5134         3147 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5135         3147 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    5136         3147 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    5137         3147 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    5138         3147 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    5139         3147 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    5140         3147 :       recog_data.dup_num[0] = 3;
    5141         3147 :       break;
    5142              : 
    5143         1373 :     case 4025:  /* avx512f_fnmadd_v8df_mask_round */
    5144         1373 :     case 4021:  /* avx512f_fnmadd_v16sf_mask_round */
    5145         1373 :     case 4017:  /* avx512bw_fnmadd_v32hf_mask_round */
    5146         1373 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5147         1373 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    5148         1373 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    5149         1373 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    5150         1373 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    5151         1373 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5152         1373 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    5153         1373 :       recog_data.dup_num[0] = 1;
    5154         1373 :       break;
    5155              : 
    5156         3590 :     case 10733:  /* avx10_2_fnmaddbf16_v8bf_mask */
    5157         3590 :     case 10732:  /* avx10_2_fnmaddbf16_v16bf_mask */
    5158         3590 :     case 10731:  /* avx10_2_fnmaddbf16_v32bf_mask */
    5159         3590 :     case 4027:  /* avx512vl_fnmadd_v2df_mask */
    5160         3590 :     case 4026:  /* avx512vl_fnmadd_v4df_mask */
    5161         3590 :     case 4024:  /* avx512f_fnmadd_v8df_mask */
    5162         3590 :     case 4023:  /* avx512vl_fnmadd_v4sf_mask */
    5163         3590 :     case 4022:  /* avx512vl_fnmadd_v8sf_mask */
    5164         3590 :     case 4020:  /* avx512f_fnmadd_v16sf_mask */
    5165         3590 :     case 4019:  /* avx512fp16_fnmadd_v8hf_mask */
    5166         3590 :     case 4018:  /* avx512vl_fnmadd_v16hf_mask */
    5167         3590 :     case 4016:  /* avx512bw_fnmadd_v32hf_mask */
    5168         3590 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5169         3590 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    5170         3590 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    5171         3590 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    5172         3590 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    5173         3590 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    5174         3590 :       recog_data.dup_num[0] = 1;
    5175         3590 :       break;
    5176              : 
    5177         1150 :     case 4011:  /* fma_fnmadd_v8df_maskz_1_round */
    5178         1150 :     case 4002:  /* fma_fnmadd_v16sf_maskz_1_round */
    5179         1150 :     case 3992:  /* fma_fnmadd_v32hf_maskz_1_round */
    5180         1150 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5181         1150 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    5182         1150 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    5183         1150 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    5184         1150 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    5185         1150 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    5186         1150 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5187         1150 :       break;
    5188              : 
    5189         3437 :     case 10730:  /* avx10_2_fnmaddbf16_v8bf_maskz_1 */
    5190         3437 :     case 10728:  /* avx10_2_fnmaddbf16_v16bf_maskz_1 */
    5191         3437 :     case 10726:  /* avx10_2_fnmaddbf16_v32bf_maskz_1 */
    5192         3437 :     case 4015:  /* fma_fnmadd_v2df_maskz_1 */
    5193         3437 :     case 4013:  /* fma_fnmadd_v4df_maskz_1 */
    5194         3437 :     case 4009:  /* fma_fnmadd_v8df_maskz_1 */
    5195         3437 :     case 4006:  /* fma_fnmadd_v4sf_maskz_1 */
    5196         3437 :     case 4004:  /* fma_fnmadd_v8sf_maskz_1 */
    5197         3437 :     case 4000:  /* fma_fnmadd_v16sf_maskz_1 */
    5198         3437 :     case 3996:  /* fma_fnmadd_v8hf_maskz_1 */
    5199         3437 :     case 3994:  /* fma_fnmadd_v16hf_maskz_1 */
    5200         3437 :     case 3990:  /* fma_fnmadd_v32hf_maskz_1 */
    5201         3437 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5202         3437 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    5203         3437 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    5204         3437 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    5205         3437 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    5206         3437 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
    5207         3437 :       break;
    5208              : 
    5209         1213 :     case 3980:  /* avx512f_fmsub_v8df_mask3_round */
    5210         1213 :     case 3976:  /* avx512f_fmsub_v16sf_mask3_round */
    5211         1213 :     case 3972:  /* avx512bw_fmsub_v32hf_mask3_round */
    5212         1213 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5213         1213 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    5214         1213 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    5215         1213 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0));
    5216         1213 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    5217         1213 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5218         1213 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    5219         1213 :       recog_data.dup_num[0] = 3;
    5220         1213 :       break;
    5221              : 
    5222         3149 :     case 10748:  /* avx10_2_fmsubbf16_v8bf_mask3 */
    5223         3149 :     case 10747:  /* avx10_2_fmsubbf16_v16bf_mask3 */
    5224         3149 :     case 10746:  /* avx10_2_fmsubbf16_v32bf_mask3 */
    5225         3149 :     case 3982:  /* avx512vl_fmsub_v2df_mask3 */
    5226         3149 :     case 3981:  /* avx512vl_fmsub_v4df_mask3 */
    5227         3149 :     case 3979:  /* avx512f_fmsub_v8df_mask3 */
    5228         3149 :     case 3978:  /* avx512vl_fmsub_v4sf_mask3 */
    5229         3149 :     case 3977:  /* avx512vl_fmsub_v8sf_mask3 */
    5230         3149 :     case 3975:  /* avx512f_fmsub_v16sf_mask3 */
    5231         3149 :     case 3974:  /* avx512fp16_fmsub_v8hf_mask3 */
    5232         3149 :     case 3973:  /* avx512vl_fmsub_v16hf_mask3 */
    5233         3149 :     case 3971:  /* avx512bw_fmsub_v32hf_mask3 */
    5234         3149 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5235         3149 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    5236         3149 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    5237         3149 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0));
    5238         3149 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    5239         3149 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    5240         3149 :       recog_data.dup_num[0] = 3;
    5241         3149 :       break;
    5242              : 
    5243         1373 :     case 3970:  /* avx512vl_fmsub_v2df_mask_round */
    5244         1373 :     case 3968:  /* avx512vl_fmsub_v4df_mask_round */
    5245         1373 :     case 3966:  /* avx512f_fmsub_v8df_mask_round */
    5246         1373 :     case 3964:  /* avx512vl_fmsub_v4sf_mask_round */
    5247         1373 :     case 3962:  /* avx512vl_fmsub_v8sf_mask_round */
    5248         1373 :     case 3960:  /* avx512f_fmsub_v16sf_mask_round */
    5249         1373 :     case 3958:  /* avx512fp16_fmsub_v8hf_mask_round */
    5250         1373 :     case 3956:  /* avx512vl_fmsub_v16hf_mask_round */
    5251         1373 :     case 3954:  /* avx512bw_fmsub_v32hf_mask_round */
    5252         1373 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5253         1373 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    5254         1373 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    5255         1373 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0));
    5256         1373 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    5257         1373 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5258         1373 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    5259         1373 :       recog_data.dup_num[0] = 1;
    5260         1373 :       break;
    5261              : 
    5262         3590 :     case 10745:  /* avx10_2_fmsubbf16_v8bf_mask */
    5263         3590 :     case 10744:  /* avx10_2_fmsubbf16_v16bf_mask */
    5264         3590 :     case 10743:  /* avx10_2_fmsubbf16_v32bf_mask */
    5265         3590 :     case 3969:  /* avx512vl_fmsub_v2df_mask */
    5266         3590 :     case 3967:  /* avx512vl_fmsub_v4df_mask */
    5267         3590 :     case 3965:  /* avx512f_fmsub_v8df_mask */
    5268         3590 :     case 3963:  /* avx512vl_fmsub_v4sf_mask */
    5269         3590 :     case 3961:  /* avx512vl_fmsub_v8sf_mask */
    5270         3590 :     case 3959:  /* avx512f_fmsub_v16sf_mask */
    5271         3590 :     case 3957:  /* avx512fp16_fmsub_v8hf_mask */
    5272         3590 :     case 3955:  /* avx512vl_fmsub_v16hf_mask */
    5273         3590 :     case 3953:  /* avx512bw_fmsub_v32hf_mask */
    5274         3590 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5275         3590 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    5276         3590 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    5277         3590 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0));
    5278         3590 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    5279         3590 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    5280         3590 :       recog_data.dup_num[0] = 1;
    5281         3590 :       break;
    5282              : 
    5283         1150 :     case 3948:  /* fma_fmsub_v8df_maskz_1_round */
    5284         1150 :     case 3939:  /* fma_fmsub_v16sf_maskz_1_round */
    5285         1150 :     case 3929:  /* fma_fmsub_v32hf_maskz_1_round */
    5286         1150 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5287         1150 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    5288         1150 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    5289         1150 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2), 0));
    5290         1150 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    5291         1150 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    5292         1150 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5293         1150 :       break;
    5294              : 
    5295          764 :     case 3947:  /* *fma_fmsub_v8df_round */
    5296          764 :     case 3938:  /* *fma_fmsub_v16sf_round */
    5297          764 :     case 3928:  /* *fma_fmsub_v32hf_round */
    5298          764 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5299          764 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
    5300          764 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    5301          764 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2), 0));
    5302          764 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5303          764 :       break;
    5304              : 
    5305         3476 :     case 10742:  /* avx10_2_fmsubbf16_v8bf_maskz_1 */
    5306         3476 :     case 10740:  /* avx10_2_fmsubbf16_v16bf_maskz_1 */
    5307         3476 :     case 10738:  /* avx10_2_fmsubbf16_v32bf_maskz_1 */
    5308         3476 :     case 3952:  /* fma_fmsub_v2df_maskz_1 */
    5309         3476 :     case 3950:  /* fma_fmsub_v4df_maskz_1 */
    5310         3476 :     case 3946:  /* fma_fmsub_v8df_maskz_1 */
    5311         3476 :     case 3943:  /* fma_fmsub_v4sf_maskz_1 */
    5312         3476 :     case 3941:  /* fma_fmsub_v8sf_maskz_1 */
    5313         3476 :     case 3937:  /* fma_fmsub_v16sf_maskz_1 */
    5314         3476 :     case 3933:  /* fma_fmsub_v8hf_maskz_1 */
    5315         3476 :     case 3931:  /* fma_fmsub_v16hf_maskz_1 */
    5316         3476 :     case 3927:  /* fma_fmsub_v32hf_maskz_1 */
    5317         3476 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5318         3476 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    5319         3476 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    5320         3476 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 2), 0));
    5321         3476 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    5322         3476 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
    5323         3476 :       break;
    5324              : 
    5325        52173 :     case 10741:  /* avx10_2_fmsubbf16_v8bf */
    5326        52173 :     case 10739:  /* avx10_2_fmsubbf16_v16bf */
    5327        52173 :     case 10737:  /* avx10_2_fmsubbf16_v32bf */
    5328        52173 :     case 3951:  /* *fma_fmsub_v2df */
    5329        52173 :     case 3949:  /* *fma_fmsub_v4df */
    5330        52173 :     case 3945:  /* *fma_fmsub_v8df */
    5331        52173 :     case 3944:  /* *fma_fmsub_df */
    5332        52173 :     case 3942:  /* *fma_fmsub_v4sf */
    5333        52173 :     case 3940:  /* *fma_fmsub_v8sf */
    5334        52173 :     case 3936:  /* *fma_fmsub_v16sf */
    5335        52173 :     case 3935:  /* *fma_fmsub_sf */
    5336        52173 :     case 3934:  /* *fma_fmsub_hf */
    5337        52173 :     case 3932:  /* *fma_fmsub_v8hf */
    5338        52173 :     case 3930:  /* *fma_fmsub_v16hf */
    5339        52173 :     case 3926:  /* *fma_fmsub_v32hf */
    5340        52173 :     case 3925:  /* *fma_fmsub_v4df */
    5341        52173 :     case 3924:  /* *fma_fmsub_v8sf */
    5342        52173 :     case 3923:  /* *fma_fmsub_v2df */
    5343        52173 :     case 3922:  /* *fma_fmsub_v4sf */
    5344        52173 :     case 3921:  /* *fma_fmsub_df */
    5345        52173 :     case 3920:  /* *fma_fmsub_sf */
    5346        52173 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5347        52173 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    5348        52173 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    5349        52173 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 2), 0));
    5350        52173 :       break;
    5351              : 
    5352         1269 :     case 3919:  /* avx512vl_fmadd_v2df_mask3_round */
    5353         1269 :     case 3917:  /* avx512vl_fmadd_v4df_mask3_round */
    5354         1269 :     case 3915:  /* avx512f_fmadd_v8df_mask3_round */
    5355         1269 :     case 3913:  /* avx512vl_fmadd_v4sf_mask3_round */
    5356         1269 :     case 3911:  /* avx512vl_fmadd_v8sf_mask3_round */
    5357         1269 :     case 3909:  /* avx512f_fmadd_v16sf_mask3_round */
    5358         1269 :     case 3907:  /* avx512fp16_fmadd_v8hf_mask3_round */
    5359         1269 :     case 3905:  /* avx512vl_fmadd_v16hf_mask3_round */
    5360         1269 :     case 3903:  /* avx512bw_fmadd_v32hf_mask3_round */
    5361         1269 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5362         1269 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    5363         1269 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    5364         1269 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    5365         1269 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    5366         1269 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5367         1269 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    5368         1269 :       recog_data.dup_num[0] = 3;
    5369         1269 :       break;
    5370              : 
    5371         3343 :     case 10724:  /* avx10_2_fmaddbf16_v8bf_mask3 */
    5372         3343 :     case 10723:  /* avx10_2_fmaddbf16_v16bf_mask3 */
    5373         3343 :     case 10722:  /* avx10_2_fmaddbf16_v32bf_mask3 */
    5374         3343 :     case 3918:  /* avx512vl_fmadd_v2df_mask3 */
    5375         3343 :     case 3916:  /* avx512vl_fmadd_v4df_mask3 */
    5376         3343 :     case 3914:  /* avx512f_fmadd_v8df_mask3 */
    5377         3343 :     case 3912:  /* avx512vl_fmadd_v4sf_mask3 */
    5378         3343 :     case 3910:  /* avx512vl_fmadd_v8sf_mask3 */
    5379         3343 :     case 3908:  /* avx512f_fmadd_v16sf_mask3 */
    5380         3343 :     case 3906:  /* avx512fp16_fmadd_v8hf_mask3 */
    5381         3343 :     case 3904:  /* avx512vl_fmadd_v16hf_mask3 */
    5382         3343 :     case 3902:  /* avx512bw_fmadd_v32hf_mask3 */
    5383         3343 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5384         3343 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    5385         3343 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    5386         3343 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    5387         3343 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    5388         3343 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    5389         3343 :       recog_data.dup_num[0] = 3;
    5390         3343 :       break;
    5391              : 
    5392         1373 :     case 3899:  /* avx512f_fmadd_v8df_mask_round */
    5393         1373 :     case 3895:  /* avx512f_fmadd_v16sf_mask_round */
    5394         1373 :     case 3891:  /* avx512bw_fmadd_v32hf_mask_round */
    5395         1373 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5396         1373 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    5397         1373 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    5398         1373 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    5399         1373 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    5400         1373 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5401         1373 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    5402         1373 :       recog_data.dup_num[0] = 1;
    5403         1373 :       break;
    5404              : 
    5405         3608 :     case 10721:  /* avx10_2_fmaddbf16_v8bf_mask */
    5406         3608 :     case 10720:  /* avx10_2_fmaddbf16_v16bf_mask */
    5407         3608 :     case 10719:  /* avx10_2_fmaddbf16_v32bf_mask */
    5408         3608 :     case 3901:  /* avx512vl_fmadd_v2df_mask */
    5409         3608 :     case 3900:  /* avx512vl_fmadd_v4df_mask */
    5410         3608 :     case 3898:  /* avx512f_fmadd_v8df_mask */
    5411         3608 :     case 3897:  /* avx512vl_fmadd_v4sf_mask */
    5412         3608 :     case 3896:  /* avx512vl_fmadd_v8sf_mask */
    5413         3608 :     case 3894:  /* avx512f_fmadd_v16sf_mask */
    5414         3608 :     case 3893:  /* avx512fp16_fmadd_v8hf_mask */
    5415         3608 :     case 3892:  /* avx512vl_fmadd_v16hf_mask */
    5416         3608 :     case 3890:  /* avx512bw_fmadd_v32hf_mask */
    5417         3608 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5418         3608 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    5419         3608 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    5420         3608 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    5421         3608 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    5422         3608 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    5423         3608 :       recog_data.dup_num[0] = 1;
    5424         3608 :       break;
    5425              : 
    5426         1150 :     case 3885:  /* fma_fmadd_v8df_maskz_1_round */
    5427         1150 :     case 3876:  /* fma_fmadd_v16sf_maskz_1_round */
    5428         1150 :     case 3866:  /* fma_fmadd_v32hf_maskz_1_round */
    5429         1150 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5430         1150 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    5431         1150 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    5432         1150 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    5433         1150 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    5434         1150 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    5435         1150 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5436         1150 :       break;
    5437              : 
    5438          764 :     case 3884:  /* *fma_fmadd_v8df_round */
    5439          764 :     case 3875:  /* *fma_fmadd_v16sf_round */
    5440          764 :     case 3865:  /* *fma_fmadd_v32hf_round */
    5441          764 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5442          764 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
    5443          764 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    5444          764 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    5445          764 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5446          764 :       break;
    5447              : 
    5448         3699 :     case 10718:  /* avx10_2_fmaddbf16_v8bf_maskz_1 */
    5449         3699 :     case 10716:  /* avx10_2_fmaddbf16_v16bf_maskz_1 */
    5450         3699 :     case 10714:  /* avx10_2_fmaddbf16_v32bf_maskz_1 */
    5451         3699 :     case 3889:  /* fma_fmadd_v2df_maskz_1 */
    5452         3699 :     case 3887:  /* fma_fmadd_v4df_maskz_1 */
    5453         3699 :     case 3883:  /* fma_fmadd_v8df_maskz_1 */
    5454         3699 :     case 3880:  /* fma_fmadd_v4sf_maskz_1 */
    5455         3699 :     case 3878:  /* fma_fmadd_v8sf_maskz_1 */
    5456         3699 :     case 3874:  /* fma_fmadd_v16sf_maskz_1 */
    5457         3699 :     case 3870:  /* fma_fmadd_v8hf_maskz_1 */
    5458         3699 :     case 3868:  /* fma_fmadd_v16hf_maskz_1 */
    5459         3699 :     case 3864:  /* fma_fmadd_v32hf_maskz_1 */
    5460         3699 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5461         3699 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    5462         3699 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    5463         3699 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    5464         3699 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    5465         3699 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
    5466         3699 :       break;
    5467              : 
    5468        10516 :     case 9562:  /* vec_set_hi_v8sf_mask */
    5469        10516 :     case 9560:  /* vec_set_hi_v8si_mask */
    5470        10516 :     case 9554:  /* vec_set_hi_v4df_mask */
    5471        10516 :     case 9552:  /* vec_set_hi_v4di_mask */
    5472        10516 :     case 8468:  /* vec_set_hi_v8di_mask */
    5473        10516 :     case 8466:  /* vec_set_hi_v8df_mask */
    5474        10516 :     case 8460:  /* vec_set_hi_v16si_mask */
    5475        10516 :     case 8458:  /* vec_set_hi_v16sf_mask */
    5476        10516 :     case 8059:  /* *andnotv2di3_mask */
    5477        10516 :     case 8058:  /* *andnotv4di3_mask */
    5478        10516 :     case 8057:  /* *andnotv8di3_mask */
    5479        10516 :     case 8056:  /* *andnotv4si3_mask */
    5480        10516 :     case 8055:  /* *andnotv8si3_mask */
    5481        10516 :     case 8054:  /* *andnotv16si3_mask */
    5482        10516 :     case 3769:  /* avx512f_andnotv8df3_mask */
    5483        10516 :     case 3767:  /* avx512f_andnotv16sf3_mask */
    5484        10516 :     case 3763:  /* sse2_andnotv2df3_mask */
    5485        10516 :     case 3761:  /* avx_andnotv4df3_mask */
    5486        10516 :     case 3759:  /* sse_andnotv4sf3_mask */
    5487        10516 :     case 3757:  /* avx_andnotv8sf3_mask */
    5488        10516 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5489        10516 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    5490        10516 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    5491        10516 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    5492        10516 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    5493        10516 :       break;
    5494              : 
    5495          680 :     case 3750:  /* sse2_ucomi_round */
    5496          680 :     case 3746:  /* sse_ucomi_round */
    5497          680 :     case 3742:  /* avx512fp16_ucomi_round */
    5498          680 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 0), 0));
    5499          680 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 1), 0));
    5500          680 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5501          680 :       break;
    5502              : 
    5503         4370 :     case 3749:  /* sse2_ucomi */
    5504         4370 :     case 3745:  /* sse_ucomi */
    5505         4370 :     case 3741:  /* avx512fp16_ucomi */
    5506         4370 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    5507         4370 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1), 0));
    5508         4370 :       break;
    5509              : 
    5510         1128 :     case 3748:  /* sse2_comi_round */
    5511         1128 :     case 3744:  /* sse_comi_round */
    5512         1128 :     case 3740:  /* avx512fp16_comi_round */
    5513         1128 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    5514         1128 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1), 0));
    5515         1128 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5516         1128 :       break;
    5517              : 
    5518         5148 :     case 3751:  /* avx10_2_comisbf16_v8bf */
    5519         5148 :     case 3747:  /* sse2_comi */
    5520         5148 :     case 3743:  /* sse_comi */
    5521         5148 :     case 3739:  /* avx512fp16_comi */
    5522         5148 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    5523         5148 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    5524         5148 :       break;
    5525              : 
    5526           89 :     case 3738:  /* avx10_2_ucomxdf_round */
    5527           89 :     case 3734:  /* avx10_2_ucomxsf_round */
    5528           89 :     case 3730:  /* avx10_2_ucomxhf_round */
    5529           89 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 0, 0), 0));
    5530           89 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 0, 1), 0));
    5531           89 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5532           89 :       break;
    5533              : 
    5534          566 :     case 3737:  /* avx10_2_ucomxdf */
    5535          566 :     case 3733:  /* avx10_2_ucomxsf */
    5536          566 :     case 3729:  /* avx10_2_ucomxhf */
    5537          566 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 0));
    5538          566 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 1), 0));
    5539          566 :       break;
    5540              : 
    5541           43 :     case 3736:  /* avx10_2_comxdf_round */
    5542           43 :     case 3732:  /* avx10_2_comxsf_round */
    5543           43 :     case 3728:  /* avx10_2_comxhf_round */
    5544           43 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 0));
    5545           43 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 1), 0));
    5546           43 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5547           43 :       break;
    5548              : 
    5549          566 :     case 3735:  /* avx10_2_comxdf */
    5550          566 :     case 3731:  /* avx10_2_comxsf */
    5551          566 :     case 3727:  /* avx10_2_comxhf */
    5552          566 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
    5553          566 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 1), 0));
    5554          566 :       break;
    5555              : 
    5556         1491 :     case 3726:  /* avx512f_vmcmpv2df3_mask_round */
    5557         1491 :     case 3724:  /* avx512f_vmcmpv4sf3_mask_round */
    5558         1491 :     case 3722:  /* avx512f_vmcmpv8hf3_mask_round */
    5559         1491 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5560         1491 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    5561         1491 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    5562         1491 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    5563         1491 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1), 0));
    5564         1491 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5565         1491 :       break;
    5566              : 
    5567         1091 :     case 3725:  /* avx512f_vmcmpv2df3_mask */
    5568         1091 :     case 3723:  /* avx512f_vmcmpv4sf3_mask */
    5569         1091 :     case 3721:  /* avx512f_vmcmpv8hf3_mask */
    5570         1091 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5571         1091 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    5572         1091 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    5573         1091 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    5574         1091 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    5575         1091 :       break;
    5576              : 
    5577         3943 :     case 3720:  /* avx512f_vmcmpv2df3_round */
    5578         3943 :     case 3718:  /* avx512f_vmcmpv4sf3_round */
    5579         3943 :     case 3716:  /* avx512f_vmcmpv8hf3_round */
    5580         3943 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5581         3943 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    5582         3943 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    5583         3943 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    5584         3943 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5585         3943 :       break;
    5586              : 
    5587           72 :     case 3714:  /* *avx512vl_ucmpv8hi3_1 */
    5588           72 :     case 3713:  /* *avx512vl_ucmpv8hi3_1 */
    5589           72 :     case 3712:  /* *avx512vl_ucmpv16hi3_1 */
    5590           72 :     case 3711:  /* *avx512vl_ucmpv16hi3_1 */
    5591           72 :     case 3710:  /* *avx512bw_ucmpv32hi3_1 */
    5592           72 :     case 3709:  /* *avx512bw_ucmpv32hi3_1 */
    5593           72 :     case 3708:  /* *avx512vl_ucmpv32qi3_1 */
    5594           72 :     case 3707:  /* *avx512vl_ucmpv32qi3_1 */
    5595           72 :     case 3706:  /* *avx512vl_ucmpv16qi3_1 */
    5596           72 :     case 3705:  /* *avx512vl_ucmpv16qi3_1 */
    5597           72 :     case 3704:  /* *avx512bw_ucmpv64qi3_1 */
    5598           72 :     case 3703:  /* *avx512bw_ucmpv64qi3_1 */
    5599           72 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5600           72 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
    5601           72 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    5602           72 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5603           72 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 2));
    5604           72 :       break;
    5605              : 
    5606        13925 :     case 10808:  /* avx10_2_fpclassbf16_v8bf_mask */
    5607        13925 :     case 10806:  /* avx10_2_fpclassbf16_v16bf_mask */
    5608        13925 :     case 10804:  /* avx10_2_fpclassbf16_v32bf_mask */
    5609        13925 :     case 10557:  /* *vcvtbiasph2hf8sv8hf */
    5610        13925 :     case 10556:  /* *vcvtbiasph2hf8v8hf */
    5611        13925 :     case 10555:  /* *vcvtbiasph2bf8sv8hf */
    5612        13925 :     case 10554:  /* *vcvtbiasph2bf8v8hf */
    5613        13925 :     case 10414:  /* avx512vl_vpshufbitqmbv32qi_mask */
    5614        13925 :     case 10412:  /* avx512vl_vpshufbitqmbv16qi_mask */
    5615        13925 :     case 10410:  /* avx512vl_vpshufbitqmbv64qi_mask */
    5616        13925 :     case 10084:  /* avx512dq_fpclassv2df_mask */
    5617        13925 :     case 10082:  /* avx512dq_fpclassv4df_mask */
    5618        13925 :     case 10080:  /* avx512dq_fpclassv8df_mask */
    5619        13925 :     case 10078:  /* avx512dq_fpclassv4sf_mask */
    5620        13925 :     case 10076:  /* avx512dq_fpclassv8sf_mask */
    5621        13925 :     case 10074:  /* avx512dq_fpclassv16sf_mask */
    5622        13925 :     case 10072:  /* avx512dq_fpclassv8hf_mask */
    5623        13925 :     case 10070:  /* avx512dq_fpclassv16hf_mask */
    5624        13925 :     case 10068:  /* avx512dq_fpclassv32hf_mask */
    5625        13925 :     case 9742:  /* *vcvtps2ph */
    5626        13925 :     case 8212:  /* avx512vl_testnmv2di3_mask */
    5627        13925 :     case 8210:  /* avx512vl_testnmv4di3_mask */
    5628        13925 :     case 8208:  /* avx512f_testnmv8di3_mask */
    5629        13925 :     case 8206:  /* avx512vl_testnmv4si3_mask */
    5630        13925 :     case 8204:  /* avx512vl_testnmv8si3_mask */
    5631        13925 :     case 8202:  /* avx512f_testnmv16si3_mask */
    5632        13925 :     case 8200:  /* avx512vl_testnmv8hi3_mask */
    5633        13925 :     case 8198:  /* avx512vl_testnmv16hi3_mask */
    5634        13925 :     case 8196:  /* avx512bw_testnmv32hi3_mask */
    5635        13925 :     case 8194:  /* avx512vl_testnmv16qi3_mask */
    5636        13925 :     case 8192:  /* avx512vl_testnmv32qi3_mask */
    5637        13925 :     case 8190:  /* avx512bw_testnmv64qi3_mask */
    5638        13925 :     case 8188:  /* avx512vl_testmv2di3_mask */
    5639        13925 :     case 8186:  /* avx512vl_testmv4di3_mask */
    5640        13925 :     case 8184:  /* avx512f_testmv8di3_mask */
    5641        13925 :     case 8182:  /* avx512vl_testmv4si3_mask */
    5642        13925 :     case 8180:  /* avx512vl_testmv8si3_mask */
    5643        13925 :     case 8178:  /* avx512f_testmv16si3_mask */
    5644        13925 :     case 8176:  /* avx512vl_testmv8hi3_mask */
    5645        13925 :     case 8174:  /* avx512vl_testmv16hi3_mask */
    5646        13925 :     case 8172:  /* avx512bw_testmv32hi3_mask */
    5647        13925 :     case 8170:  /* avx512vl_testmv16qi3_mask */
    5648        13925 :     case 8168:  /* avx512vl_testmv32qi3_mask */
    5649        13925 :     case 8166:  /* avx512bw_testmv64qi3_mask */
    5650        13925 :     case 4370:  /* fma_v8hf_fadd_fcmul */
    5651        13925 :     case 4369:  /* fma_v16hf_fadd_fcmul */
    5652        13925 :     case 4368:  /* fma_v32hf_fadd_fcmul */
    5653        13925 :     case 4367:  /* fma_v8hf_fadd_fmul */
    5654        13925 :     case 4366:  /* fma_v16hf_fadd_fmul */
    5655        13925 :     case 4365:  /* fma_v32hf_fadd_fmul */
    5656        13925 :     case 3636:  /* *avx512vl_eqv2di3_mask_1 */
    5657        13925 :     case 3634:  /* *avx512vl_eqv2di3_mask_1 */
    5658        13925 :     case 3632:  /* *avx512vl_eqv4di3_mask_1 */
    5659        13925 :     case 3630:  /* *avx512vl_eqv4di3_mask_1 */
    5660        13925 :     case 3628:  /* *avx512f_eqv8di3_mask_1 */
    5661        13925 :     case 3626:  /* *avx512f_eqv8di3_mask_1 */
    5662        13925 :     case 3624:  /* *avx512vl_eqv4si3_mask_1 */
    5663        13925 :     case 3622:  /* *avx512vl_eqv4si3_mask_1 */
    5664        13925 :     case 3620:  /* *avx512vl_eqv8si3_mask_1 */
    5665        13925 :     case 3618:  /* *avx512vl_eqv8si3_mask_1 */
    5666        13925 :     case 3616:  /* *avx512f_eqv16si3_mask_1 */
    5667        13925 :     case 3614:  /* *avx512f_eqv16si3_mask_1 */
    5668        13925 :     case 3576:  /* *avx512vl_eqv8hi3_mask_1 */
    5669        13925 :     case 3574:  /* *avx512vl_eqv8hi3_mask_1 */
    5670        13925 :     case 3572:  /* *avx512vl_eqv16hi3_mask_1 */
    5671        13925 :     case 3570:  /* *avx512vl_eqv16hi3_mask_1 */
    5672        13925 :     case 3568:  /* *avx512bw_eqv32hi3_mask_1 */
    5673        13925 :     case 3566:  /* *avx512bw_eqv32hi3_mask_1 */
    5674        13925 :     case 3564:  /* *avx512vl_eqv32qi3_mask_1 */
    5675        13925 :     case 3562:  /* *avx512vl_eqv32qi3_mask_1 */
    5676        13925 :     case 3560:  /* *avx512vl_eqv16qi3_mask_1 */
    5677        13925 :     case 3558:  /* *avx512vl_eqv16qi3_mask_1 */
    5678        13925 :     case 3556:  /* *avx512bw_eqv64qi3_mask_1 */
    5679        13925 :     case 3554:  /* *avx512bw_eqv64qi3_mask_1 */
    5680        13925 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5681        13925 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    5682        13925 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    5683        13925 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    5684        13925 :       break;
    5685              : 
    5686          570 :     case 3696:  /* *avx512vl_ucmpv2di3_zero_extenddi_2 */
    5687          570 :     case 3695:  /* *avx512vl_ucmpv4di3_zero_extenddi_2 */
    5688          570 :     case 3694:  /* *avx512f_ucmpv8di3_zero_extenddi_2 */
    5689          570 :     case 3693:  /* *avx512vl_ucmpv4si3_zero_extenddi_2 */
    5690          570 :     case 3692:  /* *avx512vl_ucmpv8si3_zero_extenddi_2 */
    5691          570 :     case 3691:  /* *avx512f_ucmpv16si3_zero_extenddi_2 */
    5692          570 :     case 3690:  /* *avx512vl_ucmpv2di3_zero_extendsi_2 */
    5693          570 :     case 3689:  /* *avx512vl_ucmpv4di3_zero_extendsi_2 */
    5694          570 :     case 3688:  /* *avx512f_ucmpv8di3_zero_extendsi_2 */
    5695          570 :     case 3687:  /* *avx512vl_ucmpv4si3_zero_extendsi_2 */
    5696          570 :     case 3686:  /* *avx512vl_ucmpv8si3_zero_extendsi_2 */
    5697          570 :     case 3685:  /* *avx512f_ucmpv16si3_zero_extendsi_2 */
    5698          570 :     case 3684:  /* *avx512vl_ucmpv2di3_zero_extendhi_2 */
    5699          570 :     case 3683:  /* *avx512vl_ucmpv4di3_zero_extendhi_2 */
    5700          570 :     case 3682:  /* *avx512f_ucmpv8di3_zero_extendhi_2 */
    5701          570 :     case 3681:  /* *avx512vl_ucmpv4si3_zero_extendhi_2 */
    5702          570 :     case 3680:  /* *avx512vl_ucmpv8si3_zero_extendhi_2 */
    5703          570 :     case 3679:  /* *avx512f_ucmpv16si3_zero_extendhi_2 */
    5704          570 :     case 3612:  /* *avx512vl_ucmpv8hi3_zero_extenddi_2 */
    5705          570 :     case 3611:  /* *avx512vl_ucmpv8hi3_zero_extendsi_2 */
    5706          570 :     case 3610:  /* *avx512vl_ucmpv8hi3_zero_extendhi_2 */
    5707          570 :     case 3609:  /* *avx512vl_ucmpv16hi3_zero_extenddi_2 */
    5708          570 :     case 3608:  /* *avx512vl_ucmpv16hi3_zero_extendsi_2 */
    5709          570 :     case 3607:  /* *avx512vl_ucmpv16hi3_zero_extendhi_2 */
    5710          570 :     case 3606:  /* *avx512bw_ucmpv32hi3_zero_extenddi_2 */
    5711          570 :     case 3605:  /* *avx512bw_ucmpv32hi3_zero_extendsi_2 */
    5712          570 :     case 3604:  /* *avx512bw_ucmpv32hi3_zero_extendhi_2 */
    5713          570 :     case 3603:  /* *avx512vl_ucmpv32qi3_zero_extenddi_2 */
    5714          570 :     case 3602:  /* *avx512vl_ucmpv32qi3_zero_extendsi_2 */
    5715          570 :     case 3601:  /* *avx512vl_ucmpv32qi3_zero_extendhi_2 */
    5716          570 :     case 3600:  /* *avx512vl_ucmpv16qi3_zero_extenddi_2 */
    5717          570 :     case 3599:  /* *avx512vl_ucmpv16qi3_zero_extendsi_2 */
    5718          570 :     case 3598:  /* *avx512vl_ucmpv16qi3_zero_extendhi_2 */
    5719          570 :     case 3597:  /* *avx512bw_ucmpv64qi3_zero_extenddi_2 */
    5720          570 :     case 3596:  /* *avx512bw_ucmpv64qi3_zero_extendsi_2 */
    5721          570 :     case 3595:  /* *avx512bw_ucmpv64qi3_zero_extendhi_2 */
    5722          570 :     case 3516:  /* *avx512vl_cmpv8hi3_zero_extenddi_2 */
    5723          570 :     case 3515:  /* *avx512vl_cmpv8hi3_zero_extendsi_2 */
    5724          570 :     case 3514:  /* *avx512vl_cmpv8hi3_zero_extendhi_2 */
    5725          570 :     case 3513:  /* *avx512vl_cmpv16hi3_zero_extenddi_2 */
    5726          570 :     case 3512:  /* *avx512vl_cmpv16hi3_zero_extendsi_2 */
    5727          570 :     case 3511:  /* *avx512vl_cmpv16hi3_zero_extendhi_2 */
    5728          570 :     case 3510:  /* *avx512bw_cmpv32hi3_zero_extenddi_2 */
    5729          570 :     case 3509:  /* *avx512bw_cmpv32hi3_zero_extendsi_2 */
    5730          570 :     case 3508:  /* *avx512bw_cmpv32hi3_zero_extendhi_2 */
    5731          570 :     case 3507:  /* *avx512vl_cmpv32qi3_zero_extenddi_2 */
    5732          570 :     case 3506:  /* *avx512vl_cmpv32qi3_zero_extendsi_2 */
    5733          570 :     case 3505:  /* *avx512vl_cmpv32qi3_zero_extendhi_2 */
    5734          570 :     case 3504:  /* *avx512vl_cmpv16qi3_zero_extenddi_2 */
    5735          570 :     case 3503:  /* *avx512vl_cmpv16qi3_zero_extendsi_2 */
    5736          570 :     case 3502:  /* *avx512vl_cmpv16qi3_zero_extendhi_2 */
    5737          570 :     case 3501:  /* *avx512bw_cmpv64qi3_zero_extenddi_2 */
    5738          570 :     case 3500:  /* *avx512bw_cmpv64qi3_zero_extendsi_2 */
    5739          570 :     case 3499:  /* *avx512bw_cmpv64qi3_zero_extendhi_2 */
    5740          570 :     case 3426:  /* *avx512vl_cmpv2df3_zero_extenddi_2 */
    5741          570 :     case 3425:  /* *avx512vl_cmpv2df3_zero_extendsi_2 */
    5742          570 :     case 3424:  /* *avx512vl_cmpv2df3_zero_extendhi_2 */
    5743          570 :     case 3423:  /* *avx512vl_cmpv4df3_zero_extenddi_2 */
    5744          570 :     case 3422:  /* *avx512vl_cmpv4df3_zero_extendsi_2 */
    5745          570 :     case 3421:  /* *avx512vl_cmpv4df3_zero_extendhi_2 */
    5746          570 :     case 3420:  /* *avx512f_cmpv8df3_zero_extenddi_2 */
    5747          570 :     case 3419:  /* *avx512f_cmpv8df3_zero_extendsi_2 */
    5748          570 :     case 3418:  /* *avx512f_cmpv8df3_zero_extendhi_2 */
    5749          570 :     case 3417:  /* *avx512vl_cmpv4sf3_zero_extenddi_2 */
    5750          570 :     case 3416:  /* *avx512vl_cmpv4sf3_zero_extendsi_2 */
    5751          570 :     case 3415:  /* *avx512vl_cmpv4sf3_zero_extendhi_2 */
    5752          570 :     case 3414:  /* *avx512vl_cmpv8sf3_zero_extenddi_2 */
    5753          570 :     case 3413:  /* *avx512vl_cmpv8sf3_zero_extendsi_2 */
    5754          570 :     case 3412:  /* *avx512vl_cmpv8sf3_zero_extendhi_2 */
    5755          570 :     case 3411:  /* *avx512f_cmpv16sf3_zero_extenddi_2 */
    5756          570 :     case 3410:  /* *avx512f_cmpv16sf3_zero_extendsi_2 */
    5757          570 :     case 3409:  /* *avx512f_cmpv16sf3_zero_extendhi_2 */
    5758          570 :     case 3408:  /* *avx512fp16_cmpv8hf3_zero_extenddi_2 */
    5759          570 :     case 3407:  /* *avx512fp16_cmpv8hf3_zero_extendsi_2 */
    5760          570 :     case 3406:  /* *avx512fp16_cmpv8hf3_zero_extendhi_2 */
    5761          570 :     case 3405:  /* *avx512vl_cmpv16hf3_zero_extenddi_2 */
    5762          570 :     case 3404:  /* *avx512vl_cmpv16hf3_zero_extendsi_2 */
    5763          570 :     case 3403:  /* *avx512vl_cmpv16hf3_zero_extendhi_2 */
    5764          570 :     case 3402:  /* *avx512bw_cmpv32hf3_zero_extenddi_2 */
    5765          570 :     case 3401:  /* *avx512bw_cmpv32hf3_zero_extendsi_2 */
    5766          570 :     case 3400:  /* *avx512bw_cmpv32hf3_zero_extendhi_2 */
    5767          570 :     case 3399:  /* *avx512vl_cmpv2di3_zero_extenddi_2 */
    5768          570 :     case 3398:  /* *avx512vl_cmpv2di3_zero_extendsi_2 */
    5769          570 :     case 3397:  /* *avx512vl_cmpv2di3_zero_extendhi_2 */
    5770          570 :     case 3396:  /* *avx512vl_cmpv4di3_zero_extenddi_2 */
    5771          570 :     case 3395:  /* *avx512vl_cmpv4di3_zero_extendsi_2 */
    5772          570 :     case 3394:  /* *avx512vl_cmpv4di3_zero_extendhi_2 */
    5773          570 :     case 3393:  /* *avx512f_cmpv8di3_zero_extenddi_2 */
    5774          570 :     case 3392:  /* *avx512f_cmpv8di3_zero_extendsi_2 */
    5775          570 :     case 3391:  /* *avx512f_cmpv8di3_zero_extendhi_2 */
    5776          570 :     case 3390:  /* *avx512vl_cmpv4si3_zero_extenddi_2 */
    5777          570 :     case 3389:  /* *avx512vl_cmpv4si3_zero_extendsi_2 */
    5778          570 :     case 3388:  /* *avx512vl_cmpv4si3_zero_extendhi_2 */
    5779          570 :     case 3387:  /* *avx512vl_cmpv8si3_zero_extenddi_2 */
    5780          570 :     case 3386:  /* *avx512vl_cmpv8si3_zero_extendsi_2 */
    5781          570 :     case 3385:  /* *avx512vl_cmpv8si3_zero_extendhi_2 */
    5782          570 :     case 3384:  /* *avx512f_cmpv16si3_zero_extenddi_2 */
    5783          570 :     case 3383:  /* *avx512f_cmpv16si3_zero_extendsi_2 */
    5784          570 :     case 3382:  /* *avx512f_cmpv16si3_zero_extendhi_2 */
    5785          570 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    5786          570 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 0));
    5787          570 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1));
    5788          570 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 2));
    5789          570 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 1), 0));
    5790          570 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 2);
    5791          570 :       recog_data.dup_num[0] = 3;
    5792          570 :       recog_data.dup_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 1);
    5793          570 :       recog_data.dup_num[1] = 2;
    5794          570 :       recog_data.dup_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 0);
    5795          570 :       recog_data.dup_num[2] = 1;
    5796          570 :       break;
    5797              : 
    5798        15644 :     case 3719:  /* avx512f_vmcmpv2df3 */
    5799        15644 :     case 3717:  /* avx512f_vmcmpv4sf3 */
    5800        15644 :     case 3715:  /* avx512f_vmcmpv8hf3 */
    5801        15644 :     case 3702:  /* *avx512vl_ucmpv2di3 */
    5802        15644 :     case 3701:  /* *avx512vl_ucmpv4di3 */
    5803        15644 :     case 3700:  /* *avx512f_ucmpv8di3 */
    5804        15644 :     case 3699:  /* *avx512vl_ucmpv4si3 */
    5805        15644 :     case 3698:  /* *avx512vl_ucmpv8si3 */
    5806        15644 :     case 3697:  /* *avx512f_ucmpv16si3 */
    5807        15644 :     case 3678:  /* *avx512vl_ucmpv2di3_zero_extenddi */
    5808        15644 :     case 3677:  /* *avx512vl_ucmpv4di3_zero_extenddi */
    5809        15644 :     case 3676:  /* *avx512f_ucmpv8di3_zero_extenddi */
    5810        15644 :     case 3675:  /* *avx512vl_ucmpv4si3_zero_extenddi */
    5811        15644 :     case 3674:  /* *avx512vl_ucmpv8si3_zero_extenddi */
    5812        15644 :     case 3673:  /* *avx512f_ucmpv16si3_zero_extenddi */
    5813        15644 :     case 3672:  /* *avx512vl_ucmpv2di3_zero_extendsi */
    5814        15644 :     case 3671:  /* *avx512vl_ucmpv4di3_zero_extendsi */
    5815        15644 :     case 3670:  /* *avx512f_ucmpv8di3_zero_extendsi */
    5816        15644 :     case 3669:  /* *avx512vl_ucmpv4si3_zero_extendsi */
    5817        15644 :     case 3668:  /* *avx512vl_ucmpv8si3_zero_extendsi */
    5818        15644 :     case 3667:  /* *avx512f_ucmpv16si3_zero_extendsi */
    5819        15644 :     case 3666:  /* *avx512vl_ucmpv2di3_zero_extendhi */
    5820        15644 :     case 3665:  /* *avx512vl_ucmpv4di3_zero_extendhi */
    5821        15644 :     case 3664:  /* *avx512f_ucmpv8di3_zero_extendhi */
    5822        15644 :     case 3663:  /* *avx512vl_ucmpv4si3_zero_extendhi */
    5823        15644 :     case 3662:  /* *avx512vl_ucmpv8si3_zero_extendhi */
    5824        15644 :     case 3661:  /* *avx512f_ucmpv16si3_zero_extendhi */
    5825        15644 :     case 3594:  /* *avx512vl_ucmpv8hi3_zero_extenddi */
    5826        15644 :     case 3593:  /* *avx512vl_ucmpv8hi3_zero_extendsi */
    5827        15644 :     case 3592:  /* *avx512vl_ucmpv8hi3_zero_extendhi */
    5828        15644 :     case 3591:  /* *avx512vl_ucmpv16hi3_zero_extenddi */
    5829        15644 :     case 3590:  /* *avx512vl_ucmpv16hi3_zero_extendsi */
    5830        15644 :     case 3589:  /* *avx512vl_ucmpv16hi3_zero_extendhi */
    5831        15644 :     case 3588:  /* *avx512bw_ucmpv32hi3_zero_extenddi */
    5832        15644 :     case 3587:  /* *avx512bw_ucmpv32hi3_zero_extendsi */
    5833        15644 :     case 3586:  /* *avx512bw_ucmpv32hi3_zero_extendhi */
    5834        15644 :     case 3585:  /* *avx512vl_ucmpv32qi3_zero_extenddi */
    5835        15644 :     case 3584:  /* *avx512vl_ucmpv32qi3_zero_extendsi */
    5836        15644 :     case 3583:  /* *avx512vl_ucmpv32qi3_zero_extendhi */
    5837        15644 :     case 3582:  /* *avx512vl_ucmpv16qi3_zero_extenddi */
    5838        15644 :     case 3581:  /* *avx512vl_ucmpv16qi3_zero_extendsi */
    5839        15644 :     case 3580:  /* *avx512vl_ucmpv16qi3_zero_extendhi */
    5840        15644 :     case 3579:  /* *avx512bw_ucmpv64qi3_zero_extenddi */
    5841        15644 :     case 3578:  /* *avx512bw_ucmpv64qi3_zero_extendsi */
    5842        15644 :     case 3577:  /* *avx512bw_ucmpv64qi3_zero_extendhi */
    5843        15644 :     case 3528:  /* *avx512vl_cmpv8hi3 */
    5844        15644 :     case 3527:  /* *avx512vl_cmpv8hi3 */
    5845        15644 :     case 3526:  /* *avx512vl_cmpv16hi3 */
    5846        15644 :     case 3525:  /* *avx512vl_cmpv16hi3 */
    5847        15644 :     case 3524:  /* *avx512bw_cmpv32hi3 */
    5848        15644 :     case 3523:  /* *avx512bw_cmpv32hi3 */
    5849        15644 :     case 3522:  /* *avx512vl_cmpv32qi3 */
    5850        15644 :     case 3521:  /* *avx512vl_cmpv32qi3 */
    5851        15644 :     case 3520:  /* *avx512vl_cmpv16qi3 */
    5852        15644 :     case 3519:  /* *avx512vl_cmpv16qi3 */
    5853        15644 :     case 3518:  /* *avx512bw_cmpv64qi3 */
    5854        15644 :     case 3517:  /* *avx512bw_cmpv64qi3 */
    5855        15644 :     case 3498:  /* *avx512vl_cmpv8hi3_zero_extenddi */
    5856        15644 :     case 3497:  /* *avx512vl_cmpv8hi3_zero_extendsi */
    5857        15644 :     case 3496:  /* *avx512vl_cmpv8hi3_zero_extendhi */
    5858        15644 :     case 3495:  /* *avx512vl_cmpv16hi3_zero_extenddi */
    5859        15644 :     case 3494:  /* *avx512vl_cmpv16hi3_zero_extendsi */
    5860        15644 :     case 3493:  /* *avx512vl_cmpv16hi3_zero_extendhi */
    5861        15644 :     case 3492:  /* *avx512bw_cmpv32hi3_zero_extenddi */
    5862        15644 :     case 3491:  /* *avx512bw_cmpv32hi3_zero_extendsi */
    5863        15644 :     case 3490:  /* *avx512bw_cmpv32hi3_zero_extendhi */
    5864        15644 :     case 3489:  /* *avx512vl_cmpv32qi3_zero_extenddi */
    5865        15644 :     case 3488:  /* *avx512vl_cmpv32qi3_zero_extendsi */
    5866        15644 :     case 3487:  /* *avx512vl_cmpv32qi3_zero_extendhi */
    5867        15644 :     case 3486:  /* *avx512vl_cmpv16qi3_zero_extenddi */
    5868        15644 :     case 3485:  /* *avx512vl_cmpv16qi3_zero_extendsi */
    5869        15644 :     case 3484:  /* *avx512vl_cmpv16qi3_zero_extendhi */
    5870        15644 :     case 3483:  /* *avx512bw_cmpv64qi3_zero_extenddi */
    5871        15644 :     case 3482:  /* *avx512bw_cmpv64qi3_zero_extendsi */
    5872        15644 :     case 3481:  /* *avx512bw_cmpv64qi3_zero_extendhi */
    5873        15644 :     case 3454:  /* *avx512vl_ucmpv2di3_and3 */
    5874        15644 :     case 3453:  /* *avx512vl_cmpv2di3_and3 */
    5875        15644 :     case 3452:  /* *avx512vl_cmpv2df3_and3 */
    5876        15644 :     case 3447:  /* *avx512vl_ucmpv4di3_and15 */
    5877        15644 :     case 3446:  /* *avx512vl_ucmpv4si3_and15 */
    5878        15644 :     case 3445:  /* *avx512vl_cmpv4di3_and15 */
    5879        15644 :     case 3444:  /* *avx512vl_cmpv4si3_and15 */
    5880        15644 :     case 3443:  /* *avx512vl_cmpv4df3_and15 */
    5881        15644 :     case 3442:  /* *avx512vl_cmpv4sf3_and15 */
    5882        15644 :     case 3441:  /* *avx512vl_cmpv2df3 */
    5883        15644 :     case 3440:  /* *avx512vl_cmpv4df3 */
    5884        15644 :     case 3439:  /* *avx512f_cmpv8df3 */
    5885        15644 :     case 3438:  /* *avx512vl_cmpv4sf3 */
    5886        15644 :     case 3437:  /* *avx512vl_cmpv8sf3 */
    5887        15644 :     case 3436:  /* *avx512f_cmpv16sf3 */
    5888        15644 :     case 3435:  /* *avx512fp16_cmpv8hf3 */
    5889        15644 :     case 3434:  /* *avx512vl_cmpv16hf3 */
    5890        15644 :     case 3433:  /* *avx512bw_cmpv32hf3 */
    5891        15644 :     case 3432:  /* *avx512vl_cmpv2di3 */
    5892        15644 :     case 3431:  /* *avx512vl_cmpv4di3 */
    5893        15644 :     case 3430:  /* *avx512f_cmpv8di3 */
    5894        15644 :     case 3429:  /* *avx512vl_cmpv4si3 */
    5895        15644 :     case 3428:  /* *avx512vl_cmpv8si3 */
    5896        15644 :     case 3427:  /* *avx512f_cmpv16si3 */
    5897        15644 :     case 3381:  /* *avx512vl_cmpv2df3_zero_extenddi */
    5898        15644 :     case 3380:  /* *avx512vl_cmpv2df3_zero_extendsi */
    5899        15644 :     case 3379:  /* *avx512vl_cmpv2df3_zero_extendhi */
    5900        15644 :     case 3378:  /* *avx512vl_cmpv4df3_zero_extenddi */
    5901        15644 :     case 3377:  /* *avx512vl_cmpv4df3_zero_extendsi */
    5902        15644 :     case 3376:  /* *avx512vl_cmpv4df3_zero_extendhi */
    5903        15644 :     case 3375:  /* *avx512f_cmpv8df3_zero_extenddi */
    5904        15644 :     case 3374:  /* *avx512f_cmpv8df3_zero_extendsi */
    5905        15644 :     case 3373:  /* *avx512f_cmpv8df3_zero_extendhi */
    5906        15644 :     case 3372:  /* *avx512vl_cmpv4sf3_zero_extenddi */
    5907        15644 :     case 3371:  /* *avx512vl_cmpv4sf3_zero_extendsi */
    5908        15644 :     case 3370:  /* *avx512vl_cmpv4sf3_zero_extendhi */
    5909        15644 :     case 3369:  /* *avx512vl_cmpv8sf3_zero_extenddi */
    5910        15644 :     case 3368:  /* *avx512vl_cmpv8sf3_zero_extendsi */
    5911        15644 :     case 3367:  /* *avx512vl_cmpv8sf3_zero_extendhi */
    5912        15644 :     case 3366:  /* *avx512f_cmpv16sf3_zero_extenddi */
    5913        15644 :     case 3365:  /* *avx512f_cmpv16sf3_zero_extendsi */
    5914        15644 :     case 3364:  /* *avx512f_cmpv16sf3_zero_extendhi */
    5915        15644 :     case 3363:  /* *avx512fp16_cmpv8hf3_zero_extenddi */
    5916        15644 :     case 3362:  /* *avx512fp16_cmpv8hf3_zero_extendsi */
    5917        15644 :     case 3361:  /* *avx512fp16_cmpv8hf3_zero_extendhi */
    5918        15644 :     case 3360:  /* *avx512vl_cmpv16hf3_zero_extenddi */
    5919        15644 :     case 3359:  /* *avx512vl_cmpv16hf3_zero_extendsi */
    5920        15644 :     case 3358:  /* *avx512vl_cmpv16hf3_zero_extendhi */
    5921        15644 :     case 3357:  /* *avx512bw_cmpv32hf3_zero_extenddi */
    5922        15644 :     case 3356:  /* *avx512bw_cmpv32hf3_zero_extendsi */
    5923        15644 :     case 3355:  /* *avx512bw_cmpv32hf3_zero_extendhi */
    5924        15644 :     case 3354:  /* *avx512vl_cmpv2di3_zero_extenddi */
    5925        15644 :     case 3353:  /* *avx512vl_cmpv2di3_zero_extendsi */
    5926        15644 :     case 3352:  /* *avx512vl_cmpv2di3_zero_extendhi */
    5927        15644 :     case 3351:  /* *avx512vl_cmpv4di3_zero_extenddi */
    5928        15644 :     case 3350:  /* *avx512vl_cmpv4di3_zero_extendsi */
    5929        15644 :     case 3349:  /* *avx512vl_cmpv4di3_zero_extendhi */
    5930        15644 :     case 3348:  /* *avx512f_cmpv8di3_zero_extenddi */
    5931        15644 :     case 3347:  /* *avx512f_cmpv8di3_zero_extendsi */
    5932        15644 :     case 3346:  /* *avx512f_cmpv8di3_zero_extendhi */
    5933        15644 :     case 3345:  /* *avx512vl_cmpv4si3_zero_extenddi */
    5934        15644 :     case 3344:  /* *avx512vl_cmpv4si3_zero_extendsi */
    5935        15644 :     case 3343:  /* *avx512vl_cmpv4si3_zero_extendhi */
    5936        15644 :     case 3342:  /* *avx512vl_cmpv8si3_zero_extenddi */
    5937        15644 :     case 3341:  /* *avx512vl_cmpv8si3_zero_extendsi */
    5938        15644 :     case 3340:  /* *avx512vl_cmpv8si3_zero_extendhi */
    5939        15644 :     case 3339:  /* *avx512f_cmpv16si3_zero_extenddi */
    5940        15644 :     case 3338:  /* *avx512f_cmpv16si3_zero_extendsi */
    5941        15644 :     case 3337:  /* *avx512f_cmpv16si3_zero_extendhi */
    5942        15644 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5943        15644 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    5944        15644 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    5945        15644 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    5946        15644 :       break;
    5947              : 
    5948         3916 :     case 3332:  /* avx512f_cmpv8df3_mask_round */
    5949         3916 :     case 3324:  /* avx512f_cmpv16sf3_mask_round */
    5950         3916 :     case 3316:  /* avx512bw_cmpv32hf3_mask_round */
    5951         3916 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5952         3916 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    5953         3916 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    5954         3916 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    5955         3916 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    5956         3916 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    5957         3916 :       break;
    5958              : 
    5959        66226 :     case 10814:  /* avx10_2_cmpbf16_v8bf_mask */
    5960        66226 :     case 10812:  /* avx10_2_cmpbf16_v16bf_mask */
    5961        66226 :     case 10810:  /* avx10_2_cmpbf16_v32bf_mask */
    5962        66226 :     case 4376:  /* fma_fcmaddc_v8hf_fma_zero */
    5963        66226 :     case 4375:  /* fma_fmaddc_v8hf_fma_zero */
    5964        66226 :     case 4374:  /* fma_fcmaddc_v16hf_fma_zero */
    5965        66226 :     case 4373:  /* fma_fmaddc_v16hf_fma_zero */
    5966        66226 :     case 4372:  /* fma_fcmaddc_v32hf_fma_zero */
    5967        66226 :     case 4371:  /* fma_fmaddc_v32hf_fma_zero */
    5968        66226 :     case 3660:  /* avx512vl_ucmpv2di3_mask */
    5969        66226 :     case 3658:  /* avx512vl_ucmpv4di3_mask */
    5970        66226 :     case 3656:  /* avx512f_ucmpv8di3_mask */
    5971        66226 :     case 3654:  /* avx512vl_ucmpv4si3_mask */
    5972        66226 :     case 3652:  /* avx512vl_ucmpv8si3_mask */
    5973        66226 :     case 3650:  /* avx512f_ucmpv16si3_mask */
    5974        66226 :     case 3648:  /* avx512vl_ucmpv8hi3_mask */
    5975        66226 :     case 3646:  /* avx512vl_ucmpv16hi3_mask */
    5976        66226 :     case 3644:  /* avx512bw_ucmpv32hi3_mask */
    5977        66226 :     case 3642:  /* avx512vl_ucmpv16qi3_mask */
    5978        66226 :     case 3640:  /* avx512vl_ucmpv32qi3_mask */
    5979        66226 :     case 3638:  /* avx512bw_ucmpv64qi3_mask */
    5980        66226 :     case 3480:  /* avx512vl_cmpv2di3_mask */
    5981        66226 :     case 3478:  /* avx512vl_cmpv4di3_mask */
    5982        66226 :     case 3476:  /* avx512f_cmpv8di3_mask */
    5983        66226 :     case 3474:  /* avx512vl_cmpv4si3_mask */
    5984        66226 :     case 3472:  /* avx512vl_cmpv8si3_mask */
    5985        66226 :     case 3470:  /* avx512f_cmpv16si3_mask */
    5986        66226 :     case 3468:  /* avx512vl_cmpv8hi3_mask */
    5987        66226 :     case 3466:  /* avx512vl_cmpv16hi3_mask */
    5988        66226 :     case 3464:  /* avx512bw_cmpv32hi3_mask */
    5989        66226 :     case 3462:  /* avx512vl_cmpv16qi3_mask */
    5990        66226 :     case 3460:  /* avx512vl_cmpv32qi3_mask */
    5991        66226 :     case 3458:  /* avx512bw_cmpv64qi3_mask */
    5992        66226 :     case 3336:  /* avx512vl_cmpv2df3_mask */
    5993        66226 :     case 3334:  /* avx512vl_cmpv4df3_mask */
    5994        66226 :     case 3331:  /* avx512f_cmpv8df3_mask */
    5995        66226 :     case 3328:  /* avx512vl_cmpv4sf3_mask */
    5996        66226 :     case 3326:  /* avx512vl_cmpv8sf3_mask */
    5997        66226 :     case 3323:  /* avx512f_cmpv16sf3_mask */
    5998        66226 :     case 3320:  /* avx512fp16_cmpv8hf3_mask */
    5999        66226 :     case 3318:  /* avx512vl_cmpv16hf3_mask */
    6000        66226 :     case 3315:  /* avx512bw_cmpv32hf3_mask */
    6001        66226 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6002        66226 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    6003        66226 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    6004        66226 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    6005        66226 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    6006        66226 :       break;
    6007              : 
    6008         4791 :     case 11022:  /* avx10_2_minmaxpv2df_round */
    6009         4791 :     case 11018:  /* avx10_2_minmaxpv4df_round */
    6010         4791 :     case 11014:  /* avx10_2_minmaxpv8df_round */
    6011         4791 :     case 11010:  /* avx10_2_minmaxpv4sf_round */
    6012         4791 :     case 11006:  /* avx10_2_minmaxpv8sf_round */
    6013         4791 :     case 11002:  /* avx10_2_minmaxpv16sf_round */
    6014         4791 :     case 10998:  /* avx10_2_minmaxpv8hf_round */
    6015         4791 :     case 10994:  /* avx10_2_minmaxpv16hf_round */
    6016         4791 :     case 10990:  /* avx10_2_minmaxpv32hf_round */
    6017         4791 :     case 10052:  /* avx512dq_rangepv8df_round */
    6018         4791 :     case 10044:  /* avx512dq_rangepv16sf_round */
    6019         4791 :     case 4354:  /* fma_fcmaddc_v32hf_round */
    6020         4791 :     case 4350:  /* fma_fmaddc_v32hf_round */
    6021         4791 :     case 4139:  /* *fma_fmaddsub_v8df_round */
    6022         4791 :     case 4131:  /* *fma_fmaddsub_v16sf_round */
    6023         4791 :     case 4123:  /* *fma_fmaddsub_v32hf_round */
    6024         4791 :     case 3330:  /* avx512f_cmpv8df3_round */
    6025         4791 :     case 3322:  /* avx512f_cmpv16sf3_round */
    6026         4791 :     case 3314:  /* avx512bw_cmpv32hf3_round */
    6027         4791 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6028         4791 :       ro[1] = *(ro_loc[1] = &XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0));
    6029         4791 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 1));
    6030         4791 :       ro[3] = *(ro_loc[3] = &XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 2));
    6031         4791 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6032         4791 :       break;
    6033              : 
    6034         4748 :     case 3312:  /* sse2_vmmaskcmpv2df3 */
    6035         4748 :     case 3311:  /* sse_vmmaskcmpv4sf3 */
    6036         4748 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6037         4748 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    6038         4748 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    6039         4748 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 0));
    6040         4748 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    6041         4748 :       recog_data.dup_num[0] = 1;
    6042         4748 :       break;
    6043              : 
    6044           42 :     case 7965:  /* *avx2_pcmpv16qi3_4 */
    6045           42 :     case 7964:  /* *avx2_pcmpv32qi3_4 */
    6046           42 :     case 3300:  /* *avx_cmpv4di3_ltint_not */
    6047           42 :     case 3299:  /* *avx_cmpv8si3_ltint_not */
    6048           42 :     case 3298:  /* *avx_cmpv2di3_ltint_not */
    6049           42 :     case 3297:  /* *avx_cmpv4si3_ltint_not */
    6050           42 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6051           42 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    6052           42 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    6053           42 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 0), 0), 0));
    6054           42 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 1));
    6055           42 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 2));
    6056           42 :       break;
    6057              : 
    6058            0 :     case 7961:  /* *avx2_pcmpv4di3_2 */
    6059            0 :     case 7960:  /* *avx2_pcmpv8si3_2 */
    6060            0 :     case 7959:  /* *avx2_pcmpv16hi3_2 */
    6061            0 :     case 7958:  /* *avx2_pcmpv32qi3_2 */
    6062            0 :     case 7957:  /* *avx2_pcmpv2di3_2 */
    6063            0 :     case 7956:  /* *avx2_pcmpv4si3_2 */
    6064            0 :     case 7955:  /* *avx2_pcmpv8hi3_2 */
    6065            0 :     case 7954:  /* *avx2_pcmpv16qi3_2 */
    6066            0 :     case 3288:  /* *avx_cmpv2df3_4 */
    6067            0 :     case 3287:  /* *avx_cmpv4df3_4 */
    6068            0 :     case 3286:  /* *avx_cmpv4sf3_4 */
    6069            0 :     case 3285:  /* *avx_cmpv8sf3_4 */
    6070            0 :     case 3280:  /* *avx_cmpv2df3_2 */
    6071            0 :     case 3279:  /* *avx_cmpv4df3_2 */
    6072            0 :     case 3278:  /* *avx_cmpv4sf3_2 */
    6073            0 :     case 3277:  /* *avx_cmpv8sf3_2 */
    6074            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6075            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    6076            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    6077            0 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 2), 0), 0, 0));
    6078            0 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 2), 0), 0, 1));
    6079            0 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 2), 0), 0, 2));
    6080            0 :       break;
    6081              : 
    6082         3537 :     case 11036:  /* avx10_2_minmaxsv2df_mask_round */
    6083         3537 :     case 11032:  /* avx10_2_minmaxsv4sf_mask_round */
    6084         3537 :     case 11028:  /* avx10_2_minmaxsv8hf_mask_round */
    6085         3537 :     case 10138:  /* avx512f_vgetmantv2df_mask_round */
    6086         3537 :     case 10134:  /* avx512f_vgetmantv4sf_mask_round */
    6087         3537 :     case 10130:  /* avx512f_vgetmantv8hf_mask_round */
    6088         3537 :     case 10066:  /* avx512dq_rangesv2df_mask_round */
    6089         3537 :     case 10062:  /* avx512dq_rangesv4sf_mask_round */
    6090         3537 :     case 3268:  /* reducesv2df_mask_round */
    6091         3537 :     case 3264:  /* reducesv4sf_mask_round */
    6092         3537 :     case 3260:  /* reducesv8hf_mask_round */
    6093         3537 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6094         3537 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 0));
    6095         3537 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 1));
    6096         3537 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 2));
    6097         3537 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    6098         3537 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    6099         3537 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6100         3537 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    6101         3537 :       recog_data.dup_num[0] = 1;
    6102         3537 :       break;
    6103              : 
    6104         3669 :     case 11035:  /* avx10_2_minmaxsv2df_round */
    6105         3669 :     case 11031:  /* avx10_2_minmaxsv4sf_round */
    6106         3669 :     case 11027:  /* avx10_2_minmaxsv8hf_round */
    6107         3669 :     case 10137:  /* avx512f_vgetmantv2df_round */
    6108         3669 :     case 10133:  /* avx512f_vgetmantv4sf_round */
    6109         3669 :     case 10129:  /* avx512f_vgetmantv8hf_round */
    6110         3669 :     case 10065:  /* avx512dq_rangesv2df_round */
    6111         3669 :     case 10061:  /* avx512dq_rangesv4sf_round */
    6112         3669 :     case 3267:  /* reducesv2df_round */
    6113         3669 :     case 3263:  /* reducesv4sf_round */
    6114         3669 :     case 3259:  /* reducesv8hf_round */
    6115         3669 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6116         3669 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    6117         3669 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    6118         3669 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    6119         3669 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6120         3669 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    6121         3669 :       recog_data.dup_num[0] = 1;
    6122         3669 :       break;
    6123              : 
    6124         5470 :     case 11034:  /* avx10_2_minmaxsv2df_mask */
    6125         5470 :     case 11030:  /* avx10_2_minmaxsv4sf_mask */
    6126         5470 :     case 11026:  /* avx10_2_minmaxsv8hf_mask */
    6127         5470 :     case 10136:  /* avx512f_vgetmantv2df_mask */
    6128         5470 :     case 10132:  /* avx512f_vgetmantv4sf_mask */
    6129         5470 :     case 10128:  /* avx512f_vgetmantv8hf_mask */
    6130         5470 :     case 10064:  /* avx512dq_rangesv2df_mask */
    6131         5470 :     case 10060:  /* avx512dq_rangesv4sf_mask */
    6132         5470 :     case 3266:  /* reducesv2df_mask */
    6133         5470 :     case 3262:  /* reducesv4sf_mask */
    6134         5470 :     case 3258:  /* reducesv8hf_mask */
    6135         5470 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6136         5470 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    6137         5470 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
    6138         5470 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 2));
    6139         5470 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    6140         5470 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    6141         5470 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    6142         5470 :       recog_data.dup_num[0] = 1;
    6143         5470 :       break;
    6144              : 
    6145         4778 :     case 11033:  /* avx10_2_minmaxsv2df */
    6146         4778 :     case 11029:  /* avx10_2_minmaxsv4sf */
    6147         4778 :     case 11025:  /* avx10_2_minmaxsv8hf */
    6148         4778 :     case 10135:  /* avx512f_vgetmantv2df */
    6149         4778 :     case 10131:  /* avx512f_vgetmantv4sf */
    6150         4778 :     case 10127:  /* avx512f_vgetmantv8hf */
    6151         4778 :     case 10063:  /* avx512dq_rangesv2df */
    6152         4778 :     case 10059:  /* avx512dq_rangesv4sf */
    6153         4778 :     case 3302:  /* avx_vmcmpv2df3 */
    6154         4778 :     case 3301:  /* avx_vmcmpv4sf3 */
    6155         4778 :     case 3265:  /* reducesv2df */
    6156         4778 :     case 3261:  /* reducesv4sf */
    6157         4778 :     case 3257:  /* reducesv8hf */
    6158         4778 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6159         4778 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    6160         4778 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    6161         4778 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    6162         4778 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    6163         4778 :       recog_data.dup_num[0] = 1;
    6164         4778 :       break;
    6165              : 
    6166          518 :     case 3220:  /* sse3_hsubv4sf3 */
    6167          518 :     case 3219:  /* sse3_haddv4sf3 */
    6168          518 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6169          518 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    6170          518 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 0));
    6171          518 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1), 0);
    6172          518 :       recog_data.dup_num[0] = 1;
    6173          518 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0), 0);
    6174          518 :       recog_data.dup_num[1] = 1;
    6175          518 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 1), 0);
    6176          518 :       recog_data.dup_num[2] = 1;
    6177          518 :       recog_data.dup_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1), 0);
    6178          518 :       recog_data.dup_num[3] = 2;
    6179          518 :       recog_data.dup_loc[4] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 0), 0);
    6180          518 :       recog_data.dup_num[4] = 2;
    6181          518 :       recog_data.dup_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 1), 0);
    6182          518 :       recog_data.dup_num[5] = 2;
    6183          518 :       break;
    6184              : 
    6185          360 :     case 3218:  /* avx_hsubv8sf3 */
    6186          360 :     case 3217:  /* avx_haddv8sf3 */
    6187          360 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6188          360 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0));
    6189          360 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0), 0), 0));
    6190          360 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 1), 0);
    6191          360 :       recog_data.dup_num[0] = 1;
    6192          360 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1), 0), 0);
    6193          360 :       recog_data.dup_num[1] = 1;
    6194          360 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1), 1), 0);
    6195          360 :       recog_data.dup_num[2] = 1;
    6196          360 :       recog_data.dup_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0), 1), 0);
    6197          360 :       recog_data.dup_num[3] = 2;
    6198          360 :       recog_data.dup_loc[4] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 1), 0), 0);
    6199          360 :       recog_data.dup_num[4] = 2;
    6200          360 :       recog_data.dup_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 1), 1), 0);
    6201          360 :       recog_data.dup_num[5] = 2;
    6202          360 :       recog_data.dup_loc[6] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 0), 0);
    6203          360 :       recog_data.dup_num[6] = 1;
    6204          360 :       recog_data.dup_loc[7] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 1), 0);
    6205          360 :       recog_data.dup_num[7] = 1;
    6206          360 :       recog_data.dup_loc[8] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1), 0), 0);
    6207          360 :       recog_data.dup_num[8] = 1;
    6208          360 :       recog_data.dup_loc[9] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1), 1), 0);
    6209          360 :       recog_data.dup_num[9] = 1;
    6210          360 :       recog_data.dup_loc[10] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 0), 0), 0);
    6211          360 :       recog_data.dup_num[10] = 2;
    6212          360 :       recog_data.dup_loc[11] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 0), 1), 0);
    6213          360 :       recog_data.dup_num[11] = 2;
    6214          360 :       recog_data.dup_loc[12] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 1), 0), 0);
    6215          360 :       recog_data.dup_num[12] = 2;
    6216          360 :       recog_data.dup_loc[13] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 1), 1), 0);
    6217          360 :       recog_data.dup_num[13] = 2;
    6218          360 :       break;
    6219              : 
    6220          360 :     case 3212:  /* avx_hsubv4df3 */
    6221          360 :     case 3211:  /* avx_haddv4df3 */
    6222          360 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6223          360 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    6224          360 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0), 0));
    6225          360 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1), 0);
    6226          360 :       recog_data.dup_num[0] = 1;
    6227          360 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 1), 0);
    6228          360 :       recog_data.dup_num[1] = 2;
    6229          360 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 0);
    6230          360 :       recog_data.dup_num[2] = 1;
    6231          360 :       recog_data.dup_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1), 0);
    6232          360 :       recog_data.dup_num[3] = 1;
    6233          360 :       recog_data.dup_loc[4] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 0), 0);
    6234          360 :       recog_data.dup_num[4] = 2;
    6235          360 :       recog_data.dup_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 1), 0);
    6236          360 :       recog_data.dup_num[5] = 2;
    6237          360 :       break;
    6238              : 
    6239        34554 :     case 3210:  /* vec_addsubv2df3 */
    6240        34554 :     case 3209:  /* vec_addsubv4df3 */
    6241        34554 :     case 3208:  /* vec_addsubv4sf3 */
    6242        34554 :     case 3207:  /* vec_addsubv8sf3 */
    6243        34554 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6244        34554 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    6245        34554 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    6246        34554 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 1), 0);
    6247        34554 :       recog_data.dup_num[0] = 1;
    6248        34554 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 1), 1);
    6249        34554 :       recog_data.dup_num[1] = 2;
    6250        34554 :       break;
    6251              : 
    6252         3394 :     case 7090:  /* avx512f_sgetexpv2df_mask_round */
    6253         3394 :     case 7086:  /* avx512f_sgetexpv4sf_mask_round */
    6254         3394 :     case 7082:  /* avx512f_sgetexpv8hf_mask_round */
    6255         3394 :     case 5428:  /* avx512f_vmscalefv2df_mask_round */
    6256         3394 :     case 5424:  /* avx512f_vmscalefv4sf_mask_round */
    6257         3394 :     case 5420:  /* avx512f_vmscalefv8hf_mask_round */
    6258         3394 :     case 3206:  /* sse2_ieee_vmminv2df3_mask_round */
    6259         3394 :     case 3202:  /* sse2_ieee_vmmaxv2df3_mask_round */
    6260         3394 :     case 3198:  /* sse_ieee_vmminv4sf3_mask_round */
    6261         3394 :     case 3194:  /* sse_ieee_vmmaxv4sf3_mask_round */
    6262         3394 :     case 3190:  /* avx512fp16_ieee_vmminv8hf3_mask_round */
    6263         3394 :     case 3186:  /* avx512fp16_ieee_vmmaxv8hf3_mask_round */
    6264         3394 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6265         3394 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 0));
    6266         3394 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0, 1));
    6267         3394 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    6268         3394 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    6269         3394 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6270         3394 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    6271         3394 :       recog_data.dup_num[0] = 1;
    6272         3394 :       break;
    6273              : 
    6274         2287 :     case 7089:  /* avx512f_sgetexpv2df_round */
    6275         2287 :     case 7085:  /* avx512f_sgetexpv4sf_round */
    6276         2287 :     case 7081:  /* avx512f_sgetexpv8hf_round */
    6277         2287 :     case 5426:  /* avx512f_vmscalefv2df_round */
    6278         2287 :     case 5422:  /* avx512f_vmscalefv4sf_round */
    6279         2287 :     case 5418:  /* avx512f_vmscalefv8hf_round */
    6280         2287 :     case 4430:  /* avx512fp16_fcmulcsh_v8hf_round */
    6281         2287 :     case 4426:  /* avx512fp16_fmulcsh_v8hf_round */
    6282         2287 :     case 3205:  /* sse2_ieee_vmminv2df3_round */
    6283         2287 :     case 3201:  /* sse2_ieee_vmmaxv2df3_round */
    6284         2287 :     case 3197:  /* sse_ieee_vmminv4sf3_round */
    6285         2287 :     case 3193:  /* sse_ieee_vmmaxv4sf3_round */
    6286         2287 :     case 3189:  /* avx512fp16_ieee_vmminv8hf3_round */
    6287         2287 :     case 3185:  /* avx512fp16_ieee_vmmaxv8hf3_round */
    6288         2287 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6289         2287 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    6290         2287 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    6291         2287 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6292         2287 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    6293         2287 :       recog_data.dup_num[0] = 1;
    6294         2287 :       break;
    6295              : 
    6296         6294 :     case 7088:  /* avx512f_sgetexpv2df_mask */
    6297         6294 :     case 7084:  /* avx512f_sgetexpv4sf_mask */
    6298         6294 :     case 7080:  /* avx512f_sgetexpv8hf_mask */
    6299         6294 :     case 5427:  /* avx512f_vmscalefv2df_mask */
    6300         6294 :     case 5423:  /* avx512f_vmscalefv4sf_mask */
    6301         6294 :     case 5419:  /* avx512f_vmscalefv8hf_mask */
    6302         6294 :     case 3204:  /* sse2_ieee_vmminv2df3_mask */
    6303         6294 :     case 3200:  /* sse2_ieee_vmmaxv2df3_mask */
    6304         6294 :     case 3196:  /* sse_ieee_vmminv4sf3_mask */
    6305         6294 :     case 3192:  /* sse_ieee_vmmaxv4sf3_mask */
    6306         6294 :     case 3188:  /* avx512fp16_ieee_vmminv8hf3_mask */
    6307         6294 :     case 3184:  /* avx512fp16_ieee_vmmaxv8hf3_mask */
    6308         6294 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6309         6294 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    6310         6294 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
    6311         6294 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    6312         6294 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    6313         6294 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    6314         6294 :       recog_data.dup_num[0] = 1;
    6315         6294 :       break;
    6316              : 
    6317         3523 :     case 7087:  /* avx512f_sgetexpv2df */
    6318         3523 :     case 7083:  /* avx512f_sgetexpv4sf */
    6319         3523 :     case 7079:  /* avx512f_sgetexpv8hf */
    6320         3523 :     case 5425:  /* avx512f_vmscalefv2df */
    6321         3523 :     case 5421:  /* avx512f_vmscalefv4sf */
    6322         3523 :     case 5417:  /* avx512f_vmscalefv8hf */
    6323         3523 :     case 4429:  /* avx512fp16_fcmulcsh_v8hf */
    6324         3523 :     case 4425:  /* avx512fp16_fmulcsh_v8hf */
    6325         3523 :     case 3203:  /* sse2_ieee_vmminv2df3 */
    6326         3523 :     case 3199:  /* sse2_ieee_vmmaxv2df3 */
    6327         3523 :     case 3195:  /* sse_ieee_vmminv4sf3 */
    6328         3523 :     case 3191:  /* sse_ieee_vmmaxv4sf3 */
    6329         3523 :     case 3187:  /* avx512fp16_ieee_vmminv8hf3 */
    6330         3523 :     case 3183:  /* avx512fp16_ieee_vmmaxv8hf3 */
    6331         3523 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6332         3523 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    6333         3523 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    6334         3523 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    6335         3523 :       recog_data.dup_num[0] = 1;
    6336         3523 :       break;
    6337              : 
    6338          187 :     case 3158:  /* *ieee_minv2df3 */
    6339          187 :     case 3157:  /* *ieee_maxv2df3 */
    6340          187 :     case 3156:  /* *ieee_minv4sf3 */
    6341          187 :     case 3155:  /* *ieee_maxv4sf3 */
    6342          187 :     case 3154:  /* *ieee_minv8hf3 */
    6343          187 :     case 3153:  /* *ieee_maxv8hf3 */
    6344          187 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6345          187 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0), 0));
    6346          187 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 1));
    6347          187 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    6348          187 :       recog_data.dup_num[0] = 1;
    6349          187 :       break;
    6350              : 
    6351        13209 :     case 10126:  /* avx512vl_getmantv2df_mask_round */
    6352        13209 :     case 10122:  /* avx512vl_getmantv4df_mask_round */
    6353        13209 :     case 10118:  /* avx512f_getmantv8df_mask_round */
    6354        13209 :     case 10114:  /* avx512vl_getmantv4sf_mask_round */
    6355        13209 :     case 10110:  /* avx512vl_getmantv8sf_mask_round */
    6356        13209 :     case 10106:  /* avx512f_getmantv16sf_mask_round */
    6357        13209 :     case 10102:  /* avx512fp16_getmantv8hf_mask_round */
    6358        13209 :     case 10098:  /* avx512vl_getmantv16hf_mask_round */
    6359        13209 :     case 10094:  /* avx512bw_getmantv32hf_mask_round */
    6360        13209 :     case 9752:  /* avx512f_vcvtps2ph512_mask_round */
    6361        13209 :     case 7194:  /* avx512vl_rndscalev2df_mask_round */
    6362        13209 :     case 7190:  /* avx512vl_rndscalev4df_mask_round */
    6363        13209 :     case 7186:  /* avx512f_rndscalev8df_mask_round */
    6364        13209 :     case 7182:  /* avx512vl_rndscalev4sf_mask_round */
    6365        13209 :     case 7178:  /* avx512vl_rndscalev8sf_mask_round */
    6366        13209 :     case 7174:  /* avx512f_rndscalev16sf_mask_round */
    6367        13209 :     case 7170:  /* avx512fp16_rndscalev8hf_mask_round */
    6368        13209 :     case 7166:  /* avx512vl_rndscalev16hf_mask_round */
    6369        13209 :     case 7162:  /* avx512bw_rndscalev32hf_mask_round */
    6370        13209 :     case 5464:  /* avx512vl_scalefv2df_mask_round */
    6371        13209 :     case 5460:  /* avx512vl_scalefv4df_mask_round */
    6372        13209 :     case 5456:  /* avx512f_scalefv8df_mask_round */
    6373        13209 :     case 5452:  /* avx512vl_scalefv4sf_mask_round */
    6374        13209 :     case 5448:  /* avx512vl_scalefv8sf_mask_round */
    6375        13209 :     case 5444:  /* avx512f_scalefv16sf_mask_round */
    6376        13209 :     case 5440:  /* avx512fp16_scalefv8hf_mask_round */
    6377        13209 :     case 5436:  /* avx512vl_scalefv16hf_mask_round */
    6378        13209 :     case 5432:  /* avx512bw_scalefv32hf_mask_round */
    6379        13209 :     case 3256:  /* reducepv2df_mask_round */
    6380        13209 :     case 3252:  /* reducepv4df_mask_round */
    6381        13209 :     case 3248:  /* reducepv8df_mask_round */
    6382        13209 :     case 3244:  /* reducepv4sf_mask_round */
    6383        13209 :     case 3240:  /* reducepv8sf_mask_round */
    6384        13209 :     case 3236:  /* reducepv16sf_mask_round */
    6385        13209 :     case 3232:  /* reducepv8hf_mask_round */
    6386        13209 :     case 3228:  /* reducepv16hf_mask_round */
    6387        13209 :     case 3224:  /* reducepv32hf_mask_round */
    6388        13209 :     case 3144:  /* ieee_minv8df3_mask_round */
    6389        13209 :     case 3140:  /* ieee_maxv8df3_mask_round */
    6390        13209 :     case 3128:  /* ieee_minv16sf3_mask_round */
    6391        13209 :     case 3124:  /* ieee_maxv16sf3_mask_round */
    6392        13209 :     case 3112:  /* ieee_minv32hf3_mask_round */
    6393        13209 :     case 3108:  /* ieee_maxv32hf3_mask_round */
    6394        13209 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6395        13209 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    6396        13209 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    6397        13209 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    6398        13209 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    6399        13209 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6400        13209 :       break;
    6401              : 
    6402        65099 :     case 10802:  /* avx10_2_getmantbf16_v8bf_mask */
    6403        65099 :     case 10800:  /* avx10_2_reducebf16_v8bf_mask */
    6404        65099 :     case 10798:  /* avx10_2_rndscalebf16_v8bf_mask */
    6405        65099 :     case 10796:  /* avx10_2_getmantbf16_v16bf_mask */
    6406        65099 :     case 10794:  /* avx10_2_reducebf16_v16bf_mask */
    6407        65099 :     case 10792:  /* avx10_2_rndscalebf16_v16bf_mask */
    6408        65099 :     case 10790:  /* avx10_2_getmantbf16_v32bf_mask */
    6409        65099 :     case 10788:  /* avx10_2_reducebf16_v32bf_mask */
    6410        65099 :     case 10786:  /* avx10_2_rndscalebf16_v32bf_mask */
    6411        65099 :     case 10676:  /* avx10_2_scalefbf16_v8bf_mask */
    6412        65099 :     case 10674:  /* avx10_2_scalefbf16_v16bf_mask */
    6413        65099 :     case 10672:  /* avx10_2_scalefbf16_v32bf_mask */
    6414        65099 :     case 10577:  /* vcvtbiasph2hf8sv16hf_mask */
    6415        65099 :     case 10575:  /* vcvtbiasph2hf8v16hf_mask */
    6416        65099 :     case 10573:  /* vcvtbiasph2bf8sv16hf_mask */
    6417        65099 :     case 10571:  /* vcvtbiasph2bf8v16hf_mask */
    6418        65099 :     case 10569:  /* vcvtbiasph2hf8sv32hf_mask */
    6419        65099 :     case 10567:  /* vcvtbiasph2hf8v32hf_mask */
    6420        65099 :     case 10565:  /* vcvtbiasph2bf8sv32hf_mask */
    6421        65099 :     case 10563:  /* vcvtbiasph2bf8v32hf_mask */
    6422        65099 :     case 10553:  /* vcvt2ph2hf8sv8hf_mask */
    6423        65099 :     case 10551:  /* vcvt2ph2hf8v8hf_mask */
    6424        65099 :     case 10549:  /* vcvt2ph2bf8sv8hf_mask */
    6425        65099 :     case 10547:  /* vcvt2ph2bf8v8hf_mask */
    6426        65099 :     case 10545:  /* vcvt2ph2hf8sv16hf_mask */
    6427        65099 :     case 10543:  /* vcvt2ph2hf8v16hf_mask */
    6428        65099 :     case 10541:  /* vcvt2ph2bf8sv16hf_mask */
    6429        65099 :     case 10539:  /* vcvt2ph2bf8v16hf_mask */
    6430        65099 :     case 10537:  /* vcvt2ph2hf8sv32hf_mask */
    6431        65099 :     case 10535:  /* vcvt2ph2hf8v32hf_mask */
    6432        65099 :     case 10533:  /* vcvt2ph2bf8sv32hf_mask */
    6433        65099 :     case 10531:  /* vcvt2ph2bf8v32hf_mask */
    6434        65099 :     case 10267:  /* vgf2p8mulb_v16qi_mask */
    6435        65099 :     case 10265:  /* vgf2p8mulb_v32qi_mask */
    6436        65099 :     case 10263:  /* vgf2p8mulb_v64qi_mask */
    6437        65099 :     case 10217:  /* vpmultishiftqbv32qi_mask */
    6438        65099 :     case 10215:  /* vpmultishiftqbv16qi_mask */
    6439        65099 :     case 10213:  /* vpmultishiftqbv64qi_mask */
    6440        65099 :     case 10125:  /* avx512vl_getmantv2df_mask */
    6441        65099 :     case 10121:  /* avx512vl_getmantv4df_mask */
    6442        65099 :     case 10117:  /* avx512f_getmantv8df_mask */
    6443        65099 :     case 10113:  /* avx512vl_getmantv4sf_mask */
    6444        65099 :     case 10109:  /* avx512vl_getmantv8sf_mask */
    6445        65099 :     case 10105:  /* avx512f_getmantv16sf_mask */
    6446        65099 :     case 10101:  /* avx512fp16_getmantv8hf_mask */
    6447        65099 :     case 10097:  /* avx512vl_getmantv16hf_mask */
    6448        65099 :     case 10093:  /* avx512bw_getmantv32hf_mask */
    6449        65099 :     case 9751:  /* avx512f_vcvtps2ph512_mask */
    6450        65099 :     case 9746:  /* vcvtps2ph256_mask */
    6451        65099 :     case 9448:  /* avx_vpermilvarv2df3_mask */
    6452        65099 :     case 9446:  /* avx_vpermilvarv4df3_mask */
    6453        65099 :     case 9444:  /* avx512f_vpermilvarv8df3_mask */
    6454        65099 :     case 9442:  /* avx_vpermilvarv4sf3_mask */
    6455        65099 :     case 9440:  /* avx_vpermilvarv8sf3_mask */
    6456        65099 :     case 9438:  /* avx512f_vpermilvarv16sf3_mask */
    6457        65099 :     case 9219:  /* avx512bw_permvarv32bf_mask */
    6458        65099 :     case 9217:  /* avx512vl_permvarv16bf_mask */
    6459        65099 :     case 9215:  /* avx512vl_permvarv8bf_mask */
    6460        65099 :     case 9213:  /* avx512bw_permvarv32hf_mask */
    6461        65099 :     case 9211:  /* avx512vl_permvarv16hf_mask */
    6462        65099 :     case 9209:  /* avx512fp16_permvarv8hf_mask */
    6463        65099 :     case 9207:  /* avx512bw_permvarv32hi_mask */
    6464        65099 :     case 9205:  /* avx512vl_permvarv16hi_mask */
    6465        65099 :     case 9203:  /* avx512vl_permvarv8hi_mask */
    6466        65099 :     case 9201:  /* avx512vl_permvarv32qi_mask */
    6467        65099 :     case 9199:  /* avx512vl_permvarv16qi_mask */
    6468        65099 :     case 9197:  /* avx512bw_permvarv64qi_mask */
    6469        65099 :     case 9195:  /* avx2_permvarv4df_mask */
    6470        65099 :     case 9193:  /* avx2_permvarv4di_mask */
    6471        65099 :     case 9191:  /* avx512f_permvarv8df_mask */
    6472        65099 :     case 9189:  /* avx512f_permvarv8di_mask */
    6473        65099 :     case 9187:  /* avx512f_permvarv16sf_mask */
    6474        65099 :     case 9185:  /* avx512f_permvarv16si_mask */
    6475        65099 :     case 9183:  /* avx2_permvarv8sf_mask */
    6476        65099 :     case 9181:  /* avx2_permvarv8si_mask */
    6477        65099 :     case 8789:  /* sse4_1_packusdw_mask */
    6478        65099 :     case 8787:  /* avx2_packusdw_mask */
    6479        65099 :     case 8785:  /* avx512bw_packusdw_mask */
    6480        65099 :     case 8685:  /* ssse3_pshufbv16qi3_mask */
    6481        65099 :     case 8683:  /* avx2_pshufbv32qi3_mask */
    6482        65099 :     case 8681:  /* avx512bw_pshufbv64qi3_mask */
    6483        65099 :     case 8667:  /* avx512bw_pmaddubsw512v32hi_mask */
    6484        65099 :     case 8665:  /* avx512bw_pmaddubsw512v16hi_mask */
    6485        65099 :     case 8663:  /* avx512bw_pmaddubsw512v8hi_mask */
    6486        65099 :     case 8506:  /* avx512bw_pshufhwv32hi_mask */
    6487        65099 :     case 8500:  /* avx512bw_pshuflwv32hi_mask */
    6488        65099 :     case 8374:  /* sse2_packuswb_mask */
    6489        65099 :     case 8372:  /* avx2_packuswb_mask */
    6490        65099 :     case 8370:  /* avx512bw_packuswb_mask */
    6491        65099 :     case 7641:  /* avx512bw_pmaddwd512v8hi_mask */
    6492        65099 :     case 7639:  /* avx512bw_pmaddwd512v16hi_mask */
    6493        65099 :     case 7637:  /* avx512bw_pmaddwd512v32hi_mask */
    6494        65099 :     case 7193:  /* avx512vl_rndscalev2df_mask */
    6495        65099 :     case 7189:  /* avx512vl_rndscalev4df_mask */
    6496        65099 :     case 7185:  /* avx512f_rndscalev8df_mask */
    6497        65099 :     case 7181:  /* avx512vl_rndscalev4sf_mask */
    6498        65099 :     case 7177:  /* avx512vl_rndscalev8sf_mask */
    6499        65099 :     case 7173:  /* avx512f_rndscalev16sf_mask */
    6500        65099 :     case 7169:  /* avx512fp16_rndscalev8hf_mask */
    6501        65099 :     case 7165:  /* avx512vl_rndscalev16hf_mask */
    6502        65099 :     case 7161:  /* avx512bw_rndscalev32hf_mask */
    6503        65099 :     case 5463:  /* avx512vl_scalefv2df_mask */
    6504        65099 :     case 5459:  /* avx512vl_scalefv4df_mask */
    6505        65099 :     case 5455:  /* avx512f_scalefv8df_mask */
    6506        65099 :     case 5451:  /* avx512vl_scalefv4sf_mask */
    6507        65099 :     case 5447:  /* avx512vl_scalefv8sf_mask */
    6508        65099 :     case 5443:  /* avx512f_scalefv16sf_mask */
    6509        65099 :     case 5439:  /* avx512fp16_scalefv8hf_mask */
    6510        65099 :     case 5435:  /* avx512vl_scalefv16hf_mask */
    6511        65099 :     case 5431:  /* avx512bw_scalefv32hf_mask */
    6512        65099 :     case 3255:  /* reducepv2df_mask */
    6513        65099 :     case 3251:  /* reducepv4df_mask */
    6514        65099 :     case 3247:  /* reducepv8df_mask */
    6515        65099 :     case 3243:  /* reducepv4sf_mask */
    6516        65099 :     case 3239:  /* reducepv8sf_mask */
    6517        65099 :     case 3235:  /* reducepv16sf_mask */
    6518        65099 :     case 3231:  /* reducepv8hf_mask */
    6519        65099 :     case 3227:  /* reducepv16hf_mask */
    6520        65099 :     case 3223:  /* reducepv32hf_mask */
    6521        65099 :     case 3152:  /* ieee_minv2df3_mask */
    6522        65099 :     case 3150:  /* ieee_maxv2df3_mask */
    6523        65099 :     case 3148:  /* ieee_minv4df3_mask */
    6524        65099 :     case 3146:  /* ieee_maxv4df3_mask */
    6525        65099 :     case 3143:  /* ieee_minv8df3_mask */
    6526        65099 :     case 3139:  /* ieee_maxv8df3_mask */
    6527        65099 :     case 3136:  /* ieee_minv4sf3_mask */
    6528        65099 :     case 3134:  /* ieee_maxv4sf3_mask */
    6529        65099 :     case 3132:  /* ieee_minv8sf3_mask */
    6530        65099 :     case 3130:  /* ieee_maxv8sf3_mask */
    6531        65099 :     case 3127:  /* ieee_minv16sf3_mask */
    6532        65099 :     case 3123:  /* ieee_maxv16sf3_mask */
    6533        65099 :     case 3120:  /* ieee_minv8hf3_mask */
    6534        65099 :     case 3118:  /* ieee_maxv8hf3_mask */
    6535        65099 :     case 3116:  /* ieee_minv16hf3_mask */
    6536        65099 :     case 3114:  /* ieee_maxv16hf3_mask */
    6537        65099 :     case 3111:  /* ieee_minv32hf3_mask */
    6538        65099 :     case 3107:  /* ieee_maxv32hf3_mask */
    6539        65099 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6540        65099 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    6541        65099 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    6542        65099 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    6543        65099 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    6544        65099 :       break;
    6545              : 
    6546         5079 :     case 10124:  /* avx512vl_getmantv2df_round */
    6547         5079 :     case 10120:  /* avx512vl_getmantv4df_round */
    6548         5079 :     case 10116:  /* avx512f_getmantv8df_round */
    6549         5079 :     case 10112:  /* avx512vl_getmantv4sf_round */
    6550         5079 :     case 10108:  /* avx512vl_getmantv8sf_round */
    6551         5079 :     case 10104:  /* avx512f_getmantv16sf_round */
    6552         5079 :     case 10100:  /* avx512fp16_getmantv8hf_round */
    6553         5079 :     case 10096:  /* avx512vl_getmantv16hf_round */
    6554         5079 :     case 10092:  /* avx512bw_getmantv32hf_round */
    6555         5079 :     case 9750:  /* *avx512f_vcvtps2ph512_round */
    6556         5079 :     case 7192:  /* avx512vl_rndscalev2df_round */
    6557         5079 :     case 7188:  /* avx512vl_rndscalev4df_round */
    6558         5079 :     case 7184:  /* avx512f_rndscalev8df_round */
    6559         5079 :     case 7180:  /* avx512vl_rndscalev4sf_round */
    6560         5079 :     case 7176:  /* avx512vl_rndscalev8sf_round */
    6561         5079 :     case 7172:  /* avx512f_rndscalev16sf_round */
    6562         5079 :     case 7168:  /* avx512fp16_rndscalev8hf_round */
    6563         5079 :     case 7164:  /* avx512vl_rndscalev16hf_round */
    6564         5079 :     case 7160:  /* avx512bw_rndscalev32hf_round */
    6565         5079 :     case 5462:  /* avx512vl_scalefv2df_round */
    6566         5079 :     case 5458:  /* avx512vl_scalefv4df_round */
    6567         5079 :     case 5454:  /* avx512f_scalefv8df_round */
    6568         5079 :     case 5450:  /* avx512vl_scalefv4sf_round */
    6569         5079 :     case 5446:  /* avx512vl_scalefv8sf_round */
    6570         5079 :     case 5442:  /* avx512f_scalefv16sf_round */
    6571         5079 :     case 5438:  /* avx512fp16_scalefv8hf_round */
    6572         5079 :     case 5434:  /* avx512vl_scalefv16hf_round */
    6573         5079 :     case 5430:  /* avx512bw_scalefv32hf_round */
    6574         5079 :     case 4403:  /* avx512bw_fcmulc_v32hf_round */
    6575         5079 :     case 4399:  /* avx512bw_fmulc_v32hf_round */
    6576         5079 :     case 3254:  /* *reducepv2df_round */
    6577         5079 :     case 3250:  /* *reducepv4df_round */
    6578         5079 :     case 3246:  /* *reducepv8df_round */
    6579         5079 :     case 3242:  /* *reducepv4sf_round */
    6580         5079 :     case 3238:  /* *reducepv8sf_round */
    6581         5079 :     case 3234:  /* *reducepv16sf_round */
    6582         5079 :     case 3230:  /* *reducepv8hf_round */
    6583         5079 :     case 3226:  /* *reducepv16hf_round */
    6584         5079 :     case 3222:  /* *reducepv32hf_round */
    6585         5079 :     case 3142:  /* ieee_minv8df3_round */
    6586         5079 :     case 3138:  /* ieee_maxv8df3_round */
    6587         5079 :     case 3126:  /* ieee_minv16sf3_round */
    6588         5079 :     case 3122:  /* ieee_maxv16sf3_round */
    6589         5079 :     case 3110:  /* ieee_minv32hf3_round */
    6590         5079 :     case 3106:  /* ieee_maxv32hf3_round */
    6591         5079 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6592         5079 :       ro[1] = *(ro_loc[1] = &XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0));
    6593         5079 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 1));
    6594         5079 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6595         5079 :       break;
    6596              : 
    6597           56 :     case 3104:  /* *minmaxv2df3_4 */
    6598           56 :     case 3103:  /* *minmaxv4df3_4 */
    6599           56 :     case 3102:  /* *minmaxv4sf3_4 */
    6600           56 :     case 3101:  /* *minmaxv8sf3_4 */
    6601           56 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6602           56 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    6603           56 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    6604           56 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    6605           56 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    6606           56 :       break;
    6607              : 
    6608           60 :     case 3100:  /* *minmaxv2df3_3 */
    6609           60 :     case 3099:  /* *minmaxv4df3_3 */
    6610           60 :     case 3098:  /* *minmaxv4sf3_3 */
    6611           60 :     case 3097:  /* *minmaxv8sf3_3 */
    6612           60 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6613           60 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    6614           60 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    6615           60 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    6616           60 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    6617           60 :       break;
    6618              : 
    6619         4158 :     case 7999:  /* *avx2_pcmpv4di3_8 */
    6620         4158 :     case 7998:  /* *avx2_pcmpv8si3_8 */
    6621         4158 :     case 7997:  /* *avx2_pcmpv16hi3_8 */
    6622         4158 :     case 7996:  /* *avx2_pcmpv32qi3_8 */
    6623         4158 :     case 7995:  /* *avx2_pcmpv2di3_8 */
    6624         4158 :     case 7994:  /* *avx2_pcmpv4si3_8 */
    6625         4158 :     case 7993:  /* *avx2_pcmpv8hi3_8 */
    6626         4158 :     case 7992:  /* *avx2_pcmpv16qi3_8 */
    6627         4158 :     case 7991:  /* *avx2_pcmpv4di3_7 */
    6628         4158 :     case 7990:  /* *avx2_pcmpv8si3_7 */
    6629         4158 :     case 7989:  /* *avx2_pcmpv16hi3_7 */
    6630         4158 :     case 7988:  /* *avx2_pcmpv32qi3_7 */
    6631         4158 :     case 7987:  /* *avx2_pcmpv2di3_7 */
    6632         4158 :     case 7986:  /* *avx2_pcmpv4si3_7 */
    6633         4158 :     case 7985:  /* *avx2_pcmpv8hi3_7 */
    6634         4158 :     case 7984:  /* *avx2_pcmpv16qi3_7 */
    6635         4158 :     case 7983:  /* *avx2_pcmpv4di3_6 */
    6636         4158 :     case 7982:  /* *avx2_pcmpv4di3_6 */
    6637         4158 :     case 7981:  /* *avx2_pcmpv8si3_6 */
    6638         4158 :     case 7980:  /* *avx2_pcmpv8si3_6 */
    6639         4158 :     case 7979:  /* *avx2_pcmpv16hi3_6 */
    6640         4158 :     case 7978:  /* *avx2_pcmpv16hi3_6 */
    6641         4158 :     case 7977:  /* *avx2_pcmpv32qi3_6 */
    6642         4158 :     case 7976:  /* *avx2_pcmpv32qi3_6 */
    6643         4158 :     case 7975:  /* *avx2_pcmpv2di3_6 */
    6644         4158 :     case 7974:  /* *avx2_pcmpv2di3_6 */
    6645         4158 :     case 7973:  /* *avx2_pcmpv4si3_6 */
    6646         4158 :     case 7972:  /* *avx2_pcmpv4si3_6 */
    6647         4158 :     case 7971:  /* *avx2_pcmpv8hi3_6 */
    6648         4158 :     case 7970:  /* *avx2_pcmpv8hi3_6 */
    6649         4158 :     case 7969:  /* *avx2_pcmpv16qi3_6 */
    6650         4158 :     case 7968:  /* *avx2_pcmpv16qi3_6 */
    6651         4158 :     case 7963:  /* *avx2_pcmpv16qi3_3 */
    6652         4158 :     case 7962:  /* *avx2_pcmpv32qi3_3 */
    6653         4158 :     case 7953:  /* *avx2_pcmpv4di3_1 */
    6654         4158 :     case 7952:  /* *avx2_pcmpv8si3_1 */
    6655         4158 :     case 7951:  /* *avx2_pcmpv16hi3_1 */
    6656         4158 :     case 7950:  /* *avx2_pcmpv32qi3_1 */
    6657         4158 :     case 7949:  /* *avx2_pcmpv2di3_1 */
    6658         4158 :     case 7948:  /* *avx2_pcmpv4si3_1 */
    6659         4158 :     case 7947:  /* *avx2_pcmpv8hi3_1 */
    6660         4158 :     case 7946:  /* *avx2_pcmpv16qi3_1 */
    6661         4158 :     case 3296:  /* *avx_cmpv4di3_ltint */
    6662         4158 :     case 3295:  /* *avx_cmpv8si3_ltint */
    6663         4158 :     case 3294:  /* *avx_cmpv2di3_ltint */
    6664         4158 :     case 3293:  /* *avx_cmpv4si3_ltint */
    6665         4158 :     case 3292:  /* *avx_cmpv2df3_lt */
    6666         4158 :     case 3291:  /* *avx_cmpv4df3_lt */
    6667         4158 :     case 3290:  /* *avx_cmpv4sf3_lt */
    6668         4158 :     case 3289:  /* *avx_cmpv8sf3_lt */
    6669         4158 :     case 3284:  /* *avx_cmpv2df3_3 */
    6670         4158 :     case 3283:  /* *avx_cmpv4df3_3 */
    6671         4158 :     case 3282:  /* *avx_cmpv4sf3_3 */
    6672         4158 :     case 3281:  /* *avx_cmpv8sf3_3 */
    6673         4158 :     case 3276:  /* *avx_cmpv2df3_1 */
    6674         4158 :     case 3275:  /* *avx_cmpv4df3_1 */
    6675         4158 :     case 3274:  /* *avx_cmpv4sf3_1 */
    6676         4158 :     case 3273:  /* *avx_cmpv8sf3_1 */
    6677         4158 :     case 3092:  /* *minmaxv2df3_1 */
    6678         4158 :     case 3091:  /* *minmaxv4df3_1 */
    6679         4158 :     case 3090:  /* *minmaxv8df3_1 */
    6680         4158 :     case 3089:  /* *minmaxv4sf3_1 */
    6681         4158 :     case 3088:  /* *minmaxv8sf3_1 */
    6682         4158 :     case 3087:  /* *minmaxv16sf3_1 */
    6683         4158 :     case 3086:  /* *minmaxv8hf3_1 */
    6684         4158 :     case 3085:  /* *minmaxv16hf3_1 */
    6685         4158 :     case 3084:  /* *minmaxv32hf3_1 */
    6686         4158 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6687         4158 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    6688         4158 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    6689         4158 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 0));
    6690         4158 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 1));
    6691         4158 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 2));
    6692         4158 :       break;
    6693              : 
    6694            0 :     case 3035:  /* *avx512fp16_vmrsqrtv8hf2 */
    6695            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6696            0 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0, 0));
    6697            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    6698            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    6699            0 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    6700            0 :       break;
    6701              : 
    6702            0 :     case 3005:  /* *sse2_vmsqrtv2df2_mask_round */
    6703            0 :     case 3001:  /* *sse_vmsqrtv4sf2_mask_round */
    6704            0 :     case 2997:  /* *avx512fp16_vmsqrtv8hf2_mask_round */
    6705            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6706            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0), 0));
    6707            0 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    6708            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    6709            0 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    6710            0 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6711            0 :       break;
    6712              : 
    6713            0 :     case 4811:  /* avx512fp16_vcvtsd2sh_mask_mem */
    6714            0 :     case 4809:  /* avx512fp16_vcvtss2sh_mask_mem */
    6715            0 :     case 4799:  /* avx512fp16_vcvtsh2ss_mask_mem */
    6716            0 :     case 4797:  /* avx512fp16_vcvtsh2sd_mask_mem */
    6717            0 :     case 3004:  /* *sse2_vmsqrtv2df2_mask */
    6718            0 :     case 3000:  /* *sse_vmsqrtv4sf2_mask */
    6719            0 :     case 2996:  /* *avx512fp16_vmsqrtv8hf2_mask */
    6720            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6721            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    6722            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    6723            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    6724            0 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    6725            0 :       break;
    6726              : 
    6727            0 :     case 3003:  /* *sse2_vmsqrtv2df2_round */
    6728            0 :     case 2999:  /* *sse_vmsqrtv4sf2_round */
    6729            0 :     case 2995:  /* *avx512fp16_vmsqrtv8hf2_round */
    6730            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6731            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    6732            0 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    6733            0 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6734            0 :       break;
    6735              : 
    6736         1721 :     case 2993:  /* sse2_vmsqrtv2df2_mask_round */
    6737         1721 :     case 2989:  /* sse_vmsqrtv4sf2_mask_round */
    6738         1721 :     case 2985:  /* avx512fp16_vmsqrtv8hf2_mask_round */
    6739         1721 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6740         1721 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    6741         1721 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    6742         1721 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    6743         1721 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    6744         1721 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6745         1721 :       break;
    6746              : 
    6747          310 :     case 2992:  /* sse2_vmsqrtv2df2_mask */
    6748          310 :     case 2988:  /* sse_vmsqrtv4sf2_mask */
    6749          310 :     case 2984:  /* avx512fp16_vmsqrtv8hf2_mask */
    6750          310 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6751          310 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    6752          310 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    6753          310 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    6754          310 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    6755          310 :       break;
    6756              : 
    6757          486 :     case 2991:  /* sse2_vmsqrtv2df2_round */
    6758          486 :     case 2987:  /* sse_vmsqrtv4sf2_round */
    6759          486 :     case 2983:  /* avx512fp16_vmsqrtv8hf2_round */
    6760          486 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6761          486 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    6762          486 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    6763          486 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6764          486 :       break;
    6765              : 
    6766        16658 :     case 5191:  /* avx512f_cvtps2pd512_mask_round */
    6767        16658 :     case 5181:  /* avx512f_cvtpd2ps512_mask_round */
    6768        16658 :     case 5142:  /* fixuns_truncv8sfv8di2_mask_round */
    6769        16658 :     case 5138:  /* fix_truncv8sfv8di2_mask_round */
    6770        16658 :     case 5098:  /* fixuns_truncv8dfv8di2_mask_round */
    6771        16658 :     case 5094:  /* fix_truncv8dfv8di2_mask_round */
    6772        16658 :     case 5061:  /* fixuns_truncv8dfv8si2_mask_round */
    6773        16658 :     case 5057:  /* fix_truncv8dfv8si2_mask_round */
    6774        16658 :     case 5004:  /* floatunsv8div8sf2_mask_round */
    6775        16658 :     case 5000:  /* floatv8div8sf2_mask_round */
    6776        16658 :     case 4996:  /* floatunsv2div2df2_mask_round */
    6777        16658 :     case 4992:  /* floatv2div2df2_mask_round */
    6778        16658 :     case 4988:  /* floatunsv4div4df2_mask_round */
    6779        16658 :     case 4984:  /* floatv4div4df2_mask_round */
    6780        16658 :     case 4980:  /* floatunsv8div8df2_mask_round */
    6781        16658 :     case 4976:  /* floatv8div8df2_mask_round */
    6782        16658 :     case 4912:  /* fixuns_truncv16sfv16si2_mask_round */
    6783        16658 :     case 4908:  /* fix_truncv16sfv16si2_mask_round */
    6784        16658 :     case 4860:  /* floatunsv4siv4sf2_mask_round */
    6785        16658 :     case 4856:  /* floatunsv8siv8sf2_mask_round */
    6786        16658 :     case 4852:  /* floatunsv16siv16sf2_mask_round */
    6787        16658 :     case 4844:  /* floatv16siv16sf2_mask_round */
    6788        16658 :     case 4778:  /* avx512fp16_vcvtps2ph_v8sf_mask_round */
    6789        16658 :     case 4774:  /* avx512fp16_vcvtps2ph_v16sf_mask_round */
    6790        16658 :     case 4770:  /* avx512fp16_vcvtpd2ph_v8df_mask_round */
    6791        16658 :     case 4754:  /* avx512fp16_float_extend_phv8sf2_mask_round */
    6792        16658 :     case 4750:  /* avx512fp16_float_extend_phv16sf2_mask_round */
    6793        16658 :     case 4746:  /* avx512fp16_float_extend_phv8df2_mask_round */
    6794        16658 :     case 4686:  /* avx512fp16_fixuns_truncv8di2_mask_round */
    6795        16658 :     case 4682:  /* avx512fp16_fix_truncv8di2_mask_round */
    6796        16658 :     case 4678:  /* avx512fp16_fixuns_truncv16si2_mask_round */
    6797        16658 :     case 4674:  /* avx512fp16_fix_truncv16si2_mask_round */
    6798        16658 :     case 4670:  /* avx512fp16_fixuns_truncv8si2_mask_round */
    6799        16658 :     case 4666:  /* avx512fp16_fix_truncv8si2_mask_round */
    6800        16658 :     case 4662:  /* avx512fp16_fixuns_truncv32hi2_mask_round */
    6801        16658 :     case 4658:  /* avx512fp16_fix_truncv32hi2_mask_round */
    6802        16658 :     case 4654:  /* avx512fp16_fixuns_truncv16hi2_mask_round */
    6803        16658 :     case 4650:  /* avx512fp16_fix_truncv16hi2_mask_round */
    6804        16658 :     case 4646:  /* avx512fp16_fixuns_truncv8hi2_mask_round */
    6805        16658 :     case 4642:  /* avx512fp16_fix_truncv8hi2_mask_round */
    6806        16658 :     case 4552:  /* avx512fp16_vcvtuqq2ph_v8di_mask_round */
    6807        16658 :     case 4548:  /* avx512fp16_vcvtqq2ph_v8di_mask_round */
    6808        16658 :     case 4544:  /* avx512fp16_vcvtudq2ph_v16si_mask_round */
    6809        16658 :     case 4540:  /* avx512fp16_vcvtdq2ph_v16si_mask_round */
    6810        16658 :     case 4536:  /* avx512fp16_vcvtudq2ph_v8si_mask_round */
    6811        16658 :     case 4532:  /* avx512fp16_vcvtdq2ph_v8si_mask_round */
    6812        16658 :     case 4528:  /* avx512fp16_vcvtuw2ph_v32hi_mask_round */
    6813        16658 :     case 4524:  /* avx512fp16_vcvtw2ph_v32hi_mask_round */
    6814        16658 :     case 4520:  /* avx512fp16_vcvtuw2ph_v16hi_mask_round */
    6815        16658 :     case 4516:  /* avx512fp16_vcvtw2ph_v16hi_mask_round */
    6816        16658 :     case 4512:  /* avx512fp16_vcvtuw2ph_v8hi_mask_round */
    6817        16658 :     case 4508:  /* avx512fp16_vcvtw2ph_v8hi_mask_round */
    6818        16658 :     case 4010:  /* *fma_fnmadd_v8df_round */
    6819        16658 :     case 4001:  /* *fma_fnmadd_v16sf_round */
    6820        16658 :     case 3991:  /* *fma_fnmadd_v32hf_round */
    6821        16658 :     case 2977:  /* avx512f_sqrtv8df2_mask_round */
    6822        16658 :     case 2969:  /* avx512f_sqrtv16sf2_mask_round */
    6823        16658 :     case 2961:  /* avx512fp16_sqrtv32hf2_mask_round */
    6824        16658 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6825        16658 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    6826        16658 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    6827        16658 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    6828        16658 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6829        16658 :       break;
    6830              : 
    6831       196112 :     case 10772:  /* avx10_2_sqrtbf16_v8bf_mask */
    6832       196112 :     case 10770:  /* avx10_2_sqrtbf16_v16bf_mask */
    6833       196112 :     case 10768:  /* avx10_2_sqrtbf16_v32bf_mask */
    6834       196112 :     case 10729:  /* avx10_2_fnmaddbf16_v8bf */
    6835       196112 :     case 10727:  /* avx10_2_fnmaddbf16_v16bf */
    6836       196112 :     case 10725:  /* avx10_2_fnmaddbf16_v32bf */
    6837       196112 :     case 10435:  /* avx512f_cvtneps2bf16_v8sf_mask */
    6838       196112 :     case 10433:  /* avx512f_cvtneps2bf16_v16sf_mask */
    6839       196112 :     case 10249:  /* vpopcountv8hi_mask */
    6840       196112 :     case 10247:  /* vpopcountv16hi_mask */
    6841       196112 :     case 10245:  /* vpopcountv32hi_mask */
    6842       196112 :     case 10243:  /* vpopcountv32qi_mask */
    6843       196112 :     case 10241:  /* vpopcountv16qi_mask */
    6844       196112 :     case 10239:  /* vpopcountv64qi_mask */
    6845       196112 :     case 10229:  /* vpopcountv2di_mask */
    6846       196112 :     case 10227:  /* vpopcountv4di_mask */
    6847       196112 :     case 10225:  /* vpopcountv8di_mask */
    6848       196112 :     case 10223:  /* vpopcountv4si_mask */
    6849       196112 :     case 10221:  /* vpopcountv8si_mask */
    6850       196112 :     case 10219:  /* vpopcountv16si_mask */
    6851       196112 :     case 10156:  /* clzv2di2_mask */
    6852       196112 :     case 10154:  /* clzv4di2_mask */
    6853       196112 :     case 10152:  /* clzv8di2_mask */
    6854       196112 :     case 10150:  /* clzv4si2_mask */
    6855       196112 :     case 10148:  /* clzv8si2_mask */
    6856       196112 :     case 10146:  /* clzv16si2_mask */
    6857       196112 :     case 9430:  /* avx512dq_broadcastv4df_mask_1 */
    6858       196112 :     case 9428:  /* avx512dq_broadcastv4di_mask_1 */
    6859       196112 :     case 9426:  /* avx512dq_broadcastv8df_mask_1 */
    6860       196112 :     case 9424:  /* avx512dq_broadcastv8di_mask_1 */
    6861       196112 :     case 9422:  /* avx512dq_broadcastv16si_mask_1 */
    6862       196112 :     case 9420:  /* avx512dq_broadcastv16sf_mask_1 */
    6863       196112 :     case 9418:  /* avx512vl_broadcastv8sf_mask_1 */
    6864       196112 :     case 9416:  /* avx512vl_broadcastv8si_mask_1 */
    6865       196112 :     case 9366:  /* avx512vl_vec_dup_gprv2df_mask */
    6866       196112 :     case 9364:  /* avx512vl_vec_dup_gprv4df_mask */
    6867       196112 :     case 9362:  /* avx512f_vec_dup_gprv8df_mask */
    6868       196112 :     case 9360:  /* avx512vl_vec_dup_gprv4sf_mask */
    6869       196112 :     case 9358:  /* avx512vl_vec_dup_gprv8sf_mask */
    6870       196112 :     case 9356:  /* avx512f_vec_dup_gprv16sf_mask */
    6871       196112 :     case 9354:  /* avx512vl_vec_dup_gprv2di_mask */
    6872       196112 :     case 9352:  /* avx512vl_vec_dup_gprv4di_mask */
    6873       196112 :     case 9350:  /* avx512f_vec_dup_gprv8di_mask */
    6874       196112 :     case 9348:  /* avx512vl_vec_dup_gprv4si_mask */
    6875       196112 :     case 9346:  /* avx512vl_vec_dup_gprv8si_mask */
    6876       196112 :     case 9344:  /* avx512f_vec_dup_gprv16si_mask */
    6877       196112 :     case 9342:  /* avx512vl_vec_dup_gprv8bf_mask */
    6878       196112 :     case 9340:  /* avx512vl_vec_dup_gprv16bf_mask */
    6879       196112 :     case 9338:  /* avx512bw_vec_dup_gprv32bf_mask */
    6880       196112 :     case 9336:  /* avx512fp16_vec_dup_gprv8hf_mask */
    6881       196112 :     case 9334:  /* avx512vl_vec_dup_gprv16hf_mask */
    6882       196112 :     case 9332:  /* avx512bw_vec_dup_gprv32hf_mask */
    6883       196112 :     case 9330:  /* avx512vl_vec_dup_gprv8hi_mask */
    6884       196112 :     case 9328:  /* avx512vl_vec_dup_gprv16hi_mask */
    6885       196112 :     case 9326:  /* avx512bw_vec_dup_gprv32hi_mask */
    6886       196112 :     case 9324:  /* avx512vl_vec_dup_gprv32qi_mask */
    6887       196112 :     case 9322:  /* avx512vl_vec_dup_gprv16qi_mask */
    6888       196112 :     case 9320:  /* avx512bw_vec_dup_gprv64qi_mask */
    6889       196112 :     case 9318:  /* avx512f_broadcastv8di_mask */
    6890       196112 :     case 9316:  /* avx512f_broadcastv8df_mask */
    6891       196112 :     case 9314:  /* avx512f_broadcastv16si_mask */
    6892       196112 :     case 9312:  /* avx512f_broadcastv16sf_mask */
    6893       196112 :     case 8985:  /* *sse4_1_zero_extendv2siv2di2_mask_1 */
    6894       196112 :     case 8983:  /* *sse4_1_sign_extendv2siv2di2_mask_1 */
    6895       196112 :     case 8975:  /* avx2_zero_extendv4siv4di2_mask */
    6896       196112 :     case 8973:  /* avx2_sign_extendv4siv4di2_mask */
    6897       196112 :     case 8969:  /* avx512f_zero_extendv8siv8di2_mask */
    6898       196112 :     case 8967:  /* avx512f_sign_extendv8siv8di2_mask */
    6899       196112 :     case 8961:  /* *sse4_1_zero_extendv2hiv2di2_mask_1 */
    6900       196112 :     case 8959:  /* *sse4_1_sign_extendv2hiv2di2_mask_1 */
    6901       196112 :     case 8949:  /* *avx2_zero_extendv4hiv4di2_mask_1 */
    6902       196112 :     case 8947:  /* *avx2_sign_extendv4hiv4di2_mask_1 */
    6903       196112 :     case 8941:  /* avx512f_zero_extendv8hiv8di2_mask */
    6904       196112 :     case 8939:  /* avx512f_sign_extendv8hiv8di2_mask */
    6905       196112 :     case 8934:  /* *sse4_1_zero_extendv2qiv2di2_mask_1 */
    6906       196112 :     case 8932:  /* *sse4_1_sign_extendv2qiv2di2_mask_1 */
    6907       196112 :     case 8922:  /* *avx2_zero_extendv4qiv4di2_mask_1 */
    6908       196112 :     case 8920:  /* *avx2_sign_extendv4qiv4di2_mask_1 */
    6909       196112 :     case 8910:  /* *avx512f_zero_extendv8qiv8di2_mask_1 */
    6910       196112 :     case 8908:  /* *avx512f_sign_extendv8qiv8di2_mask_1 */
    6911       196112 :     case 8894:  /* *sse4_1_zero_extendv4hiv4si2_mask_1 */
    6912       196112 :     case 8892:  /* *sse4_1_sign_extendv4hiv4si2_mask_1 */
    6913       196112 :     case 8882:  /* avx2_zero_extendv8hiv8si2_mask */
    6914       196112 :     case 8880:  /* avx2_sign_extendv8hiv8si2_mask */
    6915       196112 :     case 8874:  /* avx512f_zero_extendv16hiv16si2_mask */
    6916       196112 :     case 8872:  /* avx512f_sign_extendv16hiv16si2_mask */
    6917       196112 :     case 8864:  /* *sse4_1_zero_extendv4qiv4si2_mask_1 */
    6918       196112 :     case 8862:  /* *sse4_1_sign_extendv4qiv4si2_mask_1 */
    6919       196112 :     case 8852:  /* *avx2_zero_extendv8qiv8si2_mask_1 */
    6920       196112 :     case 8850:  /* *avx2_sign_extendv8qiv8si2_mask_1 */
    6921       196112 :     case 8844:  /* avx512f_zero_extendv16qiv16si2_mask */
    6922       196112 :     case 8842:  /* avx512f_sign_extendv16qiv16si2_mask */
    6923       196112 :     case 8832:  /* *sse4_1_zero_extendv8qiv8hi2_mask_1 */
    6924       196112 :     case 8830:  /* *sse4_1_sign_extendv8qiv8hi2_mask_1 */
    6925       196112 :     case 8820:  /* avx512bw_zero_extendv32qiv32hi2_mask */
    6926       196112 :     case 8818:  /* avx512bw_sign_extendv32qiv32hi2_mask */
    6927       196112 :     case 8812:  /* avx2_zero_extendv16qiv16hi2_mask */
    6928       196112 :     case 8810:  /* avx2_sign_extendv16qiv16hi2_mask */
    6929       196112 :     case 8726:  /* absv8hi2_mask */
    6930       196112 :     case 8725:  /* absv16hi2_mask */
    6931       196112 :     case 8724:  /* absv32hi2_mask */
    6932       196112 :     case 8723:  /* absv32qi2_mask */
    6933       196112 :     case 8722:  /* absv16qi2_mask */
    6934       196112 :     case 8721:  /* absv64qi2_mask */
    6935       196112 :     case 8720:  /* absv2di2_mask */
    6936       196112 :     case 8719:  /* absv4di2_mask */
    6937       196112 :     case 8718:  /* absv8di2_mask */
    6938       196112 :     case 8717:  /* absv4si2_mask */
    6939       196112 :     case 8716:  /* absv8si2_mask */
    6940       196112 :     case 8715:  /* absv16si2_mask */
    6941       196112 :     case 8444:  /* *avx512f_vinserti32x4_0 */
    6942       196112 :     case 8443:  /* *avx512f_vinsertf32x4_0 */
    6943       196112 :     case 8442:  /* *avx512dq_vinserti64x2_0 */
    6944       196112 :     case 8441:  /* *avx512dq_vinsertf64x2_0 */
    6945       196112 :     case 7302:  /* avx512vl_us_truncatev16hiv16qi2_mask */
    6946       196112 :     case 7301:  /* avx512vl_truncatev16hiv16qi2_mask */
    6947       196112 :     case 7300:  /* avx512vl_ss_truncatev16hiv16qi2_mask */
    6948       196112 :     case 7299:  /* avx512vl_us_truncatev8siv8hi2_mask */
    6949       196112 :     case 7298:  /* avx512vl_truncatev8siv8hi2_mask */
    6950       196112 :     case 7297:  /* avx512vl_ss_truncatev8siv8hi2_mask */
    6951       196112 :     case 7296:  /* avx512vl_us_truncatev4div4si2_mask */
    6952       196112 :     case 7295:  /* avx512vl_truncatev4div4si2_mask */
    6953       196112 :     case 7294:  /* avx512vl_ss_truncatev4div4si2_mask */
    6954       196112 :     case 7282:  /* avx512bw_us_truncatev32hiv32qi2_mask */
    6955       196112 :     case 7281:  /* avx512bw_truncatev32hiv32qi2_mask */
    6956       196112 :     case 7280:  /* avx512bw_ss_truncatev32hiv32qi2_mask */
    6957       196112 :     case 7275:  /* avx512f_us_truncatev8div8hi2_mask */
    6958       196112 :     case 7274:  /* avx512f_truncatev8div8hi2_mask */
    6959       196112 :     case 7273:  /* avx512f_ss_truncatev8div8hi2_mask */
    6960       196112 :     case 7272:  /* avx512f_us_truncatev8div8si2_mask */
    6961       196112 :     case 7271:  /* avx512f_truncatev8div8si2_mask */
    6962       196112 :     case 7270:  /* avx512f_ss_truncatev8div8si2_mask */
    6963       196112 :     case 7269:  /* avx512f_us_truncatev16siv16hi2_mask */
    6964       196112 :     case 7268:  /* avx512f_truncatev16siv16hi2_mask */
    6965       196112 :     case 7267:  /* avx512f_ss_truncatev16siv16hi2_mask */
    6966       196112 :     case 7266:  /* avx512f_us_truncatev16siv16qi2_mask */
    6967       196112 :     case 7265:  /* avx512f_truncatev16siv16qi2_mask */
    6968       196112 :     case 7264:  /* avx512f_ss_truncatev16siv16qi2_mask */
    6969       196112 :     case 7243:  /* vec_dupv2df_mask */
    6970       196112 :     case 5374:  /* vec_extract_hi_v8sf_mask */
    6971       196112 :     case 5373:  /* vec_extract_hi_v8si_mask */
    6972       196112 :     case 5370:  /* vec_extract_lo_v8sf_mask */
    6973       196112 :     case 5369:  /* vec_extract_lo_v8si_mask */
    6974       196112 :     case 5366:  /* vec_extract_hi_v4df_mask */
    6975       196112 :     case 5365:  /* vec_extract_hi_v4di_mask */
    6976       196112 :     case 5362:  /* vec_extract_lo_v4df_mask */
    6977       196112 :     case 5361:  /* vec_extract_lo_v4di_mask */
    6978       196112 :     case 5358:  /* vec_extract_lo_v16si_mask */
    6979       196112 :     case 5357:  /* vec_extract_lo_v16sf_mask */
    6980       196112 :     case 5354:  /* vec_extract_hi_v16si_mask */
    6981       196112 :     case 5353:  /* vec_extract_hi_v16sf_mask */
    6982       196112 :     case 5350:  /* vec_extract_hi_v8di_mask */
    6983       196112 :     case 5349:  /* vec_extract_hi_v8df_mask */
    6984       196112 :     case 5346:  /* vec_extract_lo_v8di_mask */
    6985       196112 :     case 5345:  /* vec_extract_lo_v8df_mask */
    6986       196112 :     case 5241:  /* sse2_cvtps2pd_mask_1 */
    6987       196112 :     case 5193:  /* avx_cvtps2pd256_mask */
    6988       196112 :     case 5190:  /* avx512f_cvtps2pd512_mask */
    6989       196112 :     case 5183:  /* avx_cvtpd2ps256_mask */
    6990       196112 :     case 5180:  /* avx512f_cvtpd2ps512_mask */
    6991       196112 :     case 5162:  /* fixuns_truncv4sfv4si2_mask */
    6992       196112 :     case 5160:  /* fixuns_truncv8sfv8si2_mask */
    6993       196112 :     case 5146:  /* fixuns_truncv4sfv4di2_mask */
    6994       196112 :     case 5144:  /* fix_truncv4sfv4di2_mask */
    6995       196112 :     case 5141:  /* fixuns_truncv8sfv8di2_mask */
    6996       196112 :     case 5137:  /* fix_truncv8sfv8di2_mask */
    6997       196112 :     case 5106:  /* fixuns_truncv2dfv2di2_mask */
    6998       196112 :     case 5104:  /* fix_truncv2dfv2di2_mask */
    6999       196112 :     case 5102:  /* fixuns_truncv4dfv4di2_mask */
    7000       196112 :     case 5100:  /* fix_truncv4dfv4di2_mask */
    7001       196112 :     case 5097:  /* fixuns_truncv8dfv8di2_mask */
    7002       196112 :     case 5093:  /* fix_truncv8dfv8di2_mask */
    7003       196112 :     case 5074:  /* fixuns_truncv4dfv4si2_mask */
    7004       196112 :     case 5070:  /* fix_truncv4dfv4si2_mask */
    7005       196112 :     case 5060:  /* fixuns_truncv8dfv8si2_mask */
    7006       196112 :     case 5056:  /* fix_truncv8dfv8si2_mask */
    7007       196112 :     case 5018:  /* floatunsv4siv4df2_mask */
    7008       196112 :     case 5016:  /* floatunsv8siv8df2_mask */
    7009       196112 :     case 5008:  /* floatunsv4div4sf2_mask */
    7010       196112 :     case 5006:  /* floatv4div4sf2_mask */
    7011       196112 :     case 5003:  /* floatunsv8div8sf2_mask */
    7012       196112 :     case 4999:  /* floatv8div8sf2_mask */
    7013       196112 :     case 4995:  /* floatunsv2div2df2_mask */
    7014       196112 :     case 4991:  /* floatv2div2df2_mask */
    7015       196112 :     case 4987:  /* floatunsv4div4df2_mask */
    7016       196112 :     case 4983:  /* floatv4div4df2_mask */
    7017       196112 :     case 4979:  /* floatunsv8div8df2_mask */
    7018       196112 :     case 4975:  /* floatv8div8df2_mask */
    7019       196112 :     case 4972:  /* floatv4siv4df2_mask */
    7020       196112 :     case 4970:  /* floatv8siv8df2_mask */
    7021       196112 :     case 4920:  /* fix_truncv4sfv4si2_mask */
    7022       196112 :     case 4916:  /* fix_truncv8sfv8si2_mask */
    7023       196112 :     case 4911:  /* fixuns_truncv16sfv16si2_mask */
    7024       196112 :     case 4907:  /* fix_truncv16sfv16si2_mask */
    7025       196112 :     case 4859:  /* floatunsv4siv4sf2_mask */
    7026       196112 :     case 4855:  /* floatunsv8siv8sf2_mask */
    7027       196112 :     case 4851:  /* floatunsv16siv16sf2_mask */
    7028       196112 :     case 4848:  /* floatv4siv4sf2_mask */
    7029       196112 :     case 4846:  /* floatv8siv8sf2_mask */
    7030       196112 :     case 4843:  /* floatv16siv16sf2_mask */
    7031       196112 :     case 4777:  /* avx512fp16_vcvtps2ph_v8sf_mask */
    7032       196112 :     case 4773:  /* avx512fp16_vcvtps2ph_v16sf_mask */
    7033       196112 :     case 4769:  /* avx512fp16_vcvtpd2ph_v8df_mask */
    7034       196112 :     case 4766:  /* *avx512fp16_float_extend_phv2df2_load_mask */
    7035       196112 :     case 4762:  /* *avx512fp16_float_extend_phv4sf2_load_mask */
    7036       196112 :     case 4760:  /* *avx512fp16_float_extend_phv4df2_load_mask */
    7037       196112 :     case 4753:  /* avx512fp16_float_extend_phv8sf2_mask */
    7038       196112 :     case 4749:  /* avx512fp16_float_extend_phv16sf2_mask */
    7039       196112 :     case 4745:  /* avx512fp16_float_extend_phv8df2_mask */
    7040       196112 :     case 4722:  /* *avx512fp16_fixuns_truncv2di2_load_mask */
    7041       196112 :     case 4720:  /* *avx512fp16_fix_truncv2di2_load_mask */
    7042       196112 :     case 4710:  /* *avx512fp16_fixuns_truncv4di2_load_mask */
    7043       196112 :     case 4708:  /* *avx512fp16_fix_truncv4di2_load_mask */
    7044       196112 :     case 4706:  /* *avx512fp16_fixuns_truncv4si2_load_mask */
    7045       196112 :     case 4704:  /* *avx512fp16_fix_truncv4si2_load_mask */
    7046       196112 :     case 4685:  /* avx512fp16_fixuns_truncv8di2_mask */
    7047       196112 :     case 4681:  /* avx512fp16_fix_truncv8di2_mask */
    7048       196112 :     case 4677:  /* avx512fp16_fixuns_truncv16si2_mask */
    7049       196112 :     case 4673:  /* avx512fp16_fix_truncv16si2_mask */
    7050       196112 :     case 4669:  /* avx512fp16_fixuns_truncv8si2_mask */
    7051       196112 :     case 4665:  /* avx512fp16_fix_truncv8si2_mask */
    7052       196112 :     case 4661:  /* avx512fp16_fixuns_truncv32hi2_mask */
    7053       196112 :     case 4657:  /* avx512fp16_fix_truncv32hi2_mask */
    7054       196112 :     case 4653:  /* avx512fp16_fixuns_truncv16hi2_mask */
    7055       196112 :     case 4649:  /* avx512fp16_fix_truncv16hi2_mask */
    7056       196112 :     case 4645:  /* avx512fp16_fixuns_truncv8hi2_mask */
    7057       196112 :     case 4641:  /* avx512fp16_fix_truncv8hi2_mask */
    7058       196112 :     case 4551:  /* avx512fp16_vcvtuqq2ph_v8di_mask */
    7059       196112 :     case 4547:  /* avx512fp16_vcvtqq2ph_v8di_mask */
    7060       196112 :     case 4543:  /* avx512fp16_vcvtudq2ph_v16si_mask */
    7061       196112 :     case 4539:  /* avx512fp16_vcvtdq2ph_v16si_mask */
    7062       196112 :     case 4535:  /* avx512fp16_vcvtudq2ph_v8si_mask */
    7063       196112 :     case 4531:  /* avx512fp16_vcvtdq2ph_v8si_mask */
    7064       196112 :     case 4527:  /* avx512fp16_vcvtuw2ph_v32hi_mask */
    7065       196112 :     case 4523:  /* avx512fp16_vcvtw2ph_v32hi_mask */
    7066       196112 :     case 4519:  /* avx512fp16_vcvtuw2ph_v16hi_mask */
    7067       196112 :     case 4515:  /* avx512fp16_vcvtw2ph_v16hi_mask */
    7068       196112 :     case 4511:  /* avx512fp16_vcvtuw2ph_v8hi_mask */
    7069       196112 :     case 4507:  /* avx512fp16_vcvtw2ph_v8hi_mask */
    7070       196112 :     case 4014:  /* *fma_fnmadd_v2df */
    7071       196112 :     case 4012:  /* *fma_fnmadd_v4df */
    7072       196112 :     case 4008:  /* *fma_fnmadd_v8df */
    7073       196112 :     case 4007:  /* *fma_fnmadd_df */
    7074       196112 :     case 4005:  /* *fma_fnmadd_v4sf */
    7075       196112 :     case 4003:  /* *fma_fnmadd_v8sf */
    7076       196112 :     case 3999:  /* *fma_fnmadd_v16sf */
    7077       196112 :     case 3998:  /* *fma_fnmadd_sf */
    7078       196112 :     case 3997:  /* *fma_fnmadd_hf */
    7079       196112 :     case 3995:  /* *fma_fnmadd_v8hf */
    7080       196112 :     case 3993:  /* *fma_fnmadd_v16hf */
    7081       196112 :     case 3989:  /* *fma_fnmadd_v32hf */
    7082       196112 :     case 3988:  /* *fma_fnmadd_v4df */
    7083       196112 :     case 3987:  /* *fma_fnmadd_v8sf */
    7084       196112 :     case 3986:  /* *fma_fnmadd_v2df */
    7085       196112 :     case 3985:  /* *fma_fnmadd_v4sf */
    7086       196112 :     case 3984:  /* *fma_fnmadd_df */
    7087       196112 :     case 3983:  /* *fma_fnmadd_sf */
    7088       196112 :     case 2981:  /* sse2_sqrtv2df2_mask */
    7089       196112 :     case 2979:  /* avx_sqrtv4df2_mask */
    7090       196112 :     case 2976:  /* avx512f_sqrtv8df2_mask */
    7091       196112 :     case 2973:  /* sse_sqrtv4sf2_mask */
    7092       196112 :     case 2971:  /* avx_sqrtv8sf2_mask */
    7093       196112 :     case 2968:  /* avx512f_sqrtv16sf2_mask */
    7094       196112 :     case 2965:  /* avx512fp16_sqrtv8hf2_mask */
    7095       196112 :     case 2963:  /* avx512fp16_sqrtv16hf2_mask */
    7096       196112 :     case 2960:  /* avx512fp16_sqrtv32hf2_mask */
    7097       196112 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7098       196112 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    7099       196112 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    7100       196112 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    7101       196112 :       break;
    7102              : 
    7103         4149 :     case 5189:  /* avx512f_cvtps2pd512_round */
    7104         4149 :     case 5179:  /* *avx512f_cvtpd2ps512_round */
    7105         4149 :     case 5140:  /* fixuns_truncv8sfv8di2_round */
    7106         4149 :     case 5136:  /* fix_truncv8sfv8di2_round */
    7107         4149 :     case 5096:  /* fixuns_truncv8dfv8di2_round */
    7108         4149 :     case 5092:  /* fix_truncv8dfv8di2_round */
    7109         4149 :     case 5059:  /* fixuns_truncv8dfv8si2_round */
    7110         4149 :     case 5055:  /* fix_truncv8dfv8si2_round */
    7111         4149 :     case 5002:  /* floatunsv8div8sf2_round */
    7112         4149 :     case 4998:  /* floatv8div8sf2_round */
    7113         4149 :     case 4994:  /* floatunsv2div2df2_round */
    7114         4149 :     case 4990:  /* floatv2div2df2_round */
    7115         4149 :     case 4986:  /* floatunsv4div4df2_round */
    7116         4149 :     case 4982:  /* floatv4div4df2_round */
    7117         4149 :     case 4978:  /* floatunsv8div8df2_round */
    7118         4149 :     case 4974:  /* floatv8div8df2_round */
    7119         4149 :     case 4910:  /* fixuns_truncv16sfv16si2_round */
    7120         4149 :     case 4906:  /* fix_truncv16sfv16si2_round */
    7121         4149 :     case 4858:  /* *floatunsv4siv4sf2_round */
    7122         4149 :     case 4854:  /* *floatunsv8siv8sf2_round */
    7123         4149 :     case 4850:  /* *floatunsv16siv16sf2_round */
    7124         4149 :     case 4842:  /* floatv16siv16sf2_round */
    7125         4149 :     case 4776:  /* avx512fp16_vcvtps2ph_v8sf_round */
    7126         4149 :     case 4772:  /* avx512fp16_vcvtps2ph_v16sf_round */
    7127         4149 :     case 4768:  /* avx512fp16_vcvtpd2ph_v8df_round */
    7128         4149 :     case 4752:  /* avx512fp16_float_extend_phv8sf2_round */
    7129         4149 :     case 4748:  /* avx512fp16_float_extend_phv16sf2_round */
    7130         4149 :     case 4744:  /* avx512fp16_float_extend_phv8df2_round */
    7131         4149 :     case 4684:  /* avx512fp16_fixuns_truncv8di2_round */
    7132         4149 :     case 4680:  /* avx512fp16_fix_truncv8di2_round */
    7133         4149 :     case 4676:  /* avx512fp16_fixuns_truncv16si2_round */
    7134         4149 :     case 4672:  /* avx512fp16_fix_truncv16si2_round */
    7135         4149 :     case 4668:  /* avx512fp16_fixuns_truncv8si2_round */
    7136         4149 :     case 4664:  /* avx512fp16_fix_truncv8si2_round */
    7137         4149 :     case 4660:  /* avx512fp16_fixuns_truncv32hi2_round */
    7138         4149 :     case 4656:  /* avx512fp16_fix_truncv32hi2_round */
    7139         4149 :     case 4652:  /* avx512fp16_fixuns_truncv16hi2_round */
    7140         4149 :     case 4648:  /* avx512fp16_fix_truncv16hi2_round */
    7141         4149 :     case 4644:  /* avx512fp16_fixuns_truncv8hi2_round */
    7142         4149 :     case 4640:  /* avx512fp16_fix_truncv8hi2_round */
    7143         4149 :     case 4550:  /* avx512fp16_vcvtuqq2ph_v8di_round */
    7144         4149 :     case 4546:  /* avx512fp16_vcvtqq2ph_v8di_round */
    7145         4149 :     case 4542:  /* avx512fp16_vcvtudq2ph_v16si_round */
    7146         4149 :     case 4538:  /* avx512fp16_vcvtdq2ph_v16si_round */
    7147         4149 :     case 4534:  /* avx512fp16_vcvtudq2ph_v8si_round */
    7148         4149 :     case 4530:  /* avx512fp16_vcvtdq2ph_v8si_round */
    7149         4149 :     case 4526:  /* avx512fp16_vcvtuw2ph_v32hi_round */
    7150         4149 :     case 4522:  /* avx512fp16_vcvtw2ph_v32hi_round */
    7151         4149 :     case 4518:  /* avx512fp16_vcvtuw2ph_v16hi_round */
    7152         4149 :     case 4514:  /* avx512fp16_vcvtw2ph_v16hi_round */
    7153         4149 :     case 4510:  /* avx512fp16_vcvtuw2ph_v8hi_round */
    7154         4149 :     case 4506:  /* avx512fp16_vcvtw2ph_v8hi_round */
    7155         4149 :     case 2975:  /* avx512f_sqrtv8df2_round */
    7156         4149 :     case 2967:  /* avx512f_sqrtv16sf2_round */
    7157         4149 :     case 2959:  /* avx512fp16_sqrtv32hf2_round */
    7158         4149 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7159         4149 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
    7160         4149 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    7161         4149 :       break;
    7162              : 
    7163         2977 :     case 3033:  /* avx512fp16_vmrsqrtv8hf2_mask */
    7164         2977 :     case 3029:  /* rsqrt14_v2df_mask */
    7165         2977 :     case 3028:  /* rsqrt14_v4sf_mask */
    7166         2977 :     case 2957:  /* srcp14v2df_mask */
    7167         2977 :     case 2956:  /* srcp14v4sf_mask */
    7168         2977 :     case 2940:  /* avx512fp16_vmrcpv8hf2_mask */
    7169         2977 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7170         2977 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    7171         2977 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    7172         2977 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    7173         2977 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    7174         2977 :       break;
    7175              : 
    7176          460 :     case 3034:  /* *avx512fp16_vmrsqrtv8hf2 */
    7177          460 :     case 3031:  /* *sse_vmrsqrtv4sf2 */
    7178          460 :     case 2941:  /* *avx512fp16_vmrcpv8hf2 */
    7179          460 :     case 2932:  /* *sse_vmrcpv4sf2 */
    7180          460 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7181          460 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0, 0));
    7182          460 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    7183          460 :       break;
    7184              : 
    7185         2538 :     case 10581:  /* *vcvtph2hf8sv8hf */
    7186         2538 :     case 10580:  /* *vcvtph2hf8v8hf */
    7187         2538 :     case 10579:  /* *vcvtph2bf8sv8hf */
    7188         2538 :     case 10578:  /* *vcvtph2bf8v8hf */
    7189         2538 :     case 9126:  /* *xop_vmfrczv2df2 */
    7190         2538 :     case 9125:  /* *xop_vmfrczv4sf2 */
    7191         2538 :     case 5031:  /* *avx_cvtpd2dq256_2 */
    7192         2538 :     case 3032:  /* avx512fp16_vmrsqrtv8hf2 */
    7193         2538 :     case 3030:  /* sse_vmrsqrtv4sf2 */
    7194         2538 :     case 3027:  /* rsqrt14v2df */
    7195         2538 :     case 3026:  /* rsqrt14v4sf */
    7196         2538 :     case 2955:  /* srcp14v2df */
    7197         2538 :     case 2954:  /* srcp14v4sf */
    7198         2538 :     case 2939:  /* avx512fp16_vmrcpv8hf2 */
    7199         2538 :     case 2931:  /* sse_vmrcpv4sf2 */
    7200         2538 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7201         2538 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    7202         2538 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    7203         2538 :       break;
    7204              : 
    7205         8580 :     case 3182:  /* *sse2_vmsminv2df3_mask_round */
    7206         8580 :     case 3178:  /* *sse2_vmsmaxv2df3_mask_round */
    7207         8580 :     case 3174:  /* *sse_vmsminv4sf3_mask_round */
    7208         8580 :     case 3170:  /* *sse_vmsmaxv4sf3_mask_round */
    7209         8580 :     case 3166:  /* *avx512fp16_vmsminv8hf3_mask_round */
    7210         8580 :     case 3162:  /* *avx512fp16_vmsmaxv8hf3_mask_round */
    7211         8580 :     case 2904:  /* sse2_vmdivv2df3_mask_round */
    7212         8580 :     case 2900:  /* sse2_vmmulv2df3_mask_round */
    7213         8580 :     case 2896:  /* sse_vmdivv4sf3_mask_round */
    7214         8580 :     case 2892:  /* sse_vmmulv4sf3_mask_round */
    7215         8580 :     case 2888:  /* avx512fp16_vmdivv8hf3_mask_round */
    7216         8580 :     case 2884:  /* avx512fp16_vmmulv8hf3_mask_round */
    7217         8580 :     case 2838:  /* sse2_vmsubv2df3_mask_round */
    7218         8580 :     case 2834:  /* sse2_vmaddv2df3_mask_round */
    7219         8580 :     case 2830:  /* sse_vmsubv4sf3_mask_round */
    7220         8580 :     case 2826:  /* sse_vmaddv4sf3_mask_round */
    7221         8580 :     case 2822:  /* avx512fp16_vmsubv8hf3_mask_round */
    7222         8580 :     case 2818:  /* avx512fp16_vmaddv8hf3_mask_round */
    7223         8580 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7224         8580 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 0));
    7225         8580 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0), 1));
    7226         8580 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    7227         8580 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 2));
    7228         8580 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    7229         8580 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    7230         8580 :       recog_data.dup_num[0] = 1;
    7231         8580 :       break;
    7232              : 
    7233         3239 :     case 3180:  /* *sse2_vmsminv2df3_mask */
    7234         3239 :     case 3176:  /* *sse2_vmsmaxv2df3_mask */
    7235         3239 :     case 3172:  /* *sse_vmsminv4sf3_mask */
    7236         3239 :     case 3168:  /* *sse_vmsmaxv4sf3_mask */
    7237         3239 :     case 3164:  /* *avx512fp16_vmsminv8hf3_mask */
    7238         3239 :     case 3160:  /* *avx512fp16_vmsmaxv8hf3_mask */
    7239         3239 :     case 2903:  /* sse2_vmdivv2df3_mask */
    7240         3239 :     case 2899:  /* sse2_vmmulv2df3_mask */
    7241         3239 :     case 2895:  /* sse_vmdivv4sf3_mask */
    7242         3239 :     case 2891:  /* sse_vmmulv4sf3_mask */
    7243         3239 :     case 2887:  /* avx512fp16_vmdivv8hf3_mask */
    7244         3239 :     case 2883:  /* avx512fp16_vmmulv8hf3_mask */
    7245         3239 :     case 2837:  /* sse2_vmsubv2df3_mask */
    7246         3239 :     case 2833:  /* sse2_vmaddv2df3_mask */
    7247         3239 :     case 2829:  /* sse_vmsubv4sf3_mask */
    7248         3239 :     case 2825:  /* sse_vmaddv4sf3_mask */
    7249         3239 :     case 2821:  /* avx512fp16_vmsubv8hf3_mask */
    7250         3239 :     case 2817:  /* avx512fp16_vmaddv8hf3_mask */
    7251         3239 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7252         3239 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    7253         3239 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    7254         3239 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    7255         3239 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    7256         3239 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    7257         3239 :       recog_data.dup_num[0] = 1;
    7258         3239 :       break;
    7259              : 
    7260         4865 :     case 3181:  /* *sse2_vmsminv2df3_round */
    7261         4865 :     case 3177:  /* *sse2_vmsmaxv2df3_round */
    7262         4865 :     case 3173:  /* *sse_vmsminv4sf3_round */
    7263         4865 :     case 3169:  /* *sse_vmsmaxv4sf3_round */
    7264         4865 :     case 3165:  /* *avx512fp16_vmsminv8hf3_round */
    7265         4865 :     case 3161:  /* *avx512fp16_vmsmaxv8hf3_round */
    7266         4865 :     case 2902:  /* sse2_vmdivv2df3_round */
    7267         4865 :     case 2898:  /* sse2_vmmulv2df3_round */
    7268         4865 :     case 2894:  /* sse_vmdivv4sf3_round */
    7269         4865 :     case 2890:  /* sse_vmmulv4sf3_round */
    7270         4865 :     case 2886:  /* avx512fp16_vmdivv8hf3_round */
    7271         4865 :     case 2882:  /* avx512fp16_vmmulv8hf3_round */
    7272         4865 :     case 2836:  /* sse2_vmsubv2df3_round */
    7273         4865 :     case 2832:  /* sse2_vmaddv2df3_round */
    7274         4865 :     case 2828:  /* sse_vmsubv4sf3_round */
    7275         4865 :     case 2824:  /* sse_vmaddv4sf3_round */
    7276         4865 :     case 2820:  /* avx512fp16_vmsubv8hf3_round */
    7277         4865 :     case 2816:  /* avx512fp16_vmaddv8hf3_round */
    7278         4865 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7279         4865 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    7280         4865 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    7281         4865 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 1));
    7282         4865 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    7283         4865 :       recog_data.dup_num[0] = 1;
    7284         4865 :       break;
    7285              : 
    7286         1719 :     case 3179:  /* *sse2_vmsminv2df3 */
    7287         1719 :     case 3175:  /* *sse2_vmsmaxv2df3 */
    7288         1719 :     case 3171:  /* *sse_vmsminv4sf3 */
    7289         1719 :     case 3167:  /* *sse_vmsmaxv4sf3 */
    7290         1719 :     case 3163:  /* *avx512fp16_vmsminv8hf3 */
    7291         1719 :     case 3159:  /* *avx512fp16_vmsmaxv8hf3 */
    7292         1719 :     case 2901:  /* sse2_vmdivv2df3 */
    7293         1719 :     case 2897:  /* sse2_vmmulv2df3 */
    7294         1719 :     case 2893:  /* sse_vmdivv4sf3 */
    7295         1719 :     case 2889:  /* sse_vmmulv4sf3 */
    7296         1719 :     case 2885:  /* avx512fp16_vmdivv8hf3 */
    7297         1719 :     case 2881:  /* avx512fp16_vmmulv8hf3 */
    7298         1719 :     case 2835:  /* sse2_vmsubv2df3 */
    7299         1719 :     case 2831:  /* sse2_vmaddv2df3 */
    7300         1719 :     case 2827:  /* sse_vmsubv4sf3 */
    7301         1719 :     case 2823:  /* sse_vmaddv4sf3 */
    7302         1719 :     case 2819:  /* avx512fp16_vmsubv8hf3 */
    7303         1719 :     case 2815:  /* avx512fp16_vmaddv8hf3 */
    7304         1719 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7305         1719 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    7306         1719 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    7307         1719 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    7308         1719 :       recog_data.dup_num[0] = 1;
    7309         1719 :       break;
    7310              : 
    7311          855 :     case 2880:  /* *sse2_vmdivv2df3 */
    7312          855 :     case 2879:  /* *sse2_vmmulv2df3 */
    7313          855 :     case 2878:  /* *sse_vmdivv4sf3 */
    7314          855 :     case 2877:  /* *sse_vmmulv4sf3 */
    7315          855 :     case 2876:  /* *avx512fp16_vmdivv8hf3 */
    7316          855 :     case 2875:  /* *avx512fp16_vmmulv8hf3 */
    7317          855 :     case 2814:  /* *sse2_vmsubv2df3 */
    7318          855 :     case 2813:  /* *sse2_vmaddv2df3 */
    7319          855 :     case 2812:  /* *sse_vmsubv4sf3 */
    7320          855 :     case 2811:  /* *sse_vmaddv4sf3 */
    7321          855 :     case 2810:  /* *avx512fp16_vmsubv8hf3 */
    7322          855 :     case 2809:  /* *avx512fp16_vmaddv8hf3 */
    7323          855 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7324          855 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    7325          855 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
    7326          855 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    7327          855 :       recog_data.dup_num[0] = 1;
    7328          855 :       break;
    7329              : 
    7330         8912 :     case 3075:  /* *sminv8df3_mask_round */
    7331         8912 :     case 3071:  /* *smaxv8df3_mask_round */
    7332         8912 :     case 3059:  /* *sminv16sf3_mask_round */
    7333         8912 :     case 3055:  /* *smaxv16sf3_mask_round */
    7334         8912 :     case 3043:  /* *sminv32hf3_mask_round */
    7335         8912 :     case 3039:  /* *smaxv32hf3_mask_round */
    7336         8912 :     case 2924:  /* avx512f_divv8df3_mask_round */
    7337         8912 :     case 2916:  /* avx512f_divv16sf3_mask_round */
    7338         8912 :     case 2908:  /* avx512fp16_divv32hf3_mask_round */
    7339         8912 :     case 2874:  /* *mulv2df3_mask_round */
    7340         8912 :     case 2870:  /* *mulv4df3_mask_round */
    7341         8912 :     case 2866:  /* *mulv8df3_mask_round */
    7342         8912 :     case 2862:  /* *mulv4sf3_mask_round */
    7343         8912 :     case 2858:  /* *mulv8sf3_mask_round */
    7344         8912 :     case 2854:  /* *mulv16sf3_mask_round */
    7345         8912 :     case 2850:  /* *mulv8hf3_mask_round */
    7346         8912 :     case 2846:  /* *mulv16hf3_mask_round */
    7347         8912 :     case 2842:  /* *mulv32hf3_mask_round */
    7348         8912 :     case 2808:  /* *subv2df3_mask_round */
    7349         8912 :     case 2804:  /* *addv2df3_mask_round */
    7350         8912 :     case 2800:  /* *subv4df3_mask_round */
    7351         8912 :     case 2796:  /* *addv4df3_mask_round */
    7352         8912 :     case 2792:  /* *subv8df3_mask_round */
    7353         8912 :     case 2788:  /* *addv8df3_mask_round */
    7354         8912 :     case 2784:  /* *subv4sf3_mask_round */
    7355         8912 :     case 2780:  /* *addv4sf3_mask_round */
    7356         8912 :     case 2776:  /* *subv8sf3_mask_round */
    7357         8912 :     case 2772:  /* *addv8sf3_mask_round */
    7358         8912 :     case 2768:  /* *subv16sf3_mask_round */
    7359         8912 :     case 2764:  /* *addv16sf3_mask_round */
    7360         8912 :     case 2760:  /* *subv8hf3_mask_round */
    7361         8912 :     case 2756:  /* *addv8hf3_mask_round */
    7362         8912 :     case 2752:  /* *subv16hf3_mask_round */
    7363         8912 :     case 2748:  /* *addv16hf3_mask_round */
    7364         8912 :     case 2744:  /* *subv32hf3_mask_round */
    7365         8912 :     case 2740:  /* *addv32hf3_mask_round */
    7366         8912 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7367         8912 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    7368         8912 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    7369         8912 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    7370         8912 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 2));
    7371         8912 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (pat, 1), 0, 1));
    7372         8912 :       break;
    7373              : 
    7374       210080 :     case 10712:  /* avx10_2_divbf16_v8bf_mask */
    7375       210080 :     case 10710:  /* avx10_2_mulbf16_v8bf_mask */
    7376       210080 :     case 10708:  /* avx10_2_subbf16_v8bf_mask */
    7377       210080 :     case 10706:  /* avx10_2_addbf16_v8bf_mask */
    7378       210080 :     case 10704:  /* avx10_2_divbf16_v16bf_mask */
    7379       210080 :     case 10702:  /* avx10_2_mulbf16_v16bf_mask */
    7380       210080 :     case 10700:  /* avx10_2_subbf16_v16bf_mask */
    7381       210080 :     case 10698:  /* avx10_2_addbf16_v16bf_mask */
    7382       210080 :     case 10696:  /* avx10_2_divbf16_v32bf_mask */
    7383       210080 :     case 10694:  /* avx10_2_mulbf16_v32bf_mask */
    7384       210080 :     case 10692:  /* avx10_2_subbf16_v32bf_mask */
    7385       210080 :     case 10690:  /* avx10_2_addbf16_v32bf_mask */
    7386       210080 :     case 10688:  /* avx10_2_sminbf16_v8bf_mask */
    7387       210080 :     case 10686:  /* avx10_2_smaxbf16_v8bf_mask */
    7388       210080 :     case 10684:  /* avx10_2_sminbf16_v16bf_mask */
    7389       210080 :     case 10682:  /* avx10_2_smaxbf16_v16bf_mask */
    7390       210080 :     case 10680:  /* avx10_2_sminbf16_v32bf_mask */
    7391       210080 :     case 10678:  /* avx10_2_smaxbf16_v32bf_mask */
    7392       210080 :     case 9691:  /* avx512bw_lshrvv32hi_mask */
    7393       210080 :     case 9689:  /* avx512bw_ashlvv32hi_mask */
    7394       210080 :     case 9687:  /* avx512vl_lshrvv16hi_mask */
    7395       210080 :     case 9685:  /* avx512vl_ashlvv16hi_mask */
    7396       210080 :     case 9683:  /* avx512vl_lshrvv8hi_mask */
    7397       210080 :     case 9681:  /* avx512vl_ashlvv8hi_mask */
    7398       210080 :     case 9679:  /* avx2_lshrvv2di_mask */
    7399       210080 :     case 9677:  /* avx2_ashlvv2di_mask */
    7400       210080 :     case 9675:  /* avx2_lshrvv4di_mask */
    7401       210080 :     case 9673:  /* avx2_ashlvv4di_mask */
    7402       210080 :     case 9671:  /* avx512f_lshrvv8di_mask */
    7403       210080 :     case 9669:  /* avx512f_ashlvv8di_mask */
    7404       210080 :     case 9667:  /* avx2_lshrvv4si_mask */
    7405       210080 :     case 9665:  /* avx2_ashlvv4si_mask */
    7406       210080 :     case 9663:  /* avx2_lshrvv8si_mask */
    7407       210080 :     case 9661:  /* avx2_ashlvv8si_mask */
    7408       210080 :     case 9659:  /* avx512f_lshrvv16si_mask */
    7409       210080 :     case 9657:  /* avx512f_ashlvv16si_mask */
    7410       210080 :     case 9655:  /* avx512bw_ashrvv32hi_mask */
    7411       210080 :     case 9653:  /* avx512vl_ashrvv16hi_mask */
    7412       210080 :     case 9651:  /* avx512vl_ashrvv8hi_mask */
    7413       210080 :     case 9649:  /* avx512f_ashrvv8di_mask */
    7414       210080 :     case 9647:  /* avx2_ashrvv4di_mask */
    7415       210080 :     case 9645:  /* avx2_ashrvv2di_mask */
    7416       210080 :     case 9643:  /* avx512f_ashrvv16si_mask */
    7417       210080 :     case 9641:  /* avx2_ashrvv8si_mask */
    7418       210080 :     case 9639:  /* avx2_ashrvv4si_mask */
    7419       210080 :     case 8095:  /* *xorv2di3_mask */
    7420       210080 :     case 8093:  /* *iorv2di3_mask */
    7421       210080 :     case 8091:  /* *andv2di3_mask */
    7422       210080 :     case 8089:  /* *xorv4di3_mask */
    7423       210080 :     case 8087:  /* *iorv4di3_mask */
    7424       210080 :     case 8085:  /* *andv4di3_mask */
    7425       210080 :     case 8083:  /* *xorv8di3_mask */
    7426       210080 :     case 8081:  /* *iorv8di3_mask */
    7427       210080 :     case 8079:  /* *andv8di3_mask */
    7428       210080 :     case 8077:  /* *xorv4si3_mask */
    7429       210080 :     case 8075:  /* *iorv4si3_mask */
    7430       210080 :     case 8073:  /* *andv4si3_mask */
    7431       210080 :     case 8071:  /* *xorv8si3_mask */
    7432       210080 :     case 8069:  /* *iorv8si3_mask */
    7433       210080 :     case 8067:  /* *andv8si3_mask */
    7434       210080 :     case 8065:  /* *xorv16si3_mask */
    7435       210080 :     case 8063:  /* *iorv16si3_mask */
    7436       210080 :     case 8061:  /* *andv16si3_mask */
    7437       210080 :     case 8029:  /* one_cmplv2di2_mask */
    7438       210080 :     case 8027:  /* one_cmplv4di2_mask */
    7439       210080 :     case 8025:  /* one_cmplv4si2_mask */
    7440       210080 :     case 8023:  /* one_cmplv8si2_mask */
    7441       210080 :     case 8015:  /* one_cmplv8di2_mask */
    7442       210080 :     case 8013:  /* one_cmplv16si2_mask */
    7443       210080 :     case 7931:  /* *sse4_1_uminv4si3_mask */
    7444       210080 :     case 7929:  /* *sse4_1_umaxv4si3_mask */
    7445       210080 :     case 7927:  /* *sse4_1_uminv8hi3_mask */
    7446       210080 :     case 7925:  /* *sse4_1_umaxv8hi3_mask */
    7447       210080 :     case 7921:  /* *sse4_1_sminv4si3_mask */
    7448       210080 :     case 7919:  /* *sse4_1_smaxv4si3_mask */
    7449       210080 :     case 7917:  /* *sse4_1_sminv16qi3_mask */
    7450       210080 :     case 7915:  /* *sse4_1_smaxv16qi3_mask */
    7451       210080 :     case 7913:  /* *avx512bw_uminv8hi3_mask */
    7452       210080 :     case 7911:  /* *avx512bw_umaxv8hi3_mask */
    7453       210080 :     case 7909:  /* *avx512bw_sminv8hi3_mask */
    7454       210080 :     case 7907:  /* *avx512bw_smaxv8hi3_mask */
    7455       210080 :     case 7905:  /* *avx512bw_uminv16hi3_mask */
    7456       210080 :     case 7903:  /* *avx512bw_umaxv16hi3_mask */
    7457       210080 :     case 7901:  /* *avx512bw_sminv16hi3_mask */
    7458       210080 :     case 7899:  /* *avx512bw_smaxv16hi3_mask */
    7459       210080 :     case 7897:  /* *avx512bw_uminv32hi3_mask */
    7460       210080 :     case 7895:  /* *avx512bw_umaxv32hi3_mask */
    7461       210080 :     case 7893:  /* *avx512bw_sminv32hi3_mask */
    7462       210080 :     case 7891:  /* *avx512bw_smaxv32hi3_mask */
    7463       210080 :     case 7889:  /* *avx512bw_uminv32qi3_mask */
    7464       210080 :     case 7887:  /* *avx512bw_umaxv32qi3_mask */
    7465       210080 :     case 7885:  /* *avx512bw_sminv32qi3_mask */
    7466       210080 :     case 7883:  /* *avx512bw_smaxv32qi3_mask */
    7467       210080 :     case 7881:  /* *avx512bw_uminv16qi3_mask */
    7468       210080 :     case 7879:  /* *avx512bw_umaxv16qi3_mask */
    7469       210080 :     case 7877:  /* *avx512bw_sminv16qi3_mask */
    7470       210080 :     case 7875:  /* *avx512bw_smaxv16qi3_mask */
    7471       210080 :     case 7873:  /* *avx512bw_uminv64qi3_mask */
    7472       210080 :     case 7871:  /* *avx512bw_umaxv64qi3_mask */
    7473       210080 :     case 7869:  /* *avx512bw_sminv64qi3_mask */
    7474       210080 :     case 7867:  /* *avx512bw_smaxv64qi3_mask */
    7475       210080 :     case 7865:  /* *avx512f_uminv2di3_mask */
    7476       210080 :     case 7863:  /* *avx512f_umaxv2di3_mask */
    7477       210080 :     case 7861:  /* *avx512f_sminv2di3_mask */
    7478       210080 :     case 7859:  /* *avx512f_smaxv2di3_mask */
    7479       210080 :     case 7857:  /* *avx512f_uminv4di3_mask */
    7480       210080 :     case 7855:  /* *avx512f_umaxv4di3_mask */
    7481       210080 :     case 7853:  /* *avx512f_sminv4di3_mask */
    7482       210080 :     case 7851:  /* *avx512f_smaxv4di3_mask */
    7483       210080 :     case 7849:  /* *avx512f_uminv8di3_mask */
    7484       210080 :     case 7847:  /* *avx512f_umaxv8di3_mask */
    7485       210080 :     case 7845:  /* *avx512f_sminv8di3_mask */
    7486       210080 :     case 7843:  /* *avx512f_smaxv8di3_mask */
    7487       210080 :     case 7841:  /* *avx512f_uminv4si3_mask */
    7488       210080 :     case 7839:  /* *avx512f_umaxv4si3_mask */
    7489       210080 :     case 7837:  /* *avx512f_sminv4si3_mask */
    7490       210080 :     case 7835:  /* *avx512f_smaxv4si3_mask */
    7491       210080 :     case 7833:  /* *avx512f_uminv8si3_mask */
    7492       210080 :     case 7831:  /* *avx512f_umaxv8si3_mask */
    7493       210080 :     case 7829:  /* *avx512f_sminv8si3_mask */
    7494       210080 :     case 7827:  /* *avx512f_smaxv8si3_mask */
    7495       210080 :     case 7825:  /* *avx512f_uminv16si3_mask */
    7496       210080 :     case 7823:  /* *avx512f_umaxv16si3_mask */
    7497       210080 :     case 7821:  /* *avx512f_sminv16si3_mask */
    7498       210080 :     case 7819:  /* *avx512f_smaxv16si3_mask */
    7499       210080 :     case 7805:  /* avx512vl_rorv2di_mask */
    7500       210080 :     case 7803:  /* avx512vl_rolv2di_mask */
    7501       210080 :     case 7801:  /* avx512vl_rorv4di_mask */
    7502       210080 :     case 7799:  /* avx512vl_rolv4di_mask */
    7503       210080 :     case 7797:  /* avx512f_rorv8di_mask */
    7504       210080 :     case 7795:  /* avx512f_rolv8di_mask */
    7505       210080 :     case 7793:  /* avx512vl_rorv4si_mask */
    7506       210080 :     case 7791:  /* avx512vl_rolv4si_mask */
    7507       210080 :     case 7789:  /* avx512vl_rorv8si_mask */
    7508       210080 :     case 7787:  /* avx512vl_rolv8si_mask */
    7509       210080 :     case 7785:  /* avx512f_rorv16si_mask */
    7510       210080 :     case 7783:  /* avx512f_rolv16si_mask */
    7511       210080 :     case 7781:  /* avx512vl_rorvv2di_mask */
    7512       210080 :     case 7779:  /* avx512vl_rolvv2di_mask */
    7513       210080 :     case 7777:  /* avx512vl_rorvv4di_mask */
    7514       210080 :     case 7775:  /* avx512vl_rolvv4di_mask */
    7515       210080 :     case 7773:  /* avx512f_rorvv8di_mask */
    7516       210080 :     case 7771:  /* avx512f_rolvv8di_mask */
    7517       210080 :     case 7769:  /* avx512vl_rorvv4si_mask */
    7518       210080 :     case 7767:  /* avx512vl_rolvv4si_mask */
    7519       210080 :     case 7765:  /* avx512vl_rorvv8si_mask */
    7520       210080 :     case 7763:  /* avx512vl_rolvv8si_mask */
    7521       210080 :     case 7761:  /* avx512f_rorvv16si_mask */
    7522       210080 :     case 7759:  /* avx512f_rolvv16si_mask */
    7523       210080 :     case 7742:  /* lshrv8di3_mask */
    7524       210080 :     case 7740:  /* ashlv8di3_mask */
    7525       210080 :     case 7738:  /* lshrv16si3_mask */
    7526       210080 :     case 7736:  /* ashlv16si3_mask */
    7527       210080 :     case 7734:  /* lshrv32hi3_mask */
    7528       210080 :     case 7732:  /* ashlv32hi3_mask */
    7529       210080 :     case 7714:  /* lshrv2di3_mask */
    7530       210080 :     case 7712:  /* ashlv2di3_mask */
    7531       210080 :     case 7710:  /* lshrv4di3_mask */
    7532       210080 :     case 7708:  /* ashlv4di3_mask */
    7533       210080 :     case 7706:  /* lshrv4si3_mask */
    7534       210080 :     case 7704:  /* ashlv4si3_mask */
    7535       210080 :     case 7702:  /* lshrv8si3_mask */
    7536       210080 :     case 7700:  /* ashlv8si3_mask */
    7537       210080 :     case 7698:  /* lshrv8hi3_mask */
    7538       210080 :     case 7696:  /* ashlv8hi3_mask */
    7539       210080 :     case 7694:  /* lshrv16hi3_mask */
    7540       210080 :     case 7692:  /* ashlv16hi3_mask */
    7541       210080 :     case 7681:  /* ashrv8di3_mask */
    7542       210080 :     case 7679:  /* ashrv16si3_mask */
    7543       210080 :     case 7677:  /* ashrv4di3_mask */
    7544       210080 :     case 7675:  /* ashrv32hi3_mask */
    7545       210080 :     case 7665:  /* ashrv2di3_mask */
    7546       210080 :     case 7663:  /* ashrv4si3_mask */
    7547       210080 :     case 7661:  /* ashrv8si3_mask */
    7548       210080 :     case 7659:  /* ashrv8hi3_mask */
    7549       210080 :     case 7657:  /* ashrv16hi3_mask */
    7550       210080 :     case 7655:  /* *sse4_1_mulv4si3_mask */
    7551       210080 :     case 7653:  /* *avx2_mulv8si3_mask */
    7552       210080 :     case 7651:  /* *avx512f_mulv16si3_mask */
    7553       210080 :     case 7649:  /* *avx512dq_mulv2di3_mask */
    7554       210080 :     case 7647:  /* *avx512dq_mulv4di3_mask */
    7555       210080 :     case 7645:  /* *avx512dq_mulv8di3_mask */
    7556       210080 :     case 7611:  /* *mulv8hi3_mask */
    7557       210080 :     case 7609:  /* *mulv16hi3_mask */
    7558       210080 :     case 7607:  /* *mulv32hi3_mask */
    7559       210080 :     case 7605:  /* *sse2_ussubv8hi3_mask */
    7560       210080 :     case 7603:  /* *sse2_sssubv8hi3_mask */
    7561       210080 :     case 7601:  /* *sse2_usaddv8hi3_mask */
    7562       210080 :     case 7599:  /* *sse2_ssaddv8hi3_mask */
    7563       210080 :     case 7597:  /* *avx2_ussubv16hi3_mask */
    7564       210080 :     case 7595:  /* *avx2_sssubv16hi3_mask */
    7565       210080 :     case 7593:  /* *avx2_usaddv16hi3_mask */
    7566       210080 :     case 7591:  /* *avx2_ssaddv16hi3_mask */
    7567       210080 :     case 7589:  /* *avx512bw_ussubv32hi3_mask */
    7568       210080 :     case 7587:  /* *avx512bw_sssubv32hi3_mask */
    7569       210080 :     case 7585:  /* *avx512bw_usaddv32hi3_mask */
    7570       210080 :     case 7583:  /* *avx512bw_ssaddv32hi3_mask */
    7571       210080 :     case 7581:  /* *sse2_ussubv16qi3_mask */
    7572       210080 :     case 7579:  /* *sse2_sssubv16qi3_mask */
    7573       210080 :     case 7577:  /* *sse2_usaddv16qi3_mask */
    7574       210080 :     case 7575:  /* *sse2_ssaddv16qi3_mask */
    7575       210080 :     case 7573:  /* *avx2_ussubv32qi3_mask */
    7576       210080 :     case 7571:  /* *avx2_sssubv32qi3_mask */
    7577       210080 :     case 7569:  /* *avx2_usaddv32qi3_mask */
    7578       210080 :     case 7567:  /* *avx2_ssaddv32qi3_mask */
    7579       210080 :     case 7565:  /* *avx512bw_ussubv64qi3_mask */
    7580       210080 :     case 7563:  /* *avx512bw_sssubv64qi3_mask */
    7581       210080 :     case 7561:  /* *avx512bw_usaddv64qi3_mask */
    7582       210080 :     case 7559:  /* *avx512bw_ssaddv64qi3_mask */
    7583       210080 :     case 7533:  /* *subv8hi3_mask */
    7584       210080 :     case 7532:  /* *addv8hi3_mask */
    7585       210080 :     case 7531:  /* *subv16hi3_mask */
    7586       210080 :     case 7530:  /* *addv16hi3_mask */
    7587       210080 :     case 7529:  /* *subv32hi3_mask */
    7588       210080 :     case 7528:  /* *addv32hi3_mask */
    7589       210080 :     case 7527:  /* *subv32qi3_mask */
    7590       210080 :     case 7526:  /* *addv32qi3_mask */
    7591       210080 :     case 7525:  /* *subv16qi3_mask */
    7592       210080 :     case 7524:  /* *addv16qi3_mask */
    7593       210080 :     case 7523:  /* *subv64qi3_mask */
    7594       210080 :     case 7522:  /* *addv64qi3_mask */
    7595       210080 :     case 7521:  /* *subv2di3_mask */
    7596       210080 :     case 7520:  /* *addv2di3_mask */
    7597       210080 :     case 7519:  /* *subv4di3_mask */
    7598       210080 :     case 7518:  /* *addv4di3_mask */
    7599       210080 :     case 7517:  /* *subv8di3_mask */
    7600       210080 :     case 7516:  /* *addv8di3_mask */
    7601       210080 :     case 7515:  /* *subv4si3_mask */
    7602       210080 :     case 7514:  /* *addv4si3_mask */
    7603       210080 :     case 7513:  /* *subv8si3_mask */
    7604       210080 :     case 7512:  /* *addv8si3_mask */
    7605       210080 :     case 7511:  /* *subv16si3_mask */
    7606       210080 :     case 7510:  /* *addv16si3_mask */
    7607       210080 :     case 3823:  /* *xorv8df3_mask */
    7608       210080 :     case 3821:  /* *iorv8df3_mask */
    7609       210080 :     case 3819:  /* *andv8df3_mask */
    7610       210080 :     case 3817:  /* *xorv16sf3_mask */
    7611       210080 :     case 3815:  /* *iorv16sf3_mask */
    7612       210080 :     case 3813:  /* *andv16sf3_mask */
    7613       210080 :     case 3805:  /* *xorv2df3_mask */
    7614       210080 :     case 3803:  /* *iorv2df3_mask */
    7615       210080 :     case 3801:  /* *andv2df3_mask */
    7616       210080 :     case 3799:  /* *xorv4df3_mask */
    7617       210080 :     case 3797:  /* *iorv4df3_mask */
    7618       210080 :     case 3795:  /* *andv4df3_mask */
    7619       210080 :     case 3793:  /* *xorv4sf3_mask */
    7620       210080 :     case 3791:  /* *iorv4sf3_mask */
    7621       210080 :     case 3789:  /* *andv4sf3_mask */
    7622       210080 :     case 3787:  /* *xorv8sf3_mask */
    7623       210080 :     case 3785:  /* *iorv8sf3_mask */
    7624       210080 :     case 3783:  /* *andv8sf3_mask */
    7625       210080 :     case 3083:  /* *sminv2df3_mask */
    7626       210080 :     case 3081:  /* *smaxv2df3_mask */
    7627       210080 :     case 3079:  /* *sminv4df3_mask */
    7628       210080 :     case 3077:  /* *smaxv4df3_mask */
    7629       210080 :     case 3074:  /* *sminv8df3_mask */
    7630       210080 :     case 3070:  /* *smaxv8df3_mask */
    7631       210080 :     case 3067:  /* *sminv4sf3_mask */
    7632       210080 :     case 3065:  /* *smaxv4sf3_mask */
    7633       210080 :     case 3063:  /* *sminv8sf3_mask */
    7634       210080 :     case 3061:  /* *smaxv8sf3_mask */
    7635       210080 :     case 3058:  /* *sminv16sf3_mask */
    7636       210080 :     case 3054:  /* *smaxv16sf3_mask */
    7637       210080 :     case 3051:  /* *sminv8hf3_mask */
    7638       210080 :     case 3049:  /* *smaxv8hf3_mask */
    7639       210080 :     case 3047:  /* *sminv16hf3_mask */
    7640       210080 :     case 3045:  /* *smaxv16hf3_mask */
    7641       210080 :     case 3042:  /* *sminv32hf3_mask */
    7642       210080 :     case 3038:  /* *smaxv32hf3_mask */
    7643       210080 :     case 2928:  /* sse2_divv2df3_mask */
    7644       210080 :     case 2926:  /* avx_divv4df3_mask */
    7645       210080 :     case 2923:  /* avx512f_divv8df3_mask */
    7646       210080 :     case 2920:  /* sse_divv4sf3_mask */
    7647       210080 :     case 2918:  /* avx_divv8sf3_mask */
    7648       210080 :     case 2915:  /* avx512f_divv16sf3_mask */
    7649       210080 :     case 2912:  /* avx512fp16_divv8hf3_mask */
    7650       210080 :     case 2910:  /* avx512fp16_divv16hf3_mask */
    7651       210080 :     case 2907:  /* avx512fp16_divv32hf3_mask */
    7652       210080 :     case 2873:  /* *mulv2df3_mask */
    7653       210080 :     case 2869:  /* *mulv4df3_mask */
    7654       210080 :     case 2865:  /* *mulv8df3_mask */
    7655       210080 :     case 2861:  /* *mulv4sf3_mask */
    7656       210080 :     case 2857:  /* *mulv8sf3_mask */
    7657       210080 :     case 2853:  /* *mulv16sf3_mask */
    7658       210080 :     case 2849:  /* *mulv8hf3_mask */
    7659       210080 :     case 2845:  /* *mulv16hf3_mask */
    7660       210080 :     case 2841:  /* *mulv32hf3_mask */
    7661       210080 :     case 2807:  /* *subv2df3_mask */
    7662       210080 :     case 2803:  /* *addv2df3_mask */
    7663       210080 :     case 2799:  /* *subv4df3_mask */
    7664       210080 :     case 2795:  /* *addv4df3_mask */
    7665       210080 :     case 2791:  /* *subv8df3_mask */
    7666       210080 :     case 2787:  /* *addv8df3_mask */
    7667       210080 :     case 2783:  /* *subv4sf3_mask */
    7668       210080 :     case 2779:  /* *addv4sf3_mask */
    7669       210080 :     case 2775:  /* *subv8sf3_mask */
    7670       210080 :     case 2771:  /* *addv8sf3_mask */
    7671       210080 :     case 2767:  /* *subv16sf3_mask */
    7672       210080 :     case 2763:  /* *addv16sf3_mask */
    7673       210080 :     case 2759:  /* *subv8hf3_mask */
    7674       210080 :     case 2755:  /* *addv8hf3_mask */
    7675       210080 :     case 2751:  /* *subv16hf3_mask */
    7676       210080 :     case 2747:  /* *addv16hf3_mask */
    7677       210080 :     case 2743:  /* *subv32hf3_mask */
    7678       210080 :     case 2739:  /* *addv32hf3_mask */
    7679       210080 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7680       210080 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    7681       210080 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    7682       210080 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    7683       210080 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    7684       210080 :       break;
    7685              : 
    7686         1704 :     case 3073:  /* *sminv8df3_round */
    7687         1704 :     case 3069:  /* *smaxv8df3_round */
    7688         1704 :     case 3057:  /* *sminv16sf3_round */
    7689         1704 :     case 3053:  /* *smaxv16sf3_round */
    7690         1704 :     case 3041:  /* *sminv32hf3_round */
    7691         1704 :     case 3037:  /* *smaxv32hf3_round */
    7692         1704 :     case 2922:  /* avx512f_divv8df3_round */
    7693         1704 :     case 2914:  /* avx512f_divv16sf3_round */
    7694         1704 :     case 2906:  /* avx512fp16_divv32hf3_round */
    7695         1704 :     case 2872:  /* *mulv2df3_round */
    7696         1704 :     case 2868:  /* *mulv4df3_round */
    7697         1704 :     case 2864:  /* *mulv8df3_round */
    7698         1704 :     case 2860:  /* *mulv4sf3_round */
    7699         1704 :     case 2856:  /* *mulv8sf3_round */
    7700         1704 :     case 2852:  /* *mulv16sf3_round */
    7701         1704 :     case 2848:  /* *mulv8hf3_round */
    7702         1704 :     case 2844:  /* *mulv16hf3_round */
    7703         1704 :     case 2840:  /* *mulv32hf3_round */
    7704         1704 :     case 2806:  /* *subv2df3_round */
    7705         1704 :     case 2802:  /* *addv2df3_round */
    7706         1704 :     case 2798:  /* *subv4df3_round */
    7707         1704 :     case 2794:  /* *addv4df3_round */
    7708         1704 :     case 2790:  /* *subv8df3_round */
    7709         1704 :     case 2786:  /* *addv8df3_round */
    7710         1704 :     case 2782:  /* *subv4sf3_round */
    7711         1704 :     case 2778:  /* *addv4sf3_round */
    7712         1704 :     case 2774:  /* *subv8sf3_round */
    7713         1704 :     case 2770:  /* *addv8sf3_round */
    7714         1704 :     case 2766:  /* *subv16sf3_round */
    7715         1704 :     case 2762:  /* *addv16sf3_round */
    7716         1704 :     case 2758:  /* *subv8hf3_round */
    7717         1704 :     case 2754:  /* *addv8hf3_round */
    7718         1704 :     case 2750:  /* *subv16hf3_round */
    7719         1704 :     case 2746:  /* *addv16hf3_round */
    7720         1704 :     case 2742:  /* *subv32hf3_round */
    7721         1704 :     case 2738:  /* *addv32hf3_round */
    7722         1704 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7723         1704 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
    7724         1704 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
    7725         1704 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 1));
    7726         1704 :       break;
    7727              : 
    7728        15446 :     case 2706:  /* kunpckdi */
    7729        15446 :     case 2705:  /* kunpcksi */
    7730        15446 :     case 2704:  /* kunpckhi */
    7731        15446 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    7732        15446 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
    7733        15446 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
    7734        15446 :       break;
    7735              : 
    7736          224 :     case 2703:  /* *kortest_cmpdi_movdicc */
    7737          224 :     case 2702:  /* *kortest_cmpdi_movsicc */
    7738          224 :     case 2701:  /* *kortest_cmpdi_movhicc */
    7739          224 :     case 2700:  /* *kortest_cmpsi_movdicc */
    7740          224 :     case 2699:  /* *kortest_cmpsi_movsicc */
    7741          224 :     case 2698:  /* *kortest_cmpsi_movhicc */
    7742          224 :     case 2697:  /* *kortest_cmphi_movdicc */
    7743          224 :     case 2696:  /* *kortest_cmphi_movsicc */
    7744          224 :     case 2695:  /* *kortest_cmphi_movhicc */
    7745          224 :     case 2694:  /* *kortest_cmpqi_movdicc */
    7746          224 :     case 2693:  /* *kortest_cmpqi_movsicc */
    7747          224 :     case 2692:  /* *kortest_cmpqi_movhicc */
    7748          224 :     case 2691:  /* *kortest_cmpdi_movqicc */
    7749          224 :     case 2690:  /* *kortest_cmpsi_movqicc */
    7750          224 :     case 2689:  /* *kortest_cmphi_movqicc */
    7751          224 :     case 2688:  /* *kortest_cmpqi_movqicc */
    7752          224 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    7753          224 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    7754          224 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    7755          224 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 2));
    7756          224 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    7757          224 :       break;
    7758              : 
    7759          917 :     case 2687:  /* *kortest_cmpdi_jcc */
    7760          917 :     case 2686:  /* *kortest_cmpsi_jcc */
    7761          917 :     case 2685:  /* *kortest_cmphi_jcc */
    7762          917 :     case 2684:  /* *kortest_cmpqi_jcc */
    7763          917 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    7764          917 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    7765          917 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
    7766          917 :       break;
    7767              : 
    7768          428 :     case 2683:  /* *kortest_cmpdi_setcc */
    7769          428 :     case 2682:  /* *kortest_cmpsi_setcc */
    7770          428 :     case 2681:  /* *kortest_cmphi_setcc */
    7771          428 :     case 2680:  /* *kortest_cmpqi_setcc */
    7772          428 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    7773          428 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 1));
    7774          428 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    7775          428 :       break;
    7776              : 
    7777         1749 :     case 2607:  /* *avx512vl_storev8bf_mask */
    7778         1749 :     case 2606:  /* *avx512vl_storev16bf_mask */
    7779         1749 :     case 2605:  /* *avx512bw_storev32bf_mask */
    7780         1749 :     case 2604:  /* *avx512fp16_storev8hf_mask */
    7781         1749 :     case 2603:  /* *avx512vl_storev16hf_mask */
    7782         1749 :     case 2602:  /* *avx512bw_storev32hf_mask */
    7783         1749 :     case 2601:  /* *avx512vl_storev8hi_mask */
    7784         1749 :     case 2600:  /* *avx512vl_storev16hi_mask */
    7785         1749 :     case 2599:  /* *avx512bw_storev32hi_mask */
    7786         1749 :     case 2598:  /* *avx512vl_storev32qi_mask */
    7787         1749 :     case 2597:  /* *avx512vl_storev16qi_mask */
    7788         1749 :     case 2596:  /* *avx512bw_storev64qi_mask */
    7789         1749 :     case 2595:  /* *avx512vl_storev2df_mask */
    7790         1749 :     case 2594:  /* *avx512vl_storev4df_mask */
    7791         1749 :     case 2593:  /* *avx512f_storev8df_mask */
    7792         1749 :     case 2592:  /* *avx512vl_storev4sf_mask */
    7793         1749 :     case 2591:  /* *avx512vl_storev8sf_mask */
    7794         1749 :     case 2590:  /* *avx512f_storev16sf_mask */
    7795         1749 :     case 2589:  /* *avx512vl_storev2di_mask */
    7796         1749 :     case 2588:  /* *avx512vl_storev4di_mask */
    7797         1749 :     case 2587:  /* *avx512f_storev8di_mask */
    7798         1749 :     case 2586:  /* *avx512vl_storev4si_mask */
    7799         1749 :     case 2585:  /* *avx512vl_storev8si_mask */
    7800         1749 :     case 2584:  /* *avx512f_storev16si_mask */
    7801         1749 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7802         1749 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    7803         1749 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 2));
    7804         1749 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    7805         1749 :       recog_data.dup_num[0] = 0;
    7806         1749 :       break;
    7807              : 
    7808          814 :     case 2559:  /* avx512f_storedf_mask */
    7809          814 :     case 2558:  /* avx512f_storesf_mask */
    7810          814 :     case 2557:  /* avx512f_storehf_mask */
    7811          814 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7812          814 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    7813          814 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    7814          814 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 2);
    7815          814 :       recog_data.dup_num[0] = 0;
    7816          814 :       break;
    7817              : 
    7818         1846 :     case 4346:  /* *fma4i_vmfnmadd_v2df */
    7819         1846 :     case 4345:  /* *fma4i_vmfnmadd_v4sf */
    7820         1846 :     case 2556:  /* *avx512f_loaddf_mask */
    7821         1846 :     case 2555:  /* *avx512f_loadsf_mask */
    7822         1846 :     case 2554:  /* *avx512f_loadhf_mask */
    7823         1846 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7824         1846 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    7825         1846 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    7826         1846 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    7827         1846 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    7828         1846 :       break;
    7829              : 
    7830         2583 :     case 2553:  /* avx512f_movdf_mask */
    7831         2583 :     case 2552:  /* avx512f_movsf_mask */
    7832         2583 :     case 2551:  /* avx512f_movhf_mask */
    7833         2583 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7834         2583 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    7835         2583 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    7836         2583 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    7837         2583 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    7838         2583 :       break;
    7839              : 
    7840          262 :     case 2526:  /* *avx512vl_loadv2dimask_and3 */
    7841          262 :     case 2525:  /* *avx512vl_loadv2dfmask_and3 */
    7842          262 :     case 2524:  /* *avx512vl_loadv4dimask_and15 */
    7843          262 :     case 2523:  /* *avx512vl_loadv4simask_and15 */
    7844          262 :     case 2522:  /* *avx512vl_loadv4dfmask_and15 */
    7845          262 :     case 2521:  /* *avx512vl_loadv4sfmask_and15 */
    7846          262 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7847          262 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    7848          262 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    7849          262 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 2), 0));
    7850          262 :       break;
    7851              : 
    7852       137608 :     case 11067:  /* avx512bmm_vbitrevb_v32qi_mask */
    7853       137608 :     case 11066:  /* avx512bmm_vbitrevb_v16qi_mask */
    7854       137608 :     case 11065:  /* avx512bmm_vbitrevb_v64qi_mask */
    7855       137608 :     case 11060:  /* avx10_2_vmovrsqv2di_mask */
    7856       137608 :     case 11058:  /* avx10_2_vmovrsqv4di_mask */
    7857       137608 :     case 11056:  /* avx10_2_vmovrsqv8di_mask */
    7858       137608 :     case 11054:  /* avx10_2_vmovrsdv4si_mask */
    7859       137608 :     case 11052:  /* avx10_2_vmovrsdv8si_mask */
    7860       137608 :     case 11050:  /* avx10_2_vmovrsdv16si_mask */
    7861       137608 :     case 11048:  /* avx10_2_vmovrswv8hi_mask */
    7862       137608 :     case 11046:  /* avx10_2_vmovrswv16hi_mask */
    7863       137608 :     case 11044:  /* avx10_2_vmovrswv32hi_mask */
    7864       137608 :     case 11042:  /* avx10_2_vmovrsbv16qi_mask */
    7865       137608 :     case 11040:  /* avx10_2_vmovrsbv32qi_mask */
    7866       137608 :     case 11038:  /* avx10_2_vmovrsbv64qi_mask */
    7867       137608 :     case 10966:  /* avx10_2_vcvttps2uqqsv2di_mask */
    7868       137608 :     case 10964:  /* avx10_2_vcvttps2qqsv2di_mask */
    7869       137608 :     case 10962:  /* avx10_2_vcvttps2uqqsv4di_mask */
    7870       137608 :     case 10960:  /* avx10_2_vcvttps2qqsv4di_mask */
    7871       137608 :     case 10957:  /* avx10_2_vcvttps2uqqsv8di_mask */
    7872       137608 :     case 10953:  /* avx10_2_vcvttps2qqsv8di_mask */
    7873       137608 :     case 10950:  /* avx10_2_vcvttpd2uqqsv2df_mask */
    7874       137608 :     case 10948:  /* avx10_2_vcvttpd2qqsv2df_mask */
    7875       137608 :     case 10946:  /* avx10_2_vcvttpd2uqqsv4df_mask */
    7876       137608 :     case 10944:  /* avx10_2_vcvttpd2qqsv4df_mask */
    7877       137608 :     case 10941:  /* avx10_2_vcvttpd2uqqsv8df_mask */
    7878       137608 :     case 10937:  /* avx10_2_vcvttpd2qqsv8df_mask */
    7879       137608 :     case 10934:  /* avx10_2_vcvttpd2udqsv2df_mask */
    7880       137608 :     case 10932:  /* avx10_2_vcvttpd2dqsv2df_mask */
    7881       137608 :     case 10930:  /* avx10_2_vcvttpd2udqsv4df_mask */
    7882       137608 :     case 10928:  /* avx10_2_vcvttpd2dqsv4df_mask */
    7883       137608 :     case 10925:  /* avx10_2_vcvttpd2udqsv8df_mask */
    7884       137608 :     case 10921:  /* avx10_2_vcvttpd2dqsv8df_mask */
    7885       137608 :     case 10918:  /* avx10_2_vcvttps2udqsv4sf_mask */
    7886       137608 :     case 10916:  /* avx10_2_vcvttps2dqsv4sf_mask */
    7887       137608 :     case 10914:  /* avx10_2_vcvttps2udqsv8sf_mask */
    7888       137608 :     case 10912:  /* avx10_2_vcvttps2dqsv8sf_mask */
    7889       137608 :     case 10909:  /* avx10_2_vcvttps2udqsv16sf_mask */
    7890       137608 :     case 10905:  /* avx10_2_vcvttps2dqsv16sf_mask */
    7891       137608 :     case 10902:  /* avx10_2_cvttps2iubsv4sf_mask */
    7892       137608 :     case 10900:  /* avx10_2_cvttps2ibsv4sf_mask */
    7893       137608 :     case 10898:  /* avx10_2_cvttps2iubsv8sf_mask */
    7894       137608 :     case 10896:  /* avx10_2_cvttps2ibsv8sf_mask */
    7895       137608 :     case 10893:  /* avx10_2_cvttps2iubsv16sf_mask */
    7896       137608 :     case 10889:  /* avx10_2_cvttps2ibsv16sf_mask */
    7897       137608 :     case 10886:  /* avx10_2_cvtps2iubsv4sf_mask */
    7898       137608 :     case 10884:  /* avx10_2_cvtps2ibsv4sf_mask */
    7899       137608 :     case 10882:  /* avx10_2_cvtps2iubsv8sf_mask */
    7900       137608 :     case 10880:  /* avx10_2_cvtps2ibsv8sf_mask */
    7901       137608 :     case 10877:  /* avx10_2_cvtps2iubsv16sf_mask */
    7902       137608 :     case 10873:  /* avx10_2_cvtps2ibsv16sf_mask */
    7903       137608 :     case 10870:  /* avx10_2_cvttph2iubsv8hf_mask */
    7904       137608 :     case 10868:  /* avx10_2_cvttph2ibsv8hf_mask */
    7905       137608 :     case 10866:  /* avx10_2_cvttph2iubsv16hf_mask */
    7906       137608 :     case 10864:  /* avx10_2_cvttph2ibsv16hf_mask */
    7907       137608 :     case 10861:  /* avx10_2_cvttph2iubsv32hf_mask */
    7908       137608 :     case 10857:  /* avx10_2_cvttph2ibsv32hf_mask */
    7909       137608 :     case 10854:  /* avx10_2_cvtph2iubsv8hf_mask */
    7910       137608 :     case 10852:  /* avx10_2_cvtph2ibsv8hf_mask */
    7911       137608 :     case 10850:  /* avx10_2_cvtph2iubsv16hf_mask */
    7912       137608 :     case 10848:  /* avx10_2_cvtph2ibsv16hf_mask */
    7913       137608 :     case 10845:  /* avx10_2_cvtph2iubsv32hf_mask */
    7914       137608 :     case 10841:  /* avx10_2_cvtph2ibsv32hf_mask */
    7915       137608 :     case 10838:  /* avx10_2_cvttbf162iubsv8bf_mask */
    7916       137608 :     case 10836:  /* avx10_2_cvttbf162ibsv8bf_mask */
    7917       137608 :     case 10834:  /* avx10_2_cvtbf162iubsv8bf_mask */
    7918       137608 :     case 10832:  /* avx10_2_cvtbf162ibsv8bf_mask */
    7919       137608 :     case 10830:  /* avx10_2_cvttbf162iubsv16bf_mask */
    7920       137608 :     case 10828:  /* avx10_2_cvttbf162ibsv16bf_mask */
    7921       137608 :     case 10826:  /* avx10_2_cvtbf162iubsv16bf_mask */
    7922       137608 :     case 10824:  /* avx10_2_cvtbf162ibsv16bf_mask */
    7923       137608 :     case 10822:  /* avx10_2_cvttbf162iubsv32bf_mask */
    7924       137608 :     case 10820:  /* avx10_2_cvttbf162ibsv32bf_mask */
    7925       137608 :     case 10818:  /* avx10_2_cvtbf162iubsv32bf_mask */
    7926       137608 :     case 10816:  /* avx10_2_cvtbf162ibsv32bf_mask */
    7927       137608 :     case 10784:  /* avx10_2_getexpbf16_v8bf_mask */
    7928       137608 :     case 10782:  /* avx10_2_getexpbf16_v16bf_mask */
    7929       137608 :     case 10780:  /* avx10_2_getexpbf16_v32bf_mask */
    7930       137608 :     case 10778:  /* avx10_2_rcpbf16_v8bf_mask */
    7931       137608 :     case 10776:  /* avx10_2_rcpbf16_v16bf_mask */
    7932       137608 :     case 10774:  /* avx10_2_rcpbf16_v32bf_mask */
    7933       137608 :     case 10766:  /* avx10_2_rsqrtbf16_v8bf_mask */
    7934       137608 :     case 10764:  /* avx10_2_rsqrtbf16_v16bf_mask */
    7935       137608 :     case 10762:  /* avx10_2_rsqrtbf16_v32bf_mask */
    7936       137608 :     case 10607:  /* vcvthf82phv8hf_mask */
    7937       137608 :     case 10605:  /* vcvthf82phv16hf_mask */
    7938       137608 :     case 10603:  /* vcvthf82phv32hf_mask */
    7939       137608 :     case 10601:  /* vcvtph2hf8sv32hf_mask */
    7940       137608 :     case 10599:  /* vcvtph2hf8v32hf_mask */
    7941       137608 :     case 10597:  /* vcvtph2bf8sv32hf_mask */
    7942       137608 :     case 10595:  /* vcvtph2bf8v32hf_mask */
    7943       137608 :     case 10593:  /* vcvtph2hf8sv16hf_mask */
    7944       137608 :     case 10591:  /* vcvtph2hf8v16hf_mask */
    7945       137608 :     case 10589:  /* vcvtph2bf8sv16hf_mask */
    7946       137608 :     case 10587:  /* vcvtph2bf8v16hf_mask */
    7947       137608 :     case 10168:  /* conflictv2di_mask */
    7948       137608 :     case 10166:  /* conflictv4di_mask */
    7949       137608 :     case 10164:  /* conflictv8di_mask */
    7950       137608 :     case 10162:  /* conflictv4si_mask */
    7951       137608 :     case 10160:  /* conflictv8si_mask */
    7952       137608 :     case 10158:  /* conflictv16si_mask */
    7953       137608 :     case 9740:  /* avx512f_vcvtph2ps512_mask */
    7954       137608 :     case 9737:  /* vcvtph2ps256_mask */
    7955       137608 :     case 9735:  /* *vcvtph2ps_load_mask */
    7956       137608 :     case 7077:  /* avx512vl_getexpv2df_mask */
    7957       137608 :     case 7073:  /* avx512vl_getexpv4df_mask */
    7958       137608 :     case 7069:  /* avx512f_getexpv8df_mask */
    7959       137608 :     case 7065:  /* avx512vl_getexpv4sf_mask */
    7960       137608 :     case 7061:  /* avx512vl_getexpv8sf_mask */
    7961       137608 :     case 7057:  /* avx512f_getexpv16sf_mask */
    7962       137608 :     case 7053:  /* avx512fp16_getexpv8hf_mask */
    7963       137608 :     case 7049:  /* avx512vl_getexpv16hf_mask */
    7964       137608 :     case 7045:  /* avx512bw_getexpv32hf_mask */
    7965       137608 :     case 5164:  /* unspec_sse2_cvttpd2dq_mask */
    7966       137608 :     case 5158:  /* unspec_fixuns_truncv4sfv4si2_mask */
    7967       137608 :     case 5156:  /* unspec_fixuns_truncv8sfv8si2_mask */
    7968       137608 :     case 5150:  /* unspec_avx512dq_fixuns_truncv2sfv2di2_mask */
    7969       137608 :     case 5148:  /* unspec_avx512dq_fix_truncv2sfv2di2_mask */
    7970       137608 :     case 5134:  /* unspec_fixuns_truncv4sfv4di2_mask */
    7971       137608 :     case 5132:  /* unspec_fix_truncv4sfv4di2_mask */
    7972       137608 :     case 5129:  /* unspec_fixuns_truncv8sfv8di2_mask */
    7973       137608 :     case 5125:  /* unspec_fix_truncv8sfv8di2_mask */
    7974       137608 :     case 5122:  /* fixuns_notruncv2dfv2di2_mask */
    7975       137608 :     case 5120:  /* fixuns_notruncv4dfv4di2_mask */
    7976       137608 :     case 5117:  /* fixuns_notruncv8dfv8di2_mask */
    7977       137608 :     case 5114:  /* fix_notruncv2dfv2di2_mask */
    7978       137608 :     case 5112:  /* fix_notruncv4dfv4di2_mask */
    7979       137608 :     case 5109:  /* fix_notruncv8dfv8di2_mask */
    7980       137608 :     case 5090:  /* unspec_fixuns_truncv2dfv2di2_mask */
    7981       137608 :     case 5088:  /* unspec_fix_truncv2dfv2di2_mask */
    7982       137608 :     case 5086:  /* unspec_fixuns_truncv4dfv4di2_mask */
    7983       137608 :     case 5084:  /* unspec_fix_truncv4dfv4di2_mask */
    7984       137608 :     case 5081:  /* unspec_fixuns_truncv8dfv8di2_mask */
    7985       137608 :     case 5077:  /* unspec_fix_truncv8dfv8di2_mask */
    7986       137608 :     case 5072:  /* unspec_fixuns_truncv4dfv4si2_mask */
    7987       137608 :     case 5068:  /* unspec_fix_truncv4dfv4si2_mask */
    7988       137608 :     case 5052:  /* unspec_fixuns_truncv8dfv8si2_mask */
    7989       137608 :     case 5048:  /* unspec_fix_truncv8dfv8si2_mask */
    7990       137608 :     case 5041:  /* fixuns_notruncv4dfv4si2_mask */
    7991       137608 :     case 5037:  /* fixuns_notruncv8dfv8si2_mask */
    7992       137608 :     case 5030:  /* avx_cvtpd2dq256_mask */
    7993       137608 :     case 5027:  /* avx512f_cvtpd2dq512_mask */
    7994       137608 :     case 4918:  /* unspec_fix_truncv4sfv4si2_mask */
    7995       137608 :     case 4914:  /* unspec_fix_truncv8sfv8si2_mask */
    7996       137608 :     case 4903:  /* unspec_fixuns_truncv16sfv16si2_mask */
    7997       137608 :     case 4899:  /* unspec_fix_truncv16sfv16si2_mask */
    7998       137608 :     case 4894:  /* avx512dq_cvtps2uqqv4di_mask */
    7999       137608 :     case 4891:  /* avx512dq_cvtps2uqqv8di_mask */
    8000       137608 :     case 4886:  /* avx512dq_cvtps2qqv4di_mask */
    8001       137608 :     case 4883:  /* avx512dq_cvtps2qqv8di_mask */
    8002       137608 :     case 4879:  /* avx512vl_fixuns_notruncv4sfv4si_mask */
    8003       137608 :     case 4875:  /* avx512vl_fixuns_notruncv8sfv8si_mask */
    8004       137608 :     case 4871:  /* avx512f_fixuns_notruncv16sfv16si_mask */
    8005       137608 :     case 4867:  /* avx512f_fix_notruncv16sfv16si_mask */
    8006       137608 :     case 4864:  /* sse2_fix_notruncv4sfv4si_mask */
    8007       137608 :     case 4862:  /* avx_fix_notruncv8sfv8si_mask */
    8008       137608 :     case 4714:  /* unspec_avx512fp16_fixuns_truncv2di2_mask */
    8009       137608 :     case 4712:  /* unspec_avx512fp16_fix_truncv2di2_mask */
    8010       137608 :     case 4694:  /* unspec_avx512fp16_fixuns_truncv4di2_mask */
    8011       137608 :     case 4692:  /* unspec_avx512fp16_fix_truncv4di2_mask */
    8012       137608 :     case 4690:  /* unspec_avx512fp16_fixuns_truncv4si2_mask */
    8013       137608 :     case 4688:  /* unspec_avx512fp16_fix_truncv4si2_mask */
    8014       137608 :     case 4637:  /* unspec_avx512fp16_fixuns_truncv8di2_mask */
    8015       137608 :     case 4633:  /* unspec_avx512fp16_fix_truncv8di2_mask */
    8016       137608 :     case 4629:  /* unspec_avx512fp16_fixuns_truncv16si2_mask */
    8017       137608 :     case 4625:  /* unspec_avx512fp16_fix_truncv16si2_mask */
    8018       137608 :     case 4621:  /* unspec_avx512fp16_fixuns_truncv8si2_mask */
    8019       137608 :     case 4617:  /* unspec_avx512fp16_fix_truncv8si2_mask */
    8020       137608 :     case 4613:  /* unspec_avx512fp16_fixuns_truncv32hi2_mask */
    8021       137608 :     case 4609:  /* unspec_avx512fp16_fix_truncv32hi2_mask */
    8022       137608 :     case 4605:  /* unspec_avx512fp16_fixuns_truncv16hi2_mask */
    8023       137608 :     case 4601:  /* unspec_avx512fp16_fix_truncv16hi2_mask */
    8024       137608 :     case 4597:  /* unspec_avx512fp16_fixuns_truncv8hi2_mask */
    8025       137608 :     case 4593:  /* unspec_avx512fp16_fix_truncv8hi2_mask */
    8026       137608 :     case 4503:  /* avx512fp16_vcvtph2qq_v2di_mask */
    8027       137608 :     case 4499:  /* avx512fp16_vcvtph2uqq_v2di_mask */
    8028       137608 :     case 4495:  /* avx512fp16_vcvtph2dq_v4si_mask */
    8029       137608 :     case 4491:  /* avx512fp16_vcvtph2udq_v4si_mask */
    8030       137608 :     case 4487:  /* avx512fp16_vcvtph2w_v8hi_mask */
    8031       137608 :     case 4483:  /* avx512fp16_vcvtph2uw_v8hi_mask */
    8032       137608 :     case 4479:  /* avx512fp16_vcvtph2qq_v4di_mask */
    8033       137608 :     case 4475:  /* avx512fp16_vcvtph2uqq_v4di_mask */
    8034       137608 :     case 4471:  /* avx512fp16_vcvtph2dq_v8si_mask */
    8035       137608 :     case 4467:  /* avx512fp16_vcvtph2udq_v8si_mask */
    8036       137608 :     case 4463:  /* avx512fp16_vcvtph2w_v16hi_mask */
    8037       137608 :     case 4459:  /* avx512fp16_vcvtph2uw_v16hi_mask */
    8038       137608 :     case 4455:  /* avx512fp16_vcvtph2qq_v8di_mask */
    8039       137608 :     case 4451:  /* avx512fp16_vcvtph2uqq_v8di_mask */
    8040       137608 :     case 4447:  /* avx512fp16_vcvtph2dq_v16si_mask */
    8041       137608 :     case 4443:  /* avx512fp16_vcvtph2udq_v16si_mask */
    8042       137608 :     case 4439:  /* avx512fp16_vcvtph2w_v32hi_mask */
    8043       137608 :     case 4435:  /* avx512fp16_vcvtph2uw_v32hi_mask */
    8044       137608 :     case 3025:  /* rsqrt14v2df_mask */
    8045       137608 :     case 3023:  /* rsqrt14v4df_mask */
    8046       137608 :     case 3021:  /* rsqrt14v8df_mask */
    8047       137608 :     case 3019:  /* rsqrt14v4sf_mask */
    8048       137608 :     case 3017:  /* rsqrt14v8sf_mask */
    8049       137608 :     case 3015:  /* rsqrt14v16sf_mask */
    8050       137608 :     case 3013:  /* avx512fp16_rsqrtv8hf2_mask */
    8051       137608 :     case 3011:  /* avx512fp16_rsqrtv16hf2_mask */
    8052       137608 :     case 3009:  /* avx512fp16_rsqrtv32hf2_mask */
    8053       137608 :     case 2953:  /* rcp14v2df_mask */
    8054       137608 :     case 2951:  /* rcp14v4df_mask */
    8055       137608 :     case 2949:  /* rcp14v8df_mask */
    8056       137608 :     case 2947:  /* rcp14v4sf_mask */
    8057       137608 :     case 2945:  /* rcp14v8sf_mask */
    8058       137608 :     case 2943:  /* rcp14v16sf_mask */
    8059       137608 :     case 2938:  /* avx512fp16_rcpv8hf2_mask */
    8060       137608 :     case 2936:  /* avx512fp16_rcpv16hf2_mask */
    8061       137608 :     case 2934:  /* avx512fp16_rcpv32hf2_mask */
    8062       137608 :     case 2538:  /* *avx512vl_loadv8bf_mask */
    8063       137608 :     case 2537:  /* *avx512vl_loadv16bf_mask */
    8064       137608 :     case 2536:  /* *avx512bw_loadv32bf_mask */
    8065       137608 :     case 2535:  /* *avx512fp16_loadv8hf_mask */
    8066       137608 :     case 2534:  /* *avx512vl_loadv16hf_mask */
    8067       137608 :     case 2533:  /* *avx512bw_loadv32hf_mask */
    8068       137608 :     case 2532:  /* *avx512vl_loadv8hi_mask */
    8069       137608 :     case 2531:  /* *avx512vl_loadv16hi_mask */
    8070       137608 :     case 2530:  /* *avx512bw_loadv32hi_mask */
    8071       137608 :     case 2529:  /* *avx512vl_loadv32qi_mask */
    8072       137608 :     case 2528:  /* *avx512vl_loadv16qi_mask */
    8073       137608 :     case 2527:  /* *avx512bw_loadv64qi_mask */
    8074       137608 :     case 2508:  /* *avx512vl_loadv2df_mask */
    8075       137608 :     case 2507:  /* *avx512vl_loadv4df_mask */
    8076       137608 :     case 2506:  /* *avx512f_loadv8df_mask */
    8077       137608 :     case 2505:  /* *avx512vl_loadv4sf_mask */
    8078       137608 :     case 2504:  /* *avx512vl_loadv8sf_mask */
    8079       137608 :     case 2503:  /* *avx512f_loadv16sf_mask */
    8080       137608 :     case 2502:  /* *avx512vl_loadv2di_mask */
    8081       137608 :     case 2501:  /* *avx512vl_loadv4di_mask */
    8082       137608 :     case 2500:  /* *avx512f_loadv8di_mask */
    8083       137608 :     case 2499:  /* *avx512vl_loadv4si_mask */
    8084       137608 :     case 2498:  /* *avx512vl_loadv8si_mask */
    8085       137608 :     case 2497:  /* *avx512f_loadv16si_mask */
    8086       137608 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8087       137608 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    8088       137608 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    8089       137608 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    8090       137608 :       break;
    8091              : 
    8092         7286 :     case 2496:  /* *vmovv2df_constm1_pternlog_false_dep */
    8093         7286 :     case 2495:  /* *vmovv4df_constm1_pternlog_false_dep */
    8094         7286 :     case 2494:  /* *vmovv8df_constm1_pternlog_false_dep */
    8095         7286 :     case 2493:  /* *vmovv4sf_constm1_pternlog_false_dep */
    8096         7286 :     case 2492:  /* *vmovv8sf_constm1_pternlog_false_dep */
    8097         7286 :     case 2491:  /* *vmovv16sf_constm1_pternlog_false_dep */
    8098         7286 :     case 2490:  /* *vmovv8bf_constm1_pternlog_false_dep */
    8099         7286 :     case 2489:  /* *vmovv16bf_constm1_pternlog_false_dep */
    8100         7286 :     case 2488:  /* *vmovv32bf_constm1_pternlog_false_dep */
    8101         7286 :     case 2487:  /* *vmovv8hf_constm1_pternlog_false_dep */
    8102         7286 :     case 2486:  /* *vmovv16hf_constm1_pternlog_false_dep */
    8103         7286 :     case 2485:  /* *vmovv32hf_constm1_pternlog_false_dep */
    8104         7286 :     case 2484:  /* *vmovv1ti_constm1_pternlog_false_dep */
    8105         7286 :     case 2483:  /* *vmovv2ti_constm1_pternlog_false_dep */
    8106         7286 :     case 2482:  /* *vmovv4ti_constm1_pternlog_false_dep */
    8107         7286 :     case 2481:  /* *vmovv2di_constm1_pternlog_false_dep */
    8108         7286 :     case 2480:  /* *vmovv4di_constm1_pternlog_false_dep */
    8109         7286 :     case 2479:  /* *vmovv8di_constm1_pternlog_false_dep */
    8110         7286 :     case 2478:  /* *vmovv4si_constm1_pternlog_false_dep */
    8111         7286 :     case 2477:  /* *vmovv8si_constm1_pternlog_false_dep */
    8112         7286 :     case 2476:  /* *vmovv16si_constm1_pternlog_false_dep */
    8113         7286 :     case 2475:  /* *vmovv8hi_constm1_pternlog_false_dep */
    8114         7286 :     case 2474:  /* *vmovv16hi_constm1_pternlog_false_dep */
    8115         7286 :     case 2473:  /* *vmovv32hi_constm1_pternlog_false_dep */
    8116         7286 :     case 2472:  /* *vmovv16qi_constm1_pternlog_false_dep */
    8117         7286 :     case 2471:  /* *vmovv32qi_constm1_pternlog_false_dep */
    8118         7286 :     case 2470:  /* *vmovv64qi_constm1_pternlog_false_dep */
    8119         7286 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8120         7286 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 1));
    8121         7286 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    8122         7286 :       break;
    8123              : 
    8124          570 :     case 8636:  /* *sse2_maskmovdqu */
    8125          570 :     case 8635:  /* *sse2_maskmovdqu */
    8126          570 :     case 2434:  /* *mmx_maskmovq */
    8127          570 :     case 2433:  /* *mmx_maskmovq */
    8128          570 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 0), 0));
    8129          570 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
    8130          570 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    8131          570 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0);
    8132          570 :       recog_data.dup_num[0] = 0;
    8133          570 :       break;
    8134              : 
    8135       107439 :     case 7233:  /* sse2_shufpd_v2df */
    8136       107439 :     case 7232:  /* sse2_shufpd_v2di */
    8137       107439 :     case 2418:  /* *punpckwd */
    8138       107439 :     case 2417:  /* *punpckwd */
    8139       107439 :     case 2416:  /* *punpckwd */
    8140       107439 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8141       107439 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    8142       107439 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    8143       107439 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    8144       107439 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    8145       107439 :       break;
    8146              : 
    8147        24599 :     case 5340:  /* *avx512dq_vextracti64x2_1 */
    8148        24599 :     case 5339:  /* *avx512dq_vextractf64x2_1 */
    8149        24599 :     case 2421:  /* *pshufwv2hi_1 */
    8150        24599 :     case 2420:  /* *pshufwv2bf_1 */
    8151        24599 :     case 2419:  /* *pshufwv2hf_1 */
    8152        24599 :     case 2383:  /* *mmx_pshufd_1 */
    8153        24599 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8154        24599 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    8155        24599 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    8156        24599 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    8157        24599 :       break;
    8158              : 
    8159       786068 :     case 9249:  /* avx2_permv4df_1 */
    8160       786068 :     case 9247:  /* avx2_permv4di_1 */
    8161       786068 :     case 8503:  /* sse2_pshuflw_1 */
    8162       786068 :     case 8497:  /* sse2_pshufd_1 */
    8163       786068 :     case 5344:  /* *avx512f_vextracti32x4_1 */
    8164       786068 :     case 5343:  /* *avx512f_vextractf32x4_1 */
    8165       786068 :     case 2382:  /* mmx_pshufwv4hi_1 */
    8166       786068 :     case 2381:  /* mmx_pshufwv4bf_1 */
    8167       786068 :     case 2380:  /* mmx_pshufwv4hf_1 */
    8168       786068 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8169       786068 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    8170       786068 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    8171       786068 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    8172       786068 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 2));
    8173       786068 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 3));
    8174       786068 :       break;
    8175              : 
    8176       208471 :     case 8531:  /* *vec_extractv4si_zext_mem */
    8177       208471 :     case 8529:  /* *vec_extractv4si_zext */
    8178       208471 :     case 8520:  /* *vec_extractv16qi_zext */
    8179       208471 :     case 8519:  /* *vec_extractv8hi_zext */
    8180       208471 :     case 8518:  /* *vec_extractv8hi_zext */
    8181       208471 :     case 8517:  /* *vec_extractv16qi_zext */
    8182       208471 :     case 8516:  /* *vec_extractv16qi_zext */
    8183       208471 :     case 2415:  /* *pextrb_zext */
    8184       208471 :     case 2414:  /* *pextrb_zext */
    8185       208471 :     case 2413:  /* *pextrb_zext */
    8186       208471 :     case 2411:  /* *pextrw_zext */
    8187       208471 :     case 2410:  /* *pextrw_zext */
    8188       208471 :     case 2402:  /* *vec_extractv2si_zext_mem */
    8189       208471 :     case 2377:  /* *mmx_pextrb_zext */
    8190       208471 :     case 2376:  /* *mmx_pextrb_zext */
    8191       208471 :     case 2375:  /* *mmx_pextrb_zext */
    8192       208471 :     case 2373:  /* *mmx_pextrw_zext */
    8193       208471 :     case 2372:  /* *mmx_pextrw_zext */
    8194       208471 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8195       208471 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    8196       208471 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
    8197       208471 :       break;
    8198              : 
    8199       224629 :     case 8534:  /* *vec_extractv4ti */
    8200       224629 :     case 8533:  /* *vec_extractv2ti */
    8201       224629 :     case 8530:  /* *vec_extractv4si_mem */
    8202       224629 :     case 8528:  /* *vec_extractv4si */
    8203       224629 :     case 8522:  /* *vec_extractv8hi_mem */
    8204       224629 :     case 8521:  /* *vec_extractv16qi_mem */
    8205       224629 :     case 8515:  /* *vec_extractv8hi */
    8206       224629 :     case 8514:  /* *vec_extractv16qi */
    8207       224629 :     case 7110:  /* *vec_extractv4dfdf_valign */
    8208       224629 :     case 7109:  /* *vec_extractv8dfdf_valign */
    8209       224629 :     case 7108:  /* *vec_extractv8sfsf_valign */
    8210       224629 :     case 7107:  /* *vec_extractv16sfsf_valign */
    8211       224629 :     case 7106:  /* *vec_extractv4didi_valign */
    8212       224629 :     case 7105:  /* *vec_extractv8didi_valign */
    8213       224629 :     case 7104:  /* *vec_extractv8sisi_valign */
    8214       224629 :     case 7103:  /* *vec_extractv16sisi_valign */
    8215       224629 :     case 5400:  /* *vec_extractbf */
    8216       224629 :     case 5399:  /* *vec_extracthf */
    8217       224629 :     case 5336:  /* *vec_extractv4sf_mem */
    8218       224629 :     case 5335:  /* *sse4_1_extractps */
    8219       224629 :     case 2412:  /* *pextrb */
    8220       224629 :     case 2409:  /* *pextrwv2bf */
    8221       224629 :     case 2408:  /* *pextrwv2hf */
    8222       224629 :     case 2407:  /* *pextrw */
    8223       224629 :     case 2374:  /* *mmx_pextrb */
    8224       224629 :     case 2371:  /* *mmx_pextrwv4bf */
    8225       224629 :     case 2370:  /* *mmx_pextrwv4hf */
    8226       224629 :     case 2369:  /* *mmx_pextrw */
    8227       224629 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8228       224629 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    8229       224629 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    8230       224629 :       break;
    8231              : 
    8232       174024 :     case 8440:  /* sse4_1_pinsrq */
    8233       174024 :     case 8439:  /* sse4_1_pinsrd */
    8234       174024 :     case 8438:  /* sse2_pinsrbf */
    8235       174024 :     case 8437:  /* sse2_pinsrph */
    8236       174024 :     case 8436:  /* sse2_pinsrw */
    8237       174024 :     case 8435:  /* sse4_1_pinsrb */
    8238       174024 :     case 5322:  /* *vec_setv4sf_sse4_1 */
    8239       174024 :     case 2406:  /* *pinsrb */
    8240       174024 :     case 2405:  /* *pinsrw */
    8241       174024 :     case 2404:  /* *pinsrw */
    8242       174024 :     case 2403:  /* *pinsrw */
    8243       174024 :     case 2368:  /* *mmx_pinsrb */
    8244       174024 :     case 2367:  /* *mmx_pinsrw */
    8245       174024 :     case 2366:  /* *mmx_pinsrw */
    8246       174024 :     case 2365:  /* *mmx_pinsrw */
    8247       174024 :     case 2364:  /* *mmx_pinsrd */
    8248       174024 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8249       174024 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    8250       174024 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    8251       174024 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    8252       174024 :       break;
    8253              : 
    8254          881 :     case 9078:  /* xop_pcmov_v2df */
    8255          881 :     case 9077:  /* xop_pcmov_v4df256 */
    8256          881 :     case 9076:  /* xop_pcmov_v4sf */
    8257          881 :     case 9075:  /* xop_pcmov_v8sf256 */
    8258          881 :     case 9074:  /* xop_pcmov_v8hf */
    8259          881 :     case 9073:  /* xop_pcmov_v16hf256 */
    8260          881 :     case 9072:  /* xop_pcmov_v1ti */
    8261          881 :     case 9071:  /* xop_pcmov_v2ti256 */
    8262          881 :     case 9070:  /* xop_pcmov_v2di */
    8263          881 :     case 9069:  /* xop_pcmov_v4di256 */
    8264          881 :     case 9068:  /* xop_pcmov_v4si */
    8265          881 :     case 9067:  /* xop_pcmov_v8si256 */
    8266          881 :     case 9066:  /* xop_pcmov_v8hi */
    8267          881 :     case 9065:  /* xop_pcmov_v16hi256 */
    8268          881 :     case 9064:  /* xop_pcmov_v16qi */
    8269          881 :     case 9063:  /* xop_pcmov_v32qi256 */
    8270          881 :     case 2310:  /* *xop_pcmov_v2bf */
    8271          881 :     case 2309:  /* *xop_pcmov_v2hf */
    8272          881 :     case 2308:  /* *xop_pcmov_v2hi */
    8273          881 :     case 2307:  /* *xop_pcmov_v2qi */
    8274          881 :     case 2306:  /* *xop_pcmov_v4qi */
    8275          881 :     case 2305:  /* *xop_pcmov_v4bf */
    8276          881 :     case 2304:  /* *xop_pcmov_v4hf */
    8277          881 :     case 2303:  /* *xop_pcmov_v2sf */
    8278          881 :     case 2302:  /* *xop_pcmov_v2si */
    8279          881 :     case 2301:  /* *xop_pcmov_v4hi */
    8280          881 :     case 2300:  /* *xop_pcmov_v8qi */
    8281          881 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8282          881 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    8283          881 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 2));
    8284          881 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 0));
    8285          881 :       break;
    8286              : 
    8287           72 :     case 2299:  /* *mmx_pblendvb_v4qi_2 */
    8288           72 :     case 2292:  /* *mmx_pblendvb_v8qi_2 */
    8289           72 :     case 2291:  /* *mmx_pblendvb_v8qi_2 */
    8290           72 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8291           72 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
    8292           72 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    8293           72 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0), 0), 0));
    8294           72 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0), 0), 1));
    8295           72 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0), 1));
    8296           72 :       break;
    8297              : 
    8298           36 :     case 2298:  /* *mmx_pblendvb_v2hi_1 */
    8299           36 :     case 2297:  /* *mmx_pblendvb_v2qi_1 */
    8300           36 :     case 2296:  /* *mmx_pblendvb_v4qi_1 */
    8301           36 :     case 2290:  /* *mmx_pblendvb_v8qi_1 */
    8302           36 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8303           36 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
    8304           36 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    8305           36 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0), 0));
    8306           36 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0), 1));
    8307           36 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 1));
    8308           36 :       break;
    8309              : 
    8310         7867 :     case 9134:  /* xop_maskcmp_unsv2di3 */
    8311         7867 :     case 9133:  /* xop_maskcmp_unsv4si3 */
    8312         7867 :     case 9132:  /* xop_maskcmp_unsv8hi3 */
    8313         7867 :     case 9131:  /* xop_maskcmp_unsv16qi3 */
    8314         7867 :     case 9130:  /* xop_maskcmpv2di3 */
    8315         7867 :     case 9129:  /* xop_maskcmpv4si3 */
    8316         7867 :     case 9128:  /* xop_maskcmpv8hi3 */
    8317         7867 :     case 9127:  /* xop_maskcmpv16qi3 */
    8318         7867 :     case 2288:  /* *xop_maskcmp_unsv2hi3 */
    8319         7867 :     case 2287:  /* *xop_maskcmp_unsv2qi3 */
    8320         7867 :     case 2286:  /* *xop_maskcmp_unsv4qi3 */
    8321         7867 :     case 2285:  /* *xop_maskcmp_unsv2si3 */
    8322         7867 :     case 2284:  /* *xop_maskcmp_unsv4hi3 */
    8323         7867 :     case 2283:  /* *xop_maskcmp_unsv8qi3 */
    8324         7867 :     case 2282:  /* *xop_maskcmpv2hi3 */
    8325         7867 :     case 2281:  /* *xop_maskcmpv2qi3 */
    8326         7867 :     case 2280:  /* *xop_maskcmpv4qi3 */
    8327         7867 :     case 2279:  /* *xop_maskcmpv2si3 */
    8328         7867 :     case 2278:  /* *xop_maskcmpv4hi3 */
    8329         7867 :     case 2277:  /* *xop_maskcmpv8qi3 */
    8330         7867 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8331         7867 :       ro[1] = *(ro_loc[1] = &XEXP (pat, 1));
    8332         7867 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
    8333         7867 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    8334         7867 :       break;
    8335              : 
    8336       333746 :     case 7634:  /* *sse4_1_mulv2siv2di3 */
    8337       333746 :     case 7632:  /* *vec_widen_smult_even_v8si */
    8338       333746 :     case 7630:  /* *vec_widen_smult_even_v16si */
    8339       333746 :     case 7628:  /* *vec_widen_umult_even_v4si */
    8340       333746 :     case 7626:  /* *vec_widen_umult_even_v8si */
    8341       333746 :     case 7624:  /* *vec_widen_umult_even_v16si */
    8342       333746 :     case 2215:  /* *sse2_umulv1siv1di3 */
    8343       333746 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8344       333746 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    8345       333746 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
    8346       333746 :       break;
    8347              : 
    8348         1727 :     case 2430:  /* uavgv2hi3_ceil */
    8349         1727 :     case 2429:  /* uavgv2qi3_ceil */
    8350         1727 :     case 2428:  /* uavgv4qi3_ceil */
    8351         1727 :     case 2427:  /* *mmx_uavgv4hi3 */
    8352         1727 :     case 2426:  /* *mmx_uavgv8qi3 */
    8353         1727 :     case 2214:  /* *mmx_pmulhrwv4hi3 */
    8354         1727 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8355         1727 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0));
    8356         1727 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 1), 0));
    8357         1727 :       break;
    8358              : 
    8359        11903 :     case 8671:  /* ssse3_pmaddubsw */
    8360        11903 :     case 8670:  /* ssse3_pmaddubsw128 */
    8361        11903 :     case 8661:  /* avx2_pmaddubsw256 */
    8362        11903 :     case 7643:  /* *sse2_pmaddwd */
    8363        11903 :     case 7642:  /* *avx2_pmaddwd */
    8364        11903 :     case 2213:  /* *mmx_pmaddwd */
    8365        11903 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8366        11903 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    8367        11903 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0), 0));
    8368        11903 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 0);
    8369        11903 :       recog_data.dup_num[0] = 1;
    8370        11903 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 0), 0);
    8371        11903 :       recog_data.dup_num[1] = 2;
    8372        11903 :       break;
    8373              : 
    8374        13112 :     case 7622:  /* *umulv8hi3_highpart */
    8375        13112 :     case 7620:  /* *smulv8hi3_highpart */
    8376        13112 :     case 7618:  /* *umulv16hi3_highpart */
    8377        13112 :     case 7616:  /* *smulv16hi3_highpart */
    8378        13112 :     case 7614:  /* *umulv32hi3_highpart */
    8379        13112 :     case 7612:  /* *smulv32hi3_highpart */
    8380        13112 :     case 2212:  /* umulv2hi3_highpart */
    8381        13112 :     case 2211:  /* smulv2hi3_highpart */
    8382        13112 :     case 2210:  /* *mmx_umulv4hi3_highpart */
    8383        13112 :     case 2209:  /* *mmx_smulv4hi3_highpart */
    8384        13112 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8385        13112 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    8386        13112 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1), 0));
    8387        13112 :       break;
    8388              : 
    8389       252814 :     case 7241:  /* sse2_movsd_v2df */
    8390       252814 :     case 7240:  /* sse2_movsd_v2di */
    8391       252814 :     case 5321:  /* *avx512fp16_movv8bf */
    8392       252814 :     case 5320:  /* *avx512fp16_movv8hf */
    8393       252814 :     case 5319:  /* *avx512fp16_movv8hi */
    8394       252814 :     case 5281:  /* sse_movss_v4sf */
    8395       252814 :     case 5280:  /* sse_movss_v4si */
    8396       252814 :     case 2139:  /* *mmx_movss_v2si */
    8397       252814 :     case 2138:  /* *mmx_movss_v2sf */
    8398       252814 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8399       252814 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    8400       252814 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
    8401       252814 :       break;
    8402              : 
    8403          494 :     case 7452:  /* *avx512f_pshufd_truncv2div2si_1 */
    8404          494 :     case 2131:  /* mmx_pi2fw */
    8405          494 :     case 2130:  /* mmx_pf2iw */
    8406          494 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8407          494 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    8408          494 :       break;
    8409              : 
    8410       204298 :     case 8807:  /* avx2_pblenddv4si */
    8411       204298 :     case 8806:  /* avx2_pblenddv8si */
    8412       204298 :     case 8805:  /* *avx2_pblendbf */
    8413       204298 :     case 8804:  /* *avx2_pblendph */
    8414       204298 :     case 8803:  /* *avx2_pblendw */
    8415       204298 :     case 8802:  /* sse4_1_pblendbf */
    8416       204298 :     case 8801:  /* sse4_1_pblendph */
    8417       204298 :     case 8800:  /* sse4_1_pblendw */
    8418       204298 :     case 8738:  /* sse4_1_blendpd */
    8419       204298 :     case 8737:  /* avx_blendpd256 */
    8420       204298 :     case 8736:  /* sse4_1_blendps */
    8421       204298 :     case 8735:  /* avx_blendps256 */
    8422       204298 :     case 2583:  /* avx512vl_blendmv8bf */
    8423       204298 :     case 2582:  /* avx512vl_blendmv16bf */
    8424       204298 :     case 2581:  /* avx512bw_blendmv32bf */
    8425       204298 :     case 2580:  /* avx512fp16_blendmv8hf */
    8426       204298 :     case 2579:  /* avx512vl_blendmv16hf */
    8427       204298 :     case 2578:  /* avx512bw_blendmv32hf */
    8428       204298 :     case 2577:  /* avx512vl_blendmv8hi */
    8429       204298 :     case 2576:  /* avx512vl_blendmv16hi */
    8430       204298 :     case 2575:  /* avx512bw_blendmv32hi */
    8431       204298 :     case 2574:  /* avx512vl_blendmv32qi */
    8432       204298 :     case 2573:  /* avx512vl_blendmv16qi */
    8433       204298 :     case 2572:  /* avx512bw_blendmv64qi */
    8434       204298 :     case 2571:  /* avx512vl_blendmv2df */
    8435       204298 :     case 2570:  /* avx512vl_blendmv4df */
    8436       204298 :     case 2569:  /* avx512f_blendmv8df */
    8437       204298 :     case 2568:  /* avx512vl_blendmv4sf */
    8438       204298 :     case 2567:  /* avx512vl_blendmv8sf */
    8439       204298 :     case 2566:  /* avx512f_blendmv16sf */
    8440       204298 :     case 2565:  /* avx512vl_blendmv2di */
    8441       204298 :     case 2564:  /* avx512vl_blendmv4di */
    8442       204298 :     case 2563:  /* avx512f_blendmv8di */
    8443       204298 :     case 2562:  /* avx512vl_blendmv4si */
    8444       204298 :     case 2561:  /* avx512vl_blendmv8si */
    8445       204298 :     case 2560:  /* avx512f_blendmv16si */
    8446       204298 :     case 2389:  /* *mmx_pblendw32 */
    8447       204298 :     case 2388:  /* *mmx_pblendw32 */
    8448       204298 :     case 2387:  /* *mmx_pblendw32 */
    8449       204298 :     case 2386:  /* *mmx_pblendw64 */
    8450       204298 :     case 2385:  /* *mmx_pblendw64 */
    8451       204298 :     case 2384:  /* *mmx_pblendw64 */
    8452       204298 :     case 2122:  /* *mmx_blendps */
    8453       204298 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8454       204298 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    8455       204298 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
    8456       204298 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    8457       204298 :       break;
    8458              : 
    8459        18212 :     case 5332:  /* sse4_1_insertps_v4sf */
    8460        18212 :     case 5331:  /* sse4_1_insertps_v4si */
    8461        18212 :     case 2121:  /* sse4_1_insertps_v2si */
    8462        18212 :     case 2120:  /* sse4_1_insertps_v2sf */
    8463        18212 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8464        18212 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 1));
    8465        18212 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 0));
    8466        18212 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 2));
    8467        18212 :       break;
    8468              : 
    8469          310 :     case 2116:  /* *mmx_haddsubv2sf3 */
    8470          310 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8471          310 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    8472          310 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
    8473          310 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1), 0, 0));
    8474          310 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 1), 0, 0));
    8475          310 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0);
    8476          310 :       recog_data.dup_num[0] = 1;
    8477          310 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 0);
    8478          310 :       recog_data.dup_num[1] = 2;
    8479          310 :       break;
    8480              : 
    8481           30 :     case 3216:  /* *sse3_hsubv2df3_low */
    8482           30 :     case 2115:  /* *mmx_hsubv2sf3_low */
    8483           30 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8484           30 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    8485           30 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 1), 0);
    8486           30 :       recog_data.dup_num[0] = 1;
    8487           30 :       break;
    8488              : 
    8489          588 :     case 3214:  /* sse3_hsubv2df3 */
    8490          588 :     case 2114:  /* mmx_hsubv2sf3 */
    8491          588 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8492          588 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    8493          588 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
    8494          588 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0);
    8495          588 :       recog_data.dup_num[0] = 1;
    8496          588 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 0);
    8497          588 :       recog_data.dup_num[1] = 2;
    8498          588 :       break;
    8499              : 
    8500           72 :     case 3215:  /* *sse3_haddv2df3_low */
    8501           72 :     case 2113:  /* *mmx_haddv2sf3_low */
    8502           72 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8503           72 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    8504           72 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
    8505           72 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 0, 0));
    8506           72 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 1), 0);
    8507           72 :       recog_data.dup_num[0] = 1;
    8508           72 :       break;
    8509              : 
    8510          606 :     case 3213:  /* *sse3_haddv2df3 */
    8511          606 :     case 2112:  /* *mmx_haddv2sf3 */
    8512          606 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8513          606 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    8514          606 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
    8515          606 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1), 0, 0));
    8516          606 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 1), 0, 0));
    8517          606 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1), 0, 0));
    8518          606 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 1), 0, 0));
    8519          606 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0);
    8520          606 :       recog_data.dup_num[0] = 1;
    8521          606 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 1), 0);
    8522          606 :       recog_data.dup_num[1] = 2;
    8523          606 :       break;
    8524              : 
    8525       369241 :     case 9010:  /* ptesttf2 */
    8526       369241 :     case 9009:  /* *avx_ptestv4df */
    8527       369241 :     case 9008:  /* *avx_ptestv8sf */
    8528       369241 :     case 9007:  /* *avx_ptestv2ti */
    8529       369241 :     case 9006:  /* *avx_ptestv4di */
    8530       369241 :     case 9005:  /* *avx_ptestv8si */
    8531       369241 :     case 9004:  /* *avx_ptestv16hi */
    8532       369241 :     case 9003:  /* *avx_ptestv32qi */
    8533       369241 :     case 9002:  /* *sse4_1_ptestv2df */
    8534       369241 :     case 9001:  /* *sse4_1_ptestv4sf */
    8535       369241 :     case 9000:  /* *sse4_1_ptestv1ti */
    8536       369241 :     case 8999:  /* *sse4_1_ptestv2di */
    8537       369241 :     case 8998:  /* *sse4_1_ptestv4si */
    8538       369241 :     case 8997:  /* *sse4_1_ptestv8hi */
    8539       369241 :     case 8996:  /* *sse4_1_ptestv16qi */
    8540       369241 :     case 8995:  /* avx_vtestpd */
    8541       369241 :     case 8994:  /* avx_vtestpd256 */
    8542       369241 :     case 8993:  /* avx_vtestps */
    8543       369241 :     case 8992:  /* avx_vtestps256 */
    8544       369241 :     case 2679:  /* kortestdi_ccz */
    8545       369241 :     case 2678:  /* kortestsi_ccz */
    8546       369241 :     case 2677:  /* kortesthi_ccz */
    8547       369241 :     case 2676:  /* kortestqi_ccz */
    8548       369241 :     case 2675:  /* kortestdi_ccc */
    8549       369241 :     case 2674:  /* kortestsi_ccc */
    8550       369241 :     case 2673:  /* kortesthi_ccc */
    8551       369241 :     case 2672:  /* kortestqi_ccc */
    8552       369241 :     case 2671:  /* *kortestdi */
    8553       369241 :     case 2670:  /* *kortestsi */
    8554       369241 :     case 2669:  /* *kortesthi */
    8555       369241 :     case 2668:  /* *kortestqi */
    8556       369241 :     case 2667:  /* ktestdi */
    8557       369241 :     case 2666:  /* ktestsi */
    8558       369241 :     case 2665:  /* ktesthi */
    8559       369241 :     case 2664:  /* ktestqi */
    8560       369241 :     case 2049:  /* tpause */
    8561       369241 :     case 2045:  /* umwait */
    8562       369241 :     case 2040:  /* enqcmds_di */
    8563       369241 :     case 2039:  /* enqcmd_di */
    8564       369241 :     case 2038:  /* enqcmds_si */
    8565       369241 :     case 2037:  /* enqcmd_si */
    8566       369241 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (pat, 1), 0, 0));
    8567       369241 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 1));
    8568       369241 :       break;
    8569              : 
    8570          361 :     case 2034:  /* movdir64b_di */
    8571          361 :     case 2033:  /* movdir64b_si */
    8572          361 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 0), 0));
    8573          361 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
    8574          361 :       break;
    8575              : 
    8576          222 :     case 2025:  /* *rdpkru */
    8577          222 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8578          222 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8579          222 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    8580          222 :       break;
    8581              : 
    8582          286 :     case 2014:  /* xbegin_1 */
    8583          286 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8584          286 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
    8585          286 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 0);
    8586          286 :       recog_data.dup_num[0] = 0;
    8587          286 :       break;
    8588              : 
    8589         1036 :     case 2050:  /* tpause_rex64 */
    8590         1036 :     case 2046:  /* umwait_rex64 */
    8591         1036 :     case 1983:  /* lwp_lwpinsdi */
    8592         1036 :     case 1982:  /* lwp_lwpinssi */
    8593         1036 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (pat, 1), 0, 0));
    8594         1036 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 1));
    8595         1036 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 2));
    8596         1036 :       break;
    8597              : 
    8598       181166 :     case 1973:  /* fldenv */
    8599       181166 :       ro[0] = *(ro_loc[0] = &XVECEXP (XVECEXP (pat, 0, 0), 0, 0));
    8600       181166 :       break;
    8601              : 
    8602         3397 :     case 8642:  /* sse3_monitor_di */
    8603         3397 :     case 8641:  /* sse3_monitor_si */
    8604         3397 :     case 2026:  /* *wrpkru */
    8605         3397 :     case 2022:  /* monitorx_di */
    8606         3397 :     case 2021:  /* monitorx_si */
    8607         3397 :     case 2020:  /* mwaitx */
    8608         3397 :     case 1981:  /* lwp_lwpvaldi */
    8609         3397 :     case 1980:  /* lwp_lwpvalsi */
    8610         3397 :     case 1969:  /* xsetbv_rex64 */
    8611         3397 :     case 1967:  /* xrstors64 */
    8612         3397 :     case 1966:  /* xrstor64 */
    8613         3397 :     case 1965:  /* xrstors_rex64 */
    8614         3397 :     case 1964:  /* xrstor_rex64 */
    8615         3397 :       ro[0] = *(ro_loc[0] = &XVECEXP (pat, 0, 0));
    8616         3397 :       ro[1] = *(ro_loc[1] = &XVECEXP (pat, 0, 1));
    8617         3397 :       ro[2] = *(ro_loc[2] = &XVECEXP (pat, 0, 2));
    8618         3397 :       break;
    8619              : 
    8620          246 :     case 1945:  /* rdtscp_rex64 */
    8621          246 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8622          246 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8623          246 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 2), 0));
    8624          246 :       break;
    8625              : 
    8626          407 :     case 1944:  /* rdtscp */
    8627          407 :     case 1943:  /* rdtsc_rex64 */
    8628          407 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8629          407 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8630          407 :       break;
    8631              : 
    8632         1208 :     case 10089:  /* avx512dq_vmfpclassv2df */
    8633         1208 :     case 10087:  /* avx512dq_vmfpclassv4sf */
    8634         1208 :     case 10085:  /* avx512dq_vmfpclassv8hf */
    8635         1208 :     case 8320:  /* *avx512vl_testnmv2di3_zext */
    8636         1208 :     case 8319:  /* *avx512vl_testnmv2di3_zext */
    8637         1208 :     case 8318:  /* *avx512vl_testnmv2di3_zext */
    8638         1208 :     case 8317:  /* *avx512vl_testnmv4di3_zext */
    8639         1208 :     case 8316:  /* *avx512vl_testnmv4di3_zext */
    8640         1208 :     case 8315:  /* *avx512vl_testnmv4di3_zext */
    8641         1208 :     case 8314:  /* *avx512f_testnmv8di3_zext */
    8642         1208 :     case 8313:  /* *avx512f_testnmv8di3_zext */
    8643         1208 :     case 8312:  /* *avx512f_testnmv8di3_zext */
    8644         1208 :     case 8311:  /* *avx512vl_testnmv4si3_zext */
    8645         1208 :     case 8310:  /* *avx512vl_testnmv4si3_zext */
    8646         1208 :     case 8309:  /* *avx512vl_testnmv4si3_zext */
    8647         1208 :     case 8308:  /* *avx512vl_testnmv8si3_zext */
    8648         1208 :     case 8307:  /* *avx512vl_testnmv8si3_zext */
    8649         1208 :     case 8306:  /* *avx512vl_testnmv8si3_zext */
    8650         1208 :     case 8305:  /* *avx512f_testnmv16si3_zext */
    8651         1208 :     case 8304:  /* *avx512f_testnmv16si3_zext */
    8652         1208 :     case 8303:  /* *avx512f_testnmv16si3_zext */
    8653         1208 :     case 8302:  /* *avx512vl_testnmv8hi3_zext */
    8654         1208 :     case 8301:  /* *avx512vl_testnmv8hi3_zext */
    8655         1208 :     case 8300:  /* *avx512vl_testnmv8hi3_zext */
    8656         1208 :     case 8299:  /* *avx512vl_testnmv16hi3_zext */
    8657         1208 :     case 8298:  /* *avx512vl_testnmv16hi3_zext */
    8658         1208 :     case 8297:  /* *avx512vl_testnmv16hi3_zext */
    8659         1208 :     case 8296:  /* *avx512bw_testnmv32hi3_zext */
    8660         1208 :     case 8295:  /* *avx512bw_testnmv32hi3_zext */
    8661         1208 :     case 8294:  /* *avx512bw_testnmv32hi3_zext */
    8662         1208 :     case 8293:  /* *avx512vl_testnmv16qi3_zext */
    8663         1208 :     case 8292:  /* *avx512vl_testnmv16qi3_zext */
    8664         1208 :     case 8291:  /* *avx512vl_testnmv16qi3_zext */
    8665         1208 :     case 8290:  /* *avx512vl_testnmv32qi3_zext */
    8666         1208 :     case 8289:  /* *avx512vl_testnmv32qi3_zext */
    8667         1208 :     case 8288:  /* *avx512vl_testnmv32qi3_zext */
    8668         1208 :     case 8287:  /* *avx512bw_testnmv64qi3_zext */
    8669         1208 :     case 8286:  /* *avx512bw_testnmv64qi3_zext */
    8670         1208 :     case 8285:  /* *avx512bw_testnmv64qi3_zext */
    8671         1208 :     case 8248:  /* *avx512vl_testmv2di3_zext */
    8672         1208 :     case 8247:  /* *avx512vl_testmv2di3_zext */
    8673         1208 :     case 8246:  /* *avx512vl_testmv2di3_zext */
    8674         1208 :     case 8245:  /* *avx512vl_testmv4di3_zext */
    8675         1208 :     case 8244:  /* *avx512vl_testmv4di3_zext */
    8676         1208 :     case 8243:  /* *avx512vl_testmv4di3_zext */
    8677         1208 :     case 8242:  /* *avx512f_testmv8di3_zext */
    8678         1208 :     case 8241:  /* *avx512f_testmv8di3_zext */
    8679         1208 :     case 8240:  /* *avx512f_testmv8di3_zext */
    8680         1208 :     case 8239:  /* *avx512vl_testmv4si3_zext */
    8681         1208 :     case 8238:  /* *avx512vl_testmv4si3_zext */
    8682         1208 :     case 8237:  /* *avx512vl_testmv4si3_zext */
    8683         1208 :     case 8236:  /* *avx512vl_testmv8si3_zext */
    8684         1208 :     case 8235:  /* *avx512vl_testmv8si3_zext */
    8685         1208 :     case 8234:  /* *avx512vl_testmv8si3_zext */
    8686         1208 :     case 8233:  /* *avx512f_testmv16si3_zext */
    8687         1208 :     case 8232:  /* *avx512f_testmv16si3_zext */
    8688         1208 :     case 8231:  /* *avx512f_testmv16si3_zext */
    8689         1208 :     case 8230:  /* *avx512vl_testmv8hi3_zext */
    8690         1208 :     case 8229:  /* *avx512vl_testmv8hi3_zext */
    8691         1208 :     case 8228:  /* *avx512vl_testmv8hi3_zext */
    8692         1208 :     case 8227:  /* *avx512vl_testmv16hi3_zext */
    8693         1208 :     case 8226:  /* *avx512vl_testmv16hi3_zext */
    8694         1208 :     case 8225:  /* *avx512vl_testmv16hi3_zext */
    8695         1208 :     case 8224:  /* *avx512bw_testmv32hi3_zext */
    8696         1208 :     case 8223:  /* *avx512bw_testmv32hi3_zext */
    8697         1208 :     case 8222:  /* *avx512bw_testmv32hi3_zext */
    8698         1208 :     case 8221:  /* *avx512vl_testmv16qi3_zext */
    8699         1208 :     case 8220:  /* *avx512vl_testmv16qi3_zext */
    8700         1208 :     case 8219:  /* *avx512vl_testmv16qi3_zext */
    8701         1208 :     case 8218:  /* *avx512vl_testmv32qi3_zext */
    8702         1208 :     case 8217:  /* *avx512vl_testmv32qi3_zext */
    8703         1208 :     case 8216:  /* *avx512vl_testmv32qi3_zext */
    8704         1208 :     case 8215:  /* *avx512bw_testmv64qi3_zext */
    8705         1208 :     case 8214:  /* *avx512bw_testmv64qi3_zext */
    8706         1208 :     case 8213:  /* *avx512bw_testmv64qi3_zext */
    8707         1208 :     case 7293:  /* *avx512f_permvar_truncv4div4si_1 */
    8708         1208 :     case 7292:  /* *avx512f_permvar_truncv16hiv16qi_1 */
    8709         1208 :     case 7279:  /* *avx512f_permvar_truncv32hiv32qi_1 */
    8710         1208 :     case 7263:  /* *avx512f_vpermvar_truncv8div8si_1 */
    8711         1208 :     case 7261:  /* *avx512f_permvar_truncv8siv8hi_1 */
    8712         1208 :     case 7259:  /* *avx512bw_permvar_truncv16siv16hi_1 */
    8713         1208 :     case 3456:  /* *avx512vl_eqv2di_and3 */
    8714         1208 :     case 3455:  /* *avx512vl_eqv2di_and3 */
    8715         1208 :     case 3451:  /* *avx512vl_eqv4di3_and15 */
    8716         1208 :     case 3450:  /* *avx512vl_eqv4di3_and15 */
    8717         1208 :     case 3449:  /* *avx512vl_eqv4si3_and15 */
    8718         1208 :     case 3448:  /* *avx512vl_eqv4si3_and15 */
    8719         1208 :     case 1939:  /* sse4_2_crc32di */
    8720         1208 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8721         1208 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    8722         1208 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    8723         1208 :       break;
    8724              : 
    8725       291515 :     case 1932:  /* *prefetch_sse */
    8726       291515 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8727       291515 :       ro[1] = *(ro_loc[1] = &XEXP (pat, 2));
    8728       291515 :       break;
    8729              : 
    8730            6 :     case 1927:  /* *stack_protect_set_4s_di_di */
    8731            6 :     case 1926:  /* *stack_protect_set_4s_si_di */
    8732            6 :     case 1925:  /* *stack_protect_set_4z_di_di */
    8733            6 :     case 1924:  /* *stack_protect_set_4z_si_di */
    8734            6 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8735            6 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8736            6 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0));
    8737            6 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    8738            6 :       break;
    8739              : 
    8740          273 :     case 1923:  /* *stack_protect_set_3_di_di */
    8741          273 :     case 1922:  /* *stack_protect_set_3_di_si */
    8742          273 :     case 1921:  /* *stack_protect_set_3_si_di */
    8743          273 :     case 1920:  /* *stack_protect_set_3_si_si */
    8744          273 :     case 1919:  /* *stack_protect_set_2_di_di */
    8745          273 :     case 1918:  /* *stack_protect_set_2_si_di */
    8746          273 :     case 1917:  /* *stack_protect_set_2_di_si */
    8747          273 :     case 1916:  /* *stack_protect_set_2_si_si */
    8748          273 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8749          273 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8750          273 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 1));
    8751          273 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    8752          273 :       break;
    8753              : 
    8754           48 :     case 1909:  /* adjust_stack_and_probe_di */
    8755           48 :     case 1908:  /* adjust_stack_and_probe_si */
    8756           48 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8757           48 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    8758           48 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
    8759           48 :       break;
    8760              : 
    8761          922 :     case 1892:  /* *plus_within_umindi3_2 */
    8762          922 :     case 1890:  /* *plus_within_umaxdi3_2 */
    8763          922 :     case 1888:  /* *plus_within_uminsi3_2 */
    8764          922 :     case 1886:  /* *plus_within_umaxsi3_2 */
    8765          922 :     case 1884:  /* *plus_within_uminhi3_2 */
    8766          922 :     case 1882:  /* *plus_within_umaxhi3_2 */
    8767          922 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8768          922 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    8769          922 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
    8770          922 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
    8771          922 :       recog_data.dup_num[0] = 2;
    8772          922 :       break;
    8773              : 
    8774          425 :     case 1898:  /* *minus_within_umindi3 */
    8775          425 :     case 1897:  /* *minus_within_umaxdi3 */
    8776          425 :     case 1896:  /* *minus_within_uminsi3 */
    8777          425 :     case 1895:  /* *minus_within_umaxsi3 */
    8778          425 :     case 1894:  /* *minus_within_uminhi3 */
    8779          425 :     case 1893:  /* *minus_within_umaxhi3 */
    8780          425 :     case 1891:  /* *plus_within_umindi3_1 */
    8781          425 :     case 1889:  /* *plus_within_umaxdi3_1 */
    8782          425 :     case 1887:  /* *plus_within_uminsi3_1 */
    8783          425 :     case 1885:  /* *plus_within_umaxsi3_1 */
    8784          425 :     case 1883:  /* *plus_within_uminhi3_1 */
    8785          425 :     case 1881:  /* *plus_within_umaxhi3_1 */
    8786          425 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8787          425 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    8788          425 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
    8789          425 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
    8790          425 :       recog_data.dup_num[0] = 1;
    8791          425 :       break;
    8792              : 
    8793         1998 :     case 8795:  /* *sse4_1_pblendvb_gt */
    8794         1998 :     case 8794:  /* *avx2_pblendvb_gt */
    8795         1998 :     case 8793:  /* *sse4_1_pblendvb_lt */
    8796         1998 :     case 8792:  /* *avx2_pblendvb_lt */
    8797         1998 :     case 8752:  /* *sse4_1_blendvpd_gt */
    8798         1998 :     case 8751:  /* *avx_blendvpd256_gt */
    8799         1998 :     case 8750:  /* *sse4_1_blendvps_gt */
    8800         1998 :     case 8749:  /* *avx_blendvps256_gt */
    8801         1998 :     case 8748:  /* *sse4_1_blendvpd_lt */
    8802         1998 :     case 8747:  /* *avx_blendvpd256_lt */
    8803         1998 :     case 8746:  /* *sse4_1_blendvps_lt */
    8804         1998 :     case 8745:  /* *avx_blendvps256_lt */
    8805         1998 :     case 3096:  /* *minmaxv2df3_2 */
    8806         1998 :     case 3095:  /* *minmaxv4df3_2 */
    8807         1998 :     case 3094:  /* *minmaxv4sf3_2 */
    8808         1998 :     case 3093:  /* *minmaxv8sf3_2 */
    8809         1998 :     case 1856:  /* *ieee_mindf3_1 */
    8810         1998 :     case 1855:  /* *ieee_minsf3_1 */
    8811         1998 :     case 1854:  /* *ieee_maxdf3_1 */
    8812         1998 :     case 1853:  /* *ieee_maxsf3_1 */
    8813         1998 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8814         1998 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
    8815         1998 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    8816         1998 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0));
    8817         1998 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 1));
    8818         1998 :       break;
    8819              : 
    8820         7348 :     case 1833:  /* *movsicc_noc_zext_1 */
    8821         7348 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8822         7348 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    8823         7348 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    8824         7348 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    8825         7348 :       break;
    8826              : 
    8827            0 :     case 1832:  /* *movsicc_noc_zext */
    8828            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8829            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    8830            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    8831            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 2), 0));
    8832            0 :       break;
    8833              : 
    8834      6593810 :     case 10717:  /* avx10_2_fmaddbf16_v8bf */
    8835      6593810 :     case 10715:  /* avx10_2_fmaddbf16_v16bf */
    8836      6593810 :     case 10713:  /* avx10_2_fmaddbf16_v32bf */
    8837      6593810 :     case 3888:  /* *fma_fmadd_v2df */
    8838      6593810 :     case 3886:  /* *fma_fmadd_v4df */
    8839      6593810 :     case 3882:  /* *fma_fmadd_v8df */
    8840      6593810 :     case 3881:  /* *fma_fmadd_df */
    8841      6593810 :     case 3879:  /* *fma_fmadd_v4sf */
    8842      6593810 :     case 3877:  /* *fma_fmadd_v8sf */
    8843      6593810 :     case 3873:  /* *fma_fmadd_v16sf */
    8844      6593810 :     case 3872:  /* *fma_fmadd_sf */
    8845      6593810 :     case 3871:  /* *fma_fmadd_hf */
    8846      6593810 :     case 3869:  /* *fma_fmadd_v8hf */
    8847      6593810 :     case 3867:  /* *fma_fmadd_v16hf */
    8848      6593810 :     case 3863:  /* *fma_fmadd_v32hf */
    8849      6593810 :     case 3862:  /* *fma_fmadd_v4df */
    8850      6593810 :     case 3861:  /* *fma_fmadd_v8sf */
    8851      6593810 :     case 3860:  /* *fma_fmadd_v2df */
    8852      6593810 :     case 3859:  /* *fma_fmadd_v4sf */
    8853      6593810 :     case 3858:  /* *fma_fmadd_df */
    8854      6593810 :     case 3857:  /* *fma_fmadd_sf */
    8855      6593810 :     case 1840:  /* *xop_pcmov_df */
    8856      6593810 :     case 1839:  /* *xop_pcmov_sf */
    8857      6593810 :     case 1838:  /* *movsfcc_1_387 */
    8858      6593810 :     case 1837:  /* *movdfcc_1 */
    8859      6593810 :     case 1836:  /* *movxfcc_1 */
    8860      6593810 :     case 1834:  /* *movqicc_noc */
    8861      6593810 :     case 1831:  /* *movdicc_noc */
    8862      6593810 :     case 1830:  /* *movsicc_noc */
    8863      6593810 :     case 1829:  /* *movhicc_noc */
    8864      6593810 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8865      6593810 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    8866      6593810 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    8867      6593810 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    8868      6593810 :       break;
    8869              : 
    8870            0 :     case 1820:  /* *strlenqi_1 */
    8871            0 :     case 1819:  /* *strlenqi_1 */
    8872            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8873            0 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8874            0 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    8875            0 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
    8876            0 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 3));
    8877            0 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0), 0));
    8878            0 :       break;
    8879              : 
    8880       174547 :     case 1818:  /* *cmpstrnqi_1 */
    8881       174547 :     case 1817:  /* *cmpstrnqi_1 */
    8882       174547 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 2), 0));
    8883       174547 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 3), 0));
    8884       174547 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 4), 0));
    8885       174547 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8886       174547 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0));
    8887       174547 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 0));
    8888       174547 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    8889       174547 :       break;
    8890              : 
    8891            0 :     case 1816:  /* *cmpstrnqi_nz_1 */
    8892            0 :     case 1815:  /* *cmpstrnqi_nz_1 */
    8893            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 3), 0));
    8894            0 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 4), 0));
    8895            0 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 5), 0));
    8896            0 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 2), 0));
    8897            0 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    8898            0 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
    8899            0 :       ro[6] = *(ro_loc[6] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8900            0 :       break;
    8901              : 
    8902        27657 :     case 1814:  /* *rep_stosqi */
    8903        27657 :     case 1813:  /* *rep_stosqi */
    8904        27657 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8905        27657 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8906        27657 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 3), 0));
    8907        27657 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0));
    8908        27657 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
    8909        27657 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 4), 0);
    8910        27657 :       recog_data.dup_num[0] = 4;
    8911        27657 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 0), 0);
    8912        27657 :       recog_data.dup_num[1] = 3;
    8913        27657 :       break;
    8914              : 
    8915       106180 :     case 1812:  /* *rep_stossi */
    8916       106180 :     case 1811:  /* *rep_stossi */
    8917       106180 :     case 1810:  /* *rep_stosdi_rex64 */
    8918       106180 :     case 1809:  /* *rep_stosdi_rex64 */
    8919       106180 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8920       106180 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8921       106180 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 3), 0));
    8922       106180 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
    8923       106180 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0));
    8924       106180 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 4), 0);
    8925       106180 :       recog_data.dup_num[0] = 4;
    8926       106180 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 0), 0);
    8927       106180 :       recog_data.dup_num[1] = 3;
    8928       106180 :       break;
    8929              : 
    8930            0 :     case 1808:  /* *strsetqi_1 */
    8931            0 :     case 1807:  /* *strsetqi_1 */
    8932            0 :     case 1806:  /* *strsethi_1 */
    8933            0 :     case 1805:  /* *strsethi_1 */
    8934            0 :     case 1804:  /* *strsetsi_1 */
    8935            0 :     case 1803:  /* *strsetsi_1 */
    8936            0 :     case 1802:  /* *strsetdi_rex_1 */
    8937            0 :     case 1801:  /* *strsetdi_rex_1 */
    8938            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8939            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
    8940            0 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 0), 1));
    8941            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
    8942            0 :       recog_data.dup_num[0] = 1;
    8943            0 :       break;
    8944              : 
    8945       118934 :     case 1800:  /* *rep_movqi */
    8946       118934 :     case 1799:  /* *rep_movqi */
    8947       118934 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8948       118934 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 2), 0));
    8949       118934 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8950       118934 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0));
    8951       118934 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0));
    8952       118934 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
    8953       118934 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 4), 0);
    8954       118934 :       recog_data.dup_num[0] = 5;
    8955       118934 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 3), 0), 0);
    8956       118934 :       recog_data.dup_num[1] = 3;
    8957       118934 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 3), 1), 0);
    8958       118934 :       recog_data.dup_num[2] = 4;
    8959       118934 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 1), 1);
    8960       118934 :       recog_data.dup_num[3] = 5;
    8961       118934 :       break;
    8962              : 
    8963       169082 :     case 1798:  /* *rep_movsi */
    8964       169082 :     case 1797:  /* *rep_movsi */
    8965       169082 :     case 1796:  /* *rep_movdi_rex64 */
    8966       169082 :     case 1795:  /* *rep_movdi_rex64 */
    8967       169082 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8968       169082 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 2), 0));
    8969       169082 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8970       169082 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
    8971       169082 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 1), 1));
    8972       169082 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0));
    8973       169082 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 4), 0);
    8974       169082 :       recog_data.dup_num[0] = 5;
    8975       169082 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 3), 0), 0);
    8976       169082 :       recog_data.dup_num[1] = 3;
    8977       169082 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 3), 1), 0);
    8978       169082 :       recog_data.dup_num[2] = 4;
    8979       169082 :       recog_data.dup_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0), 0);
    8980       169082 :       recog_data.dup_num[3] = 5;
    8981       169082 :       break;
    8982              : 
    8983          487 :     case 1794:  /* *strmovqi_1 */
    8984          487 :     case 1793:  /* *strmovqi_1 */
    8985          487 :     case 1792:  /* *strmovhi_1 */
    8986          487 :     case 1791:  /* *strmovhi_1 */
    8987          487 :     case 1790:  /* *strmovsi_1 */
    8988          487 :     case 1789:  /* *strmovsi_1 */
    8989          487 :     case 1788:  /* *strmovdi_rex_1 */
    8990          487 :     case 1787:  /* *strmovdi_rex_1 */
    8991          487 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8992          487 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 2), 0));
    8993          487 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
    8994          487 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    8995          487 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0);
    8996          487 :       recog_data.dup_num[0] = 3;
    8997          487 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
    8998          487 :       recog_data.dup_num[1] = 2;
    8999          487 :       break;
    9000              : 
    9001         1954 :     case 1777:  /* fistdi2_ceil */
    9002         1954 :     case 1776:  /* fistdi2_floor */
    9003         1954 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9004         1954 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9005         1954 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9006         1954 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 2), 0));
    9007         1954 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 3), 0));
    9008         1954 :       break;
    9009              : 
    9010        30669 :     case 11080:  /* atomic_storedi_fpu */
    9011        30669 :     case 11075:  /* atomic_loaddi_fpu */
    9012        30669 :     case 1781:  /* fistsi2_ceil */
    9013        30669 :     case 1780:  /* fistsi2_floor */
    9014        30669 :     case 1779:  /* fisthi2_ceil */
    9015        30669 :     case 1778:  /* fisthi2_floor */
    9016        30669 :     case 1769:  /* frndintxf2_trunc_i387 */
    9017        30669 :     case 1768:  /* frndintxf2_ceil_i387 */
    9018        30669 :     case 1767:  /* frndintxf2_floor_i387 */
    9019        30669 :     case 1766:  /* frndintxf2_roundeven_i387 */
    9020        30669 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9021        30669 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9022        30669 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9023        30669 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 2), 0));
    9024        30669 :       break;
    9025              : 
    9026          669 :     case 1752:  /* fscalexf4_i387 */
    9027          669 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9028          669 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9029          669 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9030          669 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    9031          669 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 1);
    9032          669 :       recog_data.dup_num[0] = 3;
    9033          669 :       recog_data.dup_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 0);
    9034          669 :       recog_data.dup_num[1] = 2;
    9035          669 :       break;
    9036              : 
    9037         6461 :     case 1929:  /* stack_protect_test_1_di */
    9038         6461 :     case 1928:  /* stack_protect_test_1_si */
    9039         6461 :     case 1749:  /* fyl2xp1xf3_i387 */
    9040         6461 :     case 1748:  /* fyl2xxf3_i387 */
    9041         6461 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9042         6461 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9043         6461 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    9044         6461 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9045         6461 :       break;
    9046              : 
    9047          177 :     case 1747:  /* atan2xf3 */
    9048          177 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9049          177 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    9050          177 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9051          177 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9052          177 :       break;
    9053              : 
    9054           34 :     case 1746:  /* fptanxf4_i387 */
    9055           34 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9056           34 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9057           34 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 0));
    9058           34 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 0), 1));
    9059           34 :       break;
    9060              : 
    9061          730 :     case 1971:  /* xgetbv_rex64 */
    9062          730 :     case 1941:  /* rdpmc_rex64 */
    9063          730 :     case 1750:  /* fxtractxf3_i387 */
    9064          730 :     case 1745:  /* sincosxf3 */
    9065          730 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9066          730 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9067          730 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9068          730 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 0);
    9069          730 :       recog_data.dup_num[0] = 2;
    9070          730 :       break;
    9071              : 
    9072         5378 :     case 1742:  /* fprem1xf4_i387 */
    9073         5378 :     case 1741:  /* fpremxf4_i387 */
    9074         5378 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9075         5378 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9076         5378 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9077         5378 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    9078         5378 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0, 1);
    9079         5378 :       recog_data.dup_num[0] = 3;
    9080         5378 :       recog_data.dup_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0, 0);
    9081         5378 :       recog_data.dup_num[1] = 2;
    9082         5378 :       recog_data.dup_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 1);
    9083         5378 :       recog_data.dup_num[2] = 3;
    9084         5378 :       recog_data.dup_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0, 0);
    9085         5378 :       recog_data.dup_num[3] = 2;
    9086         5378 :       break;
    9087              : 
    9088        79672 :     case 1731:  /* *fop_df_6_i387 */
    9089        79672 :     case 1730:  /* *fop_xf_6_i387 */
    9090        79672 :     case 1729:  /* *fop_xf_6_i387 */
    9091        79672 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    9092        79672 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    9093        79672 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    9094        79672 :       ro[3] = *(ro_loc[3] = &XEXP (pat, 1));
    9095        79672 :       break;
    9096              : 
    9097        64689 :     case 1728:  /* *fop_df_5_i387 */
    9098        64689 :     case 1727:  /* *fop_xf_5_i387 */
    9099        64689 :     case 1726:  /* *fop_xf_5_i387 */
    9100        64689 :     case 1722:  /* *fop_xf_3_i387 */
    9101        64689 :     case 1721:  /* *fop_df_3_i387 */
    9102        64689 :     case 1720:  /* *fop_sf_3_i387 */
    9103        64689 :     case 1719:  /* *fop_xf_3_i387 */
    9104        64689 :     case 1718:  /* *fop_df_3_i387 */
    9105        64689 :     case 1717:  /* *fop_sf_3_i387 */
    9106        64689 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    9107        64689 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    9108        64689 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    9109        64689 :       ro[3] = *(ro_loc[3] = &XEXP (pat, 1));
    9110        64689 :       break;
    9111              : 
    9112        89267 :     case 1725:  /* *fop_df_4_i387 */
    9113        89267 :     case 1724:  /* *fop_xf_4_i387 */
    9114        89267 :     case 1723:  /* *fop_xf_4_i387 */
    9115        89267 :     case 1716:  /* *fop_xf_2_i387 */
    9116        89267 :     case 1715:  /* *fop_df_2_i387 */
    9117        89267 :     case 1714:  /* *fop_sf_2_i387 */
    9118        89267 :     case 1713:  /* *fop_xf_2_i387 */
    9119        89267 :     case 1712:  /* *fop_df_2_i387 */
    9120        89267 :     case 1711:  /* *fop_sf_2_i387 */
    9121        89267 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    9122        89267 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    9123        89267 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    9124        89267 :       ro[3] = *(ro_loc[3] = &XEXP (pat, 1));
    9125        89267 :       break;
    9126              : 
    9127           95 :     case 1698:  /* *tls_dynamic_gnu2_combine_64_di */
    9128           95 :     case 1697:  /* *tls_dynamic_gnu2_combine_64_si */
    9129           95 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9130           95 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0, 0));
    9131           95 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 0));
    9132           95 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1));
    9133           95 :       break;
    9134              : 
    9135            0 :     case 1692:  /* *tls_dynamic_gnu2_combine_32 */
    9136            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9137            0 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0, 0));
    9138            0 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 2));
    9139            0 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 0));
    9140            0 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1));
    9141            0 :       break;
    9142              : 
    9143            0 :     case 1691:  /* *tls_dynamic_gnu2_call_32 */
    9144            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9145            0 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9146            0 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    9147            0 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
    9148            0 :       break;
    9149              : 
    9150            0 :     case 1690:  /* *tls_dynamic_gnu2_lea_32 */
    9151            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    9152            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    9153            0 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0, 0));
    9154            0 :       break;
    9155              : 
    9156            6 :     case 1689:  /* *add_tp_x32_zext */
    9157            6 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9158            6 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
    9159            6 :       break;
    9160              : 
    9161         5665 :     case 1688:  /* *add_tp_di */
    9162         5665 :     case 1687:  /* *add_tp_si */
    9163         5665 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9164         5665 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    9165         5665 :       break;
    9166              : 
    9167          156 :     case 1683:  /* *tls_local_dynamic_32_once */
    9168          156 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9169          156 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 0));
    9170          156 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1));
    9171          156 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0, 0));
    9172          156 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9173          156 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (pat, 0, 2), 0));
    9174          156 :       break;
    9175              : 
    9176           13 :     case 1682:  /* *tls_local_dynamic_base_64_largepic */
    9177           13 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9178           13 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
    9179           13 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
    9180           13 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    9181           13 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 2), 0));
    9182           13 :       break;
    9183              : 
    9184         2408 :     case 1681:  /* *tls_local_dynamic_base_64_di */
    9185         2408 :     case 1680:  /* *tls_local_dynamic_base_64_si */
    9186         2408 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9187         2408 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    9188         2408 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    9189         2408 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 2), 0));
    9190         2408 :       break;
    9191              : 
    9192          884 :     case 1679:  /* *tls_local_dynamic_base_32_gnu */
    9193          884 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9194          884 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9195          884 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    9196          884 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9197          884 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 2), 0));
    9198          884 :       break;
    9199              : 
    9200           13 :     case 1678:  /* *tls_global_dynamic_64_largepic */
    9201           13 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9202           13 :       ro[1] = *(ro_loc[1] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    9203           13 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
    9204           13 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
    9205           13 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    9206           13 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (pat, 0, 2), 0));
    9207           13 :       break;
    9208              : 
    9209        32439 :     case 1677:  /* *tls_global_dynamic_64_di */
    9210        32439 :     case 1676:  /* *tls_global_dynamic_64_si */
    9211        32439 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9212        32439 :       ro[1] = *(ro_loc[1] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    9213        32439 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    9214        32439 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    9215        32439 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 2), 0));
    9216        32439 :       break;
    9217              : 
    9218        32410 :     case 1675:  /* *tls_global_dynamic_32_gnu */
    9219        32410 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9220        32410 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9221        32410 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    9222        32410 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
    9223        32410 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9224        32410 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (pat, 0, 2), 0));
    9225        32410 :       break;
    9226              : 
    9227         2525 :     case 1673:  /* parityhi2_cmp */
    9228         2525 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9229         2525 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0);
    9230         2525 :       recog_data.dup_num[0] = 0;
    9231         2525 :       break;
    9232              : 
    9233            0 :     case 1672:  /* bswaphisi2_lowpart */
    9234            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    9235            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    9236            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0);
    9237            0 :       recog_data.dup_num[0] = 1;
    9238            0 :       break;
    9239              : 
    9240         1488 :     case 1649:  /* *tbm_tzmsk_di */
    9241         1488 :     case 1648:  /* *tbm_tzmsk_si */
    9242         1488 :     case 1647:  /* *tbm_t1mskc_di */
    9243         1488 :     case 1646:  /* *tbm_t1mskc_si */
    9244         1488 :     case 1645:  /* *tbm_blsic_di */
    9245         1488 :     case 1644:  /* *tbm_blsic_si */
    9246         1488 :     case 1637:  /* *tbm_blcic_di */
    9247         1488 :     case 1636:  /* *tbm_blcic_si */
    9248         1488 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9249         1488 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    9250         1488 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0);
    9251         1488 :       recog_data.dup_num[0] = 1;
    9252         1488 :       break;
    9253              : 
    9254            0 :     case 1635:  /* *tbm_blci_di */
    9255            0 :     case 1634:  /* *tbm_blci_si */
    9256            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9257            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
    9258            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
    9259            0 :       recog_data.dup_num[0] = 1;
    9260            0 :       break;
    9261              : 
    9262          396 :     case 1631:  /* tbm_bextri_di */
    9263          396 :     case 1630:  /* tbm_bextri_si */
    9264          396 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9265          396 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    9266          396 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    9267          396 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 2));
    9268          396 :       break;
    9269              : 
    9270            0 :     case 1625:  /* *bmi2_bzhi_zero_extendsidi_5 */
    9271            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9272            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    9273            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 1));
    9274            0 :       break;
    9275              : 
    9276           17 :     case 1624:  /* *bmi2_bzhi_zero_extendsidi_4 */
    9277           17 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9278           17 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
    9279           17 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 1));
    9280           17 :       break;
    9281              : 
    9282           17 :     case 1619:  /* *bmi2_bzhi_di3_1_ccz */
    9283           17 :     case 1618:  /* *bmi2_bzhi_si3_1_ccz */
    9284           17 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9285           17 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
    9286           17 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
    9287           17 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 1), 1));
    9288           17 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 1), 0);
    9289           17 :       recog_data.dup_num[0] = 2;
    9290           17 :       break;
    9291              : 
    9292         1088 :     case 1617:  /* *bmi2_bzhi_di3 */
    9293         1088 :     case 1616:  /* *bmi2_bzhi_si3 */
    9294         1088 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9295         1088 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
    9296         1088 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    9297         1088 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 1));
    9298         1088 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 0);
    9299         1088 :       recog_data.dup_num[0] = 2;
    9300         1088 :       break;
    9301              : 
    9302            4 :     case 1607:  /* *bmi_blsmsk_di_falsedep */
    9303            4 :     case 1606:  /* *bmi_blsmsk_si_falsedep */
    9304            4 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9305            4 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    9306            4 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (pat, 0, 2), 0, 0));
    9307            4 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
    9308            4 :       recog_data.dup_num[0] = 1;
    9309            4 :       break;
    9310              : 
    9311          180 :     case 1615:  /* *bmi_blsr_di_ccz */
    9312          180 :     case 1614:  /* *bmi_blsr_si_ccz */
    9313          180 :     case 1603:  /* *bmi_blsi_di_ccno */
    9314          180 :     case 1602:  /* *bmi_blsi_si_ccno */
    9315          180 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9316          180 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
    9317          180 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1);
    9318          180 :       recog_data.dup_num[0] = 1;
    9319          180 :       break;
    9320              : 
    9321           16 :     case 1613:  /* *bmi_blsr_di_cmp_falsedep */
    9322           16 :     case 1612:  /* *bmi_blsr_si_cmp_falsedep */
    9323           16 :     case 1601:  /* *bmi_blsi_di_falsedep */
    9324           16 :     case 1600:  /* *bmi_blsi_si_falsedep */
    9325           16 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9326           16 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
    9327           16 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (pat, 0, 2), 0, 0));
    9328           16 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
    9329           16 :       recog_data.dup_num[0] = 1;
    9330           16 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
    9331           16 :       recog_data.dup_num[1] = 1;
    9332           16 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1);
    9333           16 :       recog_data.dup_num[2] = 1;
    9334           16 :       break;
    9335              : 
    9336           44 :     case 1611:  /* *bmi_blsr_di_cmp */
    9337           44 :     case 1610:  /* *bmi_blsr_si_cmp */
    9338           44 :     case 1599:  /* *bmi_blsi_di_cmp */
    9339           44 :     case 1598:  /* *bmi_blsi_si_cmp */
    9340           44 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9341           44 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
    9342           44 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
    9343           44 :       recog_data.dup_num[0] = 1;
    9344           44 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
    9345           44 :       recog_data.dup_num[1] = 1;
    9346           44 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1);
    9347           44 :       recog_data.dup_num[2] = 1;
    9348           44 :       break;
    9349              : 
    9350         4284 :     case 1643:  /* *tbm_blsfill_di */
    9351         4284 :     case 1642:  /* *tbm_blsfill_si */
    9352         4284 :     case 1641:  /* *tbm_blcs_di */
    9353         4284 :     case 1640:  /* *tbm_blcs_si */
    9354         4284 :     case 1639:  /* *tbm_blcmsk_di */
    9355         4284 :     case 1638:  /* *tbm_blcmsk_si */
    9356         4284 :     case 1633:  /* *tbm_blcfill_di */
    9357         4284 :     case 1632:  /* *tbm_blcfill_si */
    9358         4284 :     case 1609:  /* *bmi_blsr_di */
    9359         4284 :     case 1608:  /* *bmi_blsr_si */
    9360         4284 :     case 1605:  /* *bmi_blsmsk_di */
    9361         4284 :     case 1604:  /* *bmi_blsmsk_si */
    9362         4284 :     case 1597:  /* *bmi_blsi_di */
    9363         4284 :     case 1596:  /* *bmi_blsi_si */
    9364         4284 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9365         4284 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    9366         4284 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
    9367         4284 :       recog_data.dup_num[0] = 1;
    9368         4284 :       break;
    9369              : 
    9370           17 :     case 1595:  /* *bmi_bextr_di_ccz */
    9371           17 :     case 1594:  /* *bmi_bextr_si_ccz */
    9372           17 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9373           17 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 0));
    9374           17 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0, 1));
    9375           17 :       break;
    9376              : 
    9377          268 :     case 1587:  /* *lzcnt_di_falsedep */
    9378          268 :     case 1586:  /* *tzcnt_di_falsedep */
    9379          268 :     case 1585:  /* *lzcnt_si_falsedep */
    9380          268 :     case 1584:  /* *tzcnt_si_falsedep */
    9381          268 :     case 1583:  /* *lzcnt_di_falsedep_nf */
    9382          268 :     case 1582:  /* *tzcnt_di_falsedep_nf */
    9383          268 :     case 1581:  /* *lzcnt_si_falsedep_nf */
    9384          268 :     case 1580:  /* *tzcnt_si_falsedep_nf */
    9385          268 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9386          268 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9387          268 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    9388          268 :       break;
    9389              : 
    9390         6831 :     case 1907:  /* probe_stack_1 */
    9391         6831 :     case 1906:  /* allocate_stack_worker_probe_di */
    9392         6831 :     case 1905:  /* allocate_stack_worker_probe_si */
    9393         6831 :     case 1775:  /* *fistdi2_ceil_1 */
    9394         6831 :     case 1774:  /* *fistdi2_floor_1 */
    9395         6831 :     case 1773:  /* *fistsi2_ceil_1 */
    9396         6831 :     case 1772:  /* *fistsi2_floor_1 */
    9397         6831 :     case 1771:  /* *fisthi2_ceil_1 */
    9398         6831 :     case 1770:  /* *fisthi2_floor_1 */
    9399         6831 :     case 1765:  /* frndintxf2_trunc */
    9400         6831 :     case 1764:  /* frndintxf2_ceil */
    9401         6831 :     case 1763:  /* frndintxf2_floor */
    9402         6831 :     case 1762:  /* frndintxf2_roundeven */
    9403         6831 :     case 1591:  /* lzcnt_hi */
    9404         6831 :     case 1589:  /* tzcnt_hi */
    9405         6831 :     case 1579:  /* lzcnt_di */
    9406         6831 :     case 1578:  /* tzcnt_di */
    9407         6831 :     case 1577:  /* lzcnt_si */
    9408         6831 :     case 1576:  /* tzcnt_si */
    9409         6831 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9410         6831 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9411         6831 :       break;
    9412              : 
    9413          101 :     case 1557:  /* *bsru_2 */
    9414          101 :     case 1556:  /* *bsr_2 */
    9415          101 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9416          101 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1), 0));
    9417          101 :       break;
    9418              : 
    9419          461 :     case 1555:  /* *bsr_rex64u_2 */
    9420          461 :     case 1554:  /* *bsr_rex64_2 */
    9421          461 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9422          461 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1), 0), 0));
    9423          461 :       break;
    9424              : 
    9425           75 :     case 1553:  /* bsr_zext_1 */
    9426           75 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9427           75 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
    9428           75 :       break;
    9429              : 
    9430        10049 :     case 1550:  /* bsr_rex64_1_zext */
    9431        10049 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9432        10049 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0), 0));
    9433        10049 :       break;
    9434              : 
    9435        32518 :     case 1552:  /* bsr_1 */
    9436        32518 :     case 1549:  /* bsr_rex64_1 */
    9437        32518 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9438        32518 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
    9439        32518 :       break;
    9440              : 
    9441        75776 :     case 1551:  /* bsr */
    9442        75776 :     case 1548:  /* bsr_rex64 */
    9443        75776 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9444        75776 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    9445        75776 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1), 0);
    9446        75776 :       recog_data.dup_num[0] = 1;
    9447        75776 :       break;
    9448              : 
    9449          646 :     case 1661:  /* *popcountsi2_zext_2_falsedep */
    9450          646 :     case 1571:  /* *clzsi2_lzcnt_zext_2_falsedep */
    9451          646 :     case 1570:  /* *clzsi2_lzcnt_zext_2_falsedep */
    9452          646 :     case 1547:  /* *ctzsidi2_uext_falsedep */
    9453          646 :     case 1546:  /* *ctzsidi2_sext_falsedep */
    9454          646 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9455          646 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    9456          646 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    9457          646 :       break;
    9458              : 
    9459           40 :     case 1659:  /* *popcountsi2_zext_falsedep */
    9460           40 :     case 1568:  /* *clzsi2_lzcnt_zext_falsedep */
    9461           40 :     case 1567:  /* *clzsi2_lzcnt_zext_falsedep */
    9462           40 :     case 1543:  /* *ctzsi2_zext_falsedep */
    9463           40 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9464           40 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
    9465           40 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    9466           40 :       break;
    9467              : 
    9468          256 :     case 1658:  /* *popcountsi2_zext */
    9469          256 :     case 1566:  /* *clzsi2_lzcnt_zext */
    9470          256 :     case 1542:  /* *ctzsi2_zext */
    9471          256 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9472          256 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
    9473          256 :       break;
    9474              : 
    9475         4576 :     case 1657:  /* *popcountdi2_falsedep */
    9476         4576 :     case 1656:  /* *popcountsi2_falsedep */
    9477         4576 :     case 1655:  /* *popcountdi2_falsedep_nf */
    9478         4576 :     case 1654:  /* *popcountsi2_falsedep_nf */
    9479         4576 :     case 1565:  /* *clzdi2_lzcnt_falsedep */
    9480         4576 :     case 1564:  /* *clzsi2_lzcnt_falsedep */
    9481         4576 :     case 1563:  /* *clzdi2_lzcnt_falsedep_nf */
    9482         4576 :     case 1562:  /* *clzsi2_lzcnt_falsedep_nf */
    9483         4576 :     case 1541:  /* *ctzdi2_falsedep */
    9484         4576 :     case 1540:  /* *ctzsi2_falsedep */
    9485         4576 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9486         4576 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    9487         4576 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    9488         4576 :       break;
    9489              : 
    9490          110 :     case 1535:  /* *tzcntdi_1_falsedep */
    9491          110 :     case 1534:  /* *tzcntsi_1_falsedep */
    9492          110 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9493          110 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    9494          110 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (pat, 0, 2), 0, 0));
    9495          110 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
    9496          110 :       recog_data.dup_num[0] = 1;
    9497          110 :       break;
    9498              : 
    9499         2680 :     case 1537:  /* *bsfdi_1 */
    9500         2680 :     case 1536:  /* *bsfsi_1 */
    9501         2680 :     case 1533:  /* *tzcntdi_1 */
    9502         2680 :     case 1532:  /* *tzcntsi_1 */
    9503         2680 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9504         2680 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    9505         2680 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
    9506         2680 :       recog_data.dup_num[0] = 1;
    9507         2680 :       break;
    9508              : 
    9509         5155 :     case 10981:  /* avx10_2_vcvttss2usisdi */
    9510         5155 :     case 10979:  /* avx10_2_vcvttss2sisdi */
    9511         5155 :     case 10977:  /* avx10_2_vcvttss2usissi */
    9512         5155 :     case 10975:  /* avx10_2_vcvttss2sissi */
    9513         5155 :     case 10973:  /* avx10_2_vcvttsd2usisdi */
    9514         5155 :     case 10971:  /* avx10_2_vcvttsd2sisdi */
    9515         5155 :     case 10969:  /* avx10_2_vcvttsd2usissi */
    9516         5155 :     case 10967:  /* avx10_2_vcvttsd2sissi */
    9517         5155 :     case 8730:  /* sse4a_vmmovntv2df */
    9518         5155 :     case 8729:  /* sse4a_vmmovntv4sf */
    9519         5155 :     case 4957:  /* sse2_cvtsd2siq */
    9520         5155 :     case 4955:  /* sse2_cvtsd2si */
    9521         5155 :     case 4945:  /* avx512f_vcvtsd2usiq */
    9522         5155 :     case 4943:  /* avx512f_vcvtsd2usi */
    9523         5155 :     case 4933:  /* avx512f_vcvtss2usiq */
    9524         5155 :     case 4931:  /* avx512f_vcvtss2usi */
    9525         5155 :     case 4895:  /* *avx512dq_cvtps2uqqv2di */
    9526         5155 :     case 4887:  /* *avx512dq_cvtps2qqv2di */
    9527         5155 :     case 4822:  /* sse_cvtss2siq */
    9528         5155 :     case 4820:  /* sse_cvtss2si */
    9529         5155 :     case 4577:  /* avx512fp16_vcvtsh2siq */
    9530         5155 :     case 4575:  /* avx512fp16_vcvtsh2usiq */
    9531         5155 :     case 4573:  /* avx512fp16_vcvtsh2si */
    9532         5155 :     case 4571:  /* avx512fp16_vcvtsh2usi */
    9533         5155 :     case 1526:  /* set_got_offset_rex64 */
    9534         5155 :     case 1525:  /* set_rip_rex64 */
    9535         5155 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    9536         5155 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
    9537         5155 :       break;
    9538              : 
    9539            0 :     case 1523:  /* *set_got_labelled */
    9540            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9541            0 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0), 0));
    9542            0 :       break;
    9543              : 
    9544       654595 :     case 1999:  /* rdseeddi */
    9545       654595 :     case 1998:  /* rdseedsi */
    9546       654595 :     case 1997:  /* rdseedhi */
    9547       654595 :     case 1996:  /* rdranddi */
    9548       654595 :     case 1995:  /* rdrandsi */
    9549       654595 :     case 1994:  /* rdrandhi */
    9550       654595 :     case 1972:  /* fnstenv */
    9551       654595 :     case 1522:  /* *set_got */
    9552       654595 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9553       654595 :       break;
    9554              : 
    9555       186675 :     case 8640:  /* sse3_mwait */
    9556       186675 :     case 2057:  /* uwrmsr */
    9557       186675 :     case 2054:  /* patchable_area */
    9558       186675 :     case 2010:  /* wrussdi */
    9559       186675 :     case 2009:  /* wrusssi */
    9560       186675 :     case 2008:  /* wrssdi */
    9561       186675 :     case 2007:  /* wrsssi */
    9562       186675 :     case 1968:  /* xsetbv */
    9563       186675 :     case 1963:  /* xrstors */
    9564       186675 :     case 1962:  /* xrstor */
    9565       186675 :     case 1934:  /* prefetchi */
    9566       186675 :     case 1521:  /* max_skip_align */
    9567       186675 :       ro[0] = *(ro_loc[0] = &XVECEXP (pat, 0, 0));
    9568       186675 :       ro[1] = *(ro_loc[1] = &XVECEXP (pat, 0, 1));
    9569       186675 :       break;
    9570              : 
    9571        58648 :     case 1518:  /* *simple_return_indirect_internaldi */
    9572        58648 :     case 1517:  /* *simple_return_indirect_internalsi */
    9573        58648 :     case 1516:  /* simple_return_pop_internal */
    9574        58648 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9575        58648 :       break;
    9576              : 
    9577      1510238 :     case 8639:  /* sse2_clflush */
    9578      1510238 :     case 8637:  /* sse_ldmxcsr */
    9579      1510238 :     case 2058:  /* ldtilecfg */
    9580      1510238 :     case 2055:  /* hreset */
    9581      1510238 :     case 2051:  /* cldemote */
    9582      1510238 :     case 2048:  /* umonitor_di */
    9583      1510238 :     case 2047:  /* umonitor_si */
    9584      1510238 :     case 2044:  /* senduipi */
    9585      1510238 :     case 2024:  /* clzero_di */
    9586      1510238 :     case 2023:  /* clzero_si */
    9587      1510238 :     case 2019:  /* clflushopt */
    9588      1510238 :     case 2018:  /* clwb */
    9589      1510238 :     case 2016:  /* xabort */
    9590      1510238 :     case 2012:  /* clrssbsy */
    9591      1510238 :     case 2006:  /* rstorssp */
    9592      1510238 :     case 2004:  /* incsspdi */
    9593      1510238 :     case 2003:  /* incsspsi */
    9594      1510238 :     case 1993:  /* ptwritedi */
    9595      1510238 :     case 1992:  /* ptwritesi */
    9596      1510238 :     case 1991:  /* wrgsbasedi */
    9597      1510238 :     case 1990:  /* wrfsbasedi */
    9598      1510238 :     case 1989:  /* wrgsbasesi */
    9599      1510238 :     case 1988:  /* wrfsbasesi */
    9600      1510238 :     case 1977:  /* lwp_llwpcbdi */
    9601      1510238 :     case 1976:  /* lwp_llwpcbsi */
    9602      1510238 :     case 1949:  /* fxrstor64 */
    9603      1510238 :     case 1948:  /* fxrstor */
    9604      1510238 :     case 1530:  /* split_stack_return */
    9605      1510238 :     case 1520:  /* nops */
    9606      1510238 :     case 1512:  /* prologue_use */
    9607      1510238 :       ro[0] = *(ro_loc[0] = &XVECEXP (pat, 0, 0));
    9608      1510238 :       break;
    9609              : 
    9610      2044642 :     case 11073:  /* mfence_sse2 */
    9611      2044642 :     case 11072:  /* *sse_sfence */
    9612      2044642 :     case 11071:  /* *sse2_lfence */
    9613      2044642 :     case 2000:  /* *pause */
    9614      2044642 :     case 1511:  /* *memory_blockage */
    9615      2044642 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    9616      2044642 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (pat, 1), 0, 0);
    9617      2044642 :       recog_data.dup_num[0] = 0;
    9618      2044642 :       break;
    9619              : 
    9620            0 :     case 1509:  /* *sibcall_value_pop_memory */
    9621            0 :     case 1508:  /* *sibcall_value_pop */
    9622            0 :     case 1507:  /* *call_value_pop */
    9623            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9624            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    9625            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    9626            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
    9627            0 :       break;
    9628              : 
    9629            0 :     case 1502:  /* *sibcall_value_GOT_32 */
    9630            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    9631            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
    9632            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 1));
    9633            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    9634            0 :       break;
    9635              : 
    9636          214 :     case 5329:  /* *vec_setv2di_0_zero_extendsi */
    9637          214 :     case 5328:  /* *vec_setv4di_0_zero_extendsi */
    9638          214 :     case 5327:  /* *vec_setv8di_0_zero_extendsi */
    9639          214 :     case 5317:  /* *vec_setv2di_0_zero_extendhi */
    9640          214 :     case 5316:  /* *vec_setv4di_0_zero_extendhi */
    9641          214 :     case 5315:  /* *vec_setv8di_0_zero_extendhi */
    9642          214 :     case 5314:  /* *vec_setv4si_0_zero_extendhi */
    9643          214 :     case 5313:  /* *vec_setv8si_0_zero_extendhi */
    9644          214 :     case 5312:  /* *vec_setv16si_0_zero_extendhi */
    9645          214 :     case 4810:  /* avx512fp16_vcvtsd2sh_mem */
    9646          214 :     case 4808:  /* avx512fp16_vcvtss2sh_mem */
    9647          214 :     case 4798:  /* avx512fp16_vcvtsh2ss_mem */
    9648          214 :     case 4796:  /* avx512fp16_vcvtsh2sd_mem */
    9649          214 :     case 3002:  /* *sse2_vmsqrtv2df2 */
    9650          214 :     case 2998:  /* *sse_vmsqrtv4sf2 */
    9651          214 :     case 2994:  /* *avx512fp16_vmsqrtv8hf2 */
    9652          214 :     case 1501:  /* *call_value_got_x32 */
    9653          214 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    9654          214 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    9655          214 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    9656          214 :       break;
    9657              : 
    9658      3650427 :     case 1498:  /* *sibcall_pop_memory */
    9659      3650427 :     case 1497:  /* *sibcall_pop */
    9660      3650427 :     case 1496:  /* *call_pop */
    9661      3650427 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
    9662      3650427 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 1));
    9663      3650427 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
    9664      3650427 :       break;
    9665              : 
    9666            0 :     case 1491:  /* *sibcall_GOT_32 */
    9667            0 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 0), 0), 0), 0));
    9668            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 0), 0), 0), 1));
    9669            0 :       ro[2] = *(ro_loc[2] = &XEXP (pat, 1));
    9670            0 :       break;
    9671              : 
    9672            0 :     case 1490:  /* *call_got_x32 */
    9673            0 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (pat, 0), 0), 0));
    9674            0 :       ro[1] = *(ro_loc[1] = &XEXP (pat, 1));
    9675            0 :       break;
    9676              : 
    9677       160234 :     case 1487:  /* *tablejump_1 */
    9678       160234 :     case 1486:  /* *tablejump_1 */
    9679       160234 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 1));
    9680       160234 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 0), 0));
    9681       160234 :       break;
    9682              : 
    9683        22999 :     case 1485:  /* *indirect_jump */
    9684        22999 :     case 1484:  /* *indirect_jump */
    9685        22999 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 1));
    9686        22999 :       break;
    9687              : 
    9688     39745878 :     case 1483:  /* jump */
    9689     39745878 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 1), 0));
    9690     39745878 :       break;
    9691              : 
    9692    141408380 :     case 1482:  /* *jcc */
    9693    141408380 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    9694    141408380 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    9695    141408380 :       break;
    9696              : 
    9697       489696 :     case 11064:  /* avx512bmm_vbmacxor16x16x16_v16hi */
    9698       489696 :     case 11063:  /* avx512bmm_vbmacxor16x16x16_v32hi */
    9699       489696 :     case 11062:  /* avx512bmm_vbmacor16x16x16_v16hi */
    9700       489696 :     case 11061:  /* avx512bmm_vbmacor16x16x16_v32hi */
    9701       489696 :     case 11021:  /* avx10_2_minmaxpv2df */
    9702       489696 :     case 11017:  /* avx10_2_minmaxpv4df */
    9703       489696 :     case 11013:  /* avx10_2_minmaxpv8df */
    9704       489696 :     case 11009:  /* avx10_2_minmaxpv4sf */
    9705       489696 :     case 11005:  /* avx10_2_minmaxpv8sf */
    9706       489696 :     case 11001:  /* avx10_2_minmaxpv16sf */
    9707       489696 :     case 10997:  /* avx10_2_minmaxpv8hf */
    9708       489696 :     case 10993:  /* avx10_2_minmaxpv16hf */
    9709       489696 :     case 10989:  /* avx10_2_minmaxpv32hf */
    9710       489696 :     case 10987:  /* avx10_2_minmaxbf16_v8bf */
    9711       489696 :     case 10985:  /* avx10_2_minmaxbf16_v16bf */
    9712       489696 :     case 10983:  /* avx10_2_minmaxbf16_v32bf */
    9713       489696 :     case 10813:  /* avx10_2_cmpbf16_v8bf */
    9714       489696 :     case 10811:  /* avx10_2_cmpbf16_v16bf */
    9715       489696 :     case 10809:  /* avx10_2_cmpbf16_v32bf */
    9716       489696 :     case 10664:  /* vdpphps_v4sf */
    9717       489696 :     case 10663:  /* vdpphps_v8sf */
    9718       489696 :     case 10662:  /* vdpphps_v16sf */
    9719       489696 :     case 10625:  /* vpdpwuuds_v16si */
    9720       489696 :     case 10624:  /* vpdpwuud_v16si */
    9721       489696 :     case 10623:  /* vpdpwsuds_v16si */
    9722       489696 :     case 10622:  /* vpdpwsud_v16si */
    9723       489696 :     case 10621:  /* vpdpwusds_v16si */
    9724       489696 :     case 10620:  /* vpdpwusd_v16si */
    9725       489696 :     case 10619:  /* vpdpwuuds_v4si */
    9726       489696 :     case 10618:  /* vpdpwuud_v4si */
    9727       489696 :     case 10617:  /* vpdpwsuds_v4si */
    9728       489696 :     case 10616:  /* vpdpwsud_v4si */
    9729       489696 :     case 10615:  /* vpdpwusds_v4si */
    9730       489696 :     case 10614:  /* vpdpwusd_v4si */
    9731       489696 :     case 10613:  /* vpdpwuuds_v8si */
    9732       489696 :     case 10612:  /* vpdpwuud_v8si */
    9733       489696 :     case 10611:  /* vpdpwsuds_v8si */
    9734       489696 :     case 10610:  /* vpdpwsud_v8si */
    9735       489696 :     case 10609:  /* vpdpwusds_v8si */
    9736       489696 :     case 10608:  /* vpdpwusd_v8si */
    9737       489696 :     case 10473:  /* vpdpbuuds_v16si */
    9738       489696 :     case 10472:  /* vpdpbuud_v16si */
    9739       489696 :     case 10471:  /* vpdpbsuds_v16si */
    9740       489696 :     case 10470:  /* vpdpbsud_v16si */
    9741       489696 :     case 10469:  /* vpdpbssds_v16si */
    9742       489696 :     case 10468:  /* vpdpbssd_v16si */
    9743       489696 :     case 10467:  /* vpdpbuuds_v4si */
    9744       489696 :     case 10466:  /* vpdpbuud_v4si */
    9745       489696 :     case 10465:  /* vpdpbsuds_v4si */
    9746       489696 :     case 10464:  /* vpdpbsud_v4si */
    9747       489696 :     case 10463:  /* vpdpbssds_v4si */
    9748       489696 :     case 10462:  /* vpdpbssd_v4si */
    9749       489696 :     case 10461:  /* vpdpbuuds_v8si */
    9750       489696 :     case 10460:  /* vpdpbuud_v8si */
    9751       489696 :     case 10459:  /* vpdpbsuds_v8si */
    9752       489696 :     case 10458:  /* vpdpbsud_v8si */
    9753       489696 :     case 10457:  /* vpdpbssds_v8si */
    9754       489696 :     case 10456:  /* vpdpbssd_v8si */
    9755       489696 :     case 10440:  /* avx512f_dpbf16ps_v4sf */
    9756       489696 :     case 10438:  /* avx512f_dpbf16ps_v8sf */
    9757       489696 :     case 10436:  /* avx512f_dpbf16ps_v16sf */
    9758       489696 :     case 10408:  /* vpclmulqdq_v2di */
    9759       489696 :     case 10407:  /* vpclmulqdq_v4di */
    9760       489696 :     case 10406:  /* vpclmulqdq_v8di */
    9761       489696 :     case 10387:  /* vpdpwssds_v4si */
    9762       489696 :     case 10386:  /* vpdpwssds_v8si */
    9763       489696 :     case 10385:  /* vpdpwssds_v16si */
    9764       489696 :     case 10378:  /* vpdpwssd_v4si */
    9765       489696 :     case 10377:  /* vpdpwssd_v8si */
    9766       489696 :     case 10376:  /* vpdpwssd_v16si */
    9767       489696 :     case 10369:  /* vpdpbusds_v4si */
    9768       489696 :     case 10368:  /* vpdpbusds_v8si */
    9769       489696 :     case 10367:  /* vpdpbusds_v16si */
    9770       489696 :     case 10360:  /* vpdpbusd_v4si */
    9771       489696 :     case 10359:  /* vpdpbusd_v8si */
    9772       489696 :     case 10358:  /* vpdpbusd_v16si */
    9773       489696 :     case 10339:  /* vpshldv_v2di */
    9774       489696 :     case 10338:  /* vpshldv_v4si */
    9775       489696 :     case 10337:  /* vpshldv_v8hi */
    9776       489696 :     case 10336:  /* vpshldv_v4di */
    9777       489696 :     case 10335:  /* vpshldv_v8si */
    9778       489696 :     case 10334:  /* vpshldv_v16hi */
    9779       489696 :     case 10333:  /* vpshldv_v8di */
    9780       489696 :     case 10332:  /* vpshldv_v16si */
    9781       489696 :     case 10331:  /* vpshldv_v32hi */
    9782       489696 :     case 10312:  /* vpshrdv_v2di */
    9783       489696 :     case 10311:  /* vpshrdv_v4si */
    9784       489696 :     case 10310:  /* vpshrdv_v8hi */
    9785       489696 :     case 10309:  /* vpshrdv_v4di */
    9786       489696 :     case 10308:  /* vpshrdv_v8si */
    9787       489696 :     case 10307:  /* vpshrdv_v16hi */
    9788       489696 :     case 10306:  /* vpshrdv_v8di */
    9789       489696 :     case 10305:  /* vpshrdv_v16si */
    9790       489696 :     case 10304:  /* vpshrdv_v32hi */
    9791       489696 :     case 10302:  /* vpshld_v2di */
    9792       489696 :     case 10300:  /* vpshld_v4si */
    9793       489696 :     case 10298:  /* vpshld_v8hi */
    9794       489696 :     case 10296:  /* vpshld_v4di */
    9795       489696 :     case 10294:  /* vpshld_v8si */
    9796       489696 :     case 10292:  /* vpshld_v16hi */
    9797       489696 :     case 10290:  /* vpshld_v8di */
    9798       489696 :     case 10288:  /* vpshld_v16si */
    9799       489696 :     case 10286:  /* vpshld_v32hi */
    9800       489696 :     case 10284:  /* vpshrd_v2di */
    9801       489696 :     case 10282:  /* vpshrd_v4si */
    9802       489696 :     case 10280:  /* vpshrd_v8hi */
    9803       489696 :     case 10278:  /* vpshrd_v4di */
    9804       489696 :     case 10276:  /* vpshrd_v8si */
    9805       489696 :     case 10274:  /* vpshrd_v16hi */
    9806       489696 :     case 10272:  /* vpshrd_v8di */
    9807       489696 :     case 10270:  /* vpshrd_v16si */
    9808       489696 :     case 10268:  /* vpshrd_v32hi */
    9809       489696 :     case 10260:  /* vgf2p8affineqb_v16qi */
    9810       489696 :     case 10258:  /* vgf2p8affineqb_v32qi */
    9811       489696 :     case 10256:  /* vgf2p8affineqb_v64qi */
    9812       489696 :     case 10254:  /* vgf2p8affineinvqb_v16qi */
    9813       489696 :     case 10252:  /* vgf2p8affineinvqb_v32qi */
    9814       489696 :     case 10250:  /* vgf2p8affineinvqb_v64qi */
    9815       489696 :     case 10199:  /* vpmadd52huqv2di */
    9816       489696 :     case 10198:  /* vpmadd52luqv2di */
    9817       489696 :     case 10197:  /* vpmadd52huqv4di */
    9818       489696 :     case 10196:  /* vpmadd52luqv4di */
    9819       489696 :     case 10195:  /* vpmadd52huqv8di */
    9820       489696 :     case 10194:  /* vpmadd52luqv8di */
    9821       489696 :     case 10181:  /* vsha512rnds2 */
    9822       489696 :     case 10177:  /* vsm3msg2 */
    9823       489696 :     case 10176:  /* vsm3msg1 */
    9824       489696 :     case 10175:  /* sha256rnds2 */
    9825       489696 :     case 10172:  /* sha1rnds4 */
    9826       489696 :     case 10143:  /* *avx512bw_dbpsadbwv32hi */
    9827       489696 :     case 10141:  /* *avx512bw_dbpsadbwv16hi */
    9828       489696 :     case 10139:  /* *avx512bw_dbpsadbwv8hi */
    9829       489696 :     case 10057:  /* avx512dq_rangepv2df */
    9830       489696 :     case 10055:  /* avx512dq_rangepv4df */
    9831       489696 :     case 10051:  /* avx512dq_rangepv8df */
    9832       489696 :     case 10049:  /* avx512dq_rangepv4sf */
    9833       489696 :     case 10047:  /* avx512dq_rangepv8sf */
    9834       489696 :     case 10043:  /* avx512dq_rangepv16sf */
    9835       489696 :     case 10042:  /* *expandv8hi_mask */
    9836       489696 :     case 10041:  /* *expandv16hi_mask */
    9837       489696 :     case 10040:  /* *expandv32hi_mask */
    9838       489696 :     case 10039:  /* *expandv32qi_mask */
    9839       489696 :     case 10038:  /* *expandv16qi_mask */
    9840       489696 :     case 10037:  /* *expandv64qi_mask */
    9841       489696 :     case 10036:  /* *expandv2df_mask */
    9842       489696 :     case 10035:  /* *expandv2di_mask */
    9843       489696 :     case 10034:  /* *expandv4sf_mask */
    9844       489696 :     case 10033:  /* *expandv4si_mask */
    9845       489696 :     case 10032:  /* *expandv4df_mask */
    9846       489696 :     case 10031:  /* *expandv4di_mask */
    9847       489696 :     case 10030:  /* *expandv8sf_mask */
    9848       489696 :     case 10029:  /* *expandv8si_mask */
    9849       489696 :     case 10028:  /* *expandv8df_mask */
    9850       489696 :     case 10027:  /* *expandv8di_mask */
    9851       489696 :     case 10026:  /* *expandv16sf_mask */
    9852       489696 :     case 10025:  /* *expandv16si_mask */
    9853       489696 :     case 10024:  /* expandv8hi_mask */
    9854       489696 :     case 10023:  /* expandv16hi_mask */
    9855       489696 :     case 10022:  /* expandv32hi_mask */
    9856       489696 :     case 10021:  /* expandv32qi_mask */
    9857       489696 :     case 10020:  /* expandv16qi_mask */
    9858       489696 :     case 10019:  /* expandv64qi_mask */
    9859       489696 :     case 10018:  /* expandv2df_mask */
    9860       489696 :     case 10017:  /* expandv2di_mask */
    9861       489696 :     case 10016:  /* expandv4sf_mask */
    9862       489696 :     case 10015:  /* expandv4si_mask */
    9863       489696 :     case 10014:  /* expandv4df_mask */
    9864       489696 :     case 10013:  /* expandv4di_mask */
    9865       489696 :     case 10012:  /* expandv8sf_mask */
    9866       489696 :     case 10011:  /* expandv8si_mask */
    9867       489696 :     case 10010:  /* expandv8df_mask */
    9868       489696 :     case 10009:  /* expandv8di_mask */
    9869       489696 :     case 10008:  /* expandv16sf_mask */
    9870       489696 :     case 10007:  /* expandv16si_mask */
    9871       489696 :     case 9988:  /* compressv8hi_mask */
    9872       489696 :     case 9987:  /* compressv16hi_mask */
    9873       489696 :     case 9986:  /* compressv32hi_mask */
    9874       489696 :     case 9985:  /* compressv32qi_mask */
    9875       489696 :     case 9984:  /* compressv16qi_mask */
    9876       489696 :     case 9983:  /* compressv64qi_mask */
    9877       489696 :     case 9982:  /* avx512vl_compressv2df_mask */
    9878       489696 :     case 9981:  /* avx512vl_compressv2di_mask */
    9879       489696 :     case 9980:  /* avx512vl_compressv4sf_mask */
    9880       489696 :     case 9979:  /* avx512vl_compressv4si_mask */
    9881       489696 :     case 9978:  /* avx512vl_compressv4df_mask */
    9882       489696 :     case 9977:  /* avx512vl_compressv4di_mask */
    9883       489696 :     case 9976:  /* avx512vl_compressv8sf_mask */
    9884       489696 :     case 9975:  /* avx512vl_compressv8si_mask */
    9885       489696 :     case 9974:  /* avx512f_compressv8df_mask */
    9886       489696 :     case 9973:  /* avx512f_compressv8di_mask */
    9887       489696 :     case 9972:  /* avx512f_compressv16sf_mask */
    9888       489696 :     case 9971:  /* avx512f_compressv16si_mask */
    9889       489696 :     case 9535:  /* *avx_vperm2f128v4df_full */
    9890       489696 :     case 9534:  /* *avx_vperm2f128v8sf_full */
    9891       489696 :     case 9533:  /* *avx_vperm2f128v8si_full */
    9892       489696 :     case 9513:  /* avx512vl_vpermt2varv8bf3 */
    9893       489696 :     case 9511:  /* avx512vl_vpermt2varv16bf3 */
    9894       489696 :     case 9509:  /* avx512bw_vpermt2varv32bf3 */
    9895       489696 :     case 9507:  /* avx512fp16_vpermt2varv8hf3 */
    9896       489696 :     case 9505:  /* avx512vl_vpermt2varv16hf3 */
    9897       489696 :     case 9503:  /* avx512bw_vpermt2varv32hf3 */
    9898       489696 :     case 9501:  /* avx512vl_vpermt2varv16qi3 */
    9899       489696 :     case 9499:  /* avx512vl_vpermt2varv32qi3 */
    9900       489696 :     case 9497:  /* avx512bw_vpermt2varv64qi3 */
    9901       489696 :     case 9495:  /* avx512vl_vpermt2varv8hi3 */
    9902       489696 :     case 9493:  /* avx512vl_vpermt2varv16hi3 */
    9903       489696 :     case 9491:  /* avx512bw_vpermt2varv32hi3 */
    9904       489696 :     case 9489:  /* avx512vl_vpermt2varv2df3 */
    9905       489696 :     case 9487:  /* avx512vl_vpermt2varv2di3 */
    9906       489696 :     case 9485:  /* avx512vl_vpermt2varv4sf3 */
    9907       489696 :     case 9483:  /* avx512vl_vpermt2varv4si3 */
    9908       489696 :     case 9481:  /* avx512vl_vpermt2varv4df3 */
    9909       489696 :     case 9479:  /* avx512vl_vpermt2varv4di3 */
    9910       489696 :     case 9477:  /* avx512vl_vpermt2varv8sf3 */
    9911       489696 :     case 9475:  /* avx512vl_vpermt2varv8si3 */
    9912       489696 :     case 9473:  /* avx512f_vpermt2varv8df3 */
    9913       489696 :     case 9471:  /* avx512f_vpermt2varv8di3 */
    9914       489696 :     case 9469:  /* avx512f_vpermt2varv16sf3 */
    9915       489696 :     case 9467:  /* avx512f_vpermt2varv16si3 */
    9916       489696 :     case 9255:  /* avx2_permv2ti */
    9917       489696 :     case 9153:  /* pclmulqdq */
    9918       489696 :     case 9142:  /* xop_pcom_tfv2di3 */
    9919       489696 :     case 9141:  /* xop_pcom_tfv4si3 */
    9920       489696 :     case 9140:  /* xop_pcom_tfv8hi3 */
    9921       489696 :     case 9139:  /* xop_pcom_tfv16qi3 */
    9922       489696 :     case 9094:  /* xop_pperm */
    9923       489696 :     case 8791:  /* sse4_1_pblendvb */
    9924       489696 :     case 8790:  /* avx2_pblendvb */
    9925       489696 :     case 8782:  /* *sse4_1_mpsadbw */
    9926       489696 :     case 8780:  /* *avx2_mpsadbw */
    9927       489696 :     case 8778:  /* avx10_2_mpsadbw */
    9928       489696 :     case 8777:  /* sse4_1_mpsadbw */
    9929       489696 :     case 8776:  /* avx2_mpsadbw */
    9930       489696 :     case 8772:  /* sse4_1_dppd */
    9931       489696 :     case 8771:  /* avx_dppd256 */
    9932       489696 :     case 8770:  /* sse4_1_dpps */
    9933       489696 :     case 8769:  /* avx_dpps256 */
    9934       489696 :     case 8744:  /* sse4_1_blendvsd */
    9935       489696 :     case 8743:  /* sse4_1_blendvss */
    9936       489696 :     case 8742:  /* sse4_1_blendvpd */
    9937       489696 :     case 8741:  /* avx_blendvpd256 */
    9938       489696 :     case 8740:  /* sse4_1_blendvps */
    9939       489696 :     case 8739:  /* avx_blendvps256 */
    9940       489696 :     case 8731:  /* sse4a_extrqi */
    9941       489696 :     case 8702:  /* ssse3_palignrdi */
    9942       489696 :     case 8701:  /* ssse3_palignrv1ti */
    9943       489696 :     case 8700:  /* avx2_palignrv2ti */
    9944       489696 :     case 8699:  /* avx512bw_palignrv4ti */
    9945       489696 :     case 7101:  /* *avx512vl_alignv2di */
    9946       489696 :     case 7099:  /* *avx512vl_alignv4di */
    9947       489696 :     case 7097:  /* *avx512f_alignv8di */
    9948       489696 :     case 7095:  /* *avx512vl_alignv4si */
    9949       489696 :     case 7093:  /* *avx512vl_alignv8si */
    9950       489696 :     case 7091:  /* *avx512f_alignv16si */
    9951       489696 :     case 4382:  /* fma_fcmaddc_v4sf_pair */
    9952       489696 :     case 4381:  /* fma_fmaddc_v4sf_pair */
    9953       489696 :     case 4380:  /* fma_fcmaddc_v8sf_pair */
    9954       489696 :     case 4379:  /* fma_fmaddc_v8sf_pair */
    9955       489696 :     case 4378:  /* fma_fcmaddc_v16sf_pair */
    9956       489696 :     case 4377:  /* fma_fmaddc_v16sf_pair */
    9957       489696 :     case 4363:  /* fma_fcmaddc_v8hf */
    9958       489696 :     case 4361:  /* fma_fmaddc_v8hf */
    9959       489696 :     case 4359:  /* fma_fcmaddc_v16hf */
    9960       489696 :     case 4357:  /* fma_fmaddc_v16hf */
    9961       489696 :     case 4353:  /* fma_fcmaddc_v32hf */
    9962       489696 :     case 4349:  /* fma_fmaddc_v32hf */
    9963       489696 :     case 4143:  /* *fma_fmaddsub_v2df */
    9964       489696 :     case 4141:  /* *fma_fmaddsub_v4df */
    9965       489696 :     case 4137:  /* *fma_fmaddsub_v8df */
    9966       489696 :     case 4135:  /* *fma_fmaddsub_v4sf */
    9967       489696 :     case 4133:  /* *fma_fmaddsub_v8sf */
    9968       489696 :     case 4129:  /* *fma_fmaddsub_v16sf */
    9969       489696 :     case 4127:  /* *fma_fmaddsub_v8hf */
    9970       489696 :     case 4125:  /* *fma_fmaddsub_v16hf */
    9971       489696 :     case 4121:  /* *fma_fmaddsub_v32hf */
    9972       489696 :     case 4120:  /* *fma_fmaddsub_v2df */
    9973       489696 :     case 4119:  /* *fma_fmaddsub_v4df */
    9974       489696 :     case 4118:  /* *fma_fmaddsub_v4sf */
    9975       489696 :     case 4117:  /* *fma_fmaddsub_v8sf */
    9976       489696 :     case 3659:  /* avx512vl_ucmpv2di3 */
    9977       489696 :     case 3657:  /* avx512vl_ucmpv4di3 */
    9978       489696 :     case 3655:  /* avx512f_ucmpv8di3 */
    9979       489696 :     case 3653:  /* avx512vl_ucmpv4si3 */
    9980       489696 :     case 3651:  /* avx512vl_ucmpv8si3 */
    9981       489696 :     case 3649:  /* avx512f_ucmpv16si3 */
    9982       489696 :     case 3647:  /* avx512vl_ucmpv8hi3 */
    9983       489696 :     case 3645:  /* avx512vl_ucmpv16hi3 */
    9984       489696 :     case 3643:  /* avx512bw_ucmpv32hi3 */
    9985       489696 :     case 3641:  /* avx512vl_ucmpv16qi3 */
    9986       489696 :     case 3639:  /* avx512vl_ucmpv32qi3 */
    9987       489696 :     case 3637:  /* avx512bw_ucmpv64qi3 */
    9988       489696 :     case 3552:  /* *avx512vl_cmpv2di3_dup_op */
    9989       489696 :     case 3551:  /* *avx512vl_cmpv2di3_dup_op */
    9990       489696 :     case 3550:  /* *avx512vl_cmpv4di3_dup_op */
    9991       489696 :     case 3549:  /* *avx512vl_cmpv4di3_dup_op */
    9992       489696 :     case 3548:  /* *avx512f_cmpv8di3_dup_op */
    9993       489696 :     case 3547:  /* *avx512f_cmpv8di3_dup_op */
    9994       489696 :     case 3546:  /* *avx512vl_cmpv4si3_dup_op */
    9995       489696 :     case 3545:  /* *avx512vl_cmpv4si3_dup_op */
    9996       489696 :     case 3544:  /* *avx512vl_cmpv8si3_dup_op */
    9997       489696 :     case 3543:  /* *avx512vl_cmpv8si3_dup_op */
    9998       489696 :     case 3542:  /* *avx512f_cmpv16si3_dup_op */
    9999       489696 :     case 3541:  /* *avx512f_cmpv16si3_dup_op */
   10000       489696 :     case 3540:  /* *avx512vl_cmpv8hi3_dup_op */
   10001       489696 :     case 3539:  /* *avx512vl_cmpv8hi3_dup_op */
   10002       489696 :     case 3538:  /* *avx512vl_cmpv16hi3_dup_op */
   10003       489696 :     case 3537:  /* *avx512vl_cmpv16hi3_dup_op */
   10004       489696 :     case 3536:  /* *avx512bw_cmpv32hi3_dup_op */
   10005       489696 :     case 3535:  /* *avx512bw_cmpv32hi3_dup_op */
   10006       489696 :     case 3534:  /* *avx512vl_cmpv16qi3_dup_op */
   10007       489696 :     case 3533:  /* *avx512vl_cmpv16qi3_dup_op */
   10008       489696 :     case 3532:  /* *avx512vl_cmpv32qi3_dup_op */
   10009       489696 :     case 3531:  /* *avx512vl_cmpv32qi3_dup_op */
   10010       489696 :     case 3530:  /* *avx512bw_cmpv64qi3_dup_op */
   10011       489696 :     case 3529:  /* *avx512bw_cmpv64qi3_dup_op */
   10012       489696 :     case 3479:  /* avx512vl_cmpv2di3 */
   10013       489696 :     case 3477:  /* avx512vl_cmpv4di3 */
   10014       489696 :     case 3475:  /* avx512f_cmpv8di3 */
   10015       489696 :     case 3473:  /* avx512vl_cmpv4si3 */
   10016       489696 :     case 3471:  /* avx512vl_cmpv8si3 */
   10017       489696 :     case 3469:  /* avx512f_cmpv16si3 */
   10018       489696 :     case 3467:  /* avx512vl_cmpv8hi3 */
   10019       489696 :     case 3465:  /* avx512vl_cmpv16hi3 */
   10020       489696 :     case 3463:  /* avx512bw_cmpv32hi3 */
   10021       489696 :     case 3461:  /* avx512vl_cmpv16qi3 */
   10022       489696 :     case 3459:  /* avx512vl_cmpv32qi3 */
   10023       489696 :     case 3457:  /* avx512bw_cmpv64qi3 */
   10024       489696 :     case 3335:  /* avx512vl_cmpv2df3 */
   10025       489696 :     case 3333:  /* avx512vl_cmpv4df3 */
   10026       489696 :     case 3329:  /* avx512f_cmpv8df3 */
   10027       489696 :     case 3327:  /* avx512vl_cmpv4sf3 */
   10028       489696 :     case 3325:  /* avx512vl_cmpv8sf3 */
   10029       489696 :     case 3321:  /* avx512f_cmpv16sf3 */
   10030       489696 :     case 3319:  /* avx512fp16_cmpv8hf3 */
   10031       489696 :     case 3317:  /* avx512vl_cmpv16hf3 */
   10032       489696 :     case 3313:  /* avx512bw_cmpv32hf3 */
   10033       489696 :     case 3272:  /* avx_cmpv2df3 */
   10034       489696 :     case 3271:  /* avx_cmpv4df3 */
   10035       489696 :     case 3270:  /* avx_cmpv4sf3 */
   10036       489696 :     case 3269:  /* avx_cmpv8sf3 */
   10037       489696 :     case 2312:  /* mmx_ppermv32 */
   10038       489696 :     case 2311:  /* mmx_ppermv64 */
   10039       489696 :     case 2295:  /* mmx_pblendvb_v2hi */
   10040       489696 :     case 2294:  /* mmx_pblendvb_v2qi */
   10041       489696 :     case 2293:  /* mmx_pblendvb_v4qi */
   10042       489696 :     case 2289:  /* mmx_pblendvb_v8qi */
   10043       489696 :     case 2123:  /* mmx_blendvps */
   10044       489696 :     case 1835:  /* movhf_mask */
   10045       489696 :     case 1481:  /* setcc_hf_mask */
   10046       489696 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10047       489696 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
   10048       489696 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
   10049       489696 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 2));
   10050       489696 :       break;
   10051              : 
   10052     13414255 :     case 3310:  /* sse2_maskcmpv2df3 */
   10053     13414255 :     case 3309:  /* avx_maskcmpv4df3 */
   10054     13414255 :     case 3308:  /* sse_maskcmpv4sf3 */
   10055     13414255 :     case 3307:  /* avx_maskcmpv8sf3 */
   10056     13414255 :     case 3306:  /* *sse2_maskcmpv2df3_comm */
   10057     13414255 :     case 3305:  /* *avx_maskcmpv4df3_comm */
   10058     13414255 :     case 3304:  /* *sse_maskcmpv4sf3_comm */
   10059     13414255 :     case 3303:  /* *avx_maskcmpv8sf3_comm */
   10060     13414255 :     case 1710:  /* *fop_df_1 */
   10061     13414255 :     case 1709:  /* *fop_sf_1 */
   10062     13414255 :     case 1708:  /* *fop_xf_1_i387 */
   10063     13414255 :     case 1701:  /* *fop_df_comm */
   10064     13414255 :     case 1700:  /* *fop_sf_comm */
   10065     13414255 :     case 1699:  /* *fop_xf_comm_i387 */
   10066     13414255 :     case 1480:  /* setcc_df_sse */
   10067     13414255 :     case 1479:  /* setcc_sf_sse */
   10068     13414255 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10069     13414255 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
   10070     13414255 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
   10071     13414255 :       ro[3] = *(ro_loc[3] = &XEXP (pat, 1));
   10072     13414255 :       break;
   10073              : 
   10074          702 :     case 1467:  /* *btdi_setcdi_mask */
   10075          702 :     case 1466:  /* *btsi_setcsi_mask */
   10076          702 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10077          702 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10078          702 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 2), 0), 0));
   10079          702 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 2), 0), 1));
   10080          702 :       break;
   10081              : 
   10082          243 :     case 1465:  /* *btdi_setncqi_2 */
   10083          243 :     case 1464:  /* *btsi_setncqi_2 */
   10084          243 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10085          243 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10086          243 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 2));
   10087          243 :       break;
   10088              : 
   10089           54 :     case 1463:  /* *btdi_setncdi */
   10090           54 :     case 1462:  /* *btsi_setncsi */
   10091           54 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10092           54 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   10093           54 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   10094           54 :       break;
   10095              : 
   10096           81 :     case 1461:  /* *btdi_setncqi */
   10097           81 :     case 1460:  /* *btsi_setncqi */
   10098           81 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10099           81 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   10100           81 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 1));
   10101           81 :       break;
   10102              : 
   10103         5121 :     case 1459:  /* *btdi_setcqi */
   10104         5121 :     case 1458:  /* *btsi_setcqi */
   10105         5121 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   10106         5121 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10107         5121 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 2));
   10108         5121 :       break;
   10109              : 
   10110          412 :     case 1457:  /* *jcc_btdi_mask_1 */
   10111          412 :     case 1456:  /* *jcc_btsi_mask_1 */
   10112          412 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10113          412 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   10114          412 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 2), 0), 0));
   10115          412 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 2), 0), 1));
   10116          412 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   10117          412 :       break;
   10118              : 
   10119           12 :     case 1455:  /* *jcc_btdi_mask */
   10120           12 :     case 1454:  /* *jcc_btsi_mask */
   10121           12 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10122           12 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   10123           12 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 2), 0));
   10124           12 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 2), 1));
   10125           12 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   10126           12 :       break;
   10127              : 
   10128        11094 :     case 1453:  /* *jcc_btdi */
   10129        11094 :     case 1452:  /* *jcc_btsi */
   10130        11094 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10131        11094 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   10132        11094 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 2));
   10133        11094 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   10134        11094 :       break;
   10135              : 
   10136            0 :     case 1451:  /* *btdi_mask */
   10137            0 :     case 1450:  /* *btsi_mask */
   10138            0 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   10139            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 2), 0), 0));
   10140            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 2), 0), 1));
   10141            0 :       break;
   10142              : 
   10143        99182 :     case 1449:  /* *btdi */
   10144        99182 :     case 1448:  /* *btsi */
   10145        99182 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   10146        99182 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 1), 2));
   10147        99182 :       break;
   10148              : 
   10149        24429 :     case 1447:  /* *btcq_imm */
   10150        24429 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   10151        24429 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 2));
   10152        24429 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0);
   10153        24429 :       recog_data.dup_num[0] = 0;
   10154        24429 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 2);
   10155        24429 :       recog_data.dup_num[1] = 1;
   10156        24429 :       break;
   10157              : 
   10158        22653 :     case 1446:  /* *btrq_imm */
   10159        22653 :     case 1445:  /* *btsq_imm */
   10160        22653 :     case 1444:  /* *btrhi_2 */
   10161        22653 :     case 1443:  /* *btrqi_2 */
   10162        22653 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   10163        22653 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 2));
   10164        22653 :       break;
   10165              : 
   10166          234 :     case 1623:  /* *bmi2_bzhi_di3_3 */
   10167          234 :     case 1622:  /* *bmi2_bzhi_si3_3 */
   10168          234 :     case 1621:  /* *bmi2_bzhi_di3_2 */
   10169          234 :     case 1620:  /* *bmi2_bzhi_si3_2 */
   10170          234 :     case 1442:  /* *btrhi_1 */
   10171          234 :     case 1441:  /* *btrqi_1 */
   10172          234 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10173          234 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   10174          234 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   10175          234 :       break;
   10176              : 
   10177            6 :     case 1440:  /* *btrdi_mask_1 */
   10178            6 :     case 1439:  /* *btrsi_mask_1 */
   10179            6 :     case 1434:  /* *btcdi_mask_1 */
   10180            6 :     case 1433:  /* *btsdi_mask_1 */
   10181            6 :     case 1432:  /* *btcsi_mask_1 */
   10182            6 :     case 1431:  /* *btssi_mask_1 */
   10183            6 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10184            6 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   10185            6 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 1));
   10186            6 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   10187            6 :       break;
   10188              : 
   10189           30 :     case 1438:  /* *btrdi_mask */
   10190           30 :     case 1437:  /* *btrsi_mask */
   10191           30 :     case 1430:  /* *btcdi_mask */
   10192           30 :     case 1429:  /* *btsdi_mask */
   10193           30 :     case 1428:  /* *btcsi_mask */
   10194           30 :     case 1427:  /* *btssi_mask */
   10195           30 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10196           30 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0), 0));
   10197           30 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0), 1));
   10198           30 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   10199           30 :       break;
   10200              : 
   10201         4941 :     case 1436:  /* *btrdi */
   10202         4941 :     case 1435:  /* *btrsi */
   10203         4941 :     case 1426:  /* *btcdi */
   10204         4941 :     case 1425:  /* *btsdi */
   10205         4941 :     case 1424:  /* *btcsi */
   10206         4941 :     case 1423:  /* *btssi */
   10207         4941 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10208         4941 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   10209         4941 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10210         4941 :       break;
   10211              : 
   10212           12 :     case 1422:  /* ashrdi3_carry */
   10213           12 :     case 1421:  /* lshrdi3_carry */
   10214           12 :     case 1420:  /* ashrsi3_carry */
   10215           12 :     case 1419:  /* lshrsi3_carry */
   10216           12 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10217           12 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0), 0));
   10218           12 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   10219           12 :       recog_data.dup_num[0] = 1;
   10220           12 :       break;
   10221              : 
   10222         1078 :     case 1367:  /* ix86_rotrti3_doubleword */
   10223         1078 :     case 1366:  /* ix86_rotrdi3_doubleword */
   10224         1078 :     case 1365:  /* ix86_rotlti3_doubleword */
   10225         1078 :     case 1364:  /* ix86_rotldi3_doubleword */
   10226         1078 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10227         1078 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10228         1078 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   10229         1078 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 2), 0));
   10230         1078 :       break;
   10231              : 
   10232        42253 :     case 1313:  /* *extendti2_doubleword_highpart */
   10233        42253 :     case 1312:  /* *extenddi2_doubleword_highpart */
   10234        42253 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10235        42253 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10236        42253 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10237        42253 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   10238        42253 :       break;
   10239              : 
   10240         3069 :     case 1363:  /* *rotrdi3_sub_1 */
   10241         3069 :     case 1362:  /* *rotldi3_sub_1 */
   10242         3069 :     case 1361:  /* *rotrsi3_sub_1 */
   10243         3069 :     case 1360:  /* *rotlsi3_sub_1 */
   10244         3069 :     case 1359:  /* *rotrhi3_sub_1 */
   10245         3069 :     case 1358:  /* *rotlhi3_sub_1 */
   10246         3069 :     case 1357:  /* *rotrqi3_sub_1 */
   10247         3069 :     case 1356:  /* *rotlqi3_sub_1 */
   10248         3069 :     case 1311:  /* *ashrdi3_sub_1 */
   10249         3069 :     case 1310:  /* *lshrdi3_sub_1 */
   10250         3069 :     case 1309:  /* *ashldi3_sub_1 */
   10251         3069 :     case 1308:  /* *ashrsi3_sub_1 */
   10252         3069 :     case 1307:  /* *lshrsi3_sub_1 */
   10253         3069 :     case 1306:  /* *ashlsi3_sub_1 */
   10254         3069 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10255         3069 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10256         3069 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1));
   10257         3069 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   10258         3069 :       break;
   10259              : 
   10260            0 :     case 1355:  /* *rotrdi3_sub */
   10261            0 :     case 1354:  /* *rotldi3_sub */
   10262            0 :     case 1353:  /* *rotrsi3_sub */
   10263            0 :     case 1352:  /* *rotlsi3_sub */
   10264            0 :     case 1351:  /* *rotrhi3_sub */
   10265            0 :     case 1350:  /* *rotlhi3_sub */
   10266            0 :     case 1349:  /* *rotrqi3_sub */
   10267            0 :     case 1348:  /* *rotlqi3_sub */
   10268            0 :     case 1305:  /* *ashrdi3_sub */
   10269            0 :     case 1304:  /* *lshrdi3_sub */
   10270            0 :     case 1303:  /* *ashldi3_sub */
   10271            0 :     case 1302:  /* *ashrsi3_sub */
   10272            0 :     case 1301:  /* *lshrsi3_sub */
   10273            0 :     case 1300:  /* *ashlsi3_sub */
   10274            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10275            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10276            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1));
   10277            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0));
   10278            0 :       break;
   10279              : 
   10280            0 :     case 1185:  /* *x86_64_shrd_ndd_2 */
   10281            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10282            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10283            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   10284            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10285            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 1);
   10286            0 :       recog_data.dup_num[0] = 2;
   10287            0 :       break;
   10288              : 
   10289            3 :     case 1197:  /* *x86_shrd_ndd_2 */
   10290            3 :     case 1117:  /* *x86_shld_ndd_2 */
   10291            3 :     case 1105:  /* *x86_64_shld_ndd_2 */
   10292            3 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10293            3 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10294            3 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   10295            3 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10296            3 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 1);
   10297            3 :       recog_data.dup_num[0] = 3;
   10298            3 :       break;
   10299              : 
   10300            6 :     case 1196:  /* *x86_shrd_2 */
   10301            6 :     case 1184:  /* *x86_64_shrd_2 */
   10302            6 :     case 1116:  /* *x86_shld_2 */
   10303            6 :     case 1104:  /* *x86_64_shld_2 */
   10304            6 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10305            6 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   10306            6 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10307            6 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0);
   10308            6 :       recog_data.dup_num[0] = 0;
   10309            6 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 1);
   10310            6 :       recog_data.dup_num[1] = 2;
   10311            6 :       break;
   10312              : 
   10313         3368 :     case 1195:  /* *x86_shrd_shld_1_nozext */
   10314         3368 :     case 1183:  /* *x86_64_shrd_shld_1_nozext */
   10315         3368 :     case 1115:  /* *x86_shld_shrd_1_nozext */
   10316         3368 :     case 1103:  /* *x86_64_shld_shrd_1_nozext */
   10317         3368 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10318         3368 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   10319         3368 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10320         3368 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1));
   10321         3368 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10322         3368 :       break;
   10323              : 
   10324            0 :     case 1194:  /* *x86_shrd_shld_1_nozext_nf */
   10325            0 :     case 1182:  /* *x86_64_shrd_shld_1_nozext_nf */
   10326            0 :     case 1114:  /* *x86_shld_shrd_1_nozext_nf */
   10327            0 :     case 1102:  /* *x86_64_shld_shrd_1_nozext_nf */
   10328            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10329            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   10330            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10331            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 1), 1));
   10332            0 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   10333            0 :       break;
   10334              : 
   10335          112 :     case 1193:  /* x86_shrd_ndd_1 */
   10336          112 :     case 1181:  /* x86_64_shrd_ndd_1 */
   10337          112 :     case 1113:  /* x86_shld_ndd_1 */
   10338          112 :     case 1101:  /* x86_64_shld_ndd_1 */
   10339          112 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10340          112 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10341          112 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0));
   10342          112 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10343          112 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1));
   10344          112 :       break;
   10345              : 
   10346            0 :     case 1192:  /* x86_shrd_ndd_1_nf */
   10347            0 :     case 1180:  /* x86_64_shrd_ndd_1_nf */
   10348            0 :     case 1112:  /* x86_shld_ndd_1_nf */
   10349            0 :     case 1100:  /* x86_64_shld_ndd_1_nf */
   10350            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10351            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   10352            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 0));
   10353            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10354            0 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1));
   10355            0 :       break;
   10356              : 
   10357        16096 :     case 1191:  /* x86_shrd_1 */
   10358        16096 :     case 1179:  /* x86_64_shrd_1 */
   10359        16096 :     case 1111:  /* x86_shld_1 */
   10360        16096 :     case 1099:  /* x86_64_shld_1 */
   10361        16096 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10362        16096 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0));
   10363        16096 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10364        16096 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1));
   10365        16096 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0);
   10366        16096 :       recog_data.dup_num[0] = 0;
   10367        16096 :       break;
   10368              : 
   10369            7 :     case 1190:  /* x86_shrd_1_nf */
   10370            7 :     case 1178:  /* x86_64_shrd_1_nf */
   10371            7 :     case 1110:  /* x86_shld_1_nf */
   10372            7 :     case 1098:  /* x86_64_shld_1_nf */
   10373            7 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10374            7 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 0));
   10375            7 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10376            7 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1));
   10377            7 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 0);
   10378            7 :       recog_data.dup_num[0] = 0;
   10379            7 :       break;
   10380              : 
   10381           45 :     case 1189:  /* x86_shrd_ndd */
   10382           45 :     case 1177:  /* x86_64_shrd_ndd */
   10383           45 :     case 1109:  /* x86_shld_ndd */
   10384           45 :     case 1097:  /* x86_64_shld_ndd */
   10385           45 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10386           45 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10387           45 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0));
   10388           45 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   10389           45 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1), 1), 0);
   10390           45 :       recog_data.dup_num[0] = 3;
   10391           45 :       break;
   10392              : 
   10393            0 :     case 1188:  /* x86_shrd_ndd_nf */
   10394            0 :     case 1176:  /* x86_64_shrd_ndd_nf */
   10395            0 :     case 1108:  /* x86_shld_ndd_nf */
   10396            0 :     case 1096:  /* x86_64_shld_ndd_nf */
   10397            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10398            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   10399            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 0));
   10400            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
   10401            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1), 1), 0);
   10402            0 :       recog_data.dup_num[0] = 3;
   10403            0 :       break;
   10404              : 
   10405        87180 :     case 1187:  /* x86_shrd */
   10406        87180 :     case 1175:  /* x86_64_shrd */
   10407        87180 :     case 1107:  /* x86_shld */
   10408        87180 :     case 1095:  /* x86_64_shld */
   10409        87180 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10410        87180 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0));
   10411        87180 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   10412        87180 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0);
   10413        87180 :       recog_data.dup_num[0] = 0;
   10414        87180 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1), 1), 0);
   10415        87180 :       recog_data.dup_num[1] = 2;
   10416        87180 :       break;
   10417              : 
   10418            0 :     case 1186:  /* x86_shrd_nf */
   10419            0 :     case 1174:  /* x86_64_shrd_nf */
   10420            0 :     case 1106:  /* x86_shld_nf */
   10421            0 :     case 1094:  /* x86_64_shld_nf */
   10422            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10423            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 0));
   10424            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
   10425            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 0);
   10426            0 :       recog_data.dup_num[0] = 0;
   10427            0 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1), 1), 0);
   10428            0 :       recog_data.dup_num[1] = 2;
   10429            0 :       break;
   10430              : 
   10431         4151 :     case 1347:  /* *rotrdi3_add_1 */
   10432         4151 :     case 1346:  /* *rotldi3_add_1 */
   10433         4151 :     case 1345:  /* *rotrsi3_add_1 */
   10434         4151 :     case 1344:  /* *rotlsi3_add_1 */
   10435         4151 :     case 1343:  /* *rotrhi3_add_1 */
   10436         4151 :     case 1342:  /* *rotlhi3_add_1 */
   10437         4151 :     case 1341:  /* *rotrqi3_add_1 */
   10438         4151 :     case 1340:  /* *rotlqi3_add_1 */
   10439         4151 :     case 1331:  /* *rotrdi3_mask_1 */
   10440         4151 :     case 1330:  /* *rotldi3_mask_1 */
   10441         4151 :     case 1329:  /* *rotrsi3_mask_1 */
   10442         4151 :     case 1328:  /* *rotlsi3_mask_1 */
   10443         4151 :     case 1327:  /* *rotrhi3_mask_1 */
   10444         4151 :     case 1326:  /* *rotlhi3_mask_1 */
   10445         4151 :     case 1325:  /* *rotrqi3_mask_1 */
   10446         4151 :     case 1324:  /* *rotlqi3_mask_1 */
   10447         4151 :     case 1299:  /* *ashrdi3_add_1 */
   10448         4151 :     case 1298:  /* *lshrdi3_add_1 */
   10449         4151 :     case 1297:  /* *ashldi3_add_1 */
   10450         4151 :     case 1296:  /* *ashrsi3_add_1 */
   10451         4151 :     case 1295:  /* *lshrsi3_add_1 */
   10452         4151 :     case 1294:  /* *ashlsi3_add_1 */
   10453         4151 :     case 1287:  /* *ashrdi3_mask_1 */
   10454         4151 :     case 1286:  /* *lshrdi3_mask_1 */
   10455         4151 :     case 1285:  /* *ashldi3_mask_1 */
   10456         4151 :     case 1284:  /* *ashrsi3_mask_1 */
   10457         4151 :     case 1283:  /* *lshrsi3_mask_1 */
   10458         4151 :     case 1282:  /* *ashlsi3_mask_1 */
   10459         4151 :     case 1161:  /* *ashrti3_doubleword_mask_1 */
   10460         4151 :     case 1160:  /* *lshrti3_doubleword_mask_1 */
   10461         4151 :     case 1159:  /* *ashrdi3_doubleword_mask_1 */
   10462         4151 :     case 1158:  /* *lshrdi3_doubleword_mask_1 */
   10463         4151 :     case 1087:  /* *ashlti3_doubleword_mask_1 */
   10464         4151 :     case 1086:  /* *ashldi3_doubleword_mask_1 */
   10465         4151 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10466         4151 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10467         4151 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   10468         4151 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1));
   10469         4151 :       break;
   10470              : 
   10471        31461 :     case 1339:  /* *rotrdi3_add */
   10472        31461 :     case 1338:  /* *rotldi3_add */
   10473        31461 :     case 1337:  /* *rotrsi3_add */
   10474        31461 :     case 1336:  /* *rotlsi3_add */
   10475        31461 :     case 1335:  /* *rotrhi3_add */
   10476        31461 :     case 1334:  /* *rotlhi3_add */
   10477        31461 :     case 1333:  /* *rotrqi3_add */
   10478        31461 :     case 1332:  /* *rotlqi3_add */
   10479        31461 :     case 1323:  /* *rotrdi3_mask */
   10480        31461 :     case 1322:  /* *rotldi3_mask */
   10481        31461 :     case 1321:  /* *rotrsi3_mask */
   10482        31461 :     case 1320:  /* *rotlsi3_mask */
   10483        31461 :     case 1319:  /* *rotrhi3_mask */
   10484        31461 :     case 1318:  /* *rotlhi3_mask */
   10485        31461 :     case 1317:  /* *rotrqi3_mask */
   10486        31461 :     case 1316:  /* *rotlqi3_mask */
   10487        31461 :     case 1293:  /* *ashrdi3_add */
   10488        31461 :     case 1292:  /* *lshrdi3_add */
   10489        31461 :     case 1291:  /* *ashldi3_add */
   10490        31461 :     case 1290:  /* *ashrsi3_add */
   10491        31461 :     case 1289:  /* *lshrsi3_add */
   10492        31461 :     case 1288:  /* *ashlsi3_add */
   10493        31461 :     case 1281:  /* *ashrdi3_mask */
   10494        31461 :     case 1280:  /* *lshrdi3_mask */
   10495        31461 :     case 1279:  /* *ashldi3_mask */
   10496        31461 :     case 1278:  /* *ashrsi3_mask */
   10497        31461 :     case 1277:  /* *lshrsi3_mask */
   10498        31461 :     case 1276:  /* *ashlsi3_mask */
   10499        31461 :     case 1157:  /* *ashrti3_doubleword_mask */
   10500        31461 :     case 1156:  /* *lshrti3_doubleword_mask */
   10501        31461 :     case 1155:  /* *ashrdi3_doubleword_mask */
   10502        31461 :     case 1154:  /* *lshrdi3_doubleword_mask */
   10503        31461 :     case 1085:  /* *ashlti3_doubleword_mask */
   10504        31461 :     case 1084:  /* *ashldi3_doubleword_mask */
   10505        31461 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10506        31461 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10507        31461 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0));
   10508        31461 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1));
   10509        31461 :       break;
   10510              : 
   10511           16 :     case 2736:  /* *nabsv2df2 */
   10512           16 :     case 2735:  /* *nabsv4df2 */
   10513           16 :     case 2734:  /* *nabsv8df2 */
   10514           16 :     case 2733:  /* *nabsv4sf2 */
   10515           16 :     case 2732:  /* *nabsv8sf2 */
   10516           16 :     case 2731:  /* *nabsv16sf2 */
   10517           16 :     case 2154:  /* *mmx_nabsv4hf2 */
   10518           16 :     case 2153:  /* *mmx_nabsv2hf2 */
   10519           16 :     case 2152:  /* *mmx_nabsv4bf2 */
   10520           16 :     case 2151:  /* *mmx_nabsv2bf2 */
   10521           16 :     case 2099:  /* *mmx_nabsv2sf2 */
   10522           16 :     case 1055:  /* *nabsdf2_1 */
   10523           16 :     case 1054:  /* *nabssf2_1 */
   10524           16 :     case 1041:  /* *nabstf2_1 */
   10525           16 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10526           16 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10527           16 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10528           16 :       break;
   10529              : 
   10530        15219 :     case 1026:  /* *negvdi3 */
   10531        15219 :     case 1025:  /* *negvsi3 */
   10532        15219 :     case 1024:  /* *negvhi3 */
   10533        15219 :     case 1023:  /* *negvqi3 */
   10534        15219 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10535        15219 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
   10536        15219 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
   10537        15219 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   10538        15219 :       recog_data.dup_num[0] = 1;
   10539        15219 :       break;
   10540              : 
   10541           63 :     case 1022:  /* *negqi_extdi_1 */
   10542           63 :     case 1021:  /* *negqi_extsi_1 */
   10543           63 :     case 1020:  /* *negqi_exthi_1 */
   10544           63 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   10545           63 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   10546           63 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   10547           63 :       break;
   10548              : 
   10549        23218 :     case 1019:  /* *negdi_ccc_2 */
   10550        23218 :     case 1018:  /* *negsi_ccc_2 */
   10551        23218 :     case 1017:  /* *neghi_ccc_2 */
   10552        23218 :     case 1016:  /* *negqi_ccc_2 */
   10553        23218 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10554        23218 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
   10555        23218 :       break;
   10556              : 
   10557        27658 :     case 1015:  /* *negdi_ccc_1 */
   10558        27658 :     case 1014:  /* *negsi_ccc_1 */
   10559        27658 :     case 1013:  /* *neghi_ccc_1 */
   10560        27658 :     case 1012:  /* *negqi_ccc_1 */
   10561        27658 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10562        27658 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
   10563        27658 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   10564        27658 :       recog_data.dup_num[0] = 1;
   10565        27658 :       break;
   10566              : 
   10567            0 :     case 1080:  /* *one_cmplsi2_2_zext */
   10568            0 :     case 1011:  /* *negsi_2_zext */
   10569            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10570            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10571            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   10572            0 :       recog_data.dup_num[0] = 1;
   10573            0 :       break;
   10574              : 
   10575       115147 :     case 1079:  /* *one_cmpldi2_2 */
   10576       115147 :     case 1078:  /* *one_cmplsi2_2 */
   10577       115147 :     case 1077:  /* *one_cmplhi2_2 */
   10578       115147 :     case 1076:  /* *one_cmplqi2_2 */
   10579       115147 :     case 1010:  /* *negdi_2 */
   10580       115147 :     case 1009:  /* *negsi_2 */
   10581       115147 :     case 1008:  /* *neghi_2 */
   10582       115147 :     case 1007:  /* *negqi_2 */
   10583       115147 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10584       115147 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10585       115147 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   10586       115147 :       recog_data.dup_num[0] = 1;
   10587       115147 :       break;
   10588              : 
   10589        47342 :     case 1211:  /* *highpartdisi2 */
   10590        47342 :     case 1006:  /* *neghi_1_slp */
   10591        47342 :     case 1005:  /* *negqi_1_slp */
   10592        47342 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   10593        47342 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10594        47342 :       break;
   10595              : 
   10596         6274 :     case 9436:  /* avx512cd_maskw_vec_dupv4si */
   10597         6274 :     case 9435:  /* avx512cd_maskw_vec_dupv8si */
   10598         6274 :     case 9434:  /* avx512cd_maskw_vec_dupv16si */
   10599         6274 :     case 9433:  /* avx512cd_maskb_vec_dupv2di */
   10600         6274 :     case 9432:  /* avx512cd_maskb_vec_dupv4di */
   10601         6274 :     case 9431:  /* avx512cd_maskb_vec_dupv8di */
   10602         6274 :     case 2650:  /* *knotsi_1_zext */
   10603         6274 :     case 1663:  /* *popcounthi2_2 */
   10604         6274 :     case 1662:  /* *popcounthi2_1 */
   10605         6274 :     case 1660:  /* *popcountsi2_zext_2 */
   10606         6274 :     case 1569:  /* *clzsi2_lzcnt_zext_2 */
   10607         6274 :     case 1545:  /* *ctzsidi2_uext */
   10608         6274 :     case 1544:  /* *ctzsidi2_sext */
   10609         6274 :     case 1418:  /* rcrdi2 */
   10610         6274 :     case 1417:  /* rcrsi2 */
   10611         6274 :     case 1038:  /* *nabsdi2_1 */
   10612         6274 :     case 1037:  /* *nabssi2_1 */
   10613         6274 :     case 1036:  /* *nabshi2_1 */
   10614         6274 :     case 1035:  /* *nabsqi2_1 */
   10615         6274 :     case 1030:  /* *nabsti2_doubleword */
   10616         6274 :     case 1029:  /* *nabsdi2_doubleword */
   10617         6274 :     case 1004:  /* *negsi_1_zext */
   10618         6274 :     case 1003:  /* *neghi_1_zextdi */
   10619         6274 :     case 1001:  /* *neghi_1_zextsi */
   10620         6274 :     case 999:  /* *negqi_1_zextdi */
   10621         6274 :     case 997:  /* *negqi_1_zextsi */
   10622         6274 :     case 995:  /* *negqi_1_zexthi */
   10623         6274 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10624         6274 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10625         6274 :       break;
   10626              : 
   10627     43004521 :     case 10429:  /* *vcvtneps2bf16_v4sf */
   10628     43004521 :     case 9570:  /* vec_set_hi_v32qi */
   10629     43004521 :     case 9568:  /* vec_set_hi_v16bf */
   10630     43004521 :     case 9567:  /* vec_set_hi_v16hf */
   10631     43004521 :     case 9566:  /* vec_set_hi_v16hi */
   10632     43004521 :     case 9561:  /* vec_set_hi_v8sf */
   10633     43004521 :     case 9559:  /* vec_set_hi_v8si */
   10634     43004521 :     case 9553:  /* vec_set_hi_v4df */
   10635     43004521 :     case 9551:  /* vec_set_hi_v4di */
   10636     43004521 :     case 8467:  /* vec_set_hi_v8di */
   10637     43004521 :     case 8465:  /* vec_set_hi_v8df */
   10638     43004521 :     case 8459:  /* vec_set_hi_v16si */
   10639     43004521 :     case 8457:  /* vec_set_hi_v16sf */
   10640     43004521 :     case 8128:  /* *iornotv2di3 */
   10641     43004521 :     case 8127:  /* *iornotv4di3 */
   10642     43004521 :     case 8126:  /* *iornotv4si3 */
   10643     43004521 :     case 8125:  /* *iornotv8si3 */
   10644     43004521 :     case 8124:  /* *iornotv8hi3 */
   10645     43004521 :     case 8123:  /* *iornotv16hi3 */
   10646     43004521 :     case 8122:  /* *iornotv32hi3 */
   10647     43004521 :     case 8121:  /* *iornotv16qi3 */
   10648     43004521 :     case 8120:  /* *iornotv32qi3 */
   10649     43004521 :     case 8119:  /* *iornotv64qi3 */
   10650     43004521 :     case 8118:  /* *iornotv8di3 */
   10651     43004521 :     case 8117:  /* *iornotv16si3 */
   10652     43004521 :     case 8053:  /* *andnotv2di3 */
   10653     43004521 :     case 8052:  /* *andnotv4di3 */
   10654     43004521 :     case 8051:  /* *andnotv4si3 */
   10655     43004521 :     case 8050:  /* *andnotv8si3 */
   10656     43004521 :     case 8049:  /* *andnotv8hi3 */
   10657     43004521 :     case 8048:  /* *andnotv16hi3 */
   10658     43004521 :     case 8047:  /* *andnotv32hi3 */
   10659     43004521 :     case 8046:  /* *andnotv16qi3 */
   10660     43004521 :     case 8045:  /* *andnotv32qi3 */
   10661     43004521 :     case 8044:  /* *andnotv64qi3 */
   10662     43004521 :     case 8043:  /* *andnotv8di3 */
   10663     43004521 :     case 8042:  /* *andnotv16si3 */
   10664     43004521 :     case 7451:  /* avx512vl_us_truncatev2div2si2 */
   10665     43004521 :     case 7450:  /* avx512vl_truncatev2div2si2 */
   10666     43004521 :     case 7449:  /* avx512vl_ss_truncatev2div2si2 */
   10667     43004521 :     case 7402:  /* avx512vl_us_truncatev4siv4hi2 */
   10668     43004521 :     case 7401:  /* avx512vl_truncatev4siv4hi2 */
   10669     43004521 :     case 7400:  /* avx512vl_ss_truncatev4siv4hi2 */
   10670     43004521 :     case 7399:  /* avx512vl_us_truncatev2div2hi2 */
   10671     43004521 :     case 7398:  /* avx512vl_truncatev2div2hi2 */
   10672     43004521 :     case 7397:  /* avx512vl_ss_truncatev2div2hi2 */
   10673     43004521 :     case 7396:  /* avx512vl_us_truncatev4div4hi2 */
   10674     43004521 :     case 7395:  /* avx512vl_truncatev4div4hi2 */
   10675     43004521 :     case 7394:  /* avx512vl_ss_truncatev4div4hi2 */
   10676     43004521 :     case 7317:  /* avx512vl_us_truncatev8hiv8qi2 */
   10677     43004521 :     case 7316:  /* avx512vl_truncatev8hiv8qi2 */
   10678     43004521 :     case 7315:  /* avx512vl_ss_truncatev8hiv8qi2 */
   10679     43004521 :     case 7314:  /* avx512vl_us_truncatev4siv4qi2 */
   10680     43004521 :     case 7313:  /* avx512vl_truncatev4siv4qi2 */
   10681     43004521 :     case 7312:  /* avx512vl_ss_truncatev4siv4qi2 */
   10682     43004521 :     case 7311:  /* avx512vl_us_truncatev8siv8qi2 */
   10683     43004521 :     case 7310:  /* avx512vl_truncatev8siv8qi2 */
   10684     43004521 :     case 7309:  /* avx512vl_ss_truncatev8siv8qi2 */
   10685     43004521 :     case 7308:  /* avx512vl_us_truncatev2div2qi2 */
   10686     43004521 :     case 7307:  /* avx512vl_truncatev2div2qi2 */
   10687     43004521 :     case 7306:  /* avx512vl_ss_truncatev2div2qi2 */
   10688     43004521 :     case 7305:  /* avx512vl_us_truncatev4div4qi2 */
   10689     43004521 :     case 7304:  /* avx512vl_truncatev4div4qi2 */
   10690     43004521 :     case 7303:  /* avx512vl_ss_truncatev4div4qi2 */
   10691     43004521 :     case 7238:  /* sse2_loadhpd */
   10692     43004521 :     case 5277:  /* sse_loadhps */
   10693     43004521 :     case 5184:  /* *sse2_cvtpd2ps */
   10694     43004521 :     case 5010:  /* *avx512dq_floatunsv2div2sf2 */
   10695     43004521 :     case 5009:  /* *avx512dq_floatv2div2sf2 */
   10696     43004521 :     case 4785:  /* *avx512fp16_vcvtpd2ph_v2df */
   10697     43004521 :     case 4780:  /* *avx512fp16_vcvtps2ph_v4sf */
   10698     43004521 :     case 4779:  /* *avx512fp16_vcvtpd2ph_v4df */
   10699     43004521 :     case 4566:  /* *avx512fp16_vcvtuqq2ph_v2di */
   10700     43004521 :     case 4565:  /* *avx512fp16_vcvtqq2ph_v2di */
   10701     43004521 :     case 4556:  /* *avx512fp16_vcvtuqq2ph_v4di */
   10702     43004521 :     case 4555:  /* *avx512fp16_vcvtqq2ph_v4di */
   10703     43004521 :     case 4554:  /* *avx512fp16_vcvtudq2ph_v4si */
   10704     43004521 :     case 4553:  /* *avx512fp16_vcvtdq2ph_v4si */
   10705     43004521 :     case 3841:  /* *andnotv1ti3 */
   10706     43004521 :     case 3840:  /* *andnottf3 */
   10707     43004521 :     case 3839:  /* *andnotdf3 */
   10708     43004521 :     case 3838:  /* *andnotsf3 */
   10709     43004521 :     case 3837:  /* *andnothf3 */
   10710     43004521 :     case 3836:  /* *andnotbf3 */
   10711     43004521 :     case 3768:  /* avx512f_andnotv8df3 */
   10712     43004521 :     case 3766:  /* avx512f_andnotv16sf3 */
   10713     43004521 :     case 3765:  /* avx512fp16_andnotv32hf3 */
   10714     43004521 :     case 3764:  /* avx512bf16_andnotv32bf3 */
   10715     43004521 :     case 3762:  /* sse2_andnotv2df3 */
   10716     43004521 :     case 3760:  /* avx_andnotv4df3 */
   10717     43004521 :     case 3758:  /* sse_andnotv4sf3 */
   10718     43004521 :     case 3756:  /* avx_andnotv8sf3 */
   10719     43004521 :     case 3755:  /* avx512fp16_andnotv8hf3 */
   10720     43004521 :     case 3754:  /* avx512fp16_andnotv16hf3 */
   10721     43004521 :     case 3753:  /* avx512bf16_andnotv8bf3 */
   10722     43004521 :     case 3752:  /* avx512bf16_andnotv16bf3 */
   10723     43004521 :     case 2990:  /* sse2_vmsqrtv2df2 */
   10724     43004521 :     case 2986:  /* sse_vmsqrtv4sf2 */
   10725     43004521 :     case 2982:  /* avx512fp16_vmsqrtv8hf2 */
   10726     43004521 :     case 2609:  /* *sse2_movq128_v2df */
   10727     43004521 :     case 2608:  /* *sse2_movq128_v2di */
   10728     43004521 :     case 2318:  /* mmx_andnotv2si3 */
   10729     43004521 :     case 2317:  /* mmx_andnotv4hi3 */
   10730     43004521 :     case 2316:  /* mmx_andnotv8qi3 */
   10731     43004521 :     case 2158:  /* *mmx_andnotv4hf3 */
   10732     43004521 :     case 2157:  /* *mmx_andnotv2hf3 */
   10733     43004521 :     case 2156:  /* *mmx_andnotv4bf3 */
   10734     43004521 :     case 2155:  /* *mmx_andnotv2bf3 */
   10735     43004521 :     case 2124:  /* *mmx_andnotv2sf3 */
   10736     43004521 :     case 1504:  /* *sibcall_value */
   10737     43004521 :     case 1503:  /* *sibcall_value */
   10738     43004521 :     case 1500:  /* *call_value */
   10739     43004521 :     case 1499:  /* *call_value */
   10740     43004521 :     case 983:  /* *concatditi3_7 */
   10741     43004521 :     case 982:  /* *concatditi3_7 */
   10742     43004521 :     case 981:  /* *concatditi3_7 */
   10743     43004521 :     case 980:  /* *concatsidi3_7 */
   10744     43004521 :     case 979:  /* *concatsidi3_7 */
   10745     43004521 :     case 978:  /* *concatsidi3_7 */
   10746     43004521 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10747     43004521 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   10748     43004521 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
   10749     43004521 :       break;
   10750              : 
   10751        55935 :     case 977:  /* *concatditi3_6 */
   10752        55935 :     case 976:  /* *concatditi3_6 */
   10753        55935 :     case 975:  /* *concatditi3_6 */
   10754        55935 :     case 974:  /* *concatditi3_6 */
   10755        55935 :     case 973:  /* *concatditi3_6 */
   10756        55935 :     case 972:  /* *concatditi3_6 */
   10757        55935 :     case 971:  /* *concatsidi3_6 */
   10758        55935 :     case 970:  /* *concatsidi3_6 */
   10759        55935 :     case 969:  /* *concatsidi3_6 */
   10760        55935 :     case 968:  /* *concatsidi3_6 */
   10761        55935 :     case 967:  /* *concatsidi3_6 */
   10762        55935 :     case 966:  /* *concatsidi3_6 */
   10763        55935 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10764        55935 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   10765        55935 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10766        55935 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
   10767        55935 :       break;
   10768              : 
   10769            0 :     case 959:  /* *concatditi3_4 */
   10770            0 :     case 958:  /* *concatditi3_4 */
   10771            0 :     case 957:  /* *concatditi3_4 */
   10772            0 :     case 956:  /* *concatditi3_4 */
   10773            0 :     case 955:  /* *concatditi3_4 */
   10774            0 :     case 954:  /* *concatditi3_4 */
   10775            0 :     case 953:  /* *concatsidi3_4 */
   10776            0 :     case 952:  /* *concatsidi3_4 */
   10777            0 :     case 951:  /* *concatsidi3_4 */
   10778            0 :     case 950:  /* *concatsidi3_4 */
   10779            0 :     case 949:  /* *concatsidi3_4 */
   10780            0 :     case 948:  /* *concatsidi3_4 */
   10781            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10782            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   10783            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
   10784            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 1), 1));
   10785            0 :       break;
   10786              : 
   10787       680138 :     case 947:  /* *concatditi3_3 */
   10788       680138 :     case 946:  /* *concatditi3_3 */
   10789       680138 :     case 945:  /* *concatditi3_3 */
   10790       680138 :     case 944:  /* *concatditi3_3 */
   10791       680138 :     case 943:  /* *concatditi3_3 */
   10792       680138 :     case 942:  /* *concatditi3_3 */
   10793       680138 :     case 941:  /* *concatsidi3_3 */
   10794       680138 :     case 940:  /* *concatsidi3_3 */
   10795       680138 :     case 939:  /* *concatsidi3_3 */
   10796       680138 :     case 938:  /* *concatsidi3_3 */
   10797       680138 :     case 937:  /* *concatsidi3_3 */
   10798       680138 :     case 936:  /* *concatsidi3_3 */
   10799       680138 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10800       680138 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   10801       680138 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10802       680138 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   10803       680138 :       break;
   10804              : 
   10805            0 :     case 935:  /* *concatditi3_2 */
   10806            0 :     case 934:  /* *concatditi3_2 */
   10807            0 :     case 933:  /* *concatditi3_2 */
   10808            0 :     case 932:  /* *concatsidi3_2 */
   10809            0 :     case 931:  /* *concatsidi3_2 */
   10810            0 :     case 930:  /* *concatsidi3_2 */
   10811            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10812            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   10813            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   10814            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 1), 1));
   10815            0 :       break;
   10816              : 
   10817        24181 :     case 929:  /* *concatditi3_1 */
   10818        24181 :     case 928:  /* *concatditi3_1 */
   10819        24181 :     case 927:  /* *concatditi3_1 */
   10820        24181 :     case 926:  /* *concatsidi3_1 */
   10821        24181 :     case 925:  /* *concatsidi3_1 */
   10822        24181 :     case 924:  /* *concatsidi3_1 */
   10823        24181 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10824        24181 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   10825        24181 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10826        24181 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   10827        24181 :       break;
   10828              : 
   10829            0 :     case 911:  /* *xorsi_2_zext_imm */
   10830            0 :     case 910:  /* *iorsi_2_zext_imm */
   10831            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10832            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10833            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10834            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   10835            0 :       recog_data.dup_num[0] = 1;
   10836            0 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   10837            0 :       recog_data.dup_num[1] = 2;
   10838            0 :       break;
   10839              : 
   10840          154 :     case 870:  /* *xor2andn */
   10841          154 :     case 869:  /* *xor2andn */
   10842          154 :     case 868:  /* *xor2andn */
   10843          154 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10844          154 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   10845          154 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   10846          154 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10847          154 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
   10848          154 :       recog_data.dup_num[0] = 1;
   10849          154 :       break;
   10850              : 
   10851         2273 :     case 846:  /* *andn_di_ccno */
   10852         2273 :     case 845:  /* *andn_si_ccno */
   10853         2273 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10854         2273 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   10855         2273 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10856         2273 :       break;
   10857              : 
   10858        56044 :     case 2641:  /* kandndi */
   10859        56044 :     case 2640:  /* kandnsi */
   10860        56044 :     case 2639:  /* kandnhi */
   10861        56044 :     case 2638:  /* kandnqi */
   10862        56044 :     case 2321:  /* *andnotv2hi3 */
   10863        56044 :     case 2320:  /* *andnotv2qi3 */
   10864        56044 :     case 2319:  /* *andnotv4qi3 */
   10865        56044 :     case 1506:  /* *sibcall_value_memory */
   10866        56044 :     case 1505:  /* *sibcall_value_memory */
   10867        56044 :     case 1093:  /* *ashlti3_doubleword_highpart */
   10868        56044 :     case 1092:  /* *ashlti3_doubleword_highpart */
   10869        56044 :     case 1091:  /* *ashldi3_doubleword_highpart */
   10870        56044 :     case 1090:  /* *ashldi3_doubleword_highpart */
   10871        56044 :     case 894:  /* *xorsi_1_zext_imm */
   10872        56044 :     case 893:  /* *iorsi_1_zext_imm */
   10873        56044 :     case 844:  /* *andnhi_1 */
   10874        56044 :     case 843:  /* *andnqi_1 */
   10875        56044 :     case 842:  /* *andndi_1 */
   10876        56044 :     case 841:  /* *andnsi_1 */
   10877        56044 :     case 840:  /* *andnti3_doubleword */
   10878        56044 :     case 839:  /* *andndi3_doubleword */
   10879        56044 :     case 838:  /* *andnti3_doubleword_bmi */
   10880        56044 :     case 837:  /* *andndi3_doubleword_bmi */
   10881        56044 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10882        56044 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10883        56044 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   10884        56044 :       break;
   10885              : 
   10886          414 :     case 836:  /* *xorqi_extdi_3 */
   10887          414 :     case 835:  /* *iorqi_extdi_3 */
   10888          414 :     case 834:  /* *andqi_extdi_3 */
   10889          414 :     case 833:  /* *xorqi_extsi_3 */
   10890          414 :     case 832:  /* *iorqi_extsi_3 */
   10891          414 :     case 831:  /* *andqi_extsi_3 */
   10892          414 :     case 830:  /* *xorqi_exthi_3 */
   10893          414 :     case 829:  /* *iorqi_exthi_3 */
   10894          414 :     case 828:  /* *andqi_exthi_3 */
   10895          414 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   10896          414 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10897          414 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10898          414 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 0), 1));
   10899          414 :       break;
   10900              : 
   10901         3177 :     case 818:  /* *xorqi_extdi_1_cc */
   10902         3177 :     case 817:  /* *iorqi_extdi_1_cc */
   10903         3177 :     case 816:  /* *andqi_extdi_1_cc */
   10904         3177 :     case 815:  /* *xorqi_extsi_1_cc */
   10905         3177 :     case 814:  /* *iorqi_extsi_1_cc */
   10906         3177 :     case 813:  /* *andqi_extsi_1_cc */
   10907         3177 :     case 812:  /* *xorqi_exthi_1_cc */
   10908         3177 :     case 811:  /* *iorqi_exthi_1_cc */
   10909         3177 :     case 810:  /* *andqi_exthi_1_cc */
   10910         3177 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 0), 0));
   10911         3177 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   10912         3177 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10913         3177 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   10914         3177 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10915         3177 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (pat, 0, 0), 1));
   10916         3177 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0), 0), 0);
   10917         3177 :       recog_data.dup_num[0] = 0;
   10918         3177 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   10919         3177 :       recog_data.dup_num[1] = 2;
   10920         3177 :       break;
   10921              : 
   10922        17626 :     case 730:  /* *testti_not_doubleword */
   10923        17626 :     case 729:  /* *testdi_not_doubleword */
   10924        17626 :     case 728:  /* *testdi_not */
   10925        17626 :     case 727:  /* *testsi_not */
   10926        17626 :     case 726:  /* *testhi_not */
   10927        17626 :     case 725:  /* *testqi_not */
   10928        17626 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   10929        17626 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10930        17626 :       break;
   10931              : 
   10932       360776 :     case 724:  /* *testqi_ext_3 */
   10933       360776 :     case 723:  /* *testqi_ext_3 */
   10934       360776 :     case 722:  /* *testqi_ext_3 */
   10935       360776 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10936       360776 :       ro[1] = *(ro_loc[1] = &XEXP (pat, 1));
   10937       360776 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   10938       360776 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10939       360776 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
   10940       360776 :       break;
   10941              : 
   10942            0 :     case 720:  /* *testqi_extdi_2 */
   10943            0 :     case 719:  /* *testqi_extsi_2 */
   10944            0 :     case 718:  /* *testqi_exthi_2 */
   10945            0 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
   10946            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0), 0));
   10947            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   10948            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0));
   10949            0 :       break;
   10950              : 
   10951       103721 :     case 717:  /* *testqi_extdi_1 */
   10952       103721 :     case 716:  /* *testqi_extsi_1 */
   10953       103721 :     case 715:  /* *testqi_exthi_1 */
   10954       103721 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
   10955       103721 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10956       103721 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   10957       103721 :       break;
   10958              : 
   10959        10589 :     case 709:  /* udivmodhiqi3 */
   10960        10589 :     case 707:  /* divmodhiqi3 */
   10961        10589 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10962        10589 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0), 0));
   10963        10589 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0), 1), 0));
   10964        10589 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0);
   10965        10589 :       recog_data.dup_num[0] = 1;
   10966        10589 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 1), 0);
   10967        10589 :       recog_data.dup_num[1] = 2;
   10968        10589 :       break;
   10969              : 
   10970            0 :     case 708:  /* udivmodhiqi3_nf */
   10971            0 :     case 706:  /* divmodhiqi3_nf */
   10972            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10973            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 0));
   10974            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0), 1), 0));
   10975            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 0);
   10976            0 :       recog_data.dup_num[0] = 1;
   10977            0 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0), 1), 0);
   10978            0 :       recog_data.dup_num[1] = 2;
   10979            0 :       break;
   10980              : 
   10981          351 :     case 704:  /* *udivmodsi4_noext_zext_2 */
   10982          351 :     case 703:  /* *divmodsi4_noext_zext_2 */
   10983          351 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10984          351 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10985          351 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10986          351 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10987          351 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 2), 0));
   10988          351 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   10989          351 :       recog_data.dup_num[0] = 2;
   10990          351 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   10991          351 :       recog_data.dup_num[1] = 3;
   10992          351 :       break;
   10993              : 
   10994         1308 :     case 702:  /* *udivmodsi4_noext_zext_1 */
   10995         1308 :     case 701:  /* *divmodsi4_noext_zext_1 */
   10996         1308 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10997         1308 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10998         1308 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10999         1308 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11000         1308 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 2), 0));
   11001         1308 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11002         1308 :       recog_data.dup_num[0] = 2;
   11003         1308 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11004         1308 :       recog_data.dup_num[1] = 3;
   11005         1308 :       break;
   11006              : 
   11007       630339 :     case 700:  /* *udivmoddi4_noext */
   11008       630339 :     case 699:  /* *divmoddi4_noext */
   11009       630339 :     case 698:  /* *udivmodsi4_noext */
   11010       630339 :     case 697:  /* *divmodsi4_noext */
   11011       630339 :     case 696:  /* *udivmodhi4_noext */
   11012       630339 :     case 695:  /* *divmodhi4_noext */
   11013       630339 :     case 694:  /* *udivmoddi4_noext_nf */
   11014       630339 :     case 693:  /* *divmoddi4_noext_nf */
   11015       630339 :     case 692:  /* *udivmodsi4_noext_nf */
   11016       630339 :     case 691:  /* *divmodsi4_noext_nf */
   11017       630339 :     case 690:  /* *udivmodhi4_noext_nf */
   11018       630339 :     case 689:  /* *divmodhi4_noext_nf */
   11019       630339 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11020       630339 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11021       630339 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11022       630339 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11023       630339 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 2), 0));
   11024       630339 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11025       630339 :       recog_data.dup_num[0] = 2;
   11026       630339 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11027       630339 :       recog_data.dup_num[1] = 3;
   11028       630339 :       break;
   11029              : 
   11030          562 :     case 688:  /* *udivmodsi4_pow2_zext_2 */
   11031          562 :     case 687:  /* *udivmodsi4_zext_2 */
   11032          562 :     case 686:  /* *divmodsi4_zext_2 */
   11033          562 :     case 674:  /* udivmodsi4_zext_2 */
   11034          562 :     case 673:  /* divmodsi4_zext_2 */
   11035          562 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11036          562 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11037          562 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11038          562 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11039          562 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11040          562 :       recog_data.dup_num[0] = 2;
   11041          562 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11042          562 :       recog_data.dup_num[1] = 3;
   11043          562 :       break;
   11044              : 
   11045         2227 :     case 685:  /* *udivmodsi4_pow2_zext_1 */
   11046         2227 :     case 684:  /* *udivmodsi4_zext_1 */
   11047         2227 :     case 683:  /* *divmodsi4_zext_1 */
   11048         2227 :     case 672:  /* udivmodsi4_zext_1 */
   11049         2227 :     case 671:  /* divmodsi4_zext_1 */
   11050         2227 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11051         2227 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11052         2227 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11053         2227 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11054         2227 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11055         2227 :       recog_data.dup_num[0] = 2;
   11056         2227 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11057         2227 :       recog_data.dup_num[1] = 3;
   11058         2227 :       break;
   11059              : 
   11060            0 :     case 664:  /* *umulsi3_highpart_zext */
   11061            0 :     case 663:  /* *smulsi3_highpart_zext */
   11062            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11063            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0), 0));
   11064            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 1), 0));
   11065            0 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11066            0 :       break;
   11067              : 
   11068            0 :     case 666:  /* *umulsi3_highpart_1 */
   11069            0 :     case 665:  /* *smulsi3_highpart_1 */
   11070            0 :     case 662:  /* *umuldi3_highpart_1 */
   11071            0 :     case 661:  /* *smuldi3_highpart_1 */
   11072            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11073            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   11074            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1), 0));
   11075            0 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11076            0 :       break;
   11077              : 
   11078            0 :     case 660:  /* *umulsi3_highpart_zext */
   11079            0 :     case 659:  /* *smulsi3_highpart_zext */
   11080            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11081            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11082            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11083            0 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11084            0 :       break;
   11085              : 
   11086       409487 :     case 658:  /* umuldi3_highpart */
   11087       409487 :     case 657:  /* smuldi3_highpart */
   11088       409487 :     case 656:  /* umulsi3_highpart */
   11089       409487 :     case 655:  /* smulsi3_highpart */
   11090       409487 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11091       409487 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11092       409487 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11093       409487 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11094       409487 :       break;
   11095              : 
   11096         2754 :     case 8363:  /* sse2_packssdw */
   11097         2754 :     case 8357:  /* sse2_packsswb */
   11098         2754 :     case 8164:  /* *nandv2di3 */
   11099         2754 :     case 8163:  /* *norv2di3 */
   11100         2754 :     case 8162:  /* *nandv4di3 */
   11101         2754 :     case 8161:  /* *norv4di3 */
   11102         2754 :     case 8160:  /* *nandv4si3 */
   11103         2754 :     case 8159:  /* *norv4si3 */
   11104         2754 :     case 8158:  /* *nandv8si3 */
   11105         2754 :     case 8157:  /* *norv8si3 */
   11106         2754 :     case 8156:  /* *nandv8hi3 */
   11107         2754 :     case 8155:  /* *norv8hi3 */
   11108         2754 :     case 8154:  /* *nandv16hi3 */
   11109         2754 :     case 8153:  /* *norv16hi3 */
   11110         2754 :     case 8152:  /* *nandv32hi3 */
   11111         2754 :     case 8151:  /* *norv32hi3 */
   11112         2754 :     case 8150:  /* *nandv16qi3 */
   11113         2754 :     case 8149:  /* *norv16qi3 */
   11114         2754 :     case 8148:  /* *nandv32qi3 */
   11115         2754 :     case 8147:  /* *norv32qi3 */
   11116         2754 :     case 8146:  /* *nandv64qi3 */
   11117         2754 :     case 8145:  /* *norv64qi3 */
   11118         2754 :     case 8144:  /* *nandv8di3 */
   11119         2754 :     case 8143:  /* *norv8di3 */
   11120         2754 :     case 8142:  /* *nandv16si3 */
   11121         2754 :     case 8141:  /* *norv16si3 */
   11122         2754 :     case 2342:  /* mmx_packssdw */
   11123         2754 :     case 2340:  /* mmx_packsswb */
   11124         2754 :     case 653:  /* *umulqihi3_1_nf */
   11125         2754 :     case 651:  /* *mulqihi3_1_nf */
   11126         2754 :     case 649:  /* *mulditi3_1_nf */
   11127         2754 :     case 647:  /* *mulsidi3_1_nf */
   11128         2754 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   11129         2754 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   11130         2754 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   11131         2754 :       break;
   11132              : 
   11133       796083 :     case 654:  /* *umulqihi3_1 */
   11134       796083 :     case 652:  /* *mulqihi3_1 */
   11135       796083 :     case 650:  /* *mulditi3_1 */
   11136       796083 :     case 648:  /* *mulsidi3_1 */
   11137       796083 :     case 646:  /* *umulditi3_1 */
   11138       796083 :     case 645:  /* *umulsidi3_1 */
   11139       796083 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11140       796083 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11141       796083 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11142       796083 :       break;
   11143              : 
   11144      1213592 :     case 705:  /* *divmodsi4_const */
   11145      1213592 :     case 682:  /* *udivmoddi4_pow2 */
   11146      1213592 :     case 681:  /* *udivmodsi4_pow2 */
   11147      1213592 :     case 680:  /* *udivmoddi4 */
   11148      1213592 :     case 679:  /* *udivmodsi4 */
   11149      1213592 :     case 678:  /* *udivmodhi4 */
   11150      1213592 :     case 677:  /* *divmoddi4 */
   11151      1213592 :     case 676:  /* *divmodsi4 */
   11152      1213592 :     case 675:  /* *divmodhi4 */
   11153      1213592 :     case 670:  /* udivmoddi4_1 */
   11154      1213592 :     case 669:  /* udivmodsi4_1 */
   11155      1213592 :     case 668:  /* divmoddi4_1 */
   11156      1213592 :     case 667:  /* divmodsi4_1 */
   11157      1213592 :     case 644:  /* *bmi2_umulditi3_1 */
   11158      1213592 :     case 643:  /* *bmi2_umulsidi3_1 */
   11159      1213592 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11160      1213592 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11161      1213592 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11162      1213592 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11163      1213592 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11164      1213592 :       recog_data.dup_num[0] = 2;
   11165      1213592 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11166      1213592 :       recog_data.dup_num[1] = 3;
   11167      1213592 :       break;
   11168              : 
   11169       134628 :     case 640:  /* *umulvdi4 */
   11170       134628 :     case 639:  /* *umulvsi4 */
   11171       134628 :     case 638:  /* *umulvhi4 */
   11172       134628 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11173       134628 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   11174       134628 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   11175       134628 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 2), 0));
   11176       134628 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11177       134628 :       recog_data.dup_num[0] = 1;
   11178       134628 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11179       134628 :       recog_data.dup_num[1] = 2;
   11180       134628 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0);
   11181       134628 :       recog_data.dup_num[2] = 1;
   11182       134628 :       recog_data.dup_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1);
   11183       134628 :       recog_data.dup_num[3] = 2;
   11184       134628 :       break;
   11185              : 
   11186          165 :     case 609:  /* *subdi3_eq_1 */
   11187          165 :     case 608:  /* *subsi3_eq_1 */
   11188          165 :     case 607:  /* *subhi3_eq_1 */
   11189          165 :     case 606:  /* *subqi3_eq_1 */
   11190          165 :     case 605:  /* *subdi3_ne */
   11191          165 :     case 604:  /* *subsi3_ne */
   11192          165 :     case 603:  /* *subhi3_ne */
   11193          165 :     case 602:  /* *subqi3_ne */
   11194          165 :     case 601:  /* *subdi3_eq */
   11195          165 :     case 600:  /* *subsi3_eq */
   11196          165 :     case 599:  /* *subhi3_eq */
   11197          165 :     case 598:  /* *subqi3_eq */
   11198          165 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11199          165 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11200          165 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11201          165 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   11202          165 :       break;
   11203              : 
   11204          338 :     case 589:  /* *adddi3_ne */
   11205          338 :     case 588:  /* *addsi3_ne */
   11206          338 :     case 587:  /* *addhi3_ne */
   11207          338 :     case 586:  /* *addqi3_ne */
   11208          338 :     case 585:  /* *adddi3_eq */
   11209          338 :     case 584:  /* *addsi3_eq */
   11210          338 :     case 583:  /* *addhi3_eq */
   11211          338 :     case 582:  /* *addqi3_eq */
   11212          338 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11213          338 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11214          338 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11215          338 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   11216          338 :       break;
   11217              : 
   11218            0 :     case 579:  /* *addsi3_zext_cc_overflow_2 */
   11219            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11220            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11221            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11222            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11223            0 :       recog_data.dup_num[0] = 1;
   11224            0 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   11225            0 :       recog_data.dup_num[1] = 2;
   11226            0 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
   11227            0 :       recog_data.dup_num[2] = 2;
   11228            0 :       break;
   11229              : 
   11230         4856 :     case 578:  /* *adddi3_cc_overflow_2 */
   11231         4856 :     case 577:  /* *addsi3_cc_overflow_2 */
   11232         4856 :     case 576:  /* *addhi3_cc_overflow_2 */
   11233         4856 :     case 575:  /* *addqi3_cc_overflow_2 */
   11234         4856 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11235         4856 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11236         4856 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11237         4856 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11238         4856 :       recog_data.dup_num[0] = 1;
   11239         4856 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11240         4856 :       recog_data.dup_num[1] = 2;
   11241         4856 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
   11242         4856 :       recog_data.dup_num[2] = 2;
   11243         4856 :       break;
   11244              : 
   11245            2 :     case 574:  /* *adddi3_cconly_overflow_2 */
   11246            2 :     case 573:  /* *addsi3_cconly_overflow_2 */
   11247            2 :     case 572:  /* *addhi3_cconly_overflow_2 */
   11248            2 :     case 571:  /* *addqi3_cconly_overflow_2 */
   11249            2 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11250            2 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11251            2 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11252            2 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
   11253            2 :       recog_data.dup_num[0] = 2;
   11254            2 :       break;
   11255              : 
   11256            0 :     case 570:  /* *addsi3_zext_cc_overflow_1 */
   11257            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11258            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11259            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11260            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11261            0 :       recog_data.dup_num[0] = 1;
   11262            0 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   11263            0 :       recog_data.dup_num[1] = 2;
   11264            0 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
   11265            0 :       recog_data.dup_num[2] = 1;
   11266            0 :       break;
   11267              : 
   11268       649426 :     case 581:  /* *addti3_doubleword_cc_overflow_1 */
   11269       649426 :     case 580:  /* *adddi3_doubleword_cc_overflow_1 */
   11270       649426 :     case 569:  /* adddi3_cc_overflow_1 */
   11271       649426 :     case 568:  /* addsi3_cc_overflow_1 */
   11272       649426 :     case 567:  /* addhi3_cc_overflow_1 */
   11273       649426 :     case 566:  /* addqi3_cc_overflow_1 */
   11274       649426 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11275       649426 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11276       649426 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11277       649426 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11278       649426 :       recog_data.dup_num[0] = 1;
   11279       649426 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11280       649426 :       recog_data.dup_num[1] = 2;
   11281       649426 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
   11282       649426 :       recog_data.dup_num[2] = 1;
   11283       649426 :       break;
   11284              : 
   11285       179084 :     case 565:  /* *adddi3_cconly_overflow_1 */
   11286       179084 :     case 564:  /* *addsi3_cconly_overflow_1 */
   11287       179084 :     case 563:  /* *addhi3_cconly_overflow_1 */
   11288       179084 :     case 562:  /* *addqi3_cconly_overflow_1 */
   11289       179084 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11290       179084 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11291       179084 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11292       179084 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
   11293       179084 :       recog_data.dup_num[0] = 1;
   11294       179084 :       break;
   11295              : 
   11296          468 :     case 554:  /* *subborrowdi_1 */
   11297          468 :     case 553:  /* *subborrowsi_1 */
   11298          468 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11299          468 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11300          468 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
   11301          468 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0));
   11302          468 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11303          468 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1));
   11304          468 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1));
   11305          468 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11306          468 :       recog_data.dup_num[0] = 1;
   11307          468 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1), 0);
   11308          468 :       recog_data.dup_num[1] = 3;
   11309          468 :       break;
   11310              : 
   11311        93820 :     case 552:  /* subborrowdi */
   11312        93820 :     case 551:  /* subborrowsi */
   11313        93820 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11314        93820 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11315        93820 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 0));
   11316        93820 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0));
   11317        93820 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11318        93820 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1));
   11319        93820 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11320        93820 :       recog_data.dup_num[0] = 1;
   11321        93820 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1), 0);
   11322        93820 :       recog_data.dup_num[1] = 3;
   11323        93820 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11324        93820 :       recog_data.dup_num[2] = 2;
   11325        93820 :       break;
   11326              : 
   11327       100357 :     case 550:  /* subdi3_carry_ccgz */
   11328       100357 :     case 549:  /* subsi3_carry_ccgz */
   11329       100357 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11330       100357 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
   11331       100357 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
   11332       100357 :       break;
   11333              : 
   11334         1698 :     case 548:  /* *subdi3_carry_ccc_1 */
   11335         1698 :     case 547:  /* *subsi3_carry_ccc_1 */
   11336         1698 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11337         1698 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11338         1698 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1));
   11339         1698 :       break;
   11340              : 
   11341       341678 :     case 546:  /* subdi3_carry_ccc */
   11342       341678 :     case 545:  /* subsi3_carry_ccc */
   11343       341678 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11344       341678 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11345       341678 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 0));
   11346       341678 :       break;
   11347              : 
   11348           73 :     case 532:  /* *subsi3_carry_zext */
   11349           73 :     case 531:  /* *subhi3_carry_zextdi */
   11350           73 :     case 530:  /* *subhi3_carry_zextsi */
   11351           73 :     case 529:  /* *subqi3_carry_zextdi */
   11352           73 :     case 528:  /* *subqi3_carry_zextsi */
   11353           73 :     case 527:  /* *subqi3_carry_zexthi */
   11354           73 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11355           73 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   11356           73 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11357           73 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   11358           73 :       break;
   11359              : 
   11360          398 :     case 526:  /* *subdi3_carry_0r_cc */
   11361          398 :     case 525:  /* *subsi3_carry_0r_cc */
   11362          398 :     case 524:  /* *subhi3_carry_0r_cc */
   11363          398 :     case 523:  /* *subqi3_carry_0r_cc */
   11364          398 :     case 518:  /* *subdi3_carry_0_cc */
   11365          398 :     case 517:  /* *subsi3_carry_0_cc */
   11366          398 :     case 516:  /* *subhi3_carry_0_cc */
   11367          398 :     case 515:  /* *subqi3_carry_0_cc */
   11368          398 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11369          398 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11370          398 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11371          398 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   11372          398 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11373          398 :       recog_data.dup_num[0] = 1;
   11374          398 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11375          398 :       recog_data.dup_num[1] = 2;
   11376          398 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1), 0);
   11377          398 :       recog_data.dup_num[2] = 3;
   11378          398 :       break;
   11379              : 
   11380         1271 :     case 510:  /* *subdi3_carry_2 */
   11381         1271 :     case 509:  /* *subsi3_carry_2 */
   11382         1271 :     case 508:  /* *subhi3_carry_2 */
   11383         1271 :     case 507:  /* *subqi3_carry_2 */
   11384         1271 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11385         1271 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   11386         1271 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11387         1271 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1), 0));
   11388         1271 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   11389         1271 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11390         1271 :       recog_data.dup_num[0] = 1;
   11391         1271 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   11392         1271 :       recog_data.dup_num[1] = 4;
   11393         1271 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1), 0);
   11394         1271 :       recog_data.dup_num[2] = 3;
   11395         1271 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11396         1271 :       recog_data.dup_num[3] = 2;
   11397         1271 :       break;
   11398              : 
   11399        83512 :     case 506:  /* subdi3_carry */
   11400        83512 :     case 505:  /* subsi3_carry */
   11401        83512 :     case 504:  /* subhi3_carry */
   11402        83512 :     case 503:  /* subqi3_carry */
   11403        83512 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11404        83512 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11405        83512 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11406        83512 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   11407        83512 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11408        83512 :       break;
   11409              : 
   11410         4300 :     case 502:  /* *addcarrydi_1 */
   11411         4300 :     case 501:  /* *addcarrysi_1 */
   11412         4300 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11413         4300 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 1));
   11414         4300 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   11415         4300 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0), 0));
   11416         4300 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11417         4300 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   11418         4300 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1));
   11419         4300 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11420         4300 :       recog_data.dup_num[0] = 5;
   11421         4300 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0), 0);
   11422         4300 :       recog_data.dup_num[1] = 3;
   11423         4300 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   11424         4300 :       recog_data.dup_num[2] = 1;
   11425         4300 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11426         4300 :       recog_data.dup_num[3] = 2;
   11427         4300 :       recog_data.dup_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0);
   11428         4300 :       recog_data.dup_num[4] = 3;
   11429         4300 :       break;
   11430              : 
   11431       161652 :     case 500:  /* addcarrydi */
   11432       161652 :     case 499:  /* addcarrysi */
   11433       161652 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11434       161652 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 1));
   11435       161652 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   11436       161652 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0), 0));
   11437       161652 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11438       161652 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   11439       161652 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11440       161652 :       recog_data.dup_num[0] = 5;
   11441       161652 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0), 0);
   11442       161652 :       recog_data.dup_num[1] = 3;
   11443       161652 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   11444       161652 :       recog_data.dup_num[2] = 1;
   11445       161652 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11446       161652 :       recog_data.dup_num[3] = 2;
   11447       161652 :       recog_data.dup_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0);
   11448       161652 :       recog_data.dup_num[4] = 3;
   11449       161652 :       recog_data.dup_loc[5] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 0);
   11450       161652 :       recog_data.dup_num[5] = 2;
   11451       161652 :       break;
   11452              : 
   11453          412 :     case 498:  /* *addsi3_carry_zext_0r */
   11454          412 :     case 497:  /* *addhi3_carry_zextdi_0r */
   11455          412 :     case 496:  /* *addhi3_carry_zextsi_0r */
   11456          412 :     case 495:  /* *addqi3_carry_zextdi_0r */
   11457          412 :     case 494:  /* *addqi3_carry_zextsi_0r */
   11458          412 :     case 493:  /* *addqi3_carry_zexthi_0r */
   11459          412 :     case 492:  /* *addsi3_carry_zext_0 */
   11460          412 :     case 491:  /* *addhi3_carry_zextdi_0 */
   11461          412 :     case 490:  /* *addhi3_carry_zextsi_0 */
   11462          412 :     case 489:  /* *addqi3_carry_zextdi_0 */
   11463          412 :     case 488:  /* *addqi3_carry_zextsi_0 */
   11464          412 :     case 487:  /* *addqi3_carry_zexthi_0 */
   11465          412 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11466          412 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11467          412 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11468          412 :       break;
   11469              : 
   11470           32 :     case 486:  /* *addsi3_carry_zext */
   11471           32 :     case 485:  /* *addhi3_carry_zextdi */
   11472           32 :     case 484:  /* *addhi3_carry_zextsi */
   11473           32 :     case 483:  /* *addqi3_carry_zextdi */
   11474           32 :     case 482:  /* *addqi3_carry_zextsi */
   11475           32 :     case 481:  /* *addqi3_carry_zexthi */
   11476           32 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11477           32 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   11478           32 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11479           32 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   11480           32 :       break;
   11481              : 
   11482          120 :     case 480:  /* *adddi3_carry_0r_cc */
   11483          120 :     case 479:  /* *addsi3_carry_0r_cc */
   11484          120 :     case 478:  /* *addhi3_carry_0r_cc */
   11485          120 :     case 477:  /* *addqi3_carry_0r_cc */
   11486          120 :     case 472:  /* *adddi3_carry_0_cc */
   11487          120 :     case 471:  /* *addsi3_carry_0_cc */
   11488          120 :     case 470:  /* *addhi3_carry_0_cc */
   11489          120 :     case 469:  /* *addqi3_carry_0_cc */
   11490          120 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11491          120 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11492          120 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11493          120 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   11494          120 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11495          120 :       recog_data.dup_num[0] = 2;
   11496          120 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11497          120 :       recog_data.dup_num[1] = 3;
   11498          120 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11499          120 :       recog_data.dup_num[2] = 1;
   11500          120 :       break;
   11501              : 
   11502        36632 :     case 476:  /* *adddi3_carry_0r */
   11503        36632 :     case 475:  /* *addsi3_carry_0r */
   11504        36632 :     case 474:  /* *addhi3_carry_0r */
   11505        36632 :     case 473:  /* *addqi3_carry_0r */
   11506        36632 :     case 468:  /* *adddi3_carry_0 */
   11507        36632 :     case 467:  /* *addsi3_carry_0 */
   11508        36632 :     case 466:  /* *addhi3_carry_0 */
   11509        36632 :     case 465:  /* *addqi3_carry_0 */
   11510        36632 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11511        36632 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11512        36632 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11513        36632 :       break;
   11514              : 
   11515        18214 :     case 464:  /* *adddi3_carry_2 */
   11516        18214 :     case 463:  /* *addsi3_carry_2 */
   11517        18214 :     case 462:  /* *addhi3_carry_2 */
   11518        18214 :     case 461:  /* *addqi3_carry_2 */
   11519        18214 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11520        18214 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   11521        18214 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11522        18214 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   11523        18214 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   11524        18214 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11525        18214 :       recog_data.dup_num[0] = 4;
   11526        18214 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0), 0);
   11527        18214 :       recog_data.dup_num[1] = 3;
   11528        18214 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   11529        18214 :       recog_data.dup_num[2] = 1;
   11530        18214 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11531        18214 :       recog_data.dup_num[3] = 2;
   11532        18214 :       break;
   11533              : 
   11534       355366 :     case 460:  /* adddi3_carry */
   11535       355366 :     case 459:  /* addsi3_carry */
   11536       355366 :     case 458:  /* addhi3_carry */
   11537       355366 :     case 457:  /* addqi3_carry */
   11538       355366 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11539       355366 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11540       355366 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11541       355366 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   11542       355366 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11543       355366 :       break;
   11544              : 
   11545            0 :     case 456:  /* *subsi_3_zext */
   11546            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11547            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11548            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11549            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11550            0 :       recog_data.dup_num[0] = 1;
   11551            0 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   11552            0 :       recog_data.dup_num[1] = 2;
   11553            0 :       break;
   11554              : 
   11555          198 :     case 455:  /* *dec_cmovdi */
   11556          198 :     case 454:  /* *dec_cmovsi */
   11557          198 :     case 453:  /* *dec_cmovhi */
   11558          198 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11559          198 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11560          198 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11561          198 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 2));
   11562          198 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0);
   11563          198 :       recog_data.dup_num[0] = 2;
   11564          198 :       break;
   11565              : 
   11566       173501 :     case 452:  /* *subdi_3 */
   11567       173501 :     case 451:  /* *subsi_3 */
   11568       173501 :     case 450:  /* *subhi_3 */
   11569       173501 :     case 449:  /* *subqi_3 */
   11570       173501 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11571       173501 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11572       173501 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11573       173501 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11574       173501 :       recog_data.dup_num[0] = 1;
   11575       173501 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11576       173501 :       recog_data.dup_num[1] = 2;
   11577       173501 :       break;
   11578              : 
   11579         1413 :     case 448:  /* *subvdi4_overflow_2 */
   11580         1413 :     case 447:  /* *subvsi4_overflow_2 */
   11581         1413 :     case 446:  /* *subvhi4_overflow_2 */
   11582         1413 :     case 445:  /* *subvqi4_overflow_2 */
   11583         1413 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11584         1413 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   11585         1413 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1));
   11586         1413 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1), 0));
   11587         1413 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   11588         1413 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 1));
   11589         1413 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11590         1413 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11591         1413 :       recog_data.dup_num[0] = 1;
   11592         1413 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   11593         1413 :       recog_data.dup_num[1] = 5;
   11594         1413 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1), 0);
   11595         1413 :       recog_data.dup_num[2] = 3;
   11596         1413 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11597         1413 :       recog_data.dup_num[3] = 2;
   11598         1413 :       recog_data.dup_loc[4] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0);
   11599         1413 :       recog_data.dup_num[4] = 1;
   11600         1413 :       recog_data.dup_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 1), 0);
   11601         1413 :       recog_data.dup_num[5] = 3;
   11602         1413 :       break;
   11603              : 
   11604         5920 :     case 444:  /* *subvdi4_overflow_1 */
   11605         5920 :     case 443:  /* *subvsi4_overflow_1 */
   11606         5920 :     case 442:  /* *subvhi4_overflow_1 */
   11607         5920 :     case 441:  /* *subvqi4_overflow_1 */
   11608         5920 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11609         5920 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   11610         5920 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   11611         5920 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1), 0));
   11612         5920 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   11613         5920 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 1));
   11614         5920 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11615         5920 :       recog_data.dup_num[0] = 1;
   11616         5920 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   11617         5920 :       recog_data.dup_num[1] = 5;
   11618         5920 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1), 0);
   11619         5920 :       recog_data.dup_num[2] = 3;
   11620         5920 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11621         5920 :       recog_data.dup_num[3] = 2;
   11622         5920 :       recog_data.dup_loc[4] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0);
   11623         5920 :       recog_data.dup_num[4] = 1;
   11624         5920 :       recog_data.dup_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 1), 0);
   11625         5920 :       recog_data.dup_num[5] = 3;
   11626         5920 :       recog_data.dup_loc[6] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1);
   11627         5920 :       recog_data.dup_num[6] = 2;
   11628         5920 :       break;
   11629              : 
   11630          119 :     case 422:  /* *subqi_extdi_0 */
   11631          119 :     case 421:  /* *subqi_extsi_0 */
   11632          119 :     case 420:  /* *subqi_exthi_0 */
   11633          119 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11634          119 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11635          119 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0));
   11636          119 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11637          119 :       break;
   11638              : 
   11639           90 :     case 411:  /* *subqi_extdi_1_slp */
   11640           90 :     case 410:  /* *subqi_extsi_1_slp */
   11641           90 :     case 409:  /* *subqi_exthi_1_slp */
   11642           90 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   11643           90 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11644           90 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0));
   11645           90 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11646           90 :       break;
   11647              : 
   11648        23861 :     case 617:  /* *subdi3_ne_0 */
   11649        23861 :     case 616:  /* *subsi3_ne_0 */
   11650        23861 :     case 615:  /* *subhi3_ne_0 */
   11651        23861 :     case 614:  /* *subqi3_ne_0 */
   11652        23861 :     case 613:  /* *subdi3_eq_0 */
   11653        23861 :     case 612:  /* *subsi3_eq_0 */
   11654        23861 :     case 611:  /* *subhi3_eq_0 */
   11655        23861 :     case 610:  /* *subqi3_eq_0 */
   11656        23861 :     case 387:  /* *subti3_doubleword_zext */
   11657        23861 :     case 386:  /* *subdi3_doubleword_zext */
   11658        23861 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11659        23861 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11660        23861 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11661        23861 :       break;
   11662              : 
   11663          517 :     case 7945:  /* *eqv2di3_2_negate */
   11664          517 :     case 7944:  /* *eqv4di3_2_negate */
   11665          517 :     case 7943:  /* *eqv4si3_2_negate */
   11666          517 :     case 7942:  /* *eqv8si3_2_negate */
   11667          517 :     case 7941:  /* *eqv8hi3_2_negate */
   11668          517 :     case 7940:  /* *eqv16hi3_2_negate */
   11669          517 :     case 7939:  /* *eqv16qi3_2_negate */
   11670          517 :     case 7938:  /* *eqv32qi3_2_negate */
   11671          517 :     case 6820:  /* *avx512vl_vpternlogv2df_2 */
   11672          517 :     case 6819:  /* *avx512vl_vpternlogv2df_2 */
   11673          517 :     case 6818:  /* *avx512vl_vpternlogv2df_2 */
   11674          517 :     case 6817:  /* *avx512vl_vpternlogv2df_2 */
   11675          517 :     case 6816:  /* *avx512vl_vpternlogv2df_2 */
   11676          517 :     case 6815:  /* *avx512vl_vpternlogv2df_2 */
   11677          517 :     case 6814:  /* *avx512vl_vpternlogv2df_2 */
   11678          517 :     case 6813:  /* *avx512vl_vpternlogv2df_2 */
   11679          517 :     case 6812:  /* *avx512vl_vpternlogv2df_2 */
   11680          517 :     case 6811:  /* *avx512vl_vpternlogv2df_2 */
   11681          517 :     case 6810:  /* *avx512vl_vpternlogv2df_2 */
   11682          517 :     case 6809:  /* *avx512vl_vpternlogv2df_2 */
   11683          517 :     case 6808:  /* *avx512vl_vpternlogv2df_2 */
   11684          517 :     case 6807:  /* *avx512vl_vpternlogv2df_2 */
   11685          517 :     case 6806:  /* *avx512vl_vpternlogv2df_2 */
   11686          517 :     case 6805:  /* *avx512vl_vpternlogv2df_2 */
   11687          517 :     case 6804:  /* *avx512vl_vpternlogv2df_2 */
   11688          517 :     case 6803:  /* *avx512vl_vpternlogv2df_2 */
   11689          517 :     case 6802:  /* *avx512vl_vpternlogv2df_2 */
   11690          517 :     case 6801:  /* *avx512vl_vpternlogv2df_2 */
   11691          517 :     case 6800:  /* *avx512vl_vpternlogv2df_2 */
   11692          517 :     case 6799:  /* *avx512vl_vpternlogv2df_2 */
   11693          517 :     case 6798:  /* *avx512vl_vpternlogv2df_2 */
   11694          517 :     case 6797:  /* *avx512vl_vpternlogv2df_2 */
   11695          517 :     case 6796:  /* *avx512vl_vpternlogv2df_2 */
   11696          517 :     case 6795:  /* *avx512vl_vpternlogv2df_2 */
   11697          517 :     case 6794:  /* *avx512vl_vpternlogv2df_2 */
   11698          517 :     case 6793:  /* *avx512vl_vpternlogv4df_2 */
   11699          517 :     case 6792:  /* *avx512vl_vpternlogv4df_2 */
   11700          517 :     case 6791:  /* *avx512vl_vpternlogv4df_2 */
   11701          517 :     case 6790:  /* *avx512vl_vpternlogv4df_2 */
   11702          517 :     case 6789:  /* *avx512vl_vpternlogv4df_2 */
   11703          517 :     case 6788:  /* *avx512vl_vpternlogv4df_2 */
   11704          517 :     case 6787:  /* *avx512vl_vpternlogv4df_2 */
   11705          517 :     case 6786:  /* *avx512vl_vpternlogv4df_2 */
   11706          517 :     case 6785:  /* *avx512vl_vpternlogv4df_2 */
   11707          517 :     case 6784:  /* *avx512vl_vpternlogv4df_2 */
   11708          517 :     case 6783:  /* *avx512vl_vpternlogv4df_2 */
   11709          517 :     case 6782:  /* *avx512vl_vpternlogv4df_2 */
   11710          517 :     case 6781:  /* *avx512vl_vpternlogv4df_2 */
   11711          517 :     case 6780:  /* *avx512vl_vpternlogv4df_2 */
   11712          517 :     case 6779:  /* *avx512vl_vpternlogv4df_2 */
   11713          517 :     case 6778:  /* *avx512vl_vpternlogv4df_2 */
   11714          517 :     case 6777:  /* *avx512vl_vpternlogv4df_2 */
   11715          517 :     case 6776:  /* *avx512vl_vpternlogv4df_2 */
   11716          517 :     case 6775:  /* *avx512vl_vpternlogv4df_2 */
   11717          517 :     case 6774:  /* *avx512vl_vpternlogv4df_2 */
   11718          517 :     case 6773:  /* *avx512vl_vpternlogv4df_2 */
   11719          517 :     case 6772:  /* *avx512vl_vpternlogv4df_2 */
   11720          517 :     case 6771:  /* *avx512vl_vpternlogv4df_2 */
   11721          517 :     case 6770:  /* *avx512vl_vpternlogv4df_2 */
   11722          517 :     case 6769:  /* *avx512vl_vpternlogv4df_2 */
   11723          517 :     case 6768:  /* *avx512vl_vpternlogv4df_2 */
   11724          517 :     case 6767:  /* *avx512vl_vpternlogv4df_2 */
   11725          517 :     case 6766:  /* *avx512f_vpternlogv8df_2 */
   11726          517 :     case 6765:  /* *avx512f_vpternlogv8df_2 */
   11727          517 :     case 6764:  /* *avx512f_vpternlogv8df_2 */
   11728          517 :     case 6763:  /* *avx512f_vpternlogv8df_2 */
   11729          517 :     case 6762:  /* *avx512f_vpternlogv8df_2 */
   11730          517 :     case 6761:  /* *avx512f_vpternlogv8df_2 */
   11731          517 :     case 6760:  /* *avx512f_vpternlogv8df_2 */
   11732          517 :     case 6759:  /* *avx512f_vpternlogv8df_2 */
   11733          517 :     case 6758:  /* *avx512f_vpternlogv8df_2 */
   11734          517 :     case 6757:  /* *avx512f_vpternlogv8df_2 */
   11735          517 :     case 6756:  /* *avx512f_vpternlogv8df_2 */
   11736          517 :     case 6755:  /* *avx512f_vpternlogv8df_2 */
   11737          517 :     case 6754:  /* *avx512f_vpternlogv8df_2 */
   11738          517 :     case 6753:  /* *avx512f_vpternlogv8df_2 */
   11739          517 :     case 6752:  /* *avx512f_vpternlogv8df_2 */
   11740          517 :     case 6751:  /* *avx512f_vpternlogv8df_2 */
   11741          517 :     case 6750:  /* *avx512f_vpternlogv8df_2 */
   11742          517 :     case 6749:  /* *avx512f_vpternlogv8df_2 */
   11743          517 :     case 6748:  /* *avx512f_vpternlogv8df_2 */
   11744          517 :     case 6747:  /* *avx512f_vpternlogv8df_2 */
   11745          517 :     case 6746:  /* *avx512f_vpternlogv8df_2 */
   11746          517 :     case 6745:  /* *avx512f_vpternlogv8df_2 */
   11747          517 :     case 6744:  /* *avx512f_vpternlogv8df_2 */
   11748          517 :     case 6743:  /* *avx512f_vpternlogv8df_2 */
   11749          517 :     case 6742:  /* *avx512f_vpternlogv8df_2 */
   11750          517 :     case 6741:  /* *avx512f_vpternlogv8df_2 */
   11751          517 :     case 6740:  /* *avx512f_vpternlogv8df_2 */
   11752          517 :     case 6739:  /* *avx512vl_vpternlogv4sf_2 */
   11753          517 :     case 6738:  /* *avx512vl_vpternlogv4sf_2 */
   11754          517 :     case 6737:  /* *avx512vl_vpternlogv4sf_2 */
   11755          517 :     case 6736:  /* *avx512vl_vpternlogv4sf_2 */
   11756          517 :     case 6735:  /* *avx512vl_vpternlogv4sf_2 */
   11757          517 :     case 6734:  /* *avx512vl_vpternlogv4sf_2 */
   11758          517 :     case 6733:  /* *avx512vl_vpternlogv4sf_2 */
   11759          517 :     case 6732:  /* *avx512vl_vpternlogv4sf_2 */
   11760          517 :     case 6731:  /* *avx512vl_vpternlogv4sf_2 */
   11761          517 :     case 6730:  /* *avx512vl_vpternlogv4sf_2 */
   11762          517 :     case 6729:  /* *avx512vl_vpternlogv4sf_2 */
   11763          517 :     case 6728:  /* *avx512vl_vpternlogv4sf_2 */
   11764          517 :     case 6727:  /* *avx512vl_vpternlogv4sf_2 */
   11765          517 :     case 6726:  /* *avx512vl_vpternlogv4sf_2 */
   11766          517 :     case 6725:  /* *avx512vl_vpternlogv4sf_2 */
   11767          517 :     case 6724:  /* *avx512vl_vpternlogv4sf_2 */
   11768          517 :     case 6723:  /* *avx512vl_vpternlogv4sf_2 */
   11769          517 :     case 6722:  /* *avx512vl_vpternlogv4sf_2 */
   11770          517 :     case 6721:  /* *avx512vl_vpternlogv4sf_2 */
   11771          517 :     case 6720:  /* *avx512vl_vpternlogv4sf_2 */
   11772          517 :     case 6719:  /* *avx512vl_vpternlogv4sf_2 */
   11773          517 :     case 6718:  /* *avx512vl_vpternlogv4sf_2 */
   11774          517 :     case 6717:  /* *avx512vl_vpternlogv4sf_2 */
   11775          517 :     case 6716:  /* *avx512vl_vpternlogv4sf_2 */
   11776          517 :     case 6715:  /* *avx512vl_vpternlogv4sf_2 */
   11777          517 :     case 6714:  /* *avx512vl_vpternlogv4sf_2 */
   11778          517 :     case 6713:  /* *avx512vl_vpternlogv4sf_2 */
   11779          517 :     case 6712:  /* *avx512vl_vpternlogv8sf_2 */
   11780          517 :     case 6711:  /* *avx512vl_vpternlogv8sf_2 */
   11781          517 :     case 6710:  /* *avx512vl_vpternlogv8sf_2 */
   11782          517 :     case 6709:  /* *avx512vl_vpternlogv8sf_2 */
   11783          517 :     case 6708:  /* *avx512vl_vpternlogv8sf_2 */
   11784          517 :     case 6707:  /* *avx512vl_vpternlogv8sf_2 */
   11785          517 :     case 6706:  /* *avx512vl_vpternlogv8sf_2 */
   11786          517 :     case 6705:  /* *avx512vl_vpternlogv8sf_2 */
   11787          517 :     case 6704:  /* *avx512vl_vpternlogv8sf_2 */
   11788          517 :     case 6703:  /* *avx512vl_vpternlogv8sf_2 */
   11789          517 :     case 6702:  /* *avx512vl_vpternlogv8sf_2 */
   11790          517 :     case 6701:  /* *avx512vl_vpternlogv8sf_2 */
   11791          517 :     case 6700:  /* *avx512vl_vpternlogv8sf_2 */
   11792          517 :     case 6699:  /* *avx512vl_vpternlogv8sf_2 */
   11793          517 :     case 6698:  /* *avx512vl_vpternlogv8sf_2 */
   11794          517 :     case 6697:  /* *avx512vl_vpternlogv8sf_2 */
   11795          517 :     case 6696:  /* *avx512vl_vpternlogv8sf_2 */
   11796          517 :     case 6695:  /* *avx512vl_vpternlogv8sf_2 */
   11797          517 :     case 6694:  /* *avx512vl_vpternlogv8sf_2 */
   11798          517 :     case 6693:  /* *avx512vl_vpternlogv8sf_2 */
   11799          517 :     case 6692:  /* *avx512vl_vpternlogv8sf_2 */
   11800          517 :     case 6691:  /* *avx512vl_vpternlogv8sf_2 */
   11801          517 :     case 6690:  /* *avx512vl_vpternlogv8sf_2 */
   11802          517 :     case 6689:  /* *avx512vl_vpternlogv8sf_2 */
   11803          517 :     case 6688:  /* *avx512vl_vpternlogv8sf_2 */
   11804          517 :     case 6687:  /* *avx512vl_vpternlogv8sf_2 */
   11805          517 :     case 6686:  /* *avx512vl_vpternlogv8sf_2 */
   11806          517 :     case 6685:  /* *avx512f_vpternlogv16sf_2 */
   11807          517 :     case 6684:  /* *avx512f_vpternlogv16sf_2 */
   11808          517 :     case 6683:  /* *avx512f_vpternlogv16sf_2 */
   11809          517 :     case 6682:  /* *avx512f_vpternlogv16sf_2 */
   11810          517 :     case 6681:  /* *avx512f_vpternlogv16sf_2 */
   11811          517 :     case 6680:  /* *avx512f_vpternlogv16sf_2 */
   11812          517 :     case 6679:  /* *avx512f_vpternlogv16sf_2 */
   11813          517 :     case 6678:  /* *avx512f_vpternlogv16sf_2 */
   11814          517 :     case 6677:  /* *avx512f_vpternlogv16sf_2 */
   11815          517 :     case 6676:  /* *avx512f_vpternlogv16sf_2 */
   11816          517 :     case 6675:  /* *avx512f_vpternlogv16sf_2 */
   11817          517 :     case 6674:  /* *avx512f_vpternlogv16sf_2 */
   11818          517 :     case 6673:  /* *avx512f_vpternlogv16sf_2 */
   11819          517 :     case 6672:  /* *avx512f_vpternlogv16sf_2 */
   11820          517 :     case 6671:  /* *avx512f_vpternlogv16sf_2 */
   11821          517 :     case 6670:  /* *avx512f_vpternlogv16sf_2 */
   11822          517 :     case 6669:  /* *avx512f_vpternlogv16sf_2 */
   11823          517 :     case 6668:  /* *avx512f_vpternlogv16sf_2 */
   11824          517 :     case 6667:  /* *avx512f_vpternlogv16sf_2 */
   11825          517 :     case 6666:  /* *avx512f_vpternlogv16sf_2 */
   11826          517 :     case 6665:  /* *avx512f_vpternlogv16sf_2 */
   11827          517 :     case 6664:  /* *avx512f_vpternlogv16sf_2 */
   11828          517 :     case 6663:  /* *avx512f_vpternlogv16sf_2 */
   11829          517 :     case 6662:  /* *avx512f_vpternlogv16sf_2 */
   11830          517 :     case 6661:  /* *avx512f_vpternlogv16sf_2 */
   11831          517 :     case 6660:  /* *avx512f_vpternlogv16sf_2 */
   11832          517 :     case 6659:  /* *avx512f_vpternlogv16sf_2 */
   11833          517 :     case 6658:  /* *avx512vl_vpternlogv8bf_2 */
   11834          517 :     case 6657:  /* *avx512vl_vpternlogv8bf_2 */
   11835          517 :     case 6656:  /* *avx512vl_vpternlogv8bf_2 */
   11836          517 :     case 6655:  /* *avx512vl_vpternlogv8bf_2 */
   11837          517 :     case 6654:  /* *avx512vl_vpternlogv8bf_2 */
   11838          517 :     case 6653:  /* *avx512vl_vpternlogv8bf_2 */
   11839          517 :     case 6652:  /* *avx512vl_vpternlogv8bf_2 */
   11840          517 :     case 6651:  /* *avx512vl_vpternlogv8bf_2 */
   11841          517 :     case 6650:  /* *avx512vl_vpternlogv8bf_2 */
   11842          517 :     case 6649:  /* *avx512vl_vpternlogv8bf_2 */
   11843          517 :     case 6648:  /* *avx512vl_vpternlogv8bf_2 */
   11844          517 :     case 6647:  /* *avx512vl_vpternlogv8bf_2 */
   11845          517 :     case 6646:  /* *avx512vl_vpternlogv8bf_2 */
   11846          517 :     case 6645:  /* *avx512vl_vpternlogv8bf_2 */
   11847          517 :     case 6644:  /* *avx512vl_vpternlogv8bf_2 */
   11848          517 :     case 6643:  /* *avx512vl_vpternlogv8bf_2 */
   11849          517 :     case 6642:  /* *avx512vl_vpternlogv8bf_2 */
   11850          517 :     case 6641:  /* *avx512vl_vpternlogv8bf_2 */
   11851          517 :     case 6640:  /* *avx512vl_vpternlogv8bf_2 */
   11852          517 :     case 6639:  /* *avx512vl_vpternlogv8bf_2 */
   11853          517 :     case 6638:  /* *avx512vl_vpternlogv8bf_2 */
   11854          517 :     case 6637:  /* *avx512vl_vpternlogv8bf_2 */
   11855          517 :     case 6636:  /* *avx512vl_vpternlogv8bf_2 */
   11856          517 :     case 6635:  /* *avx512vl_vpternlogv8bf_2 */
   11857          517 :     case 6634:  /* *avx512vl_vpternlogv8bf_2 */
   11858          517 :     case 6633:  /* *avx512vl_vpternlogv8bf_2 */
   11859          517 :     case 6632:  /* *avx512vl_vpternlogv8bf_2 */
   11860          517 :     case 6631:  /* *avx512vl_vpternlogv16bf_2 */
   11861          517 :     case 6630:  /* *avx512vl_vpternlogv16bf_2 */
   11862          517 :     case 6629:  /* *avx512vl_vpternlogv16bf_2 */
   11863          517 :     case 6628:  /* *avx512vl_vpternlogv16bf_2 */
   11864          517 :     case 6627:  /* *avx512vl_vpternlogv16bf_2 */
   11865          517 :     case 6626:  /* *avx512vl_vpternlogv16bf_2 */
   11866          517 :     case 6625:  /* *avx512vl_vpternlogv16bf_2 */
   11867          517 :     case 6624:  /* *avx512vl_vpternlogv16bf_2 */
   11868          517 :     case 6623:  /* *avx512vl_vpternlogv16bf_2 */
   11869          517 :     case 6622:  /* *avx512vl_vpternlogv16bf_2 */
   11870          517 :     case 6621:  /* *avx512vl_vpternlogv16bf_2 */
   11871          517 :     case 6620:  /* *avx512vl_vpternlogv16bf_2 */
   11872          517 :     case 6619:  /* *avx512vl_vpternlogv16bf_2 */
   11873          517 :     case 6618:  /* *avx512vl_vpternlogv16bf_2 */
   11874          517 :     case 6617:  /* *avx512vl_vpternlogv16bf_2 */
   11875          517 :     case 6616:  /* *avx512vl_vpternlogv16bf_2 */
   11876          517 :     case 6615:  /* *avx512vl_vpternlogv16bf_2 */
   11877          517 :     case 6614:  /* *avx512vl_vpternlogv16bf_2 */
   11878          517 :     case 6613:  /* *avx512vl_vpternlogv16bf_2 */
   11879          517 :     case 6612:  /* *avx512vl_vpternlogv16bf_2 */
   11880          517 :     case 6611:  /* *avx512vl_vpternlogv16bf_2 */
   11881          517 :     case 6610:  /* *avx512vl_vpternlogv16bf_2 */
   11882          517 :     case 6609:  /* *avx512vl_vpternlogv16bf_2 */
   11883          517 :     case 6608:  /* *avx512vl_vpternlogv16bf_2 */
   11884          517 :     case 6607:  /* *avx512vl_vpternlogv16bf_2 */
   11885          517 :     case 6606:  /* *avx512vl_vpternlogv16bf_2 */
   11886          517 :     case 6605:  /* *avx512vl_vpternlogv16bf_2 */
   11887          517 :     case 6604:  /* *avx512bw_vpternlogv32bf_2 */
   11888          517 :     case 6603:  /* *avx512bw_vpternlogv32bf_2 */
   11889          517 :     case 6602:  /* *avx512bw_vpternlogv32bf_2 */
   11890          517 :     case 6601:  /* *avx512bw_vpternlogv32bf_2 */
   11891          517 :     case 6600:  /* *avx512bw_vpternlogv32bf_2 */
   11892          517 :     case 6599:  /* *avx512bw_vpternlogv32bf_2 */
   11893          517 :     case 6598:  /* *avx512bw_vpternlogv32bf_2 */
   11894          517 :     case 6597:  /* *avx512bw_vpternlogv32bf_2 */
   11895          517 :     case 6596:  /* *avx512bw_vpternlogv32bf_2 */
   11896          517 :     case 6595:  /* *avx512bw_vpternlogv32bf_2 */
   11897          517 :     case 6594:  /* *avx512bw_vpternlogv32bf_2 */
   11898          517 :     case 6593:  /* *avx512bw_vpternlogv32bf_2 */
   11899          517 :     case 6592:  /* *avx512bw_vpternlogv32bf_2 */
   11900          517 :     case 6591:  /* *avx512bw_vpternlogv32bf_2 */
   11901          517 :     case 6590:  /* *avx512bw_vpternlogv32bf_2 */
   11902          517 :     case 6589:  /* *avx512bw_vpternlogv32bf_2 */
   11903          517 :     case 6588:  /* *avx512bw_vpternlogv32bf_2 */
   11904          517 :     case 6587:  /* *avx512bw_vpternlogv32bf_2 */
   11905          517 :     case 6586:  /* *avx512bw_vpternlogv32bf_2 */
   11906          517 :     case 6585:  /* *avx512bw_vpternlogv32bf_2 */
   11907          517 :     case 6584:  /* *avx512bw_vpternlogv32bf_2 */
   11908          517 :     case 6583:  /* *avx512bw_vpternlogv32bf_2 */
   11909          517 :     case 6582:  /* *avx512bw_vpternlogv32bf_2 */
   11910          517 :     case 6581:  /* *avx512bw_vpternlogv32bf_2 */
   11911          517 :     case 6580:  /* *avx512bw_vpternlogv32bf_2 */
   11912          517 :     case 6579:  /* *avx512bw_vpternlogv32bf_2 */
   11913          517 :     case 6578:  /* *avx512bw_vpternlogv32bf_2 */
   11914          517 :     case 6577:  /* *avx512fp16_vpternlogv8hf_2 */
   11915          517 :     case 6576:  /* *avx512fp16_vpternlogv8hf_2 */
   11916          517 :     case 6575:  /* *avx512fp16_vpternlogv8hf_2 */
   11917          517 :     case 6574:  /* *avx512fp16_vpternlogv8hf_2 */
   11918          517 :     case 6573:  /* *avx512fp16_vpternlogv8hf_2 */
   11919          517 :     case 6572:  /* *avx512fp16_vpternlogv8hf_2 */
   11920          517 :     case 6571:  /* *avx512fp16_vpternlogv8hf_2 */
   11921          517 :     case 6570:  /* *avx512fp16_vpternlogv8hf_2 */
   11922          517 :     case 6569:  /* *avx512fp16_vpternlogv8hf_2 */
   11923          517 :     case 6568:  /* *avx512fp16_vpternlogv8hf_2 */
   11924          517 :     case 6567:  /* *avx512fp16_vpternlogv8hf_2 */
   11925          517 :     case 6566:  /* *avx512fp16_vpternlogv8hf_2 */
   11926          517 :     case 6565:  /* *avx512fp16_vpternlogv8hf_2 */
   11927          517 :     case 6564:  /* *avx512fp16_vpternlogv8hf_2 */
   11928          517 :     case 6563:  /* *avx512fp16_vpternlogv8hf_2 */
   11929          517 :     case 6562:  /* *avx512fp16_vpternlogv8hf_2 */
   11930          517 :     case 6561:  /* *avx512fp16_vpternlogv8hf_2 */
   11931          517 :     case 6560:  /* *avx512fp16_vpternlogv8hf_2 */
   11932          517 :     case 6559:  /* *avx512fp16_vpternlogv8hf_2 */
   11933          517 :     case 6558:  /* *avx512fp16_vpternlogv8hf_2 */
   11934          517 :     case 6557:  /* *avx512fp16_vpternlogv8hf_2 */
   11935          517 :     case 6556:  /* *avx512fp16_vpternlogv8hf_2 */
   11936          517 :     case 6555:  /* *avx512fp16_vpternlogv8hf_2 */
   11937          517 :     case 6554:  /* *avx512fp16_vpternlogv8hf_2 */
   11938          517 :     case 6553:  /* *avx512fp16_vpternlogv8hf_2 */
   11939          517 :     case 6552:  /* *avx512fp16_vpternlogv8hf_2 */
   11940          517 :     case 6551:  /* *avx512fp16_vpternlogv8hf_2 */
   11941          517 :     case 6550:  /* *avx512vl_vpternlogv16hf_2 */
   11942          517 :     case 6549:  /* *avx512vl_vpternlogv16hf_2 */
   11943          517 :     case 6548:  /* *avx512vl_vpternlogv16hf_2 */
   11944          517 :     case 6547:  /* *avx512vl_vpternlogv16hf_2 */
   11945          517 :     case 6546:  /* *avx512vl_vpternlogv16hf_2 */
   11946          517 :     case 6545:  /* *avx512vl_vpternlogv16hf_2 */
   11947          517 :     case 6544:  /* *avx512vl_vpternlogv16hf_2 */
   11948          517 :     case 6543:  /* *avx512vl_vpternlogv16hf_2 */
   11949          517 :     case 6542:  /* *avx512vl_vpternlogv16hf_2 */
   11950          517 :     case 6541:  /* *avx512vl_vpternlogv16hf_2 */
   11951          517 :     case 6540:  /* *avx512vl_vpternlogv16hf_2 */
   11952          517 :     case 6539:  /* *avx512vl_vpternlogv16hf_2 */
   11953          517 :     case 6538:  /* *avx512vl_vpternlogv16hf_2 */
   11954          517 :     case 6537:  /* *avx512vl_vpternlogv16hf_2 */
   11955          517 :     case 6536:  /* *avx512vl_vpternlogv16hf_2 */
   11956          517 :     case 6535:  /* *avx512vl_vpternlogv16hf_2 */
   11957          517 :     case 6534:  /* *avx512vl_vpternlogv16hf_2 */
   11958          517 :     case 6533:  /* *avx512vl_vpternlogv16hf_2 */
   11959          517 :     case 6532:  /* *avx512vl_vpternlogv16hf_2 */
   11960          517 :     case 6531:  /* *avx512vl_vpternlogv16hf_2 */
   11961          517 :     case 6530:  /* *avx512vl_vpternlogv16hf_2 */
   11962          517 :     case 6529:  /* *avx512vl_vpternlogv16hf_2 */
   11963          517 :     case 6528:  /* *avx512vl_vpternlogv16hf_2 */
   11964          517 :     case 6527:  /* *avx512vl_vpternlogv16hf_2 */
   11965          517 :     case 6526:  /* *avx512vl_vpternlogv16hf_2 */
   11966          517 :     case 6525:  /* *avx512vl_vpternlogv16hf_2 */
   11967          517 :     case 6524:  /* *avx512vl_vpternlogv16hf_2 */
   11968          517 :     case 6523:  /* *avx512bw_vpternlogv32hf_2 */
   11969          517 :     case 6522:  /* *avx512bw_vpternlogv32hf_2 */
   11970          517 :     case 6521:  /* *avx512bw_vpternlogv32hf_2 */
   11971          517 :     case 6520:  /* *avx512bw_vpternlogv32hf_2 */
   11972          517 :     case 6519:  /* *avx512bw_vpternlogv32hf_2 */
   11973          517 :     case 6518:  /* *avx512bw_vpternlogv32hf_2 */
   11974          517 :     case 6517:  /* *avx512bw_vpternlogv32hf_2 */
   11975          517 :     case 6516:  /* *avx512bw_vpternlogv32hf_2 */
   11976          517 :     case 6515:  /* *avx512bw_vpternlogv32hf_2 */
   11977          517 :     case 6514:  /* *avx512bw_vpternlogv32hf_2 */
   11978          517 :     case 6513:  /* *avx512bw_vpternlogv32hf_2 */
   11979          517 :     case 6512:  /* *avx512bw_vpternlogv32hf_2 */
   11980          517 :     case 6511:  /* *avx512bw_vpternlogv32hf_2 */
   11981          517 :     case 6510:  /* *avx512bw_vpternlogv32hf_2 */
   11982          517 :     case 6509:  /* *avx512bw_vpternlogv32hf_2 */
   11983          517 :     case 6508:  /* *avx512bw_vpternlogv32hf_2 */
   11984          517 :     case 6507:  /* *avx512bw_vpternlogv32hf_2 */
   11985          517 :     case 6506:  /* *avx512bw_vpternlogv32hf_2 */
   11986          517 :     case 6505:  /* *avx512bw_vpternlogv32hf_2 */
   11987          517 :     case 6504:  /* *avx512bw_vpternlogv32hf_2 */
   11988          517 :     case 6503:  /* *avx512bw_vpternlogv32hf_2 */
   11989          517 :     case 6502:  /* *avx512bw_vpternlogv32hf_2 */
   11990          517 :     case 6501:  /* *avx512bw_vpternlogv32hf_2 */
   11991          517 :     case 6500:  /* *avx512bw_vpternlogv32hf_2 */
   11992          517 :     case 6499:  /* *avx512bw_vpternlogv32hf_2 */
   11993          517 :     case 6498:  /* *avx512bw_vpternlogv32hf_2 */
   11994          517 :     case 6497:  /* *avx512bw_vpternlogv32hf_2 */
   11995          517 :     case 6496:  /* *avx512vl_vpternlogv2di_2 */
   11996          517 :     case 6495:  /* *avx512vl_vpternlogv2di_2 */
   11997          517 :     case 6494:  /* *avx512vl_vpternlogv2di_2 */
   11998          517 :     case 6493:  /* *avx512vl_vpternlogv2di_2 */
   11999          517 :     case 6492:  /* *avx512vl_vpternlogv2di_2 */
   12000          517 :     case 6491:  /* *avx512vl_vpternlogv2di_2 */
   12001          517 :     case 6490:  /* *avx512vl_vpternlogv2di_2 */
   12002          517 :     case 6489:  /* *avx512vl_vpternlogv2di_2 */
   12003          517 :     case 6488:  /* *avx512vl_vpternlogv2di_2 */
   12004          517 :     case 6487:  /* *avx512vl_vpternlogv2di_2 */
   12005          517 :     case 6486:  /* *avx512vl_vpternlogv2di_2 */
   12006          517 :     case 6485:  /* *avx512vl_vpternlogv2di_2 */
   12007          517 :     case 6484:  /* *avx512vl_vpternlogv2di_2 */
   12008          517 :     case 6483:  /* *avx512vl_vpternlogv2di_2 */
   12009          517 :     case 6482:  /* *avx512vl_vpternlogv2di_2 */
   12010          517 :     case 6481:  /* *avx512vl_vpternlogv2di_2 */
   12011          517 :     case 6480:  /* *avx512vl_vpternlogv2di_2 */
   12012          517 :     case 6479:  /* *avx512vl_vpternlogv2di_2 */
   12013          517 :     case 6478:  /* *avx512vl_vpternlogv2di_2 */
   12014          517 :     case 6477:  /* *avx512vl_vpternlogv2di_2 */
   12015          517 :     case 6476:  /* *avx512vl_vpternlogv2di_2 */
   12016          517 :     case 6475:  /* *avx512vl_vpternlogv2di_2 */
   12017          517 :     case 6474:  /* *avx512vl_vpternlogv2di_2 */
   12018          517 :     case 6473:  /* *avx512vl_vpternlogv2di_2 */
   12019          517 :     case 6472:  /* *avx512vl_vpternlogv2di_2 */
   12020          517 :     case 6471:  /* *avx512vl_vpternlogv2di_2 */
   12021          517 :     case 6470:  /* *avx512vl_vpternlogv2di_2 */
   12022          517 :     case 6469:  /* *avx512vl_vpternlogv4di_2 */
   12023          517 :     case 6468:  /* *avx512vl_vpternlogv4di_2 */
   12024          517 :     case 6467:  /* *avx512vl_vpternlogv4di_2 */
   12025          517 :     case 6466:  /* *avx512vl_vpternlogv4di_2 */
   12026          517 :     case 6465:  /* *avx512vl_vpternlogv4di_2 */
   12027          517 :     case 6464:  /* *avx512vl_vpternlogv4di_2 */
   12028          517 :     case 6463:  /* *avx512vl_vpternlogv4di_2 */
   12029          517 :     case 6462:  /* *avx512vl_vpternlogv4di_2 */
   12030          517 :     case 6461:  /* *avx512vl_vpternlogv4di_2 */
   12031          517 :     case 6460:  /* *avx512vl_vpternlogv4di_2 */
   12032          517 :     case 6459:  /* *avx512vl_vpternlogv4di_2 */
   12033          517 :     case 6458:  /* *avx512vl_vpternlogv4di_2 */
   12034          517 :     case 6457:  /* *avx512vl_vpternlogv4di_2 */
   12035          517 :     case 6456:  /* *avx512vl_vpternlogv4di_2 */
   12036          517 :     case 6455:  /* *avx512vl_vpternlogv4di_2 */
   12037          517 :     case 6454:  /* *avx512vl_vpternlogv4di_2 */
   12038          517 :     case 6453:  /* *avx512vl_vpternlogv4di_2 */
   12039          517 :     case 6452:  /* *avx512vl_vpternlogv4di_2 */
   12040          517 :     case 6451:  /* *avx512vl_vpternlogv4di_2 */
   12041          517 :     case 6450:  /* *avx512vl_vpternlogv4di_2 */
   12042          517 :     case 6449:  /* *avx512vl_vpternlogv4di_2 */
   12043          517 :     case 6448:  /* *avx512vl_vpternlogv4di_2 */
   12044          517 :     case 6447:  /* *avx512vl_vpternlogv4di_2 */
   12045          517 :     case 6446:  /* *avx512vl_vpternlogv4di_2 */
   12046          517 :     case 6445:  /* *avx512vl_vpternlogv4di_2 */
   12047          517 :     case 6444:  /* *avx512vl_vpternlogv4di_2 */
   12048          517 :     case 6443:  /* *avx512vl_vpternlogv4di_2 */
   12049          517 :     case 6442:  /* *avx512f_vpternlogv8di_2 */
   12050          517 :     case 6441:  /* *avx512f_vpternlogv8di_2 */
   12051          517 :     case 6440:  /* *avx512f_vpternlogv8di_2 */
   12052          517 :     case 6439:  /* *avx512f_vpternlogv8di_2 */
   12053          517 :     case 6438:  /* *avx512f_vpternlogv8di_2 */
   12054          517 :     case 6437:  /* *avx512f_vpternlogv8di_2 */
   12055          517 :     case 6436:  /* *avx512f_vpternlogv8di_2 */
   12056          517 :     case 6435:  /* *avx512f_vpternlogv8di_2 */
   12057          517 :     case 6434:  /* *avx512f_vpternlogv8di_2 */
   12058          517 :     case 6433:  /* *avx512f_vpternlogv8di_2 */
   12059          517 :     case 6432:  /* *avx512f_vpternlogv8di_2 */
   12060          517 :     case 6431:  /* *avx512f_vpternlogv8di_2 */
   12061          517 :     case 6430:  /* *avx512f_vpternlogv8di_2 */
   12062          517 :     case 6429:  /* *avx512f_vpternlogv8di_2 */
   12063          517 :     case 6428:  /* *avx512f_vpternlogv8di_2 */
   12064          517 :     case 6427:  /* *avx512f_vpternlogv8di_2 */
   12065          517 :     case 6426:  /* *avx512f_vpternlogv8di_2 */
   12066          517 :     case 6425:  /* *avx512f_vpternlogv8di_2 */
   12067          517 :     case 6424:  /* *avx512f_vpternlogv8di_2 */
   12068          517 :     case 6423:  /* *avx512f_vpternlogv8di_2 */
   12069          517 :     case 6422:  /* *avx512f_vpternlogv8di_2 */
   12070          517 :     case 6421:  /* *avx512f_vpternlogv8di_2 */
   12071          517 :     case 6420:  /* *avx512f_vpternlogv8di_2 */
   12072          517 :     case 6419:  /* *avx512f_vpternlogv8di_2 */
   12073          517 :     case 6418:  /* *avx512f_vpternlogv8di_2 */
   12074          517 :     case 6417:  /* *avx512f_vpternlogv8di_2 */
   12075          517 :     case 6416:  /* *avx512f_vpternlogv8di_2 */
   12076          517 :     case 6415:  /* *avx512vl_vpternlogv4si_2 */
   12077          517 :     case 6414:  /* *avx512vl_vpternlogv4si_2 */
   12078          517 :     case 6413:  /* *avx512vl_vpternlogv4si_2 */
   12079          517 :     case 6412:  /* *avx512vl_vpternlogv4si_2 */
   12080          517 :     case 6411:  /* *avx512vl_vpternlogv4si_2 */
   12081          517 :     case 6410:  /* *avx512vl_vpternlogv4si_2 */
   12082          517 :     case 6409:  /* *avx512vl_vpternlogv4si_2 */
   12083          517 :     case 6408:  /* *avx512vl_vpternlogv4si_2 */
   12084          517 :     case 6407:  /* *avx512vl_vpternlogv4si_2 */
   12085          517 :     case 6406:  /* *avx512vl_vpternlogv4si_2 */
   12086          517 :     case 6405:  /* *avx512vl_vpternlogv4si_2 */
   12087          517 :     case 6404:  /* *avx512vl_vpternlogv4si_2 */
   12088          517 :     case 6403:  /* *avx512vl_vpternlogv4si_2 */
   12089          517 :     case 6402:  /* *avx512vl_vpternlogv4si_2 */
   12090          517 :     case 6401:  /* *avx512vl_vpternlogv4si_2 */
   12091          517 :     case 6400:  /* *avx512vl_vpternlogv4si_2 */
   12092          517 :     case 6399:  /* *avx512vl_vpternlogv4si_2 */
   12093          517 :     case 6398:  /* *avx512vl_vpternlogv4si_2 */
   12094          517 :     case 6397:  /* *avx512vl_vpternlogv4si_2 */
   12095          517 :     case 6396:  /* *avx512vl_vpternlogv4si_2 */
   12096          517 :     case 6395:  /* *avx512vl_vpternlogv4si_2 */
   12097          517 :     case 6394:  /* *avx512vl_vpternlogv4si_2 */
   12098          517 :     case 6393:  /* *avx512vl_vpternlogv4si_2 */
   12099          517 :     case 6392:  /* *avx512vl_vpternlogv4si_2 */
   12100          517 :     case 6391:  /* *avx512vl_vpternlogv4si_2 */
   12101          517 :     case 6390:  /* *avx512vl_vpternlogv4si_2 */
   12102          517 :     case 6389:  /* *avx512vl_vpternlogv4si_2 */
   12103          517 :     case 6388:  /* *avx512vl_vpternlogv8si_2 */
   12104          517 :     case 6387:  /* *avx512vl_vpternlogv8si_2 */
   12105          517 :     case 6386:  /* *avx512vl_vpternlogv8si_2 */
   12106          517 :     case 6385:  /* *avx512vl_vpternlogv8si_2 */
   12107          517 :     case 6384:  /* *avx512vl_vpternlogv8si_2 */
   12108          517 :     case 6383:  /* *avx512vl_vpternlogv8si_2 */
   12109          517 :     case 6382:  /* *avx512vl_vpternlogv8si_2 */
   12110          517 :     case 6381:  /* *avx512vl_vpternlogv8si_2 */
   12111          517 :     case 6380:  /* *avx512vl_vpternlogv8si_2 */
   12112          517 :     case 6379:  /* *avx512vl_vpternlogv8si_2 */
   12113          517 :     case 6378:  /* *avx512vl_vpternlogv8si_2 */
   12114          517 :     case 6377:  /* *avx512vl_vpternlogv8si_2 */
   12115          517 :     case 6376:  /* *avx512vl_vpternlogv8si_2 */
   12116          517 :     case 6375:  /* *avx512vl_vpternlogv8si_2 */
   12117          517 :     case 6374:  /* *avx512vl_vpternlogv8si_2 */
   12118          517 :     case 6373:  /* *avx512vl_vpternlogv8si_2 */
   12119          517 :     case 6372:  /* *avx512vl_vpternlogv8si_2 */
   12120          517 :     case 6371:  /* *avx512vl_vpternlogv8si_2 */
   12121          517 :     case 6370:  /* *avx512vl_vpternlogv8si_2 */
   12122          517 :     case 6369:  /* *avx512vl_vpternlogv8si_2 */
   12123          517 :     case 6368:  /* *avx512vl_vpternlogv8si_2 */
   12124          517 :     case 6367:  /* *avx512vl_vpternlogv8si_2 */
   12125          517 :     case 6366:  /* *avx512vl_vpternlogv8si_2 */
   12126          517 :     case 6365:  /* *avx512vl_vpternlogv8si_2 */
   12127          517 :     case 6364:  /* *avx512vl_vpternlogv8si_2 */
   12128          517 :     case 6363:  /* *avx512vl_vpternlogv8si_2 */
   12129          517 :     case 6362:  /* *avx512vl_vpternlogv8si_2 */
   12130          517 :     case 6361:  /* *avx512f_vpternlogv16si_2 */
   12131          517 :     case 6360:  /* *avx512f_vpternlogv16si_2 */
   12132          517 :     case 6359:  /* *avx512f_vpternlogv16si_2 */
   12133          517 :     case 6358:  /* *avx512f_vpternlogv16si_2 */
   12134          517 :     case 6357:  /* *avx512f_vpternlogv16si_2 */
   12135          517 :     case 6356:  /* *avx512f_vpternlogv16si_2 */
   12136          517 :     case 6355:  /* *avx512f_vpternlogv16si_2 */
   12137          517 :     case 6354:  /* *avx512f_vpternlogv16si_2 */
   12138          517 :     case 6353:  /* *avx512f_vpternlogv16si_2 */
   12139          517 :     case 6352:  /* *avx512f_vpternlogv16si_2 */
   12140          517 :     case 6351:  /* *avx512f_vpternlogv16si_2 */
   12141          517 :     case 6350:  /* *avx512f_vpternlogv16si_2 */
   12142          517 :     case 6349:  /* *avx512f_vpternlogv16si_2 */
   12143          517 :     case 6348:  /* *avx512f_vpternlogv16si_2 */
   12144          517 :     case 6347:  /* *avx512f_vpternlogv16si_2 */
   12145          517 :     case 6346:  /* *avx512f_vpternlogv16si_2 */
   12146          517 :     case 6345:  /* *avx512f_vpternlogv16si_2 */
   12147          517 :     case 6344:  /* *avx512f_vpternlogv16si_2 */
   12148          517 :     case 6343:  /* *avx512f_vpternlogv16si_2 */
   12149          517 :     case 6342:  /* *avx512f_vpternlogv16si_2 */
   12150          517 :     case 6341:  /* *avx512f_vpternlogv16si_2 */
   12151          517 :     case 6340:  /* *avx512f_vpternlogv16si_2 */
   12152          517 :     case 6339:  /* *avx512f_vpternlogv16si_2 */
   12153          517 :     case 6338:  /* *avx512f_vpternlogv16si_2 */
   12154          517 :     case 6337:  /* *avx512f_vpternlogv16si_2 */
   12155          517 :     case 6336:  /* *avx512f_vpternlogv16si_2 */
   12156          517 :     case 6335:  /* *avx512f_vpternlogv16si_2 */
   12157          517 :     case 6334:  /* *avx512vl_vpternlogv8hi_2 */
   12158          517 :     case 6333:  /* *avx512vl_vpternlogv8hi_2 */
   12159          517 :     case 6332:  /* *avx512vl_vpternlogv8hi_2 */
   12160          517 :     case 6331:  /* *avx512vl_vpternlogv8hi_2 */
   12161          517 :     case 6330:  /* *avx512vl_vpternlogv8hi_2 */
   12162          517 :     case 6329:  /* *avx512vl_vpternlogv8hi_2 */
   12163          517 :     case 6328:  /* *avx512vl_vpternlogv8hi_2 */
   12164          517 :     case 6327:  /* *avx512vl_vpternlogv8hi_2 */
   12165          517 :     case 6326:  /* *avx512vl_vpternlogv8hi_2 */
   12166          517 :     case 6325:  /* *avx512vl_vpternlogv8hi_2 */
   12167          517 :     case 6324:  /* *avx512vl_vpternlogv8hi_2 */
   12168          517 :     case 6323:  /* *avx512vl_vpternlogv8hi_2 */
   12169          517 :     case 6322:  /* *avx512vl_vpternlogv8hi_2 */
   12170          517 :     case 6321:  /* *avx512vl_vpternlogv8hi_2 */
   12171          517 :     case 6320:  /* *avx512vl_vpternlogv8hi_2 */
   12172          517 :     case 6319:  /* *avx512vl_vpternlogv8hi_2 */
   12173          517 :     case 6318:  /* *avx512vl_vpternlogv8hi_2 */
   12174          517 :     case 6317:  /* *avx512vl_vpternlogv8hi_2 */
   12175          517 :     case 6316:  /* *avx512vl_vpternlogv8hi_2 */
   12176          517 :     case 6315:  /* *avx512vl_vpternlogv8hi_2 */
   12177          517 :     case 6314:  /* *avx512vl_vpternlogv8hi_2 */
   12178          517 :     case 6313:  /* *avx512vl_vpternlogv8hi_2 */
   12179          517 :     case 6312:  /* *avx512vl_vpternlogv8hi_2 */
   12180          517 :     case 6311:  /* *avx512vl_vpternlogv8hi_2 */
   12181          517 :     case 6310:  /* *avx512vl_vpternlogv8hi_2 */
   12182          517 :     case 6309:  /* *avx512vl_vpternlogv8hi_2 */
   12183          517 :     case 6308:  /* *avx512vl_vpternlogv8hi_2 */
   12184          517 :     case 6307:  /* *avx512vl_vpternlogv16hi_2 */
   12185          517 :     case 6306:  /* *avx512vl_vpternlogv16hi_2 */
   12186          517 :     case 6305:  /* *avx512vl_vpternlogv16hi_2 */
   12187          517 :     case 6304:  /* *avx512vl_vpternlogv16hi_2 */
   12188          517 :     case 6303:  /* *avx512vl_vpternlogv16hi_2 */
   12189          517 :     case 6302:  /* *avx512vl_vpternlogv16hi_2 */
   12190          517 :     case 6301:  /* *avx512vl_vpternlogv16hi_2 */
   12191          517 :     case 6300:  /* *avx512vl_vpternlogv16hi_2 */
   12192          517 :     case 6299:  /* *avx512vl_vpternlogv16hi_2 */
   12193          517 :     case 6298:  /* *avx512vl_vpternlogv16hi_2 */
   12194          517 :     case 6297:  /* *avx512vl_vpternlogv16hi_2 */
   12195          517 :     case 6296:  /* *avx512vl_vpternlogv16hi_2 */
   12196          517 :     case 6295:  /* *avx512vl_vpternlogv16hi_2 */
   12197          517 :     case 6294:  /* *avx512vl_vpternlogv16hi_2 */
   12198          517 :     case 6293:  /* *avx512vl_vpternlogv16hi_2 */
   12199          517 :     case 6292:  /* *avx512vl_vpternlogv16hi_2 */
   12200          517 :     case 6291:  /* *avx512vl_vpternlogv16hi_2 */
   12201          517 :     case 6290:  /* *avx512vl_vpternlogv16hi_2 */
   12202          517 :     case 6289:  /* *avx512vl_vpternlogv16hi_2 */
   12203          517 :     case 6288:  /* *avx512vl_vpternlogv16hi_2 */
   12204          517 :     case 6287:  /* *avx512vl_vpternlogv16hi_2 */
   12205          517 :     case 6286:  /* *avx512vl_vpternlogv16hi_2 */
   12206          517 :     case 6285:  /* *avx512vl_vpternlogv16hi_2 */
   12207          517 :     case 6284:  /* *avx512vl_vpternlogv16hi_2 */
   12208          517 :     case 6283:  /* *avx512vl_vpternlogv16hi_2 */
   12209          517 :     case 6282:  /* *avx512vl_vpternlogv16hi_2 */
   12210          517 :     case 6281:  /* *avx512vl_vpternlogv16hi_2 */
   12211          517 :     case 6280:  /* *avx512bw_vpternlogv32hi_2 */
   12212          517 :     case 6279:  /* *avx512bw_vpternlogv32hi_2 */
   12213          517 :     case 6278:  /* *avx512bw_vpternlogv32hi_2 */
   12214          517 :     case 6277:  /* *avx512bw_vpternlogv32hi_2 */
   12215          517 :     case 6276:  /* *avx512bw_vpternlogv32hi_2 */
   12216          517 :     case 6275:  /* *avx512bw_vpternlogv32hi_2 */
   12217          517 :     case 6274:  /* *avx512bw_vpternlogv32hi_2 */
   12218          517 :     case 6273:  /* *avx512bw_vpternlogv32hi_2 */
   12219          517 :     case 6272:  /* *avx512bw_vpternlogv32hi_2 */
   12220          517 :     case 6271:  /* *avx512bw_vpternlogv32hi_2 */
   12221          517 :     case 6270:  /* *avx512bw_vpternlogv32hi_2 */
   12222          517 :     case 6269:  /* *avx512bw_vpternlogv32hi_2 */
   12223          517 :     case 6268:  /* *avx512bw_vpternlogv32hi_2 */
   12224          517 :     case 6267:  /* *avx512bw_vpternlogv32hi_2 */
   12225          517 :     case 6266:  /* *avx512bw_vpternlogv32hi_2 */
   12226          517 :     case 6265:  /* *avx512bw_vpternlogv32hi_2 */
   12227          517 :     case 6264:  /* *avx512bw_vpternlogv32hi_2 */
   12228          517 :     case 6263:  /* *avx512bw_vpternlogv32hi_2 */
   12229          517 :     case 6262:  /* *avx512bw_vpternlogv32hi_2 */
   12230          517 :     case 6261:  /* *avx512bw_vpternlogv32hi_2 */
   12231          517 :     case 6260:  /* *avx512bw_vpternlogv32hi_2 */
   12232          517 :     case 6259:  /* *avx512bw_vpternlogv32hi_2 */
   12233          517 :     case 6258:  /* *avx512bw_vpternlogv32hi_2 */
   12234          517 :     case 6257:  /* *avx512bw_vpternlogv32hi_2 */
   12235          517 :     case 6256:  /* *avx512bw_vpternlogv32hi_2 */
   12236          517 :     case 6255:  /* *avx512bw_vpternlogv32hi_2 */
   12237          517 :     case 6254:  /* *avx512bw_vpternlogv32hi_2 */
   12238          517 :     case 6253:  /* *avx512vl_vpternlogv16qi_2 */
   12239          517 :     case 6252:  /* *avx512vl_vpternlogv16qi_2 */
   12240          517 :     case 6251:  /* *avx512vl_vpternlogv16qi_2 */
   12241          517 :     case 6250:  /* *avx512vl_vpternlogv16qi_2 */
   12242          517 :     case 6249:  /* *avx512vl_vpternlogv16qi_2 */
   12243          517 :     case 6248:  /* *avx512vl_vpternlogv16qi_2 */
   12244          517 :     case 6247:  /* *avx512vl_vpternlogv16qi_2 */
   12245          517 :     case 6246:  /* *avx512vl_vpternlogv16qi_2 */
   12246          517 :     case 6245:  /* *avx512vl_vpternlogv16qi_2 */
   12247          517 :     case 6244:  /* *avx512vl_vpternlogv16qi_2 */
   12248          517 :     case 6243:  /* *avx512vl_vpternlogv16qi_2 */
   12249          517 :     case 6242:  /* *avx512vl_vpternlogv16qi_2 */
   12250          517 :     case 6241:  /* *avx512vl_vpternlogv16qi_2 */
   12251          517 :     case 6240:  /* *avx512vl_vpternlogv16qi_2 */
   12252          517 :     case 6239:  /* *avx512vl_vpternlogv16qi_2 */
   12253          517 :     case 6238:  /* *avx512vl_vpternlogv16qi_2 */
   12254          517 :     case 6237:  /* *avx512vl_vpternlogv16qi_2 */
   12255          517 :     case 6236:  /* *avx512vl_vpternlogv16qi_2 */
   12256          517 :     case 6235:  /* *avx512vl_vpternlogv16qi_2 */
   12257          517 :     case 6234:  /* *avx512vl_vpternlogv16qi_2 */
   12258          517 :     case 6233:  /* *avx512vl_vpternlogv16qi_2 */
   12259          517 :     case 6232:  /* *avx512vl_vpternlogv16qi_2 */
   12260          517 :     case 6231:  /* *avx512vl_vpternlogv16qi_2 */
   12261          517 :     case 6230:  /* *avx512vl_vpternlogv16qi_2 */
   12262          517 :     case 6229:  /* *avx512vl_vpternlogv16qi_2 */
   12263          517 :     case 6228:  /* *avx512vl_vpternlogv16qi_2 */
   12264          517 :     case 6227:  /* *avx512vl_vpternlogv16qi_2 */
   12265          517 :     case 6226:  /* *avx512vl_vpternlogv32qi_2 */
   12266          517 :     case 6225:  /* *avx512vl_vpternlogv32qi_2 */
   12267          517 :     case 6224:  /* *avx512vl_vpternlogv32qi_2 */
   12268          517 :     case 6223:  /* *avx512vl_vpternlogv32qi_2 */
   12269          517 :     case 6222:  /* *avx512vl_vpternlogv32qi_2 */
   12270          517 :     case 6221:  /* *avx512vl_vpternlogv32qi_2 */
   12271          517 :     case 6220:  /* *avx512vl_vpternlogv32qi_2 */
   12272          517 :     case 6219:  /* *avx512vl_vpternlogv32qi_2 */
   12273          517 :     case 6218:  /* *avx512vl_vpternlogv32qi_2 */
   12274          517 :     case 6217:  /* *avx512vl_vpternlogv32qi_2 */
   12275          517 :     case 6216:  /* *avx512vl_vpternlogv32qi_2 */
   12276          517 :     case 6215:  /* *avx512vl_vpternlogv32qi_2 */
   12277          517 :     case 6214:  /* *avx512vl_vpternlogv32qi_2 */
   12278          517 :     case 6213:  /* *avx512vl_vpternlogv32qi_2 */
   12279          517 :     case 6212:  /* *avx512vl_vpternlogv32qi_2 */
   12280          517 :     case 6211:  /* *avx512vl_vpternlogv32qi_2 */
   12281          517 :     case 6210:  /* *avx512vl_vpternlogv32qi_2 */
   12282          517 :     case 6209:  /* *avx512vl_vpternlogv32qi_2 */
   12283          517 :     case 6208:  /* *avx512vl_vpternlogv32qi_2 */
   12284          517 :     case 6207:  /* *avx512vl_vpternlogv32qi_2 */
   12285          517 :     case 6206:  /* *avx512vl_vpternlogv32qi_2 */
   12286          517 :     case 6205:  /* *avx512vl_vpternlogv32qi_2 */
   12287          517 :     case 6204:  /* *avx512vl_vpternlogv32qi_2 */
   12288          517 :     case 6203:  /* *avx512vl_vpternlogv32qi_2 */
   12289          517 :     case 6202:  /* *avx512vl_vpternlogv32qi_2 */
   12290          517 :     case 6201:  /* *avx512vl_vpternlogv32qi_2 */
   12291          517 :     case 6200:  /* *avx512vl_vpternlogv32qi_2 */
   12292          517 :     case 6199:  /* *avx512bw_vpternlogv64qi_2 */
   12293          517 :     case 6198:  /* *avx512bw_vpternlogv64qi_2 */
   12294          517 :     case 6197:  /* *avx512bw_vpternlogv64qi_2 */
   12295          517 :     case 6196:  /* *avx512bw_vpternlogv64qi_2 */
   12296          517 :     case 6195:  /* *avx512bw_vpternlogv64qi_2 */
   12297          517 :     case 6194:  /* *avx512bw_vpternlogv64qi_2 */
   12298          517 :     case 6193:  /* *avx512bw_vpternlogv64qi_2 */
   12299          517 :     case 6192:  /* *avx512bw_vpternlogv64qi_2 */
   12300          517 :     case 6191:  /* *avx512bw_vpternlogv64qi_2 */
   12301          517 :     case 6190:  /* *avx512bw_vpternlogv64qi_2 */
   12302          517 :     case 6189:  /* *avx512bw_vpternlogv64qi_2 */
   12303          517 :     case 6188:  /* *avx512bw_vpternlogv64qi_2 */
   12304          517 :     case 6187:  /* *avx512bw_vpternlogv64qi_2 */
   12305          517 :     case 6186:  /* *avx512bw_vpternlogv64qi_2 */
   12306          517 :     case 6185:  /* *avx512bw_vpternlogv64qi_2 */
   12307          517 :     case 6184:  /* *avx512bw_vpternlogv64qi_2 */
   12308          517 :     case 6183:  /* *avx512bw_vpternlogv64qi_2 */
   12309          517 :     case 6182:  /* *avx512bw_vpternlogv64qi_2 */
   12310          517 :     case 6181:  /* *avx512bw_vpternlogv64qi_2 */
   12311          517 :     case 6180:  /* *avx512bw_vpternlogv64qi_2 */
   12312          517 :     case 6179:  /* *avx512bw_vpternlogv64qi_2 */
   12313          517 :     case 6178:  /* *avx512bw_vpternlogv64qi_2 */
   12314          517 :     case 6177:  /* *avx512bw_vpternlogv64qi_2 */
   12315          517 :     case 6176:  /* *avx512bw_vpternlogv64qi_2 */
   12316          517 :     case 6175:  /* *avx512bw_vpternlogv64qi_2 */
   12317          517 :     case 6174:  /* *avx512bw_vpternlogv64qi_2 */
   12318          517 :     case 6173:  /* *avx512bw_vpternlogv64qi_2 */
   12319          517 :     case 375:  /* *leahi_general_3b */
   12320          517 :     case 374:  /* *leaqi_general_3b */
   12321          517 :     case 373:  /* *leahi_general_3 */
   12322          517 :     case 372:  /* *leaqi_general_3 */
   12323          517 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   12324          517 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   12325          517 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 1));
   12326          517 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   12327          517 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
   12328          517 :       break;
   12329              : 
   12330        47119 :     case 9054:  /* xop_pmacssdd */
   12331        47119 :     case 9053:  /* xop_pmacsdd */
   12332        47119 :     case 9052:  /* xop_pmacssww */
   12333        47119 :     case 9051:  /* xop_pmacsww */
   12334        47119 :     case 7730:  /* *avx2_lshrv2di3_2 */
   12335        47119 :     case 7729:  /* *avx2_lshrv4di3_2 */
   12336        47119 :     case 7728:  /* *avx2_lshrv2di3_1 */
   12337        47119 :     case 7727:  /* *avx2_lshrv4di3_1 */
   12338        47119 :     case 7036:  /* *avx512vl_vpternlogv2df_3 */
   12339        47119 :     case 7035:  /* *avx512vl_vpternlogv2df_3 */
   12340        47119 :     case 7034:  /* *avx512vl_vpternlogv2df_3 */
   12341        47119 :     case 7033:  /* *avx512vl_vpternlogv2df_3 */
   12342        47119 :     case 7032:  /* *avx512vl_vpternlogv2df_3 */
   12343        47119 :     case 7031:  /* *avx512vl_vpternlogv2df_3 */
   12344        47119 :     case 7030:  /* *avx512vl_vpternlogv2df_3 */
   12345        47119 :     case 7029:  /* *avx512vl_vpternlogv2df_3 */
   12346        47119 :     case 7028:  /* *avx512vl_vpternlogv2df_3 */
   12347        47119 :     case 7027:  /* *avx512vl_vpternlogv4df_3 */
   12348        47119 :     case 7026:  /* *avx512vl_vpternlogv4df_3 */
   12349        47119 :     case 7025:  /* *avx512vl_vpternlogv4df_3 */
   12350        47119 :     case 7024:  /* *avx512vl_vpternlogv4df_3 */
   12351        47119 :     case 7023:  /* *avx512vl_vpternlogv4df_3 */
   12352        47119 :     case 7022:  /* *avx512vl_vpternlogv4df_3 */
   12353        47119 :     case 7021:  /* *avx512vl_vpternlogv4df_3 */
   12354        47119 :     case 7020:  /* *avx512vl_vpternlogv4df_3 */
   12355        47119 :     case 7019:  /* *avx512vl_vpternlogv4df_3 */
   12356        47119 :     case 7018:  /* *avx512f_vpternlogv8df_3 */
   12357        47119 :     case 7017:  /* *avx512f_vpternlogv8df_3 */
   12358        47119 :     case 7016:  /* *avx512f_vpternlogv8df_3 */
   12359        47119 :     case 7015:  /* *avx512f_vpternlogv8df_3 */
   12360        47119 :     case 7014:  /* *avx512f_vpternlogv8df_3 */
   12361        47119 :     case 7013:  /* *avx512f_vpternlogv8df_3 */
   12362        47119 :     case 7012:  /* *avx512f_vpternlogv8df_3 */
   12363        47119 :     case 7011:  /* *avx512f_vpternlogv8df_3 */
   12364        47119 :     case 7010:  /* *avx512f_vpternlogv8df_3 */
   12365        47119 :     case 7009:  /* *avx512vl_vpternlogv4sf_3 */
   12366        47119 :     case 7008:  /* *avx512vl_vpternlogv4sf_3 */
   12367        47119 :     case 7007:  /* *avx512vl_vpternlogv4sf_3 */
   12368        47119 :     case 7006:  /* *avx512vl_vpternlogv4sf_3 */
   12369        47119 :     case 7005:  /* *avx512vl_vpternlogv4sf_3 */
   12370        47119 :     case 7004:  /* *avx512vl_vpternlogv4sf_3 */
   12371        47119 :     case 7003:  /* *avx512vl_vpternlogv4sf_3 */
   12372        47119 :     case 7002:  /* *avx512vl_vpternlogv4sf_3 */
   12373        47119 :     case 7001:  /* *avx512vl_vpternlogv4sf_3 */
   12374        47119 :     case 7000:  /* *avx512vl_vpternlogv8sf_3 */
   12375        47119 :     case 6999:  /* *avx512vl_vpternlogv8sf_3 */
   12376        47119 :     case 6998:  /* *avx512vl_vpternlogv8sf_3 */
   12377        47119 :     case 6997:  /* *avx512vl_vpternlogv8sf_3 */
   12378        47119 :     case 6996:  /* *avx512vl_vpternlogv8sf_3 */
   12379        47119 :     case 6995:  /* *avx512vl_vpternlogv8sf_3 */
   12380        47119 :     case 6994:  /* *avx512vl_vpternlogv8sf_3 */
   12381        47119 :     case 6993:  /* *avx512vl_vpternlogv8sf_3 */
   12382        47119 :     case 6992:  /* *avx512vl_vpternlogv8sf_3 */
   12383        47119 :     case 6991:  /* *avx512f_vpternlogv16sf_3 */
   12384        47119 :     case 6990:  /* *avx512f_vpternlogv16sf_3 */
   12385        47119 :     case 6989:  /* *avx512f_vpternlogv16sf_3 */
   12386        47119 :     case 6988:  /* *avx512f_vpternlogv16sf_3 */
   12387        47119 :     case 6987:  /* *avx512f_vpternlogv16sf_3 */
   12388        47119 :     case 6986:  /* *avx512f_vpternlogv16sf_3 */
   12389        47119 :     case 6985:  /* *avx512f_vpternlogv16sf_3 */
   12390        47119 :     case 6984:  /* *avx512f_vpternlogv16sf_3 */
   12391        47119 :     case 6983:  /* *avx512f_vpternlogv16sf_3 */
   12392        47119 :     case 6982:  /* *avx512vl_vpternlogv8bf_3 */
   12393        47119 :     case 6981:  /* *avx512vl_vpternlogv8bf_3 */
   12394        47119 :     case 6980:  /* *avx512vl_vpternlogv8bf_3 */
   12395        47119 :     case 6979:  /* *avx512vl_vpternlogv8bf_3 */
   12396        47119 :     case 6978:  /* *avx512vl_vpternlogv8bf_3 */
   12397        47119 :     case 6977:  /* *avx512vl_vpternlogv8bf_3 */
   12398        47119 :     case 6976:  /* *avx512vl_vpternlogv8bf_3 */
   12399        47119 :     case 6975:  /* *avx512vl_vpternlogv8bf_3 */
   12400        47119 :     case 6974:  /* *avx512vl_vpternlogv8bf_3 */
   12401        47119 :     case 6973:  /* *avx512vl_vpternlogv16bf_3 */
   12402        47119 :     case 6972:  /* *avx512vl_vpternlogv16bf_3 */
   12403        47119 :     case 6971:  /* *avx512vl_vpternlogv16bf_3 */
   12404        47119 :     case 6970:  /* *avx512vl_vpternlogv16bf_3 */
   12405        47119 :     case 6969:  /* *avx512vl_vpternlogv16bf_3 */
   12406        47119 :     case 6968:  /* *avx512vl_vpternlogv16bf_3 */
   12407        47119 :     case 6967:  /* *avx512vl_vpternlogv16bf_3 */
   12408        47119 :     case 6966:  /* *avx512vl_vpternlogv16bf_3 */
   12409        47119 :     case 6965:  /* *avx512vl_vpternlogv16bf_3 */
   12410        47119 :     case 6964:  /* *avx512bw_vpternlogv32bf_3 */
   12411        47119 :     case 6963:  /* *avx512bw_vpternlogv32bf_3 */
   12412        47119 :     case 6962:  /* *avx512bw_vpternlogv32bf_3 */
   12413        47119 :     case 6961:  /* *avx512bw_vpternlogv32bf_3 */
   12414        47119 :     case 6960:  /* *avx512bw_vpternlogv32bf_3 */
   12415        47119 :     case 6959:  /* *avx512bw_vpternlogv32bf_3 */
   12416        47119 :     case 6958:  /* *avx512bw_vpternlogv32bf_3 */
   12417        47119 :     case 6957:  /* *avx512bw_vpternlogv32bf_3 */
   12418        47119 :     case 6956:  /* *avx512bw_vpternlogv32bf_3 */
   12419        47119 :     case 6955:  /* *avx512fp16_vpternlogv8hf_3 */
   12420        47119 :     case 6954:  /* *avx512fp16_vpternlogv8hf_3 */
   12421        47119 :     case 6953:  /* *avx512fp16_vpternlogv8hf_3 */
   12422        47119 :     case 6952:  /* *avx512fp16_vpternlogv8hf_3 */
   12423        47119 :     case 6951:  /* *avx512fp16_vpternlogv8hf_3 */
   12424        47119 :     case 6950:  /* *avx512fp16_vpternlogv8hf_3 */
   12425        47119 :     case 6949:  /* *avx512fp16_vpternlogv8hf_3 */
   12426        47119 :     case 6948:  /* *avx512fp16_vpternlogv8hf_3 */
   12427        47119 :     case 6947:  /* *avx512fp16_vpternlogv8hf_3 */
   12428        47119 :     case 6946:  /* *avx512vl_vpternlogv16hf_3 */
   12429        47119 :     case 6945:  /* *avx512vl_vpternlogv16hf_3 */
   12430        47119 :     case 6944:  /* *avx512vl_vpternlogv16hf_3 */
   12431        47119 :     case 6943:  /* *avx512vl_vpternlogv16hf_3 */
   12432        47119 :     case 6942:  /* *avx512vl_vpternlogv16hf_3 */
   12433        47119 :     case 6941:  /* *avx512vl_vpternlogv16hf_3 */
   12434        47119 :     case 6940:  /* *avx512vl_vpternlogv16hf_3 */
   12435        47119 :     case 6939:  /* *avx512vl_vpternlogv16hf_3 */
   12436        47119 :     case 6938:  /* *avx512vl_vpternlogv16hf_3 */
   12437        47119 :     case 6937:  /* *avx512bw_vpternlogv32hf_3 */
   12438        47119 :     case 6936:  /* *avx512bw_vpternlogv32hf_3 */
   12439        47119 :     case 6935:  /* *avx512bw_vpternlogv32hf_3 */
   12440        47119 :     case 6934:  /* *avx512bw_vpternlogv32hf_3 */
   12441        47119 :     case 6933:  /* *avx512bw_vpternlogv32hf_3 */
   12442        47119 :     case 6932:  /* *avx512bw_vpternlogv32hf_3 */
   12443        47119 :     case 6931:  /* *avx512bw_vpternlogv32hf_3 */
   12444        47119 :     case 6930:  /* *avx512bw_vpternlogv32hf_3 */
   12445        47119 :     case 6929:  /* *avx512bw_vpternlogv32hf_3 */
   12446        47119 :     case 6928:  /* *avx512vl_vpternlogv2di_3 */
   12447        47119 :     case 6927:  /* *avx512vl_vpternlogv2di_3 */
   12448        47119 :     case 6926:  /* *avx512vl_vpternlogv2di_3 */
   12449        47119 :     case 6925:  /* *avx512vl_vpternlogv2di_3 */
   12450        47119 :     case 6924:  /* *avx512vl_vpternlogv2di_3 */
   12451        47119 :     case 6923:  /* *avx512vl_vpternlogv2di_3 */
   12452        47119 :     case 6922:  /* *avx512vl_vpternlogv2di_3 */
   12453        47119 :     case 6921:  /* *avx512vl_vpternlogv2di_3 */
   12454        47119 :     case 6920:  /* *avx512vl_vpternlogv2di_3 */
   12455        47119 :     case 6919:  /* *avx512vl_vpternlogv4di_3 */
   12456        47119 :     case 6918:  /* *avx512vl_vpternlogv4di_3 */
   12457        47119 :     case 6917:  /* *avx512vl_vpternlogv4di_3 */
   12458        47119 :     case 6916:  /* *avx512vl_vpternlogv4di_3 */
   12459        47119 :     case 6915:  /* *avx512vl_vpternlogv4di_3 */
   12460        47119 :     case 6914:  /* *avx512vl_vpternlogv4di_3 */
   12461        47119 :     case 6913:  /* *avx512vl_vpternlogv4di_3 */
   12462        47119 :     case 6912:  /* *avx512vl_vpternlogv4di_3 */
   12463        47119 :     case 6911:  /* *avx512vl_vpternlogv4di_3 */
   12464        47119 :     case 6910:  /* *avx512f_vpternlogv8di_3 */
   12465        47119 :     case 6909:  /* *avx512f_vpternlogv8di_3 */
   12466        47119 :     case 6908:  /* *avx512f_vpternlogv8di_3 */
   12467        47119 :     case 6907:  /* *avx512f_vpternlogv8di_3 */
   12468        47119 :     case 6906:  /* *avx512f_vpternlogv8di_3 */
   12469        47119 :     case 6905:  /* *avx512f_vpternlogv8di_3 */
   12470        47119 :     case 6904:  /* *avx512f_vpternlogv8di_3 */
   12471        47119 :     case 6903:  /* *avx512f_vpternlogv8di_3 */
   12472        47119 :     case 6902:  /* *avx512f_vpternlogv8di_3 */
   12473        47119 :     case 6901:  /* *avx512vl_vpternlogv4si_3 */
   12474        47119 :     case 6900:  /* *avx512vl_vpternlogv4si_3 */
   12475        47119 :     case 6899:  /* *avx512vl_vpternlogv4si_3 */
   12476        47119 :     case 6898:  /* *avx512vl_vpternlogv4si_3 */
   12477        47119 :     case 6897:  /* *avx512vl_vpternlogv4si_3 */
   12478        47119 :     case 6896:  /* *avx512vl_vpternlogv4si_3 */
   12479        47119 :     case 6895:  /* *avx512vl_vpternlogv4si_3 */
   12480        47119 :     case 6894:  /* *avx512vl_vpternlogv4si_3 */
   12481        47119 :     case 6893:  /* *avx512vl_vpternlogv4si_3 */
   12482        47119 :     case 6892:  /* *avx512vl_vpternlogv8si_3 */
   12483        47119 :     case 6891:  /* *avx512vl_vpternlogv8si_3 */
   12484        47119 :     case 6890:  /* *avx512vl_vpternlogv8si_3 */
   12485        47119 :     case 6889:  /* *avx512vl_vpternlogv8si_3 */
   12486        47119 :     case 6888:  /* *avx512vl_vpternlogv8si_3 */
   12487        47119 :     case 6887:  /* *avx512vl_vpternlogv8si_3 */
   12488        47119 :     case 6886:  /* *avx512vl_vpternlogv8si_3 */
   12489        47119 :     case 6885:  /* *avx512vl_vpternlogv8si_3 */
   12490        47119 :     case 6884:  /* *avx512vl_vpternlogv8si_3 */
   12491        47119 :     case 6883:  /* *avx512f_vpternlogv16si_3 */
   12492        47119 :     case 6882:  /* *avx512f_vpternlogv16si_3 */
   12493        47119 :     case 6881:  /* *avx512f_vpternlogv16si_3 */
   12494        47119 :     case 6880:  /* *avx512f_vpternlogv16si_3 */
   12495        47119 :     case 6879:  /* *avx512f_vpternlogv16si_3 */
   12496        47119 :     case 6878:  /* *avx512f_vpternlogv16si_3 */
   12497        47119 :     case 6877:  /* *avx512f_vpternlogv16si_3 */
   12498        47119 :     case 6876:  /* *avx512f_vpternlogv16si_3 */
   12499        47119 :     case 6875:  /* *avx512f_vpternlogv16si_3 */
   12500        47119 :     case 6874:  /* *avx512vl_vpternlogv8hi_3 */
   12501        47119 :     case 6873:  /* *avx512vl_vpternlogv8hi_3 */
   12502        47119 :     case 6872:  /* *avx512vl_vpternlogv8hi_3 */
   12503        47119 :     case 6871:  /* *avx512vl_vpternlogv8hi_3 */
   12504        47119 :     case 6870:  /* *avx512vl_vpternlogv8hi_3 */
   12505        47119 :     case 6869:  /* *avx512vl_vpternlogv8hi_3 */
   12506        47119 :     case 6868:  /* *avx512vl_vpternlogv8hi_3 */
   12507        47119 :     case 6867:  /* *avx512vl_vpternlogv8hi_3 */
   12508        47119 :     case 6866:  /* *avx512vl_vpternlogv8hi_3 */
   12509        47119 :     case 6865:  /* *avx512vl_vpternlogv16hi_3 */
   12510        47119 :     case 6864:  /* *avx512vl_vpternlogv16hi_3 */
   12511        47119 :     case 6863:  /* *avx512vl_vpternlogv16hi_3 */
   12512        47119 :     case 6862:  /* *avx512vl_vpternlogv16hi_3 */
   12513        47119 :     case 6861:  /* *avx512vl_vpternlogv16hi_3 */
   12514        47119 :     case 6860:  /* *avx512vl_vpternlogv16hi_3 */
   12515        47119 :     case 6859:  /* *avx512vl_vpternlogv16hi_3 */
   12516        47119 :     case 6858:  /* *avx512vl_vpternlogv16hi_3 */
   12517        47119 :     case 6857:  /* *avx512vl_vpternlogv16hi_3 */
   12518        47119 :     case 6856:  /* *avx512bw_vpternlogv32hi_3 */
   12519        47119 :     case 6855:  /* *avx512bw_vpternlogv32hi_3 */
   12520        47119 :     case 6854:  /* *avx512bw_vpternlogv32hi_3 */
   12521        47119 :     case 6853:  /* *avx512bw_vpternlogv32hi_3 */
   12522        47119 :     case 6852:  /* *avx512bw_vpternlogv32hi_3 */
   12523        47119 :     case 6851:  /* *avx512bw_vpternlogv32hi_3 */
   12524        47119 :     case 6850:  /* *avx512bw_vpternlogv32hi_3 */
   12525        47119 :     case 6849:  /* *avx512bw_vpternlogv32hi_3 */
   12526        47119 :     case 6848:  /* *avx512bw_vpternlogv32hi_3 */
   12527        47119 :     case 6847:  /* *avx512vl_vpternlogv16qi_3 */
   12528        47119 :     case 6846:  /* *avx512vl_vpternlogv16qi_3 */
   12529        47119 :     case 6845:  /* *avx512vl_vpternlogv16qi_3 */
   12530        47119 :     case 6844:  /* *avx512vl_vpternlogv16qi_3 */
   12531        47119 :     case 6843:  /* *avx512vl_vpternlogv16qi_3 */
   12532        47119 :     case 6842:  /* *avx512vl_vpternlogv16qi_3 */
   12533        47119 :     case 6841:  /* *avx512vl_vpternlogv16qi_3 */
   12534        47119 :     case 6840:  /* *avx512vl_vpternlogv16qi_3 */
   12535        47119 :     case 6839:  /* *avx512vl_vpternlogv16qi_3 */
   12536        47119 :     case 6838:  /* *avx512vl_vpternlogv32qi_3 */
   12537        47119 :     case 6837:  /* *avx512vl_vpternlogv32qi_3 */
   12538        47119 :     case 6836:  /* *avx512vl_vpternlogv32qi_3 */
   12539        47119 :     case 6835:  /* *avx512vl_vpternlogv32qi_3 */
   12540        47119 :     case 6834:  /* *avx512vl_vpternlogv32qi_3 */
   12541        47119 :     case 6833:  /* *avx512vl_vpternlogv32qi_3 */
   12542        47119 :     case 6832:  /* *avx512vl_vpternlogv32qi_3 */
   12543        47119 :     case 6831:  /* *avx512vl_vpternlogv32qi_3 */
   12544        47119 :     case 6830:  /* *avx512vl_vpternlogv32qi_3 */
   12545        47119 :     case 6829:  /* *avx512bw_vpternlogv64qi_3 */
   12546        47119 :     case 6828:  /* *avx512bw_vpternlogv64qi_3 */
   12547        47119 :     case 6827:  /* *avx512bw_vpternlogv64qi_3 */
   12548        47119 :     case 6826:  /* *avx512bw_vpternlogv64qi_3 */
   12549        47119 :     case 6825:  /* *avx512bw_vpternlogv64qi_3 */
   12550        47119 :     case 6824:  /* *avx512bw_vpternlogv64qi_3 */
   12551        47119 :     case 6823:  /* *avx512bw_vpternlogv64qi_3 */
   12552        47119 :     case 6822:  /* *avx512bw_vpternlogv64qi_3 */
   12553        47119 :     case 6821:  /* *avx512bw_vpternlogv64qi_3 */
   12554        47119 :     case 1315:  /* *extendv2di2_highpart_stv_noavx512vl */
   12555        47119 :     case 1314:  /* *extendv2di2_highpart_stv */
   12556        47119 :     case 965:  /* *concatditi3_5 */
   12557        47119 :     case 964:  /* *concatditi3_5 */
   12558        47119 :     case 963:  /* *concatditi3_5 */
   12559        47119 :     case 962:  /* *concatsidi3_5 */
   12560        47119 :     case 961:  /* *concatsidi3_5 */
   12561        47119 :     case 960:  /* *concatsidi3_5 */
   12562        47119 :     case 383:  /* *leadi_general_4 */
   12563        47119 :     case 382:  /* *leadi_general_4 */
   12564        47119 :     case 381:  /* *leasi_general_4 */
   12565        47119 :     case 380:  /* *leasi_general_4 */
   12566        47119 :     case 379:  /* *leahi_general_4 */
   12567        47119 :     case 378:  /* *leahi_general_4 */
   12568        47119 :     case 377:  /* *leaqi_general_4 */
   12569        47119 :     case 376:  /* *leaqi_general_4 */
   12570        47119 :     case 371:  /* *leahi_general_2b */
   12571        47119 :     case 370:  /* *leaqi_general_2b */
   12572        47119 :     case 369:  /* *leahi_general_2 */
   12573        47119 :     case 368:  /* *leaqi_general_2 */
   12574        47119 :     case 367:  /* *leahi_general_1 */
   12575        47119 :     case 366:  /* *leaqi_general_1 */
   12576        47119 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   12577        47119 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   12578        47119 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   12579        47119 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
   12580        47119 :       break;
   12581              : 
   12582         2700 :     case 365:  /* *addvdi4_overflow_2 */
   12583         2700 :     case 364:  /* *addvsi4_overflow_2 */
   12584         2700 :     case 363:  /* *addvhi4_overflow_2 */
   12585         2700 :     case 362:  /* *addvqi4_overflow_2 */
   12586         2700 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12587         2700 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1), 0));
   12588         2700 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1));
   12589         2700 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   12590         2700 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12591         2700 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0));
   12592         2700 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   12593         2700 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   12594         2700 :       recog_data.dup_num[0] = 5;
   12595         2700 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0), 0);
   12596         2700 :       recog_data.dup_num[1] = 3;
   12597         2700 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   12598         2700 :       recog_data.dup_num[2] = 1;
   12599         2700 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   12600         2700 :       recog_data.dup_num[3] = 2;
   12601         2700 :       recog_data.dup_loc[4] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0), 0);
   12602         2700 :       recog_data.dup_num[4] = 3;
   12603         2700 :       recog_data.dup_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 1);
   12604         2700 :       recog_data.dup_num[5] = 1;
   12605         2700 :       break;
   12606              : 
   12607         8230 :     case 361:  /* *addvdi4_overflow_1 */
   12608         8230 :     case 360:  /* *addvsi4_overflow_1 */
   12609         8230 :     case 359:  /* *addvhi4_overflow_1 */
   12610         8230 :     case 358:  /* *addvqi4_overflow_1 */
   12611         8230 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12612         8230 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1), 0));
   12613         8230 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   12614         8230 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   12615         8230 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12616         8230 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0));
   12617         8230 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   12618         8230 :       recog_data.dup_num[0] = 5;
   12619         8230 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0), 0);
   12620         8230 :       recog_data.dup_num[1] = 3;
   12621         8230 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   12622         8230 :       recog_data.dup_num[2] = 1;
   12623         8230 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   12624         8230 :       recog_data.dup_num[3] = 2;
   12625         8230 :       recog_data.dup_loc[4] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0), 0);
   12626         8230 :       recog_data.dup_num[4] = 3;
   12627         8230 :       recog_data.dup_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 1);
   12628         8230 :       recog_data.dup_num[5] = 1;
   12629         8230 :       recog_data.dup_loc[6] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1);
   12630         8230 :       recog_data.dup_num[6] = 2;
   12631         8230 :       break;
   12632              : 
   12633       110086 :     case 637:  /* *mulvdi4_1 */
   12634       110086 :     case 636:  /* *mulvsi4_1 */
   12635       110086 :     case 635:  /* *mulvhi4_1 */
   12636       110086 :     case 440:  /* *subvti4_doubleword_1 */
   12637       110086 :     case 439:  /* *subvdi4_doubleword_1 */
   12638       110086 :     case 436:  /* subvdi4_1 */
   12639       110086 :     case 435:  /* subvsi4_1 */
   12640       110086 :     case 434:  /* subvhi4_1 */
   12641       110086 :     case 433:  /* subvqi4_1 */
   12642       110086 :     case 357:  /* *addvti4_doubleword_1 */
   12643       110086 :     case 356:  /* *addvdi4_doubleword_1 */
   12644       110086 :     case 353:  /* addvdi4_1 */
   12645       110086 :     case 352:  /* addvsi4_1 */
   12646       110086 :     case 351:  /* addvhi4_1 */
   12647       110086 :     case 350:  /* addvqi4_1 */
   12648       110086 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12649       110086 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12650       110086 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1));
   12651       110086 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   12652       110086 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   12653       110086 :       recog_data.dup_num[0] = 1;
   12654       110086 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   12655       110086 :       recog_data.dup_num[1] = 2;
   12656       110086 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0);
   12657       110086 :       recog_data.dup_num[2] = 1;
   12658       110086 :       break;
   12659              : 
   12660       256257 :     case 642:  /* *umulvqi4 */
   12661       256257 :     case 641:  /* *mulvqi4 */
   12662       256257 :     case 634:  /* *mulvhi4 */
   12663       256257 :     case 633:  /* *mulvdi4 */
   12664       256257 :     case 632:  /* *mulvsi4 */
   12665       256257 :     case 438:  /* *subvti4_doubleword */
   12666       256257 :     case 437:  /* *subvdi4_doubleword */
   12667       256257 :     case 432:  /* *subvdi4 */
   12668       256257 :     case 431:  /* *subvsi4 */
   12669       256257 :     case 430:  /* *subvhi4 */
   12670       256257 :     case 429:  /* *subvqi4 */
   12671       256257 :     case 355:  /* *addvti4_doubleword */
   12672       256257 :     case 354:  /* *addvdi4_doubleword */
   12673       256257 :     case 349:  /* *addvdi4 */
   12674       256257 :     case 348:  /* *addvsi4 */
   12675       256257 :     case 347:  /* *addvhi4 */
   12676       256257 :     case 346:  /* *addvqi4 */
   12677       256257 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12678       256257 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12679       256257 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   12680       256257 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   12681       256257 :       recog_data.dup_num[0] = 1;
   12682       256257 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   12683       256257 :       recog_data.dup_num[1] = 2;
   12684       256257 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0);
   12685       256257 :       recog_data.dup_num[2] = 1;
   12686       256257 :       recog_data.dup_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1);
   12687       256257 :       recog_data.dup_num[3] = 2;
   12688       256257 :       break;
   12689              : 
   12690         2298 :     case 827:  /* *xorqi_extdi_2 */
   12691         2298 :     case 826:  /* *iorqi_extdi_2 */
   12692         2298 :     case 825:  /* *andqi_extdi_2 */
   12693         2298 :     case 824:  /* *xorqi_extsi_2 */
   12694         2298 :     case 823:  /* *iorqi_extsi_2 */
   12695         2298 :     case 822:  /* *andqi_extsi_2 */
   12696         2298 :     case 821:  /* *xorqi_exthi_2 */
   12697         2298 :     case 820:  /* *iorqi_exthi_2 */
   12698         2298 :     case 819:  /* *andqi_exthi_2 */
   12699         2298 :     case 345:  /* *subqi_extdi_2 */
   12700         2298 :     case 344:  /* *addqi_extdi_2 */
   12701         2298 :     case 343:  /* *subqi_extsi_2 */
   12702         2298 :     case 342:  /* *addqi_extsi_2 */
   12703         2298 :     case 341:  /* *subqi_exthi_2 */
   12704         2298 :     case 340:  /* *addqi_exthi_2 */
   12705         2298 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   12706         2298 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   12707         2298 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0), 0));
   12708         2298 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12709         2298 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   12710         2298 :       break;
   12711              : 
   12712        43214 :     case 1275:  /* *ashrqi_extdi_1 */
   12713        43214 :     case 1274:  /* *lshrqi_extdi_1 */
   12714        43214 :     case 1273:  /* *ashrqi_extsi_1 */
   12715        43214 :     case 1272:  /* *lshrqi_extsi_1 */
   12716        43214 :     case 1271:  /* *ashrqi_exthi_1 */
   12717        43214 :     case 1270:  /* *lshrqi_exthi_1 */
   12718        43214 :     case 1153:  /* *ashlqi_extdi_1 */
   12719        43214 :     case 1152:  /* *ashlqi_extsi_1 */
   12720        43214 :     case 1151:  /* *ashlqi_exthi_1 */
   12721        43214 :     case 809:  /* *xorqi_extdi_1 */
   12722        43214 :     case 808:  /* *iorqi_extdi_1 */
   12723        43214 :     case 807:  /* *andqi_extdi_1 */
   12724        43214 :     case 806:  /* *xorqi_extsi_1 */
   12725        43214 :     case 805:  /* *iorqi_extsi_1 */
   12726        43214 :     case 804:  /* *andqi_extsi_1 */
   12727        43214 :     case 803:  /* *xorqi_exthi_1 */
   12728        43214 :     case 802:  /* *iorqi_exthi_1 */
   12729        43214 :     case 801:  /* *andqi_exthi_1 */
   12730        43214 :     case 428:  /* *subqi_extdi_1 */
   12731        43214 :     case 427:  /* *subqi_extsi_1 */
   12732        43214 :     case 426:  /* *subqi_exthi_1 */
   12733        43214 :     case 339:  /* *addqi_extdi_1 */
   12734        43214 :     case 338:  /* *addqi_extsi_1 */
   12735        43214 :     case 337:  /* *addqi_exthi_1 */
   12736        43214 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   12737        43214 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   12738        43214 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   12739        43214 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12740        43214 :       break;
   12741              : 
   12742          690 :     case 800:  /* *xorqi_ext2di_0 */
   12743          690 :     case 799:  /* *iorqi_ext2di_0 */
   12744          690 :     case 798:  /* *andqi_ext2di_0 */
   12745          690 :     case 797:  /* *xorqi_ext2si_0 */
   12746          690 :     case 796:  /* *iorqi_ext2si_0 */
   12747          690 :     case 795:  /* *andqi_ext2si_0 */
   12748          690 :     case 794:  /* *xorqi_ext2hi_0 */
   12749          690 :     case 793:  /* *iorqi_ext2hi_0 */
   12750          690 :     case 792:  /* *andqi_ext2hi_0 */
   12751          690 :     case 425:  /* *subqi_ext2di_0 */
   12752          690 :     case 424:  /* *subqi_ext2si_0 */
   12753          690 :     case 423:  /* *subqi_ext2hi_0 */
   12754          690 :     case 336:  /* *addqi_ext2di_0 */
   12755          690 :     case 335:  /* *addqi_ext2si_0 */
   12756          690 :     case 334:  /* *addqi_ext2hi_0 */
   12757          690 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   12758          690 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12759          690 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0));
   12760          690 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12761          690 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   12762          690 :       break;
   12763              : 
   12764         2608 :     case 791:  /* *xorqi_extdi_0 */
   12765         2608 :     case 790:  /* *iorqi_extdi_0 */
   12766         2608 :     case 789:  /* *andqi_extdi_0 */
   12767         2608 :     case 788:  /* *xorqi_extsi_0 */
   12768         2608 :     case 787:  /* *iorqi_extsi_0 */
   12769         2608 :     case 786:  /* *andqi_extsi_0 */
   12770         2608 :     case 785:  /* *xorqi_exthi_0 */
   12771         2608 :     case 784:  /* *iorqi_exthi_0 */
   12772         2608 :     case 783:  /* *andqi_exthi_0 */
   12773         2608 :     case 333:  /* *addqi_extdi_0 */
   12774         2608 :     case 332:  /* *addqi_extsi_0 */
   12775         2608 :     case 331:  /* *addqi_exthi_0 */
   12776         2608 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   12777         2608 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   12778         2608 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12779         2608 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12780         2608 :       break;
   12781              : 
   12782       542359 :     case 1269:  /* *ashrdi3_cconly */
   12783       542359 :     case 1268:  /* *lshrdi3_cconly */
   12784       542359 :     case 1267:  /* *ashrsi3_cconly */
   12785       542359 :     case 1266:  /* *lshrsi3_cconly */
   12786       542359 :     case 1265:  /* *ashrhi3_cconly */
   12787       542359 :     case 1264:  /* *lshrhi3_cconly */
   12788       542359 :     case 1263:  /* *ashrqi3_cconly */
   12789       542359 :     case 1262:  /* *lshrqi3_cconly */
   12790       542359 :     case 1150:  /* *ashldi3_cconly */
   12791       542359 :     case 1149:  /* *ashlsi3_cconly */
   12792       542359 :     case 1148:  /* *ashlhi3_cconly */
   12793       542359 :     case 1147:  /* *ashlqi3_cconly */
   12794       542359 :     case 923:  /* *xordi_3 */
   12795       542359 :     case 922:  /* *iordi_3 */
   12796       542359 :     case 921:  /* *xorsi_3 */
   12797       542359 :     case 920:  /* *iorsi_3 */
   12798       542359 :     case 919:  /* *xorhi_3 */
   12799       542359 :     case 918:  /* *iorhi_3 */
   12800       542359 :     case 917:  /* *xorqi_3 */
   12801       542359 :     case 916:  /* *iorqi_3 */
   12802       542359 :     case 915:  /* *iordi_ccz_1 */
   12803       542359 :     case 914:  /* *iorsi_ccz_1 */
   12804       542359 :     case 913:  /* *iorhi_ccz_1 */
   12805       542359 :     case 912:  /* *iorqi_ccz_1 */
   12806       542359 :     case 330:  /* *adddi_5 */
   12807       542359 :     case 329:  /* *addsi_5 */
   12808       542359 :     case 328:  /* *addhi_5 */
   12809       542359 :     case 327:  /* *addqi_5 */
   12810       542359 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12811       542359 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12812       542359 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   12813       542359 :       break;
   12814              : 
   12815        78228 :     case 326:  /* *addsi_4 */
   12816        78228 :     case 325:  /* *addhi_4 */
   12817        78228 :     case 324:  /* *addqi_4 */
   12818        78228 :     case 323:  /* *adddi_4 */
   12819        78228 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12820        78228 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   12821        78228 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   12822        78228 :       break;
   12823              : 
   12824            0 :     case 322:  /* *addsi_3_zext */
   12825            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12826            0 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   12827            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12828            0 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   12829            0 :       recog_data.dup_num[0] = 1;
   12830            0 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   12831            0 :       recog_data.dup_num[1] = 2;
   12832            0 :       break;
   12833              : 
   12834        36508 :     case 321:  /* *adddi_3 */
   12835        36508 :     case 320:  /* *addsi_3 */
   12836        36508 :     case 319:  /* *addhi_3 */
   12837        36508 :     case 318:  /* *addqi_3 */
   12838        36508 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12839        36508 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   12840        36508 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12841        36508 :       break;
   12842              : 
   12843           92 :     case 1261:  /* *ashrsi3_cmp_zext */
   12844           92 :     case 1260:  /* *lshrsi3_cmp_zext */
   12845           92 :     case 1146:  /* *ashlsi3_cmp_zext */
   12846           92 :     case 909:  /* *xorsi_2_zext */
   12847           92 :     case 908:  /* *iorsi_2_zext */
   12848           92 :     case 778:  /* *andsi_2_zext */
   12849           92 :     case 419:  /* *subsi_2_zext */
   12850           92 :     case 317:  /* *addsi_2_zext */
   12851           92 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12852           92 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12853           92 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   12854           92 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   12855           92 :       recog_data.dup_num[0] = 1;
   12856           92 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   12857           92 :       recog_data.dup_num[1] = 2;
   12858           92 :       break;
   12859              : 
   12860      3230544 :     case 1259:  /* *ashrdi3_cmp */
   12861      3230544 :     case 1258:  /* *lshrdi3_cmp */
   12862      3230544 :     case 1257:  /* *ashrsi3_cmp */
   12863      3230544 :     case 1256:  /* *lshrsi3_cmp */
   12864      3230544 :     case 1255:  /* *ashrhi3_cmp */
   12865      3230544 :     case 1254:  /* *lshrhi3_cmp */
   12866      3230544 :     case 1253:  /* *ashrqi3_cmp */
   12867      3230544 :     case 1252:  /* *lshrqi3_cmp */
   12868      3230544 :     case 1145:  /* *ashldi3_cmp */
   12869      3230544 :     case 1144:  /* *ashlsi3_cmp */
   12870      3230544 :     case 1143:  /* *ashlhi3_cmp */
   12871      3230544 :     case 1142:  /* *ashlqi3_cmp */
   12872      3230544 :     case 907:  /* *xordi_2 */
   12873      3230544 :     case 906:  /* *iordi_2 */
   12874      3230544 :     case 905:  /* *xorsi_2 */
   12875      3230544 :     case 904:  /* *iorsi_2 */
   12876      3230544 :     case 903:  /* *xorhi_2 */
   12877      3230544 :     case 902:  /* *iorhi_2 */
   12878      3230544 :     case 901:  /* *xorqi_2 */
   12879      3230544 :     case 900:  /* *iorqi_2 */
   12880      3230544 :     case 782:  /* *andsi_2 */
   12881      3230544 :     case 781:  /* *andhi_2 */
   12882      3230544 :     case 780:  /* *andqi_2 */
   12883      3230544 :     case 779:  /* *andqi_2_maybe_si */
   12884      3230544 :     case 777:  /* *anddi_2 */
   12885      3230544 :     case 418:  /* *subdi_2 */
   12886      3230544 :     case 417:  /* *subsi_2 */
   12887      3230544 :     case 416:  /* *subhi_2 */
   12888      3230544 :     case 415:  /* *subqi_2 */
   12889      3230544 :     case 316:  /* *adddi_2 */
   12890      3230544 :     case 315:  /* *addsi_2 */
   12891      3230544 :     case 314:  /* *addhi_2 */
   12892      3230544 :     case 313:  /* *addqi_2 */
   12893      3230544 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12894      3230544 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12895      3230544 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   12896      3230544 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   12897      3230544 :       recog_data.dup_num[0] = 1;
   12898      3230544 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   12899      3230544 :       recog_data.dup_num[1] = 2;
   12900      3230544 :       break;
   12901              : 
   12902          346 :     case 776:  /* *xorqi_extdi_2_slp */
   12903          346 :     case 775:  /* *iorqi_extdi_2_slp */
   12904          346 :     case 774:  /* *andqi_extdi_2_slp */
   12905          346 :     case 773:  /* *xorqi_extsi_2_slp */
   12906          346 :     case 772:  /* *iorqi_extsi_2_slp */
   12907          346 :     case 771:  /* *andqi_extsi_2_slp */
   12908          346 :     case 770:  /* *xorqi_exthi_2_slp */
   12909          346 :     case 769:  /* *iorqi_exthi_2_slp */
   12910          346 :     case 768:  /* *andqi_exthi_2_slp */
   12911          346 :     case 414:  /* *subqi_extdi_2_slp */
   12912          346 :     case 413:  /* *subqi_extsi_2_slp */
   12913          346 :     case 412:  /* *subqi_exthi_2_slp */
   12914          346 :     case 312:  /* *addqi_extdi_2_slp */
   12915          346 :     case 311:  /* *addqi_extsi_2_slp */
   12916          346 :     case 310:  /* *addqi_exthi_2_slp */
   12917          346 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   12918          346 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12919          346 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0));
   12920          346 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12921          346 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   12922          346 :       break;
   12923              : 
   12924          445 :     case 767:  /* *xorqi_extdi_1_slp */
   12925          445 :     case 766:  /* *iorqi_extdi_1_slp */
   12926          445 :     case 765:  /* *andqi_extdi_1_slp */
   12927          445 :     case 764:  /* *xorqi_extsi_1_slp */
   12928          445 :     case 763:  /* *iorqi_extsi_1_slp */
   12929          445 :     case 762:  /* *andqi_extsi_1_slp */
   12930          445 :     case 761:  /* *xorqi_exthi_1_slp */
   12931          445 :     case 760:  /* *iorqi_exthi_1_slp */
   12932          445 :     case 759:  /* *andqi_exthi_1_slp */
   12933          445 :     case 309:  /* *addqi_extdi_1_slp */
   12934          445 :     case 308:  /* *addqi_extsi_1_slp */
   12935          445 :     case 307:  /* *addqi_exthi_1_slp */
   12936          445 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   12937          445 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   12938          445 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12939          445 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12940          445 :       break;
   12941              : 
   12942        19143 :     case 1416:  /* *rotrhi3_1_slp */
   12943        19143 :     case 1415:  /* *rotlhi3_1_slp */
   12944        19143 :     case 1414:  /* *rotrqi3_1_slp */
   12945        19143 :     case 1413:  /* *rotlqi3_1_slp */
   12946        19143 :     case 1251:  /* *ashrhi3_1_slp */
   12947        19143 :     case 1250:  /* *lshrhi3_1_slp */
   12948        19143 :     case 1249:  /* *ashrqi3_1_slp */
   12949        19143 :     case 1248:  /* *lshrqi3_1_slp */
   12950        19143 :     case 1141:  /* *ashlhi3_1_slp */
   12951        19143 :     case 1140:  /* *ashlqi3_1_slp */
   12952        19143 :     case 758:  /* *xorhi_1_slp */
   12953        19143 :     case 757:  /* *iorhi_1_slp */
   12954        19143 :     case 756:  /* *andhi_1_slp */
   12955        19143 :     case 755:  /* *xorqi_1_slp */
   12956        19143 :     case 754:  /* *iorqi_1_slp */
   12957        19143 :     case 753:  /* *andqi_1_slp */
   12958        19143 :     case 408:  /* *subhi_1_slp */
   12959        19143 :     case 407:  /* *subqi_1_slp */
   12960        19143 :     case 306:  /* *addhi_1_slp */
   12961        19143 :     case 305:  /* *addqi_1_slp */
   12962        19143 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   12963        19143 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   12964        19143 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   12965        19143 :       break;
   12966              : 
   12967       517064 :     case 2663:  /* *klshrsi3_1_zext */
   12968       517064 :     case 2645:  /* kxnordi */
   12969       517064 :     case 2644:  /* kxnorsi */
   12970       517064 :     case 2643:  /* kxnorhi */
   12971       517064 :     case 2642:  /* kxnorqi */
   12972       517064 :     case 1404:  /* *rotrsi3_1_zext */
   12973       517064 :     case 1403:  /* *rotlsi3_1_zext */
   12974       517064 :     case 1402:  /* *rotrhi3_1_zextdi */
   12975       517064 :     case 1400:  /* *rotlhi3_1_zextdi */
   12976       517064 :     case 1398:  /* *rotrhi3_1_zextsi */
   12977       517064 :     case 1396:  /* *rotlhi3_1_zextsi */
   12978       517064 :     case 1394:  /* *rotrqi3_1_zextdi */
   12979       517064 :     case 1392:  /* *rotlqi3_1_zextdi */
   12980       517064 :     case 1390:  /* *rotrqi3_1_zextsi */
   12981       517064 :     case 1388:  /* *rotlqi3_1_zextsi */
   12982       517064 :     case 1386:  /* *rotrqi3_1_zexthi */
   12983       517064 :     case 1384:  /* *rotlqi3_1_zexthi */
   12984       517064 :     case 1239:  /* *ashrsi3_1_zext */
   12985       517064 :     case 1238:  /* *lshrsi3_1_zext */
   12986       517064 :     case 1237:  /* *ashrhi3_1_zextdi */
   12987       517064 :     case 1235:  /* *lshrhi3_1_zextdi */
   12988       517064 :     case 1233:  /* *ashrhi3_1_zextsi */
   12989       517064 :     case 1231:  /* *lshrhi3_1_zextsi */
   12990       517064 :     case 1229:  /* *ashrqi3_1_zextdi */
   12991       517064 :     case 1227:  /* *lshrqi3_1_zextdi */
   12992       517064 :     case 1225:  /* *ashrqi3_1_zextsi */
   12993       517064 :     case 1223:  /* *lshrqi3_1_zextsi */
   12994       517064 :     case 1221:  /* *ashrqi3_1_zexthi */
   12995       517064 :     case 1219:  /* *lshrqi3_1_zexthi */
   12996       517064 :     case 1202:  /* *ashrsi3_cvt_zext */
   12997       517064 :     case 1173:  /* ashrti3_doubleword_lowpart */
   12998       517064 :     case 1172:  /* lshrti3_doubleword_lowpart */
   12999       517064 :     case 1171:  /* ashrdi3_doubleword_lowpart */
   13000       517064 :     case 1170:  /* lshrdi3_doubleword_lowpart */
   13001       517064 :     case 1135:  /* *ashlsi3_1_zext */
   13002       517064 :     case 1134:  /* *ashlhi3_1_zextdi */
   13003       517064 :     case 1132:  /* *ashlhi3_1_zextsi */
   13004       517064 :     case 1130:  /* *ashlqi3_1_zextdi */
   13005       517064 :     case 1128:  /* *ashlqi3_1_zextsi */
   13006       517064 :     case 1126:  /* *ashlqi3_1_zexthi */
   13007       517064 :     case 899:  /* *notxorqi_1 */
   13008       517064 :     case 892:  /* *xorsi_1_zext */
   13009       517064 :     case 891:  /* *iorsi_1_zext */
   13010       517064 :     case 890:  /* *xorhi_1_zextdi */
   13011       517064 :     case 888:  /* *iorhi_1_zextdi */
   13012       517064 :     case 886:  /* *xorhi_1_zextsi */
   13013       517064 :     case 884:  /* *iorhi_1_zextsi */
   13014       517064 :     case 882:  /* *xorqi_1_zextdi */
   13015       517064 :     case 880:  /* *iorqi_1_zextdi */
   13016       517064 :     case 878:  /* *xorqi_1_zextsi */
   13017       517064 :     case 876:  /* *iorqi_1_zextsi */
   13018       517064 :     case 874:  /* *xorqi_1_zexthi */
   13019       517064 :     case 872:  /* *iorqi_1_zexthi */
   13020       517064 :     case 865:  /* *notxordi_1 */
   13021       517064 :     case 864:  /* *notxorsi_1 */
   13022       517064 :     case 863:  /* *notxorhi_1 */
   13023       517064 :     case 746:  /* *andsi_1_zext */
   13024       517064 :     case 745:  /* *andhi_1_zextdi */
   13025       517064 :     case 743:  /* *andhi_1_zextsi */
   13026       517064 :     case 741:  /* *andqi_1_zextdi */
   13027       517064 :     case 739:  /* *andqi_1_zextsi */
   13028       517064 :     case 737:  /* *andqi_1_zexthi */
   13029       517064 :     case 629:  /* *mulsi3_1_zext */
   13030       517064 :     case 627:  /* *imulhidizu */
   13031       517064 :     case 625:  /* *imulhisizu */
   13032       517064 :     case 544:  /* *subsi3_carry_zext_0r */
   13033       517064 :     case 543:  /* *subhi3_carry_zextdi_0r */
   13034       517064 :     case 542:  /* *subhi3_carry_zextsi_0r */
   13035       517064 :     case 541:  /* *subqi3_carry_zextdi_0r */
   13036       517064 :     case 540:  /* *subqi3_carry_zextsi_0r */
   13037       517064 :     case 539:  /* *subqi3_carry_zexthi_0r */
   13038       517064 :     case 538:  /* *subsi3_carry_zext_0 */
   13039       517064 :     case 537:  /* *subhi3_carry_zextdi_0 */
   13040       517064 :     case 536:  /* *subhi3_carry_zextsi_0 */
   13041       517064 :     case 535:  /* *subqi3_carry_zextdi_0 */
   13042       517064 :     case 534:  /* *subqi3_carry_zextsi_0 */
   13043       517064 :     case 533:  /* *subqi3_carry_zexthi_0 */
   13044       517064 :     case 406:  /* *subsi_1_zext */
   13045       517064 :     case 405:  /* *subhi_1_zextdi */
   13046       517064 :     case 403:  /* *subhi_1_zextsi */
   13047       517064 :     case 401:  /* *subqi_1_zextdi */
   13048       517064 :     case 399:  /* *subqi_1_zextsi */
   13049       517064 :     case 397:  /* *subqi_1_zexthi */
   13050       517064 :     case 300:  /* addsi_1_zext */
   13051       517064 :     case 299:  /* *addhi_1_zextdi */
   13052       517064 :     case 297:  /* *addhi_1_zextsi */
   13053       517064 :     case 295:  /* *addqi_1_zextdi */
   13054       517064 :     case 293:  /* *addqi_1_zextsi */
   13055       517064 :     case 291:  /* *addqi_1_zexthi */
   13056       517064 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   13057       517064 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   13058       517064 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   13059       517064 :       break;
   13060              : 
   13061      2516895 :     case 8433:  /* vec_interleave_lowv4si */
   13062      2516895 :     case 8431:  /* *avx512f_interleave_lowv16si */
   13063      2516895 :     case 8429:  /* avx2_interleave_lowv8si */
   13064      2516895 :     case 8427:  /* vec_interleave_highv4si */
   13065      2516895 :     case 8425:  /* *avx512f_interleave_highv16si */
   13066      2516895 :     case 8423:  /* avx2_interleave_highv8si */
   13067      2516895 :     case 8421:  /* vec_interleave_lowv8bf */
   13068      2516895 :     case 8419:  /* vec_interleave_lowv8hf */
   13069      2516895 :     case 8417:  /* vec_interleave_lowv8hi */
   13070      2516895 :     case 8415:  /* avx2_interleave_lowv16bf */
   13071      2516895 :     case 8413:  /* avx2_interleave_lowv16hf */
   13072      2516895 :     case 8411:  /* avx2_interleave_lowv16hi */
   13073      2516895 :     case 8409:  /* *avx512bw_interleave_lowv32bf */
   13074      2516895 :     case 8407:  /* *avx512bw_interleave_lowv32hf */
   13075      2516895 :     case 8405:  /* *avx512bw_interleave_lowv32hi */
   13076      2516895 :     case 8403:  /* vec_interleave_highv8bf */
   13077      2516895 :     case 8401:  /* vec_interleave_highv8hf */
   13078      2516895 :     case 8399:  /* vec_interleave_highv8hi */
   13079      2516895 :     case 8397:  /* avx2_interleave_highv16bf */
   13080      2516895 :     case 8395:  /* avx2_interleave_highv16hf */
   13081      2516895 :     case 8393:  /* avx2_interleave_highv16hi */
   13082      2516895 :     case 8391:  /* avx512bw_interleave_highv32bf */
   13083      2516895 :     case 8389:  /* avx512bw_interleave_highv32hf */
   13084      2516895 :     case 8387:  /* avx512bw_interleave_highv32hi */
   13085      2516895 :     case 8385:  /* vec_interleave_lowv16qi */
   13086      2516895 :     case 8383:  /* avx2_interleave_lowv32qi */
   13087      2516895 :     case 8381:  /* avx512bw_interleave_lowv64qi */
   13088      2516895 :     case 8379:  /* vec_interleave_highv16qi */
   13089      2516895 :     case 8377:  /* avx2_interleave_highv32qi */
   13090      2516895 :     case 8375:  /* avx512bw_interleave_highv64qi */
   13091      2516895 :     case 8140:  /* *xnorv2di3 */
   13092      2516895 :     case 8139:  /* *xnorv4di3 */
   13093      2516895 :     case 8138:  /* *xnorv4si3 */
   13094      2516895 :     case 8137:  /* *xnorv8si3 */
   13095      2516895 :     case 8136:  /* *xnorv8hi3 */
   13096      2516895 :     case 8135:  /* *xnorv16hi3 */
   13097      2516895 :     case 8134:  /* *xnorv32hi3 */
   13098      2516895 :     case 8133:  /* *xnorv16qi3 */
   13099      2516895 :     case 8132:  /* *xnorv32qi3 */
   13100      2516895 :     case 8131:  /* *xnorv64qi3 */
   13101      2516895 :     case 8130:  /* *xnorv8di3 */
   13102      2516895 :     case 8129:  /* *xnorv16si3 */
   13103      2516895 :     case 7230:  /* vec_interleave_lowv2di */
   13104      2516895 :     case 7228:  /* *avx512f_interleave_lowv8di */
   13105      2516895 :     case 7226:  /* avx2_interleave_lowv4di */
   13106      2516895 :     case 7224:  /* vec_interleave_highv2di */
   13107      2516895 :     case 7222:  /* *avx512f_interleave_highv8di */
   13108      2516895 :     case 7220:  /* avx2_interleave_highv4di */
   13109      2516895 :     case 5416:  /* *vec_interleave_lowv2df */
   13110      2516895 :     case 5413:  /* avx_unpcklpd256 */
   13111      2516895 :     case 5409:  /* avx512f_unpcklpd512 */
   13112      2516895 :     case 5406:  /* *vec_interleave_highv2df */
   13113      2516895 :     case 5403:  /* avx_unpckhpd256 */
   13114      2516895 :     case 5401:  /* *avx512f_unpckhpd512 */
   13115      2516895 :     case 5258:  /* vec_interleave_lowv4sf */
   13116      2516895 :     case 5255:  /* avx_unpcklps256 */
   13117      2516895 :     case 5253:  /* *avx512f_unpcklps512 */
   13118      2516895 :     case 5251:  /* vec_interleave_highv4sf */
   13119      2516895 :     case 5249:  /* avx_unpckhps256 */
   13120      2516895 :     case 5247:  /* *avx512f_unpckhps512 */
   13121      2516895 :     case 5246:  /* sse_movlhps_v8bf */
   13122      2516895 :     case 5245:  /* sse_movlhps_v8hf */
   13123      2516895 :     case 5244:  /* sse_movlhps_v8hi */
   13124      2516895 :     case 5243:  /* sse_movlhps */
   13125      2516895 :     case 5242:  /* sse_movhlps */
   13126      2516895 :     case 2351:  /* mmx_punpckldq */
   13127      2516895 :     case 2350:  /* mmx_punpckhdq */
   13128      2516895 :     case 2349:  /* mmx_punpcklwd */
   13129      2516895 :     case 2348:  /* mmx_punpckhwd */
   13130      2516895 :     case 2347:  /* mmx_punpcklbw_low */
   13131      2516895 :     case 2346:  /* mmx_punpcklbw */
   13132      2516895 :     case 2345:  /* mmx_punpckhbw_low */
   13133      2516895 :     case 2344:  /* mmx_punpckhbw */
   13134      2516895 :     case 2136:  /* *vec_interleave_highv2sf */
   13135      2516895 :     case 2135:  /* *vec_interleave_lowv2sf */
   13136      2516895 :     case 1401:  /* *rotrhi3_1_zextdi_nf */
   13137      2516895 :     case 1399:  /* *rotlhi3_1_zextdi_nf */
   13138      2516895 :     case 1397:  /* *rotrhi3_1_zextsi_nf */
   13139      2516895 :     case 1395:  /* *rotlhi3_1_zextsi_nf */
   13140      2516895 :     case 1393:  /* *rotrqi3_1_zextdi_nf */
   13141      2516895 :     case 1391:  /* *rotlqi3_1_zextdi_nf */
   13142      2516895 :     case 1389:  /* *rotrqi3_1_zextsi_nf */
   13143      2516895 :     case 1387:  /* *rotlqi3_1_zextsi_nf */
   13144      2516895 :     case 1385:  /* *rotrqi3_1_zexthi_nf */
   13145      2516895 :     case 1383:  /* *rotlqi3_1_zexthi_nf */
   13146      2516895 :     case 1382:  /* *bmi2_rorxsi3_1_zext */
   13147      2516895 :     case 1236:  /* *ashrhi3_1_zextdi_nf */
   13148      2516895 :     case 1234:  /* *lshrhi3_1_zextdi_nf */
   13149      2516895 :     case 1232:  /* *ashrhi3_1_zextsi_nf */
   13150      2516895 :     case 1230:  /* *lshrhi3_1_zextsi_nf */
   13151      2516895 :     case 1228:  /* *ashrqi3_1_zextdi_nf */
   13152      2516895 :     case 1226:  /* *lshrqi3_1_zextdi_nf */
   13153      2516895 :     case 1224:  /* *ashrqi3_1_zextsi_nf */
   13154      2516895 :     case 1222:  /* *lshrqi3_1_zextsi_nf */
   13155      2516895 :     case 1220:  /* *ashrqi3_1_zexthi_nf */
   13156      2516895 :     case 1218:  /* *lshrqi3_1_zexthi_nf */
   13157      2516895 :     case 1217:  /* *bmi2_ashrsi3_1_zext */
   13158      2516895 :     case 1216:  /* *bmi2_lshrsi3_1_zext */
   13159      2516895 :     case 1169:  /* ashrti3_doubleword_lowpart_nf */
   13160      2516895 :     case 1168:  /* lshrti3_doubleword_lowpart_nf */
   13161      2516895 :     case 1167:  /* ashrdi3_doubleword_lowpart_nf */
   13162      2516895 :     case 1166:  /* lshrdi3_doubleword_lowpart_nf */
   13163      2516895 :     case 1133:  /* *ashlhi3_1_zextdi_nf */
   13164      2516895 :     case 1131:  /* *ashlhi3_1_zextsi_nf */
   13165      2516895 :     case 1129:  /* *ashlqi3_1_zextdi_nf */
   13166      2516895 :     case 1127:  /* *ashlqi3_1_zextsi_nf */
   13167      2516895 :     case 1125:  /* *ashlqi3_1_zexthi_nf */
   13168      2516895 :     case 1124:  /* *bmi2_ashlsi3_1_zext */
   13169      2516895 :     case 889:  /* *xorhi_1_zextdi_nf */
   13170      2516895 :     case 887:  /* *iorhi_1_zextdi_nf */
   13171      2516895 :     case 885:  /* *xorhi_1_zextsi_nf */
   13172      2516895 :     case 883:  /* *iorhi_1_zextsi_nf */
   13173      2516895 :     case 881:  /* *xorqi_1_zextdi_nf */
   13174      2516895 :     case 879:  /* *iorqi_1_zextdi_nf */
   13175      2516895 :     case 877:  /* *xorqi_1_zextsi_nf */
   13176      2516895 :     case 875:  /* *iorqi_1_zextsi_nf */
   13177      2516895 :     case 873:  /* *xorqi_1_zexthi_nf */
   13178      2516895 :     case 871:  /* *iorqi_1_zexthi_nf */
   13179      2516895 :     case 744:  /* *andhi_1_zextdi_nf */
   13180      2516895 :     case 742:  /* *andhi_1_zextsi_nf */
   13181      2516895 :     case 740:  /* *andqi_1_zextdi_nf */
   13182      2516895 :     case 738:  /* *andqi_1_zextsi_nf */
   13183      2516895 :     case 736:  /* *andqi_1_zexthi_nf */
   13184      2516895 :     case 628:  /* *mulsi3_1_zext_nf */
   13185      2516895 :     case 626:  /* *imulhidizu_nf */
   13186      2516895 :     case 624:  /* *imulhisizu_nf */
   13187      2516895 :     case 404:  /* *subhi_1_zextdi_nf */
   13188      2516895 :     case 402:  /* *subhi_1_zextsi_nf */
   13189      2516895 :     case 400:  /* *subqi_1_zextdi_nf */
   13190      2516895 :     case 398:  /* *subqi_1_zextsi_nf */
   13191      2516895 :     case 396:  /* *subqi_1_zexthi_nf */
   13192      2516895 :     case 298:  /* *addhi_1_zextdi_nf */
   13193      2516895 :     case 296:  /* *addhi_1_zextsi_nf */
   13194      2516895 :     case 294:  /* *addqi_1_zextdi_nf */
   13195      2516895 :     case 292:  /* *addqi_1_zextsi_nf */
   13196      2516895 :     case 290:  /* *addqi_1_zexthi_nf */
   13197      2516895 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   13198      2516895 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   13199      2516895 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   13200      2516895 :       break;
   13201              : 
   13202     21580019 :     case 10711:  /* avx10_2_divbf16_v8bf */
   13203     21580019 :     case 10709:  /* avx10_2_mulbf16_v8bf */
   13204     21580019 :     case 10707:  /* avx10_2_subbf16_v8bf */
   13205     21580019 :     case 10705:  /* avx10_2_addbf16_v8bf */
   13206     21580019 :     case 10703:  /* avx10_2_divbf16_v16bf */
   13207     21580019 :     case 10701:  /* avx10_2_mulbf16_v16bf */
   13208     21580019 :     case 10699:  /* avx10_2_subbf16_v16bf */
   13209     21580019 :     case 10697:  /* avx10_2_addbf16_v16bf */
   13210     21580019 :     case 10695:  /* avx10_2_divbf16_v32bf */
   13211     21580019 :     case 10693:  /* avx10_2_mulbf16_v32bf */
   13212     21580019 :     case 10691:  /* avx10_2_subbf16_v32bf */
   13213     21580019 :     case 10689:  /* avx10_2_addbf16_v32bf */
   13214     21580019 :     case 10687:  /* avx10_2_sminbf16_v8bf */
   13215     21580019 :     case 10685:  /* avx10_2_smaxbf16_v8bf */
   13216     21580019 :     case 10683:  /* avx10_2_sminbf16_v16bf */
   13217     21580019 :     case 10681:  /* avx10_2_smaxbf16_v16bf */
   13218     21580019 :     case 10679:  /* avx10_2_sminbf16_v32bf */
   13219     21580019 :     case 10677:  /* avx10_2_smaxbf16_v32bf */
   13220     21580019 :     case 9707:  /* avx_vec_concatv8df */
   13221     21580019 :     case 9706:  /* avx_vec_concatv16sf */
   13222     21580019 :     case 9705:  /* avx_vec_concatv8di */
   13223     21580019 :     case 9704:  /* avx_vec_concatv16si */
   13224     21580019 :     case 9703:  /* avx_vec_concatv32bf */
   13225     21580019 :     case 9702:  /* avx_vec_concatv32hf */
   13226     21580019 :     case 9701:  /* avx_vec_concatv32hi */
   13227     21580019 :     case 9700:  /* avx_vec_concatv64qi */
   13228     21580019 :     case 9699:  /* avx_vec_concatv4df */
   13229     21580019 :     case 9698:  /* avx_vec_concatv8sf */
   13230     21580019 :     case 9697:  /* avx_vec_concatv4di */
   13231     21580019 :     case 9696:  /* avx_vec_concatv8si */
   13232     21580019 :     case 9695:  /* avx_vec_concatv16bf */
   13233     21580019 :     case 9694:  /* avx_vec_concatv16hf */
   13234     21580019 :     case 9693:  /* avx_vec_concatv16hi */
   13235     21580019 :     case 9692:  /* avx_vec_concatv32qi */
   13236     21580019 :     case 9690:  /* avx512bw_lshrvv32hi */
   13237     21580019 :     case 9688:  /* avx512bw_ashlvv32hi */
   13238     21580019 :     case 9686:  /* avx512vl_lshrvv16hi */
   13239     21580019 :     case 9684:  /* avx512vl_ashlvv16hi */
   13240     21580019 :     case 9682:  /* avx512vl_lshrvv8hi */
   13241     21580019 :     case 9680:  /* avx512vl_ashlvv8hi */
   13242     21580019 :     case 9678:  /* avx2_lshrvv2di */
   13243     21580019 :     case 9676:  /* avx2_ashlvv2di */
   13244     21580019 :     case 9674:  /* avx2_lshrvv4di */
   13245     21580019 :     case 9672:  /* avx2_ashlvv4di */
   13246     21580019 :     case 9670:  /* avx512f_lshrvv8di */
   13247     21580019 :     case 9668:  /* avx512f_ashlvv8di */
   13248     21580019 :     case 9666:  /* avx2_lshrvv4si */
   13249     21580019 :     case 9664:  /* avx2_ashlvv4si */
   13250     21580019 :     case 9662:  /* avx2_lshrvv8si */
   13251     21580019 :     case 9660:  /* avx2_ashlvv8si */
   13252     21580019 :     case 9658:  /* avx512f_lshrvv16si */
   13253     21580019 :     case 9656:  /* avx512f_ashlvv16si */
   13254     21580019 :     case 9654:  /* avx512bw_ashrvv32hi */
   13255     21580019 :     case 9652:  /* avx512vl_ashrvv16hi */
   13256     21580019 :     case 9650:  /* avx512vl_ashrvv8hi */
   13257     21580019 :     case 9648:  /* avx512f_ashrvv8di */
   13258     21580019 :     case 9646:  /* avx2_ashrvv4di */
   13259     21580019 :     case 9644:  /* avx2_ashrvv2di */
   13260     21580019 :     case 9642:  /* avx512f_ashrvv16si */
   13261     21580019 :     case 9640:  /* avx2_ashrvv8si */
   13262     21580019 :     case 9638:  /* avx2_ashrvv4si */
   13263     21580019 :     case 9118:  /* *ashrv2di3 */
   13264     21580019 :     case 9105:  /* xop_rotrv2di3 */
   13265     21580019 :     case 9104:  /* xop_rotrv4si3 */
   13266     21580019 :     case 9103:  /* xop_rotrv8hi3 */
   13267     21580019 :     case 9102:  /* xop_rotrv16qi3 */
   13268     21580019 :     case 9101:  /* xop_rotlv2di3 */
   13269     21580019 :     case 9100:  /* xop_rotlv4si3 */
   13270     21580019 :     case 9099:  /* xop_rotlv8hi3 */
   13271     21580019 :     case 9098:  /* xop_rotlv16qi3 */
   13272     21580019 :     case 8546:  /* *vec_concatv2di_0 */
   13273     21580019 :     case 8545:  /* vec_concatv2di */
   13274     21580019 :     case 8544:  /* *vec_concatv4si_0 */
   13275     21580019 :     case 8543:  /* *vec_concatv8hi_0 */
   13276     21580019 :     case 8542:  /* *vec_concatv16qi_0 */
   13277     21580019 :     case 8539:  /* *vec_concatv4si */
   13278     21580019 :     case 8538:  /* *vec_concatv8hi */
   13279     21580019 :     case 8537:  /* *vec_concatv16qi */
   13280     21580019 :     case 8536:  /* *vec_concatv2si */
   13281     21580019 :     case 8535:  /* *vec_concatv2si_sse4_1 */
   13282     21580019 :     case 8116:  /* xorv1ti3 */
   13283     21580019 :     case 8115:  /* iorv1ti3 */
   13284     21580019 :     case 8114:  /* andv1ti3 */
   13285     21580019 :     case 8113:  /* *xorv8hi3 */
   13286     21580019 :     case 8112:  /* *iorv8hi3 */
   13287     21580019 :     case 8111:  /* *andv8hi3 */
   13288     21580019 :     case 8110:  /* *xorv16hi3 */
   13289     21580019 :     case 8109:  /* *iorv16hi3 */
   13290     21580019 :     case 8108:  /* *andv16hi3 */
   13291     21580019 :     case 8107:  /* *xorv32hi3 */
   13292     21580019 :     case 8106:  /* *iorv32hi3 */
   13293     21580019 :     case 8105:  /* *andv32hi3 */
   13294     21580019 :     case 8104:  /* *xorv16qi3 */
   13295     21580019 :     case 8103:  /* *iorv16qi3 */
   13296     21580019 :     case 8102:  /* *andv16qi3 */
   13297     21580019 :     case 8101:  /* *xorv32qi3 */
   13298     21580019 :     case 8100:  /* *iorv32qi3 */
   13299     21580019 :     case 8099:  /* *andv32qi3 */
   13300     21580019 :     case 8098:  /* *xorv64qi3 */
   13301     21580019 :     case 8097:  /* *iorv64qi3 */
   13302     21580019 :     case 8096:  /* *andv64qi3 */
   13303     21580019 :     case 8094:  /* *xorv2di3 */
   13304     21580019 :     case 8092:  /* *iorv2di3 */
   13305     21580019 :     case 8090:  /* *andv2di3 */
   13306     21580019 :     case 8088:  /* *xorv4di3 */
   13307     21580019 :     case 8086:  /* *iorv4di3 */
   13308     21580019 :     case 8084:  /* *andv4di3 */
   13309     21580019 :     case 8082:  /* *xorv8di3 */
   13310     21580019 :     case 8080:  /* *iorv8di3 */
   13311     21580019 :     case 8078:  /* *andv8di3 */
   13312     21580019 :     case 8076:  /* *xorv4si3 */
   13313     21580019 :     case 8074:  /* *iorv4si3 */
   13314     21580019 :     case 8072:  /* *andv4si3 */
   13315     21580019 :     case 8070:  /* *xorv8si3 */
   13316     21580019 :     case 8068:  /* *iorv8si3 */
   13317     21580019 :     case 8066:  /* *andv8si3 */
   13318     21580019 :     case 8064:  /* *xorv16si3 */
   13319     21580019 :     case 8062:  /* *iorv16si3 */
   13320     21580019 :     case 8060:  /* *andv16si3 */
   13321     21580019 :     case 8028:  /* *one_cmplv2di2 */
   13322     21580019 :     case 8026:  /* *one_cmplv4di2 */
   13323     21580019 :     case 8024:  /* *one_cmplv4si2 */
   13324     21580019 :     case 8022:  /* *one_cmplv8si2 */
   13325     21580019 :     case 8021:  /* *one_cmplv8hi2 */
   13326     21580019 :     case 8020:  /* *one_cmplv16hi2 */
   13327     21580019 :     case 8019:  /* *one_cmplv32hi2 */
   13328     21580019 :     case 8018:  /* *one_cmplv16qi2 */
   13329     21580019 :     case 8017:  /* *one_cmplv32qi2 */
   13330     21580019 :     case 8016:  /* *one_cmplv64qi2 */
   13331     21580019 :     case 8014:  /* *one_cmplv8di2 */
   13332     21580019 :     case 8012:  /* *one_cmplv16si2 */
   13333     21580019 :     case 8011:  /* *sse2_gtv4si3 */
   13334     21580019 :     case 8010:  /* *sse2_gtv8hi3 */
   13335     21580019 :     case 8009:  /* *sse2_gtv16qi3 */
   13336     21580019 :     case 8008:  /* avx2_gtv4di3 */
   13337     21580019 :     case 8007:  /* avx2_gtv8si3 */
   13338     21580019 :     case 8006:  /* avx2_gtv16hi3 */
   13339     21580019 :     case 8005:  /* avx2_gtv32qi3 */
   13340     21580019 :     case 8004:  /* sse4_2_gtv2di3 */
   13341     21580019 :     case 8003:  /* *sse2_eqv4si3 */
   13342     21580019 :     case 8002:  /* *sse2_eqv8hi3 */
   13343     21580019 :     case 8001:  /* *sse2_eqv16qi3 */
   13344     21580019 :     case 8000:  /* *sse4_1_eqv2di3 */
   13345     21580019 :     case 7937:  /* *avx2_eqv4di3 */
   13346     21580019 :     case 7936:  /* *avx2_eqv8si3 */
   13347     21580019 :     case 7935:  /* *avx2_eqv16hi3 */
   13348     21580019 :     case 7934:  /* *avx2_eqv32qi3 */
   13349     21580019 :     case 7933:  /* *uminv16qi3 */
   13350     21580019 :     case 7932:  /* *umaxv16qi3 */
   13351     21580019 :     case 7930:  /* *sse4_1_uminv4si3 */
   13352     21580019 :     case 7928:  /* *sse4_1_umaxv4si3 */
   13353     21580019 :     case 7926:  /* *sse4_1_uminv8hi3 */
   13354     21580019 :     case 7924:  /* *sse4_1_umaxv8hi3 */
   13355     21580019 :     case 7923:  /* *sminv8hi3 */
   13356     21580019 :     case 7922:  /* *smaxv8hi3 */
   13357     21580019 :     case 7920:  /* *sse4_1_sminv4si3 */
   13358     21580019 :     case 7918:  /* *sse4_1_smaxv4si3 */
   13359     21580019 :     case 7916:  /* *sse4_1_sminv16qi3 */
   13360     21580019 :     case 7914:  /* *sse4_1_smaxv16qi3 */
   13361     21580019 :     case 7912:  /* *avx512bw_uminv8hi3 */
   13362     21580019 :     case 7910:  /* *avx512bw_umaxv8hi3 */
   13363     21580019 :     case 7908:  /* *avx512bw_sminv8hi3 */
   13364     21580019 :     case 7906:  /* *avx512bw_smaxv8hi3 */
   13365     21580019 :     case 7904:  /* *avx512bw_uminv16hi3 */
   13366     21580019 :     case 7902:  /* *avx512bw_umaxv16hi3 */
   13367     21580019 :     case 7900:  /* *avx512bw_sminv16hi3 */
   13368     21580019 :     case 7898:  /* *avx512bw_smaxv16hi3 */
   13369     21580019 :     case 7896:  /* *avx512bw_uminv32hi3 */
   13370     21580019 :     case 7894:  /* *avx512bw_umaxv32hi3 */
   13371     21580019 :     case 7892:  /* *avx512bw_sminv32hi3 */
   13372     21580019 :     case 7890:  /* *avx512bw_smaxv32hi3 */
   13373     21580019 :     case 7888:  /* *avx512bw_uminv32qi3 */
   13374     21580019 :     case 7886:  /* *avx512bw_umaxv32qi3 */
   13375     21580019 :     case 7884:  /* *avx512bw_sminv32qi3 */
   13376     21580019 :     case 7882:  /* *avx512bw_smaxv32qi3 */
   13377     21580019 :     case 7880:  /* *avx512bw_uminv16qi3 */
   13378     21580019 :     case 7878:  /* *avx512bw_umaxv16qi3 */
   13379     21580019 :     case 7876:  /* *avx512bw_sminv16qi3 */
   13380     21580019 :     case 7874:  /* *avx512bw_smaxv16qi3 */
   13381     21580019 :     case 7872:  /* *avx512bw_uminv64qi3 */
   13382     21580019 :     case 7870:  /* *avx512bw_umaxv64qi3 */
   13383     21580019 :     case 7868:  /* *avx512bw_sminv64qi3 */
   13384     21580019 :     case 7866:  /* *avx512bw_smaxv64qi3 */
   13385     21580019 :     case 7864:  /* *avx512f_uminv2di3 */
   13386     21580019 :     case 7862:  /* *avx512f_umaxv2di3 */
   13387     21580019 :     case 7860:  /* *avx512f_sminv2di3 */
   13388     21580019 :     case 7858:  /* *avx512f_smaxv2di3 */
   13389     21580019 :     case 7856:  /* *avx512f_uminv4di3 */
   13390     21580019 :     case 7854:  /* *avx512f_umaxv4di3 */
   13391     21580019 :     case 7852:  /* *avx512f_sminv4di3 */
   13392     21580019 :     case 7850:  /* *avx512f_smaxv4di3 */
   13393     21580019 :     case 7848:  /* *avx512f_uminv8di3 */
   13394     21580019 :     case 7846:  /* *avx512f_umaxv8di3 */
   13395     21580019 :     case 7844:  /* *avx512f_sminv8di3 */
   13396     21580019 :     case 7842:  /* *avx512f_smaxv8di3 */
   13397     21580019 :     case 7840:  /* *avx512f_uminv4si3 */
   13398     21580019 :     case 7838:  /* *avx512f_umaxv4si3 */
   13399     21580019 :     case 7836:  /* *avx512f_sminv4si3 */
   13400     21580019 :     case 7834:  /* *avx512f_smaxv4si3 */
   13401     21580019 :     case 7832:  /* *avx512f_uminv8si3 */
   13402     21580019 :     case 7830:  /* *avx512f_umaxv8si3 */
   13403     21580019 :     case 7828:  /* *avx512f_sminv8si3 */
   13404     21580019 :     case 7826:  /* *avx512f_smaxv8si3 */
   13405     21580019 :     case 7824:  /* *avx512f_uminv16si3 */
   13406     21580019 :     case 7822:  /* *avx512f_umaxv16si3 */
   13407     21580019 :     case 7820:  /* *avx512f_sminv16si3 */
   13408     21580019 :     case 7818:  /* *avx512f_smaxv16si3 */
   13409     21580019 :     case 7817:  /* *avx2_uminv8si3 */
   13410     21580019 :     case 7816:  /* *avx2_umaxv8si3 */
   13411     21580019 :     case 7815:  /* *avx2_sminv8si3 */
   13412     21580019 :     case 7814:  /* *avx2_smaxv8si3 */
   13413     21580019 :     case 7813:  /* *avx2_uminv16hi3 */
   13414     21580019 :     case 7812:  /* *avx2_umaxv16hi3 */
   13415     21580019 :     case 7811:  /* *avx2_sminv16hi3 */
   13416     21580019 :     case 7810:  /* *avx2_smaxv16hi3 */
   13417     21580019 :     case 7809:  /* *avx2_uminv32qi3 */
   13418     21580019 :     case 7808:  /* *avx2_umaxv32qi3 */
   13419     21580019 :     case 7807:  /* *avx2_sminv32qi3 */
   13420     21580019 :     case 7806:  /* *avx2_smaxv32qi3 */
   13421     21580019 :     case 7804:  /* avx512vl_rorv2di */
   13422     21580019 :     case 7802:  /* avx512vl_rolv2di */
   13423     21580019 :     case 7800:  /* avx512vl_rorv4di */
   13424     21580019 :     case 7798:  /* avx512vl_rolv4di */
   13425     21580019 :     case 7796:  /* avx512f_rorv8di */
   13426     21580019 :     case 7794:  /* avx512f_rolv8di */
   13427     21580019 :     case 7792:  /* avx512vl_rorv4si */
   13428     21580019 :     case 7790:  /* avx512vl_rolv4si */
   13429     21580019 :     case 7788:  /* avx512vl_rorv8si */
   13430     21580019 :     case 7786:  /* avx512vl_rolv8si */
   13431     21580019 :     case 7784:  /* avx512f_rorv16si */
   13432     21580019 :     case 7782:  /* avx512f_rolv16si */
   13433     21580019 :     case 7780:  /* avx512vl_rorvv2di */
   13434     21580019 :     case 7778:  /* avx512vl_rolvv2di */
   13435     21580019 :     case 7776:  /* avx512vl_rorvv4di */
   13436     21580019 :     case 7774:  /* avx512vl_rolvv4di */
   13437     21580019 :     case 7772:  /* avx512f_rorvv8di */
   13438     21580019 :     case 7770:  /* avx512f_rolvv8di */
   13439     21580019 :     case 7768:  /* avx512vl_rorvv4si */
   13440     21580019 :     case 7766:  /* avx512vl_rolvv4si */
   13441     21580019 :     case 7764:  /* avx512vl_rorvv8si */
   13442     21580019 :     case 7762:  /* avx512vl_rolvv8si */
   13443     21580019 :     case 7760:  /* avx512f_rorvv16si */
   13444     21580019 :     case 7758:  /* avx512f_rolvv16si */
   13445     21580019 :     case 7757:  /* sse2_lshrv1ti3 */
   13446     21580019 :     case 7756:  /* sse2_ashlv1ti3 */
   13447     21580019 :     case 7755:  /* avx2_lshrv2ti3 */
   13448     21580019 :     case 7754:  /* avx2_ashlv2ti3 */
   13449     21580019 :     case 7753:  /* avx512bw_lshrv1ti3 */
   13450     21580019 :     case 7752:  /* avx512bw_ashlv1ti3 */
   13451     21580019 :     case 7751:  /* avx512bw_lshrv2ti3 */
   13452     21580019 :     case 7750:  /* avx512bw_ashlv2ti3 */
   13453     21580019 :     case 7749:  /* avx512bw_lshrv4ti3 */
   13454     21580019 :     case 7748:  /* avx512bw_ashlv4ti3 */
   13455     21580019 :     case 7747:  /* *rotrv1ti3_internal */
   13456     21580019 :     case 7746:  /* *rotlv1ti3_internal */
   13457     21580019 :     case 7745:  /* *ashrv1ti3_internal */
   13458     21580019 :     case 7744:  /* *lshrv1ti3_internal */
   13459     21580019 :     case 7743:  /* *ashlv1ti3_internal */
   13460     21580019 :     case 7741:  /* lshrv8di3 */
   13461     21580019 :     case 7739:  /* ashlv8di3 */
   13462     21580019 :     case 7737:  /* lshrv16si3 */
   13463     21580019 :     case 7735:  /* ashlv16si3 */
   13464     21580019 :     case 7733:  /* lshrv32hi3 */
   13465     21580019 :     case 7731:  /* ashlv32hi3 */
   13466     21580019 :     case 7726:  /* lshrv2di3 */
   13467     21580019 :     case 7725:  /* ashlv2di3 */
   13468     21580019 :     case 7724:  /* lshrv4di3 */
   13469     21580019 :     case 7723:  /* ashlv4di3 */
   13470     21580019 :     case 7722:  /* lshrv4si3 */
   13471     21580019 :     case 7721:  /* ashlv4si3 */
   13472     21580019 :     case 7720:  /* lshrv8si3 */
   13473     21580019 :     case 7719:  /* ashlv8si3 */
   13474     21580019 :     case 7718:  /* lshrv8hi3 */
   13475     21580019 :     case 7717:  /* ashlv8hi3 */
   13476     21580019 :     case 7716:  /* lshrv16hi3 */
   13477     21580019 :     case 7715:  /* ashlv16hi3 */
   13478     21580019 :     case 7713:  /* *lshrv2di3 */
   13479     21580019 :     case 7711:  /* *ashlv2di3 */
   13480     21580019 :     case 7709:  /* *lshrv4di3 */
   13481     21580019 :     case 7707:  /* *ashlv4di3 */
   13482     21580019 :     case 7705:  /* *lshrv4si3 */
   13483     21580019 :     case 7703:  /* *ashlv4si3 */
   13484     21580019 :     case 7701:  /* *lshrv8si3 */
   13485     21580019 :     case 7699:  /* *ashlv8si3 */
   13486     21580019 :     case 7697:  /* *lshrv8hi3 */
   13487     21580019 :     case 7695:  /* *ashlv8hi3 */
   13488     21580019 :     case 7693:  /* *lshrv16hi3 */
   13489     21580019 :     case 7691:  /* *ashlv16hi3 */
   13490     21580019 :     case 7680:  /* *ashrv8di3 */
   13491     21580019 :     case 7678:  /* *ashrv16si3 */
   13492     21580019 :     case 7676:  /* *ashrv4di3 */
   13493     21580019 :     case 7674:  /* *ashrv32hi3 */
   13494     21580019 :     case 7673:  /* *ashrv4si3_1 */
   13495     21580019 :     case 7672:  /* *ashrv8si3_1 */
   13496     21580019 :     case 7671:  /* *ashrv8hi3_1 */
   13497     21580019 :     case 7670:  /* *ashrv16hi3_1 */
   13498     21580019 :     case 7669:  /* ashrv4si3 */
   13499     21580019 :     case 7668:  /* ashrv8si3 */
   13500     21580019 :     case 7667:  /* ashrv8hi3 */
   13501     21580019 :     case 7666:  /* ashrv16hi3 */
   13502     21580019 :     case 7664:  /* *ashrv2di3 */
   13503     21580019 :     case 7662:  /* *ashrv4si3 */
   13504     21580019 :     case 7660:  /* *ashrv8si3 */
   13505     21580019 :     case 7658:  /* *ashrv8hi3 */
   13506     21580019 :     case 7656:  /* *ashrv16hi3 */
   13507     21580019 :     case 7654:  /* *sse4_1_mulv4si3 */
   13508     21580019 :     case 7652:  /* *avx2_mulv8si3 */
   13509     21580019 :     case 7650:  /* *avx512f_mulv16si3 */
   13510     21580019 :     case 7648:  /* *avx512dq_mulv2di3 */
   13511     21580019 :     case 7646:  /* *avx512dq_mulv4di3 */
   13512     21580019 :     case 7644:  /* *avx512dq_mulv8di3 */
   13513     21580019 :     case 7610:  /* *mulv8hi3 */
   13514     21580019 :     case 7608:  /* *mulv16hi3 */
   13515     21580019 :     case 7606:  /* *mulv32hi3 */
   13516     21580019 :     case 7604:  /* *sse2_ussubv8hi3 */
   13517     21580019 :     case 7602:  /* *sse2_sssubv8hi3 */
   13518     21580019 :     case 7600:  /* *sse2_usaddv8hi3 */
   13519     21580019 :     case 7598:  /* *sse2_ssaddv8hi3 */
   13520     21580019 :     case 7596:  /* *avx2_ussubv16hi3 */
   13521     21580019 :     case 7594:  /* *avx2_sssubv16hi3 */
   13522     21580019 :     case 7592:  /* *avx2_usaddv16hi3 */
   13523     21580019 :     case 7590:  /* *avx2_ssaddv16hi3 */
   13524     21580019 :     case 7588:  /* *avx512bw_ussubv32hi3 */
   13525     21580019 :     case 7586:  /* *avx512bw_sssubv32hi3 */
   13526     21580019 :     case 7584:  /* *avx512bw_usaddv32hi3 */
   13527     21580019 :     case 7582:  /* *avx512bw_ssaddv32hi3 */
   13528     21580019 :     case 7580:  /* *sse2_ussubv16qi3 */
   13529     21580019 :     case 7578:  /* *sse2_sssubv16qi3 */
   13530     21580019 :     case 7576:  /* *sse2_usaddv16qi3 */
   13531     21580019 :     case 7574:  /* *sse2_ssaddv16qi3 */
   13532     21580019 :     case 7572:  /* *avx2_ussubv32qi3 */
   13533     21580019 :     case 7570:  /* *avx2_sssubv32qi3 */
   13534     21580019 :     case 7568:  /* *avx2_usaddv32qi3 */
   13535     21580019 :     case 7566:  /* *avx2_ssaddv32qi3 */
   13536     21580019 :     case 7564:  /* *avx512bw_ussubv64qi3 */
   13537     21580019 :     case 7562:  /* *avx512bw_sssubv64qi3 */
   13538     21580019 :     case 7560:  /* *avx512bw_usaddv64qi3 */
   13539     21580019 :     case 7558:  /* *avx512bw_ssaddv64qi3 */
   13540     21580019 :     case 7557:  /* *subv2di3_one */
   13541     21580019 :     case 7556:  /* *subv4di3_one */
   13542     21580019 :     case 7555:  /* *subv8di3_one */
   13543     21580019 :     case 7554:  /* *subv4si3_one */
   13544     21580019 :     case 7553:  /* *subv8si3_one */
   13545     21580019 :     case 7552:  /* *subv16si3_one */
   13546     21580019 :     case 7551:  /* *subv8hi3_one */
   13547     21580019 :     case 7550:  /* *subv16hi3_one */
   13548     21580019 :     case 7549:  /* *subv32hi3_one */
   13549     21580019 :     case 7548:  /* *subv16qi3_one */
   13550     21580019 :     case 7547:  /* *subv32qi3_one */
   13551     21580019 :     case 7546:  /* *subv64qi3_one */
   13552     21580019 :     case 7545:  /* *addv2di3_one */
   13553     21580019 :     case 7544:  /* *addv4di3_one */
   13554     21580019 :     case 7543:  /* *addv8di3_one */
   13555     21580019 :     case 7542:  /* *addv4si3_one */
   13556     21580019 :     case 7541:  /* *addv8si3_one */
   13557     21580019 :     case 7540:  /* *addv16si3_one */
   13558     21580019 :     case 7539:  /* *addv8hi3_one */
   13559     21580019 :     case 7538:  /* *addv16hi3_one */
   13560     21580019 :     case 7537:  /* *addv32hi3_one */
   13561     21580019 :     case 7536:  /* *addv16qi3_one */
   13562     21580019 :     case 7535:  /* *addv32qi3_one */
   13563     21580019 :     case 7534:  /* *addv64qi3_one */
   13564     21580019 :     case 7509:  /* *subv2di3 */
   13565     21580019 :     case 7508:  /* *addv2di3 */
   13566     21580019 :     case 7507:  /* *subv4di3 */
   13567     21580019 :     case 7506:  /* *addv4di3 */
   13568     21580019 :     case 7505:  /* *subv8di3 */
   13569     21580019 :     case 7504:  /* *addv8di3 */
   13570     21580019 :     case 7503:  /* *subv4si3 */
   13571     21580019 :     case 7502:  /* *addv4si3 */
   13572     21580019 :     case 7501:  /* *subv8si3 */
   13573     21580019 :     case 7500:  /* *addv8si3 */
   13574     21580019 :     case 7499:  /* *subv16si3 */
   13575     21580019 :     case 7498:  /* *addv16si3 */
   13576     21580019 :     case 7497:  /* *subv8hi3 */
   13577     21580019 :     case 7496:  /* *addv8hi3 */
   13578     21580019 :     case 7495:  /* *subv16hi3 */
   13579     21580019 :     case 7494:  /* *addv16hi3 */
   13580     21580019 :     case 7493:  /* *subv32hi3 */
   13581     21580019 :     case 7492:  /* *addv32hi3 */
   13582     21580019 :     case 7491:  /* *subv16qi3 */
   13583     21580019 :     case 7490:  /* *addv16qi3 */
   13584     21580019 :     case 7489:  /* *subv32qi3 */
   13585     21580019 :     case 7488:  /* *addv32qi3 */
   13586     21580019 :     case 7487:  /* *subv64qi3 */
   13587     21580019 :     case 7486:  /* *addv64qi3 */
   13588     21580019 :     case 7244:  /* vec_concatv2df */
   13589     21580019 :     case 5294:  /* *vec_concatv8bf_0 */
   13590     21580019 :     case 5293:  /* *vec_concatv8hf_0 */
   13591     21580019 :     case 5292:  /* *vec_concatv4sf_0 */
   13592     21580019 :     case 5291:  /* *vec_concatv8bf */
   13593     21580019 :     case 5290:  /* *vec_concatv8hf */
   13594     21580019 :     case 5289:  /* *vec_concatv4sf */
   13595     21580019 :     case 5288:  /* *vec_concatv2sf_sse */
   13596     21580019 :     case 5287:  /* *vec_concatv2sf_sse4_1 */
   13597     21580019 :     case 3856:  /* *xortf3 */
   13598     21580019 :     case 3855:  /* *iortf3 */
   13599     21580019 :     case 3854:  /* *andtf3 */
   13600     21580019 :     case 3853:  /* xordf3 */
   13601     21580019 :     case 3852:  /* iordf3 */
   13602     21580019 :     case 3851:  /* anddf3 */
   13603     21580019 :     case 3850:  /* xorsf3 */
   13604     21580019 :     case 3849:  /* iorsf3 */
   13605     21580019 :     case 3848:  /* andsf3 */
   13606     21580019 :     case 3847:  /* xorhf3 */
   13607     21580019 :     case 3846:  /* iorhf3 */
   13608     21580019 :     case 3845:  /* andhf3 */
   13609     21580019 :     case 3844:  /* xorbf3 */
   13610     21580019 :     case 3843:  /* iorbf3 */
   13611     21580019 :     case 3842:  /* andbf3 */
   13612     21580019 :     case 3835:  /* *bit_and_float_vector_all_ones */
   13613     21580019 :     case 3834:  /* *bit_and_float_vector_all_ones */
   13614     21580019 :     case 3833:  /* *bit_and_float_vector_all_ones */
   13615     21580019 :     case 3832:  /* *bit_and_float_vector_all_ones */
   13616     21580019 :     case 3831:  /* *bit_and_float_vector_all_ones */
   13617     21580019 :     case 3830:  /* *bit_and_float_vector_all_ones */
   13618     21580019 :     case 3829:  /* *bit_and_float_vector_all_ones */
   13619     21580019 :     case 3828:  /* *bit_and_float_vector_all_ones */
   13620     21580019 :     case 3827:  /* *bit_and_float_vector_all_ones */
   13621     21580019 :     case 3826:  /* *bit_and_float_vector_all_ones */
   13622     21580019 :     case 3825:  /* *bit_and_float_vector_all_ones */
   13623     21580019 :     case 3824:  /* *bit_and_float_vector_all_ones */
   13624     21580019 :     case 3822:  /* *xorv8df3 */
   13625     21580019 :     case 3820:  /* *iorv8df3 */
   13626     21580019 :     case 3818:  /* *andv8df3 */
   13627     21580019 :     case 3816:  /* *xorv16sf3 */
   13628     21580019 :     case 3814:  /* *iorv16sf3 */
   13629     21580019 :     case 3812:  /* *andv16sf3 */
   13630     21580019 :     case 3811:  /* *xorv32hf3 */
   13631     21580019 :     case 3810:  /* *iorv32hf3 */
   13632     21580019 :     case 3809:  /* *andv32hf3 */
   13633     21580019 :     case 3808:  /* *xorv32bf3 */
   13634     21580019 :     case 3807:  /* *iorv32bf3 */
   13635     21580019 :     case 3806:  /* *andv32bf3 */
   13636     21580019 :     case 3804:  /* *xorv2df3 */
   13637     21580019 :     case 3802:  /* *iorv2df3 */
   13638     21580019 :     case 3800:  /* *andv2df3 */
   13639     21580019 :     case 3798:  /* *xorv4df3 */
   13640     21580019 :     case 3796:  /* *iorv4df3 */
   13641     21580019 :     case 3794:  /* *andv4df3 */
   13642     21580019 :     case 3792:  /* *xorv4sf3 */
   13643     21580019 :     case 3790:  /* *iorv4sf3 */
   13644     21580019 :     case 3788:  /* *andv4sf3 */
   13645     21580019 :     case 3786:  /* *xorv8sf3 */
   13646     21580019 :     case 3784:  /* *iorv8sf3 */
   13647     21580019 :     case 3782:  /* *andv8sf3 */
   13648     21580019 :     case 3781:  /* *xorv8hf3 */
   13649     21580019 :     case 3780:  /* *iorv8hf3 */
   13650     21580019 :     case 3779:  /* *andv8hf3 */
   13651     21580019 :     case 3778:  /* *xorv16hf3 */
   13652     21580019 :     case 3777:  /* *iorv16hf3 */
   13653     21580019 :     case 3776:  /* *andv16hf3 */
   13654     21580019 :     case 3775:  /* *xorv8bf3 */
   13655     21580019 :     case 3774:  /* *iorv8bf3 */
   13656     21580019 :     case 3773:  /* *andv8bf3 */
   13657     21580019 :     case 3772:  /* *xorv16bf3 */
   13658     21580019 :     case 3771:  /* *iorv16bf3 */
   13659     21580019 :     case 3770:  /* *andv16bf3 */
   13660     21580019 :     case 3082:  /* *sminv2df3 */
   13661     21580019 :     case 3080:  /* *smaxv2df3 */
   13662     21580019 :     case 3078:  /* *sminv4df3 */
   13663     21580019 :     case 3076:  /* *smaxv4df3 */
   13664     21580019 :     case 3072:  /* *sminv8df3 */
   13665     21580019 :     case 3068:  /* *smaxv8df3 */
   13666     21580019 :     case 3066:  /* *sminv4sf3 */
   13667     21580019 :     case 3064:  /* *smaxv4sf3 */
   13668     21580019 :     case 3062:  /* *sminv8sf3 */
   13669     21580019 :     case 3060:  /* *smaxv8sf3 */
   13670     21580019 :     case 3056:  /* *sminv16sf3 */
   13671     21580019 :     case 3052:  /* *smaxv16sf3 */
   13672     21580019 :     case 3050:  /* *sminv8hf3 */
   13673     21580019 :     case 3048:  /* *smaxv8hf3 */
   13674     21580019 :     case 3046:  /* *sminv16hf3 */
   13675     21580019 :     case 3044:  /* *smaxv16hf3 */
   13676     21580019 :     case 3040:  /* *sminv32hf3 */
   13677     21580019 :     case 3036:  /* *smaxv32hf3 */
   13678     21580019 :     case 2927:  /* sse2_divv2df3 */
   13679     21580019 :     case 2925:  /* avx_divv4df3 */
   13680     21580019 :     case 2921:  /* avx512f_divv8df3 */
   13681     21580019 :     case 2919:  /* sse_divv4sf3 */
   13682     21580019 :     case 2917:  /* avx_divv8sf3 */
   13683     21580019 :     case 2913:  /* avx512f_divv16sf3 */
   13684     21580019 :     case 2911:  /* avx512fp16_divv8hf3 */
   13685     21580019 :     case 2909:  /* avx512fp16_divv16hf3 */
   13686     21580019 :     case 2905:  /* avx512fp16_divv32hf3 */
   13687     21580019 :     case 2871:  /* *mulv2df3 */
   13688     21580019 :     case 2867:  /* *mulv4df3 */
   13689     21580019 :     case 2863:  /* *mulv8df3 */
   13690     21580019 :     case 2859:  /* *mulv4sf3 */
   13691     21580019 :     case 2855:  /* *mulv8sf3 */
   13692     21580019 :     case 2851:  /* *mulv16sf3 */
   13693     21580019 :     case 2847:  /* *mulv8hf3 */
   13694     21580019 :     case 2843:  /* *mulv16hf3 */
   13695     21580019 :     case 2839:  /* *mulv32hf3 */
   13696     21580019 :     case 2805:  /* *subv2df3 */
   13697     21580019 :     case 2801:  /* *addv2df3 */
   13698     21580019 :     case 2797:  /* *subv4df3 */
   13699     21580019 :     case 2793:  /* *addv4df3 */
   13700     21580019 :     case 2789:  /* *subv8df3 */
   13701     21580019 :     case 2785:  /* *addv8df3 */
   13702     21580019 :     case 2781:  /* *subv4sf3 */
   13703     21580019 :     case 2777:  /* *addv4sf3 */
   13704     21580019 :     case 2773:  /* *subv8sf3 */
   13705     21580019 :     case 2769:  /* *addv8sf3 */
   13706     21580019 :     case 2765:  /* *subv16sf3 */
   13707     21580019 :     case 2761:  /* *addv16sf3 */
   13708     21580019 :     case 2757:  /* *subv8hf3 */
   13709     21580019 :     case 2753:  /* *addv8hf3 */
   13710     21580019 :     case 2749:  /* *subv16hf3 */
   13711     21580019 :     case 2745:  /* *addv16hf3 */
   13712     21580019 :     case 2741:  /* *subv32hf3 */
   13713     21580019 :     case 2737:  /* *addv32hf3 */
   13714     21580019 :     case 2611:  /* *sse2_movq128_v2df_1 */
   13715     21580019 :     case 2610:  /* *sse2_movq128_v2di_1 */
   13716     21580019 :     case 2396:  /* *mmx_concatv2si */
   13717     21580019 :     case 2330:  /* *mmx_xorv2si3 */
   13718     21580019 :     case 2329:  /* *mmx_iorv2si3 */
   13719     21580019 :     case 2328:  /* *mmx_andv2si3 */
   13720     21580019 :     case 2327:  /* *mmx_xorv4hi3 */
   13721     21580019 :     case 2326:  /* *mmx_iorv4hi3 */
   13722     21580019 :     case 2325:  /* *mmx_andv4hi3 */
   13723     21580019 :     case 2324:  /* *mmx_xorv8qi3 */
   13724     21580019 :     case 2323:  /* *mmx_iorv8qi3 */
   13725     21580019 :     case 2322:  /* *mmx_andv8qi3 */
   13726     21580019 :     case 2276:  /* *gtv2hi3 */
   13727     21580019 :     case 2275:  /* *gtv2qi3 */
   13728     21580019 :     case 2274:  /* *gtv4qi3 */
   13729     21580019 :     case 2273:  /* mmx_gtv2si3 */
   13730     21580019 :     case 2272:  /* mmx_gtv4hi3 */
   13731     21580019 :     case 2271:  /* mmx_gtv8qi3 */
   13732     21580019 :     case 2270:  /* *eqv2hi3 */
   13733     21580019 :     case 2269:  /* *eqv2qi3 */
   13734     21580019 :     case 2268:  /* *eqv4qi3 */
   13735     21580019 :     case 2267:  /* *mmx_eqv2si3 */
   13736     21580019 :     case 2266:  /* *mmx_eqv4hi3 */
   13737     21580019 :     case 2265:  /* *mmx_eqv8qi3 */
   13738     21580019 :     case 2261:  /* *mmx_ashrv2hi3_1 */
   13739     21580019 :     case 2260:  /* ashrv2hi3 */
   13740     21580019 :     case 2259:  /* lshrv2hi3 */
   13741     21580019 :     case 2258:  /* ashlv2hi3 */
   13742     21580019 :     case 2257:  /* mmx_lshrv1si3 */
   13743     21580019 :     case 2256:  /* mmx_ashlv1si3 */
   13744     21580019 :     case 2255:  /* mmx_lshrv1di3 */
   13745     21580019 :     case 2254:  /* mmx_ashlv1di3 */
   13746     21580019 :     case 2253:  /* mmx_lshrv2si3 */
   13747     21580019 :     case 2252:  /* mmx_ashlv2si3 */
   13748     21580019 :     case 2251:  /* mmx_lshrv4hi3 */
   13749     21580019 :     case 2250:  /* mmx_ashlv4hi3 */
   13750     21580019 :     case 2249:  /* *mmx_ashrv2si3_1 */
   13751     21580019 :     case 2248:  /* *mmx_ashrv4hi3_1 */
   13752     21580019 :     case 2247:  /* mmx_ashrv2si3 */
   13753     21580019 :     case 2246:  /* mmx_ashrv4hi3 */
   13754     21580019 :     case 2239:  /* uminv2hi3 */
   13755     21580019 :     case 2238:  /* umaxv2hi3 */
   13756     21580019 :     case 2237:  /* uminv2qi3 */
   13757     21580019 :     case 2236:  /* umaxv2qi3 */
   13758     21580019 :     case 2235:  /* uminv4qi3 */
   13759     21580019 :     case 2234:  /* umaxv4qi3 */
   13760     21580019 :     case 2233:  /* *mmx_uminv8qi3 */
   13761     21580019 :     case 2232:  /* *mmx_umaxv8qi3 */
   13762     21580019 :     case 2231:  /* uminv2si3 */
   13763     21580019 :     case 2230:  /* umaxv2si3 */
   13764     21580019 :     case 2229:  /* uminv4hi3 */
   13765     21580019 :     case 2228:  /* umaxv4hi3 */
   13766     21580019 :     case 2227:  /* sminv2hi3 */
   13767     21580019 :     case 2226:  /* smaxv2hi3 */
   13768     21580019 :     case 2225:  /* sminv2qi3 */
   13769     21580019 :     case 2224:  /* smaxv2qi3 */
   13770     21580019 :     case 2223:  /* sminv4qi3 */
   13771     21580019 :     case 2222:  /* smaxv4qi3 */
   13772     21580019 :     case 2221:  /* *mmx_sminv4hi3 */
   13773     21580019 :     case 2220:  /* *mmx_smaxv4hi3 */
   13774     21580019 :     case 2219:  /* sminv2si3 */
   13775     21580019 :     case 2218:  /* smaxv2si3 */
   13776     21580019 :     case 2217:  /* sminv8qi3 */
   13777     21580019 :     case 2216:  /* smaxv8qi3 */
   13778     21580019 :     case 2208:  /* mulv2hi3 */
   13779     21580019 :     case 2207:  /* *mmx_mulv4hi3 */
   13780     21580019 :     case 2206:  /* mulv2si3 */
   13781     21580019 :     case 2205:  /* ussubv2hi3 */
   13782     21580019 :     case 2204:  /* sssubv2hi3 */
   13783     21580019 :     case 2203:  /* usaddv2hi3 */
   13784     21580019 :     case 2202:  /* ssaddv2hi3 */
   13785     21580019 :     case 2201:  /* ussubv2qi3 */
   13786     21580019 :     case 2200:  /* sssubv2qi3 */
   13787     21580019 :     case 2199:  /* usaddv2qi3 */
   13788     21580019 :     case 2198:  /* ssaddv2qi3 */
   13789     21580019 :     case 2197:  /* ussubv4qi3 */
   13790     21580019 :     case 2196:  /* sssubv4qi3 */
   13791     21580019 :     case 2195:  /* usaddv4qi3 */
   13792     21580019 :     case 2194:  /* ssaddv4qi3 */
   13793     21580019 :     case 2193:  /* *mmx_ussubv4hi3 */
   13794     21580019 :     case 2192:  /* *mmx_sssubv4hi3 */
   13795     21580019 :     case 2191:  /* *mmx_usaddv4hi3 */
   13796     21580019 :     case 2190:  /* *mmx_ssaddv4hi3 */
   13797     21580019 :     case 2189:  /* *mmx_ussubv8qi3 */
   13798     21580019 :     case 2188:  /* *mmx_sssubv8qi3 */
   13799     21580019 :     case 2187:  /* *mmx_usaddv8qi3 */
   13800     21580019 :     case 2186:  /* *mmx_ssaddv8qi3 */
   13801     21580019 :     case 2183:  /* subv2hi3 */
   13802     21580019 :     case 2182:  /* addv2hi3 */
   13803     21580019 :     case 2181:  /* subv4qi3 */
   13804     21580019 :     case 2180:  /* addv4qi3 */
   13805     21580019 :     case 2179:  /* *mmx_subv1di3 */
   13806     21580019 :     case 2178:  /* *mmx_addv1di3 */
   13807     21580019 :     case 2177:  /* *mmx_subv2si3 */
   13808     21580019 :     case 2176:  /* *mmx_addv2si3 */
   13809     21580019 :     case 2175:  /* *mmx_subv4hi3 */
   13810     21580019 :     case 2174:  /* *mmx_addv4hi3 */
   13811     21580019 :     case 2173:  /* *mmx_subv8qi3 */
   13812     21580019 :     case 2172:  /* *mmx_addv8qi3 */
   13813     21580019 :     case 2170:  /* xorv4hf3 */
   13814     21580019 :     case 2169:  /* iorv4hf3 */
   13815     21580019 :     case 2168:  /* andv4hf3 */
   13816     21580019 :     case 2167:  /* xorv2hf3 */
   13817     21580019 :     case 2166:  /* iorv2hf3 */
   13818     21580019 :     case 2165:  /* andv2hf3 */
   13819     21580019 :     case 2164:  /* xorv4bf3 */
   13820     21580019 :     case 2163:  /* iorv4bf3 */
   13821     21580019 :     case 2162:  /* andv4bf3 */
   13822     21580019 :     case 2161:  /* xorv2bf3 */
   13823     21580019 :     case 2160:  /* iorv2bf3 */
   13824     21580019 :     case 2159:  /* andv2bf3 */
   13825     21580019 :     case 2140:  /* *mmx_concatv2sf */
   13826     21580019 :     case 2127:  /* xorv2sf3 */
   13827     21580019 :     case 2126:  /* iorv2sf3 */
   13828     21580019 :     case 2125:  /* andv2sf3 */
   13829     21580019 :     case 1846:  /* sminhf3 */
   13830     21580019 :     case 1845:  /* smaxhf3 */
   13831     21580019 :     case 1844:  /* smindf3 */
   13832     21580019 :     case 1843:  /* smaxdf3 */
   13833     21580019 :     case 1842:  /* sminsf3 */
   13834     21580019 :     case 1841:  /* smaxsf3 */
   13835     21580019 :     case 1705:  /* *divhf */
   13836     21580019 :     case 1704:  /* *mulhf */
   13837     21580019 :     case 1703:  /* *subhf */
   13838     21580019 :     case 1702:  /* *addhf */
   13839     21580019 :     case 1411:  /* *rotrhi3_1_nf */
   13840     21580019 :     case 1409:  /* *rotlhi3_1_nf */
   13841     21580019 :     case 1407:  /* *rotrqi3_1_nf */
   13842     21580019 :     case 1405:  /* *rotlqi3_1_nf */
   13843     21580019 :     case 1380:  /* *rotrdi3_1_nf */
   13844     21580019 :     case 1378:  /* *rotldi3_1_nf */
   13845     21580019 :     case 1376:  /* *rotrsi3_1_nf */
   13846     21580019 :     case 1374:  /* *rotlsi3_1_nf */
   13847     21580019 :     case 1373:  /* *bmi2_rorxdi3_1 */
   13848     21580019 :     case 1372:  /* *bmi2_rorxsi3_1 */
   13849     21580019 :     case 1246:  /* *lshrhi3_1_nf */
   13850     21580019 :     case 1244:  /* *lshrqi3_1_nf */
   13851     21580019 :     case 1242:  /* *ashrhi3_1_nf */
   13852     21580019 :     case 1240:  /* *ashrqi3_1_nf */
   13853     21580019 :     case 1214:  /* *lshrdi3_1_nf */
   13854     21580019 :     case 1212:  /* *lshrsi3_1_nf */
   13855     21580019 :     case 1209:  /* *ashrdi3_1_nf */
   13856     21580019 :     case 1207:  /* *ashrsi3_1_nf */
   13857     21580019 :     case 1206:  /* *bmi2_ashrdi3_1 */
   13858     21580019 :     case 1205:  /* *bmi2_lshrdi3_1 */
   13859     21580019 :     case 1204:  /* *bmi2_ashrsi3_1 */
   13860     21580019 :     case 1203:  /* *bmi2_lshrsi3_1 */
   13861     21580019 :     case 1200:  /* ashrdi3_cvt_nf */
   13862     21580019 :     case 1198:  /* ashrsi3_cvt_nf */
   13863     21580019 :     case 1138:  /* *ashlqi3_1_nf */
   13864     21580019 :     case 1136:  /* *ashlhi3_1_nf */
   13865     21580019 :     case 1122:  /* *ashldi3_1_nf */
   13866     21580019 :     case 1120:  /* *ashlsi3_1_nf */
   13867     21580019 :     case 1119:  /* *bmi2_ashldi3_1 */
   13868     21580019 :     case 1118:  /* *bmi2_ashlsi3_1 */
   13869     21580019 :     case 897:  /* *xorqi_1_nf */
   13870     21580019 :     case 895:  /* *iorqi_1_nf */
   13871     21580019 :     case 861:  /* *xordi_1_nf */
   13872     21580019 :     case 859:  /* *iordi_1_nf */
   13873     21580019 :     case 857:  /* *xorsi_1_nf */
   13874     21580019 :     case 855:  /* *iorsi_1_nf */
   13875     21580019 :     case 853:  /* *xorhi_1_nf */
   13876     21580019 :     case 851:  /* *iorhi_1_nf */
   13877     21580019 :     case 751:  /* *andqi_1_nf */
   13878     21580019 :     case 749:  /* *andsi_1_nf */
   13879     21580019 :     case 747:  /* *andhi_1_nf */
   13880     21580019 :     case 733:  /* *anddi_1_nf */
   13881     21580019 :     case 630:  /* *mulqi3_1_nf */
   13882     21580019 :     case 622:  /* *muldi3_1_nf */
   13883     21580019 :     case 620:  /* *mulsi3_1_nf */
   13884     21580019 :     case 618:  /* *mulhi3_1_nf */
   13885     21580019 :     case 394:  /* *subdi_1_nf */
   13886     21580019 :     case 392:  /* *subsi_1_nf */
   13887     21580019 :     case 390:  /* *subhi_1_nf */
   13888     21580019 :     case 388:  /* *subqi_1_nf */
   13889     21580019 :     case 303:  /* *addqi_1_nf */
   13890     21580019 :     case 301:  /* *addhi_1_nf */
   13891     21580019 :     case 288:  /* *adddi_1_nf */
   13892     21580019 :     case 286:  /* *addsi_1_nf */
   13893     21580019 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   13894     21580019 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
   13895     21580019 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
   13896     21580019 :       break;
   13897              : 
   13898          114 :     case 285:  /* *addti3_doubleword_concat_zext */
   13899          114 :     case 284:  /* *addti3_doubleword_concat_zext */
   13900          114 :     case 283:  /* *addti3_doubleword_concat_zext */
   13901          114 :     case 282:  /* *adddi3_doubleword_concat_zext */
   13902          114 :     case 281:  /* *adddi3_doubleword_concat_zext */
   13903          114 :     case 280:  /* *adddi3_doubleword_concat_zext */
   13904          114 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   13905          114 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   13906          114 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   13907          114 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   13908          114 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   13909          114 :       break;
   13910              : 
   13911        16057 :     case 279:  /* *addti3_doubleword_concat */
   13912        16057 :     case 278:  /* *addti3_doubleword_concat */
   13913        16057 :     case 277:  /* *addti3_doubleword_concat */
   13914        16057 :     case 276:  /* *adddi3_doubleword_concat */
   13915        16057 :     case 275:  /* *adddi3_doubleword_concat */
   13916        16057 :     case 274:  /* *adddi3_doubleword_concat */
   13917        16057 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   13918        16057 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   13919        16057 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   13920        16057 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   13921        16057 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   13922        16057 :       break;
   13923              : 
   13924        37974 :     case 597:  /* *adddi3_ne_0 */
   13925        37974 :     case 596:  /* *addsi3_ne_0 */
   13926        37974 :     case 595:  /* *addhi3_ne_0 */
   13927        37974 :     case 594:  /* *addqi3_ne_0 */
   13928        37974 :     case 593:  /* *adddi3_eq_0 */
   13929        37974 :     case 592:  /* *addsi3_eq_0 */
   13930        37974 :     case 591:  /* *addhi3_eq_0 */
   13931        37974 :     case 590:  /* *addqi3_eq_0 */
   13932        37974 :     case 273:  /* *addti3_doubleword_zext */
   13933        37974 :     case 272:  /* *adddi3_doubleword_zext */
   13934        37974 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   13935        37974 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   13936        37974 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   13937        37974 :       break;
   13938              : 
   13939    219406264 :     case 2662:  /* klshiftrtdi */
   13940    219406264 :     case 2661:  /* kashiftdi */
   13941    219406264 :     case 2660:  /* klshiftrtsi */
   13942    219406264 :     case 2659:  /* kashiftsi */
   13943    219406264 :     case 2658:  /* klshiftrthi */
   13944    219406264 :     case 2657:  /* kashifthi */
   13945    219406264 :     case 2656:  /* klshiftrtqi */
   13946    219406264 :     case 2655:  /* kashiftqi */
   13947    219406264 :     case 2654:  /* kadddi */
   13948    219406264 :     case 2653:  /* kaddsi */
   13949    219406264 :     case 2652:  /* kaddhi */
   13950    219406264 :     case 2651:  /* kaddqi */
   13951    219406264 :     case 2637:  /* kxordi */
   13952    219406264 :     case 2636:  /* kiordi */
   13953    219406264 :     case 2635:  /* kanddi */
   13954    219406264 :     case 2634:  /* kxorsi */
   13955    219406264 :     case 2633:  /* kiorsi */
   13956    219406264 :     case 2632:  /* kandsi */
   13957    219406264 :     case 2631:  /* kxorhi */
   13958    219406264 :     case 2630:  /* kiorhi */
   13959    219406264 :     case 2629:  /* kandhi */
   13960    219406264 :     case 2628:  /* kxorqi */
   13961    219406264 :     case 2627:  /* kiorqi */
   13962    219406264 :     case 2626:  /* kandqi */
   13963    219406264 :     case 2339:  /* *xorv2hi3 */
   13964    219406264 :     case 2338:  /* *iorv2hi3 */
   13965    219406264 :     case 2337:  /* *andv2hi3 */
   13966    219406264 :     case 2336:  /* *xorv2qi3 */
   13967    219406264 :     case 2335:  /* *iorv2qi3 */
   13968    219406264 :     case 2334:  /* *andv2qi3 */
   13969    219406264 :     case 2333:  /* *xorv4qi3 */
   13970    219406264 :     case 2332:  /* *iorv4qi3 */
   13971    219406264 :     case 2331:  /* *andv4qi3 */
   13972    219406264 :     case 2264:  /* ashrv2qi3 */
   13973    219406264 :     case 2263:  /* lshrv2qi3 */
   13974    219406264 :     case 2262:  /* ashlv2qi3 */
   13975    219406264 :     case 2185:  /* subv2qi3 */
   13976    219406264 :     case 2184:  /* addv2qi3 */
   13977    219406264 :     case 2119:  /* mmx_gev2sf3 */
   13978    219406264 :     case 2118:  /* mmx_gtv2sf3 */
   13979    219406264 :     case 2117:  /* *mmx_eqv2sf3 */
   13980    219406264 :     case 2104:  /* *mmx_sminv2sf3 */
   13981    219406264 :     case 2103:  /* *mmx_smaxv2sf3 */
   13982    219406264 :     case 2102:  /* *mmx_mulv2sf3 */
   13983    219406264 :     case 2101:  /* *mmx_subv2sf3 */
   13984    219406264 :     case 2100:  /* *mmx_addv2sf3 */
   13985    219406264 :     case 1904:  /* pro_epilogue_adjust_stack_sub_di */
   13986    219406264 :     case 1903:  /* pro_epilogue_adjust_stack_sub_si */
   13987    219406264 :     case 1902:  /* pro_epilogue_adjust_stack_add_noccdi */
   13988    219406264 :     case 1901:  /* pro_epilogue_adjust_stack_add_noccsi */
   13989    219406264 :     case 1900:  /* pro_epilogue_adjust_stack_add_di */
   13990    219406264 :     case 1899:  /* pro_epilogue_adjust_stack_add_si */
   13991    219406264 :     case 1880:  /* *umindi3_1 */
   13992    219406264 :     case 1879:  /* *umaxdi3_1 */
   13993    219406264 :     case 1878:  /* *smindi3_1 */
   13994    219406264 :     case 1877:  /* *smaxdi3_1 */
   13995    219406264 :     case 1876:  /* *uminsi3_1 */
   13996    219406264 :     case 1875:  /* *umaxsi3_1 */
   13997    219406264 :     case 1874:  /* *sminsi3_1 */
   13998    219406264 :     case 1873:  /* *smaxsi3_1 */
   13999    219406264 :     case 1872:  /* *uminhi3_1 */
   14000    219406264 :     case 1871:  /* *umaxhi3_1 */
   14001    219406264 :     case 1870:  /* *sminhi3_1 */
   14002    219406264 :     case 1869:  /* *smaxhi3_1 */
   14003    219406264 :     case 1868:  /* *uminqi3_1 */
   14004    219406264 :     case 1867:  /* *umaxqi3_1 */
   14005    219406264 :     case 1866:  /* *sminqi3_1 */
   14006    219406264 :     case 1865:  /* *smaxqi3_1 */
   14007    219406264 :     case 1864:  /* *uminti3_doubleword */
   14008    219406264 :     case 1863:  /* *umaxti3_doubleword */
   14009    219406264 :     case 1862:  /* *sminti3_doubleword */
   14010    219406264 :     case 1861:  /* *smaxti3_doubleword */
   14011    219406264 :     case 1860:  /* *umindi3_doubleword */
   14012    219406264 :     case 1859:  /* *umaxdi3_doubleword */
   14013    219406264 :     case 1858:  /* *smindi3_doubleword */
   14014    219406264 :     case 1857:  /* *smaxdi3_doubleword */
   14015    219406264 :     case 1412:  /* *rotrhi3_1 */
   14016    219406264 :     case 1410:  /* *rotlhi3_1 */
   14017    219406264 :     case 1408:  /* *rotrqi3_1 */
   14018    219406264 :     case 1406:  /* *rotlqi3_1 */
   14019    219406264 :     case 1381:  /* *rotrdi3_1 */
   14020    219406264 :     case 1379:  /* *rotldi3_1 */
   14021    219406264 :     case 1377:  /* *rotrsi3_1 */
   14022    219406264 :     case 1375:  /* *rotlsi3_1 */
   14023    219406264 :     case 1247:  /* *lshrhi3_1 */
   14024    219406264 :     case 1245:  /* *lshrqi3_1 */
   14025    219406264 :     case 1243:  /* *ashrhi3_1 */
   14026    219406264 :     case 1241:  /* *ashrqi3_1 */
   14027    219406264 :     case 1215:  /* *lshrdi3_1 */
   14028    219406264 :     case 1213:  /* *lshrsi3_1 */
   14029    219406264 :     case 1210:  /* *ashrdi3_1 */
   14030    219406264 :     case 1208:  /* *ashrsi3_1 */
   14031    219406264 :     case 1201:  /* ashrdi3_cvt */
   14032    219406264 :     case 1199:  /* ashrsi3_cvt */
   14033    219406264 :     case 1165:  /* ashrti3_doubleword */
   14034    219406264 :     case 1164:  /* lshrti3_doubleword */
   14035    219406264 :     case 1163:  /* ashrdi3_doubleword */
   14036    219406264 :     case 1162:  /* lshrdi3_doubleword */
   14037    219406264 :     case 1139:  /* *ashlqi3_1 */
   14038    219406264 :     case 1137:  /* *ashlhi3_1 */
   14039    219406264 :     case 1123:  /* *ashldi3_1 */
   14040    219406264 :     case 1121:  /* *ashlsi3_1 */
   14041    219406264 :     case 1089:  /* ashlti3_doubleword */
   14042    219406264 :     case 1088:  /* ashldi3_doubleword */
   14043    219406264 :     case 898:  /* *xorqi_1 */
   14044    219406264 :     case 896:  /* *iorqi_1 */
   14045    219406264 :     case 867:  /* *xordi_1_btc */
   14046    219406264 :     case 866:  /* *iordi_1_bts */
   14047    219406264 :     case 862:  /* *xordi_1 */
   14048    219406264 :     case 860:  /* *iordi_1 */
   14049    219406264 :     case 858:  /* *xorsi_1 */
   14050    219406264 :     case 856:  /* *iorsi_1 */
   14051    219406264 :     case 854:  /* *xorhi_1 */
   14052    219406264 :     case 852:  /* *iorhi_1 */
   14053    219406264 :     case 850:  /* *xorti3_doubleword */
   14054    219406264 :     case 849:  /* *iorti3_doubleword */
   14055    219406264 :     case 848:  /* *xordi3_doubleword */
   14056    219406264 :     case 847:  /* *iordi3_doubleword */
   14057    219406264 :     case 752:  /* *andqi_1 */
   14058    219406264 :     case 750:  /* *andsi_1 */
   14059    219406264 :     case 748:  /* *andhi_1 */
   14060    219406264 :     case 735:  /* *anddi_1_btr */
   14061    219406264 :     case 734:  /* *anddi_1 */
   14062    219406264 :     case 732:  /* *andti3_doubleword */
   14063    219406264 :     case 731:  /* *anddi3_doubleword */
   14064    219406264 :     case 631:  /* *mulqi3_1 */
   14065    219406264 :     case 623:  /* *muldi3_1 */
   14066    219406264 :     case 621:  /* *mulsi3_1 */
   14067    219406264 :     case 619:  /* *mulhi3_1 */
   14068    219406264 :     case 522:  /* *subdi3_carry_0r */
   14069    219406264 :     case 521:  /* *subsi3_carry_0r */
   14070    219406264 :     case 520:  /* *subhi3_carry_0r */
   14071    219406264 :     case 519:  /* *subqi3_carry_0r */
   14072    219406264 :     case 514:  /* *subdi3_carry_0 */
   14073    219406264 :     case 513:  /* *subsi3_carry_0 */
   14074    219406264 :     case 512:  /* *subhi3_carry_0 */
   14075    219406264 :     case 511:  /* *subqi3_carry_0 */
   14076    219406264 :     case 395:  /* *subdi_1 */
   14077    219406264 :     case 393:  /* *subsi_1 */
   14078    219406264 :     case 391:  /* *subhi_1 */
   14079    219406264 :     case 389:  /* *subqi_1 */
   14080    219406264 :     case 385:  /* *subti3_doubleword */
   14081    219406264 :     case 384:  /* *subdi3_doubleword */
   14082    219406264 :     case 304:  /* *addqi_1 */
   14083    219406264 :     case 302:  /* *addhi_1 */
   14084    219406264 :     case 289:  /* *adddi_1 */
   14085    219406264 :     case 287:  /* *addsi_1 */
   14086    219406264 :     case 271:  /* *addti3_doubleword */
   14087    219406264 :     case 270:  /* *adddi3_doubleword */
   14088    219406264 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14089    219406264 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14090    219406264 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   14091    219406264 :       break;
   14092              : 
   14093       549956 :     case 8638:  /* sse_stmxcsr */
   14094       549956 :     case 2059:  /* sttilecfg */
   14095       549956 :     case 2028:  /* rdpid_rex64 */
   14096       549956 :     case 2027:  /* rdpid */
   14097       549956 :     case 1987:  /* rdgsbasedi */
   14098       549956 :     case 1986:  /* rdfsbasedi */
   14099       549956 :     case 1985:  /* rdgsbasesi */
   14100       549956 :     case 1984:  /* rdfsbasesi */
   14101       549956 :     case 1979:  /* lwp_slwpcbdi */
   14102       549956 :     case 1978:  /* lwp_slwpcbsi */
   14103       549956 :     case 1974:  /* fnstsw */
   14104       549956 :     case 1947:  /* fxsave64 */
   14105       549956 :     case 1946:  /* fxsave */
   14106       549956 :     case 1942:  /* rdtsc */
   14107       549956 :     case 1935:  /* *prefetch_rst2 */
   14108       549956 :     case 1740:  /* x86_fnstsw_1 */
   14109       549956 :     case 1686:  /* *load_tp_x32_zext */
   14110       549956 :     case 1685:  /* *load_tp_di */
   14111       549956 :     case 1684:  /* *load_tp_si */
   14112       549956 :     case 1524:  /* set_got_rex64 */
   14113       549956 :     case 242:  /* x86_fnstcw_1 */
   14114       549956 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14115       549956 :       break;
   14116              : 
   14117        88177 :     case 267:  /* floatunssixf2_i387_with_xmm */
   14118        88177 :     case 266:  /* floatunssidf2_i387_with_xmm */
   14119        88177 :     case 265:  /* floatunssisf2_i387_with_xmm */
   14120        88177 :     case 241:  /* fix_truncsi_i387 */
   14121        88177 :     case 240:  /* fix_trunchi_i387 */
   14122        88177 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14123        88177 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14124        88177 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
   14125        88177 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 2), 0));
   14126        88177 :       break;
   14127              : 
   14128        97762 :     case 260:  /* floatdixf2_i387_with_xmm */
   14129        97762 :     case 259:  /* floatdidf2_i387_with_xmm */
   14130        97762 :     case 258:  /* floatdisf2_i387_with_xmm */
   14131        97762 :     case 239:  /* fix_truncdi_i387 */
   14132        97762 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14133        97762 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14134        97762 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
   14135        97762 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 2), 0));
   14136        97762 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 3), 0));
   14137        97762 :       break;
   14138              : 
   14139       507914 :     case 2730:  /* *negv2df2 */
   14140       507914 :     case 2729:  /* *absv2df2 */
   14141       507914 :     case 2728:  /* *negv4df2 */
   14142       507914 :     case 2727:  /* *absv4df2 */
   14143       507914 :     case 2726:  /* *negv8df2 */
   14144       507914 :     case 2725:  /* *absv8df2 */
   14145       507914 :     case 2724:  /* *negv4sf2 */
   14146       507914 :     case 2723:  /* *absv4sf2 */
   14147       507914 :     case 2722:  /* *negv8sf2 */
   14148       507914 :     case 2721:  /* *absv8sf2 */
   14149       507914 :     case 2720:  /* *negv16sf2 */
   14150       507914 :     case 2719:  /* *absv16sf2 */
   14151       507914 :     case 2718:  /* *negv8hf2 */
   14152       507914 :     case 2717:  /* *absv8hf2 */
   14153       507914 :     case 2716:  /* *negv16hf2 */
   14154       507914 :     case 2715:  /* *absv16hf2 */
   14155       507914 :     case 2714:  /* *negv32hf2 */
   14156       507914 :     case 2713:  /* *absv32hf2 */
   14157       507914 :     case 2712:  /* *negv8bf2 */
   14158       507914 :     case 2711:  /* *absv8bf2 */
   14159       507914 :     case 2710:  /* *negv16bf2 */
   14160       507914 :     case 2709:  /* *absv16bf2 */
   14161       507914 :     case 2708:  /* *negv32bf2 */
   14162       507914 :     case 2707:  /* *absv32bf2 */
   14163       507914 :     case 2150:  /* *mmx_negv4hf */
   14164       507914 :     case 2149:  /* *mmx_absv4hf */
   14165       507914 :     case 2148:  /* *mmx_negv2hf */
   14166       507914 :     case 2147:  /* *mmx_absv2hf */
   14167       507914 :     case 2146:  /* *mmx_negv4bf */
   14168       507914 :     case 2145:  /* *mmx_absv4bf */
   14169       507914 :     case 2144:  /* *mmx_negv2bf */
   14170       507914 :     case 2143:  /* *mmx_absv2bf */
   14171       507914 :     case 2098:  /* *mmx_negv2sf2 */
   14172       507914 :     case 2097:  /* *mmx_absv2sf2 */
   14173       507914 :     case 1531:  /* ffssi2_no_cmove */
   14174       507914 :     case 1053:  /* *negdf2_1 */
   14175       507914 :     case 1052:  /* *absdf2_1 */
   14176       507914 :     case 1051:  /* *negsf2_1 */
   14177       507914 :     case 1050:  /* *abssf2_1 */
   14178       507914 :     case 1049:  /* *neghf2_1 */
   14179       507914 :     case 1048:  /* *abshf2_1 */
   14180       507914 :     case 1040:  /* *negtf2_1 */
   14181       507914 :     case 1039:  /* *abstf2_1 */
   14182       507914 :     case 235:  /* fix_truncdi_i387_fisttp */
   14183       507914 :     case 234:  /* fix_truncsi_i387_fisttp */
   14184       507914 :     case 233:  /* fix_trunchi_i387_fisttp */
   14185       507914 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14186       507914 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14187       507914 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
   14188       507914 :       break;
   14189              : 
   14190            0 :     case 228:  /* *fixuns_truncdf_1 */
   14191            0 :     case 227:  /* *fixuns_truncsf_1 */
   14192            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14193            0 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 2), 0));
   14194            0 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 3), 0));
   14195            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14196            0 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 1), 0));
   14197            0 :       break;
   14198              : 
   14199         6207 :     case 203:  /* *extendqisi_ext_1 */
   14200         6207 :     case 202:  /* *extendqisi_ext_1 */
   14201         6207 :     case 201:  /* *extendqisi_ext_1 */
   14202         6207 :     case 200:  /* *extendqihi_ext_1 */
   14203         6207 :     case 199:  /* *extendqihi_ext_1 */
   14204         6207 :     case 198:  /* *extendqihi_ext_1 */
   14205         6207 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14206         6207 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   14207         6207 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   14208         6207 :       break;
   14209              : 
   14210       256691 :     case 10521:  /* vcvtneobf162ps_v16bf */
   14211       256691 :     case 10520:  /* vcvtneoph2ps_v16hf */
   14212       256691 :     case 10519:  /* vcvtneobf162ps_v8bf */
   14213       256691 :     case 10518:  /* vcvtneoph2ps_v8hf */
   14214       256691 :     case 10517:  /* vcvtneebf162ps_v16bf */
   14215       256691 :     case 10516:  /* vcvtneeph2ps_v16hf */
   14216       256691 :     case 10515:  /* vcvtneebf162ps_v8bf */
   14217       256691 :     case 10514:  /* vcvtneeph2ps_v8hf */
   14218       256691 :     case 10513:  /* vbcstnesh2ps_v4sf */
   14219       256691 :     case 10512:  /* vbcstnesh2ps_v8sf */
   14220       256691 :     case 10511:  /* vbcstnebf162ps_v4sf */
   14221       256691 :     case 10510:  /* vbcstnebf162ps_v8sf */
   14222       256691 :     case 10190:  /* avx512f_pd512_pd */
   14223       256691 :     case 10189:  /* avx512f_ps512_ps */
   14224       256691 :     case 10188:  /* avx512f_si512_si */
   14225       256691 :     case 9413:  /* *avx512dq_broadcastv8sf */
   14226       256691 :     case 9411:  /* *avx512dq_broadcastv16sf */
   14227       256691 :     case 9409:  /* *avx512dq_broadcastv4si */
   14228       256691 :     case 9407:  /* *avx512dq_broadcastv8si */
   14229       256691 :     case 9405:  /* *avx512dq_broadcastv16si */
   14230       256691 :     case 9309:  /* avx512vl_vec_dupv8bf */
   14231       256691 :     case 9307:  /* avx512vl_vec_dupv16bf */
   14232       256691 :     case 9305:  /* avx512bw_vec_dupv32bf */
   14233       256691 :     case 9303:  /* avx512fp16_vec_dupv8hf */
   14234       256691 :     case 9301:  /* avx512vl_vec_dupv16hf */
   14235       256691 :     case 9299:  /* avx512bw_vec_dupv32hf */
   14236       256691 :     case 9297:  /* avx512vl_vec_dupv8hi */
   14237       256691 :     case 9295:  /* avx512vl_vec_dupv16hi */
   14238       256691 :     case 9293:  /* avx512bw_vec_dupv32hi */
   14239       256691 :     case 9291:  /* avx512vl_vec_dupv32qi */
   14240       256691 :     case 9289:  /* avx512vl_vec_dupv16qi */
   14241       256691 :     case 9287:  /* avx512bw_vec_dupv64qi */
   14242       256691 :     case 9285:  /* avx512vl_vec_dupv2df */
   14243       256691 :     case 9283:  /* avx512vl_vec_dupv4df */
   14244       256691 :     case 9281:  /* avx512f_vec_dupv8df */
   14245       256691 :     case 9279:  /* avx512vl_vec_dupv4sf */
   14246       256691 :     case 9277:  /* avx512vl_vec_dupv8sf */
   14247       256691 :     case 9275:  /* avx512f_vec_dupv16sf */
   14248       256691 :     case 9273:  /* avx512vl_vec_dupv2di */
   14249       256691 :     case 9271:  /* avx512vl_vec_dupv4di */
   14250       256691 :     case 9269:  /* avx512f_vec_dupv8di */
   14251       256691 :     case 9267:  /* avx512vl_vec_dupv4si */
   14252       256691 :     case 9265:  /* avx512vl_vec_dupv8si */
   14253       256691 :     case 9263:  /* avx512f_vec_dupv16si */
   14254       256691 :     case 9262:  /* avx512bw_vec_dupv32bf_1 */
   14255       256691 :     case 9261:  /* avx512bw_vec_dupv32hf_1 */
   14256       256691 :     case 9260:  /* avx512bw_vec_dupv64qi_1 */
   14257       256691 :     case 9259:  /* avx512bw_vec_dupv32hi_1 */
   14258       256691 :     case 9258:  /* avx512f_vec_dupv8di_1 */
   14259       256691 :     case 9257:  /* avx512f_vec_dupv16si_1 */
   14260       256691 :     case 9256:  /* avx2_vec_dupv4df */
   14261       256691 :     case 9179:  /* avx2_pbroadcastv16bf_1 */
   14262       256691 :     case 9178:  /* avx2_pbroadcastv16hf_1 */
   14263       256691 :     case 9177:  /* avx2_pbroadcastv4di_1 */
   14264       256691 :     case 9176:  /* avx2_pbroadcastv8si_1 */
   14265       256691 :     case 9175:  /* avx2_pbroadcastv16hi_1 */
   14266       256691 :     case 9174:  /* avx2_pbroadcastv32qi_1 */
   14267       256691 :     case 9173:  /* avx2_pbroadcastv8bf */
   14268       256691 :     case 9172:  /* avx2_pbroadcastv16bf */
   14269       256691 :     case 9171:  /* avx2_pbroadcastv32bf */
   14270       256691 :     case 9170:  /* avx2_pbroadcastv8hf */
   14271       256691 :     case 9169:  /* avx2_pbroadcastv16hf */
   14272       256691 :     case 9168:  /* avx2_pbroadcastv32hf */
   14273       256691 :     case 9167:  /* avx2_pbroadcastv2di */
   14274       256691 :     case 9166:  /* avx2_pbroadcastv4di */
   14275       256691 :     case 9165:  /* avx2_pbroadcastv4si */
   14276       256691 :     case 9164:  /* avx2_pbroadcastv8si */
   14277       256691 :     case 9163:  /* avx2_pbroadcastv8hi */
   14278       256691 :     case 9162:  /* avx2_pbroadcastv16hi */
   14279       256691 :     case 9161:  /* avx2_pbroadcastv32hi */
   14280       256691 :     case 9160:  /* avx2_pbroadcastv16qi */
   14281       256691 :     case 9159:  /* avx2_pbroadcastv32qi */
   14282       256691 :     case 9158:  /* avx2_pbroadcastv64qi */
   14283       256691 :     case 9157:  /* avx2_pbroadcastv8di */
   14284       256691 :     case 9156:  /* avx2_pbroadcastv16si */
   14285       256691 :     case 8980:  /* sse4_1_zero_extendv2siv2di2 */
   14286       256691 :     case 8978:  /* sse4_1_sign_extendv2siv2di2 */
   14287       256691 :     case 8956:  /* sse4_1_zero_extendv2hiv2di2 */
   14288       256691 :     case 8954:  /* sse4_1_sign_extendv2hiv2di2 */
   14289       256691 :     case 8944:  /* avx2_zero_extendv4hiv4di2 */
   14290       256691 :     case 8942:  /* avx2_sign_extendv4hiv4di2 */
   14291       256691 :     case 8929:  /* sse4_1_zero_extendv2qiv2di2 */
   14292       256691 :     case 8927:  /* sse4_1_sign_extendv2qiv2di2 */
   14293       256691 :     case 8917:  /* avx2_zero_extendv4qiv4di2 */
   14294       256691 :     case 8915:  /* avx2_sign_extendv4qiv4di2 */
   14295       256691 :     case 8905:  /* avx512f_zero_extendv8qiv8di2 */
   14296       256691 :     case 8903:  /* avx512f_sign_extendv8qiv8di2 */
   14297       256691 :     case 8889:  /* sse4_1_zero_extendv4hiv4si2 */
   14298       256691 :     case 8887:  /* sse4_1_sign_extendv4hiv4si2 */
   14299       256691 :     case 8859:  /* sse4_1_zero_extendv4qiv4si2 */
   14300       256691 :     case 8857:  /* sse4_1_sign_extendv4qiv4si2 */
   14301       256691 :     case 8847:  /* avx2_zero_extendv8qiv8si2 */
   14302       256691 :     case 8845:  /* avx2_sign_extendv8qiv8si2 */
   14303       256691 :     case 8827:  /* sse4_1_zero_extendv8qiv8hi2 */
   14304       256691 :     case 8825:  /* sse4_1_sign_extendv8qiv8hi2 */
   14305       256691 :     case 8527:  /* *vec_extractv4si_0_zext */
   14306       256691 :     case 8526:  /* *vec_extractv4si_0_zext_sse4 */
   14307       256691 :     case 7476:  /* *avx512f_us_truncatev8div16qi2_store_2 */
   14308       256691 :     case 7475:  /* *avx512f_truncatev8div16qi2_store_2 */
   14309       256691 :     case 7474:  /* *avx512f_ss_truncatev8div16qi2_store_2 */
   14310       256691 :     case 7470:  /* avx512f_us_truncatev8div16qi2 */
   14311       256691 :     case 7469:  /* avx512f_truncatev8div16qi2 */
   14312       256691 :     case 7468:  /* avx512f_ss_truncatev8div16qi2 */
   14313       256691 :     case 7458:  /* *avx512vl_us_truncatev2div2si2_store_2 */
   14314       256691 :     case 7457:  /* *avx512vl_truncatev2div2si2_store_2 */
   14315       256691 :     case 7456:  /* *avx512vl_ss_truncatev2div2si2_store_2 */
   14316       256691 :     case 7439:  /* *avx512vl_us_truncatev2div2hi2_store_2 */
   14317       256691 :     case 7438:  /* *avx512vl_truncatev2div2hi2_store_2 */
   14318       256691 :     case 7437:  /* *avx512vl_ss_truncatev2div2hi2_store_2 */
   14319       256691 :     case 7415:  /* *avx512vl_us_truncatev4div4hi2_store_2 */
   14320       256691 :     case 7414:  /* *avx512vl_truncatev4div4hi2_store_2 */
   14321       256691 :     case 7413:  /* *avx512vl_ss_truncatev4div4hi2_store_2 */
   14322       256691 :     case 7412:  /* *avx512vl_us_truncatev4siv4hi2_store_2 */
   14323       256691 :     case 7411:  /* *avx512vl_truncatev4siv4hi2_store_2 */
   14324       256691 :     case 7410:  /* *avx512vl_ss_truncatev4siv4hi2_store_2 */
   14325       256691 :     case 7375:  /* *avx512vl_us_truncatev8siv8qi2_store_2 */
   14326       256691 :     case 7374:  /* *avx512vl_truncatev8siv8qi2_store_2 */
   14327       256691 :     case 7373:  /* *avx512vl_ss_truncatev8siv8qi2_store_2 */
   14328       256691 :     case 7372:  /* *avx512vl_us_truncatev8hiv8qi2_store_2 */
   14329       256691 :     case 7371:  /* *avx512vl_truncatev8hiv8qi2_store_2 */
   14330       256691 :     case 7370:  /* *avx512vl_ss_truncatev8hiv8qi2_store_2 */
   14331       256691 :     case 7345:  /* *avx512vl_us_truncatev4div4qi2_store_2 */
   14332       256691 :     case 7344:  /* *avx512vl_truncatev4div4qi2_store_2 */
   14333       256691 :     case 7343:  /* *avx512vl_ss_truncatev4div4qi2_store_2 */
   14334       256691 :     case 7342:  /* *avx512vl_us_truncatev4siv4qi2_store_2 */
   14335       256691 :     case 7341:  /* *avx512vl_truncatev4siv4qi2_store_2 */
   14336       256691 :     case 7340:  /* *avx512vl_ss_truncatev4siv4qi2_store_2 */
   14337       256691 :     case 7324:  /* *avx512vl_us_truncatev2div2qi2_store_2 */
   14338       256691 :     case 7323:  /* *avx512vl_truncatev2div2qi2_store_2 */
   14339       256691 :     case 7322:  /* *avx512vl_ss_truncatev2div2qi2_store_2 */
   14340       256691 :     case 5330:  /* *vec_setv2di_0_zero_extendsi_1 */
   14341       256691 :     case 5318:  /* *vec_setv2di_0_zero_extendhi_1 */
   14342       256691 :     case 5286:  /* avx512f_vec_dupv8df_1 */
   14343       256691 :     case 5285:  /* avx512f_vec_dupv16sf_1 */
   14344       256691 :     case 5284:  /* avx2_vec_dupv8sf_1 */
   14345       256691 :     case 5283:  /* avx2_vec_dupv4sf */
   14346       256691 :     case 5282:  /* avx2_vec_dupv8sf */
   14347       256691 :     case 5238:  /* sse2_cvtps2pd */
   14348       256691 :     case 5195:  /* vec_unpacks_lo_v16sf */
   14349       256691 :     case 5194:  /* *avx_cvtps2pd256_2 */
   14350       256691 :     case 5165:  /* sse2_cvttpd2dq */
   14351       256691 :     case 5153:  /* avx512dq_fixuns_truncv2sfv2di2 */
   14352       256691 :     case 5151:  /* avx512dq_fix_truncv2sfv2di2 */
   14353       256691 :     case 5063:  /* *fixuns_truncv2dfv2si2 */
   14354       256691 :     case 5023:  /* sse2_cvtdq2pd */
   14355       256691 :     case 5022:  /* avx_cvtdq2pd256_2 */
   14356       256691 :     case 5021:  /* avx512f_cvtdq2pd512_2 */
   14357       256691 :     case 5019:  /* *floatunsv2siv2df2 */
   14358       256691 :     case 4967:  /* sse2_cvttsd2siq */
   14359       256691 :     case 4965:  /* sse2_cvttsd2si */
   14360       256691 :     case 4953:  /* avx512f_vcvttsd2usiq */
   14361       256691 :     case 4951:  /* avx512f_vcvttsd2usi */
   14362       256691 :     case 4941:  /* avx512f_vcvttss2usiq */
   14363       256691 :     case 4939:  /* avx512f_vcvttss2usi */
   14364       256691 :     case 4832:  /* sse_cvttss2siq */
   14365       256691 :     case 4830:  /* sse_cvttss2si */
   14366       256691 :     case 4815:  /* sse_cvttps2pi */
   14367       256691 :     case 4763:  /* avx512fp16_float_extend_phv2df2 */
   14368       256691 :     case 4757:  /* avx512fp16_float_extend_phv4sf2 */
   14369       256691 :     case 4755:  /* avx512fp16_float_extend_phv4df2 */
   14370       256691 :     case 4737:  /* avx512fp16_fixuns_truncdi2 */
   14371       256691 :     case 4735:  /* avx512fp16_fix_truncdi2 */
   14372       256691 :     case 4733:  /* avx512fp16_fixuns_truncsi2 */
   14373       256691 :     case 4731:  /* avx512fp16_fix_truncsi2 */
   14374       256691 :     case 4717:  /* avx512fp16_fixuns_truncv2di2 */
   14375       256691 :     case 4715:  /* avx512fp16_fix_truncv2di2 */
   14376       256691 :     case 4701:  /* avx512fp16_fixuns_truncv4di2 */
   14377       256691 :     case 4699:  /* avx512fp16_fix_truncv4di2 */
   14378       256691 :     case 4697:  /* avx512fp16_fixuns_truncv4si2 */
   14379       256691 :     case 4695:  /* avx512fp16_fix_truncv4si2 */
   14380       256691 :     case 2422:  /* *vec_dupv2hi */
   14381       256691 :     case 2401:  /* *vec_extractv2si_1_zext */
   14382       256691 :     case 2399:  /* *vec_extractv2si_0_zext */
   14383       256691 :     case 2398:  /* *vec_extractv2si_0_zext_sse4 */
   14384       256691 :     case 2391:  /* *vec_dupv4hi */
   14385       256691 :     case 2359:  /* sse4_1_zero_extendv2qiv2hi2 */
   14386       256691 :     case 2358:  /* sse4_1_sign_extendv2qiv2hi2 */
   14387       256691 :     case 2357:  /* sse4_1_zero_extendv2qiv2si2 */
   14388       256691 :     case 2356:  /* sse4_1_sign_extendv2qiv2si2 */
   14389       256691 :     case 2355:  /* sse4_1_zero_extendv2hiv2si2 */
   14390       256691 :     case 2354:  /* sse4_1_sign_extendv2hiv2si2 */
   14391       256691 :     case 2353:  /* sse4_1_zero_extendv4qiv4hi2 */
   14392       256691 :     case 2352:  /* sse4_1_sign_extendv4qiv4hi2 */
   14393       256691 :     case 1072:  /* *one_cmplsi2_1_zext */
   14394       256691 :     case 1071:  /* *one_cmplhi2_1_zextdi */
   14395       256691 :     case 1070:  /* *one_cmplhi2_1_zextsi */
   14396       256691 :     case 1069:  /* *one_cmplqi2_1_zextdi */
   14397       256691 :     case 1068:  /* *one_cmplqi2_1_zextsi */
   14398       256691 :     case 1067:  /* *one_cmplqi2_1_zexthi */
   14399       256691 :     case 1002:  /* *neghi_1_zextdi_nf */
   14400       256691 :     case 1000:  /* *neghi_1_zextsi_nf */
   14401       256691 :     case 998:  /* *negqi_1_zextdi_nf */
   14402       256691 :     case 996:  /* *negqi_1_zextsi_nf */
   14403       256691 :     case 994:  /* *negqi_1_zexthi_nf */
   14404       256691 :     case 226:  /* *fixuns_truncdfsi2_avx512f_zext */
   14405       256691 :     case 225:  /* *fixuns_truncsfsi2_avx512f_zext */
   14406       256691 :     case 224:  /* *fixuns_trunchfsi2zext */
   14407       256691 :     case 196:  /* *extendqisi2_zext */
   14408       256691 :     case 194:  /* *extendhisi2_zext */
   14409       256691 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14410       256691 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   14411       256691 :       break;
   14412              : 
   14413       137347 :     case 190:  /* extendditi2 */
   14414       137347 :     case 189:  /* extendsidi2_1 */
   14415       137347 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14416       137347 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14417       137347 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 2), 0));
   14418       137347 :       break;
   14419              : 
   14420         3235 :     case 2106:  /* mmx_ieee_minv2sf3 */
   14421         3235 :     case 2105:  /* mmx_ieee_maxv2sf3 */
   14422         3235 :     case 1911:  /* probe_stack_range_di */
   14423         3235 :     case 1910:  /* probe_stack_range_si */
   14424         3235 :     case 1696:  /* *tls_dynamic_gnu2_call_64_di */
   14425         3235 :     case 1695:  /* *tls_dynamic_gnu2_call_64_si */
   14426         3235 :     case 1593:  /* bmi_bextr_di */
   14427         3235 :     case 1592:  /* bmi_bextr_si */
   14428         3235 :     case 167:  /* push2p_di */
   14429         3235 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14430         3235 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
   14431         3235 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
   14432         3235 :       break;
   14433              : 
   14434         6413 :     case 2612:  /* movdi_to_sse */
   14435         6413 :     case 1915:  /* stack_protect_set_1_di_di */
   14436         6413 :     case 1914:  /* stack_protect_set_1_si_di */
   14437         6413 :     case 1913:  /* stack_protect_set_1_di_si */
   14438         6413 :     case 1912:  /* stack_protect_set_1_si_si */
   14439         6413 :     case 1759:  /* lrintxfdi2 */
   14440         6413 :     case 168:  /* pop2p_di */
   14441         6413 :     case 164:  /* pop2_di */
   14442         6413 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14443         6413 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
   14444         6413 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
   14445         6413 :       break;
   14446              : 
   14447       780004 :     case 11079:  /* atomic_storedi_1 */
   14448       780004 :     case 11078:  /* atomic_storesi_1 */
   14449       780004 :     case 11077:  /* atomic_storehi_1 */
   14450       780004 :     case 11076:  /* atomic_storeqi_1 */
   14451       780004 :     case 10807:  /* avx10_2_fpclassbf16_v8bf */
   14452       780004 :     case 10805:  /* avx10_2_fpclassbf16_v16bf */
   14453       780004 :     case 10803:  /* avx10_2_fpclassbf16_v32bf */
   14454       780004 :     case 10801:  /* avx10_2_getmantbf16_v8bf */
   14455       780004 :     case 10799:  /* avx10_2_reducebf16_v8bf */
   14456       780004 :     case 10797:  /* avx10_2_rndscalebf16_v8bf */
   14457       780004 :     case 10795:  /* avx10_2_getmantbf16_v16bf */
   14458       780004 :     case 10793:  /* avx10_2_reducebf16_v16bf */
   14459       780004 :     case 10791:  /* avx10_2_rndscalebf16_v16bf */
   14460       780004 :     case 10789:  /* avx10_2_getmantbf16_v32bf */
   14461       780004 :     case 10787:  /* avx10_2_reducebf16_v32bf */
   14462       780004 :     case 10785:  /* avx10_2_rndscalebf16_v32bf */
   14463       780004 :     case 10675:  /* avx10_2_scalefbf16_v8bf */
   14464       780004 :     case 10673:  /* avx10_2_scalefbf16_v16bf */
   14465       780004 :     case 10671:  /* avx10_2_scalefbf16_v32bf */
   14466       780004 :     case 10576:  /* vcvtbiasph2hf8sv16hf */
   14467       780004 :     case 10574:  /* vcvtbiasph2hf8v16hf */
   14468       780004 :     case 10572:  /* vcvtbiasph2bf8sv16hf */
   14469       780004 :     case 10570:  /* vcvtbiasph2bf8v16hf */
   14470       780004 :     case 10568:  /* vcvtbiasph2hf8sv32hf */
   14471       780004 :     case 10566:  /* vcvtbiasph2hf8v32hf */
   14472       780004 :     case 10564:  /* vcvtbiasph2bf8sv32hf */
   14473       780004 :     case 10562:  /* vcvtbiasph2bf8v32hf */
   14474       780004 :     case 10552:  /* vcvt2ph2hf8sv8hf */
   14475       780004 :     case 10550:  /* vcvt2ph2hf8v8hf */
   14476       780004 :     case 10548:  /* vcvt2ph2bf8sv8hf */
   14477       780004 :     case 10546:  /* vcvt2ph2bf8v8hf */
   14478       780004 :     case 10544:  /* vcvt2ph2hf8sv16hf */
   14479       780004 :     case 10542:  /* vcvt2ph2hf8v16hf */
   14480       780004 :     case 10540:  /* vcvt2ph2bf8sv16hf */
   14481       780004 :     case 10538:  /* vcvt2ph2bf8v16hf */
   14482       780004 :     case 10536:  /* vcvt2ph2hf8sv32hf */
   14483       780004 :     case 10534:  /* vcvt2ph2hf8v32hf */
   14484       780004 :     case 10532:  /* vcvt2ph2bf8sv32hf */
   14485       780004 :     case 10530:  /* vcvt2ph2bf8v32hf */
   14486       780004 :     case 10422:  /* avx512vp2intersect_2intersectv16si */
   14487       780004 :     case 10421:  /* avx512vp2intersect_2intersectv4si */
   14488       780004 :     case 10420:  /* avx512vp2intersect_2intersectv8si */
   14489       780004 :     case 10419:  /* avx512vp2intersect_2intersectv2di */
   14490       780004 :     case 10418:  /* avx512vp2intersect_2intersectv4di */
   14491       780004 :     case 10417:  /* avx512vp2intersect_2intersectv8di */
   14492       780004 :     case 10413:  /* avx512vl_vpshufbitqmbv32qi */
   14493       780004 :     case 10411:  /* avx512vl_vpshufbitqmbv16qi */
   14494       780004 :     case 10409:  /* avx512vl_vpshufbitqmbv64qi */
   14495       780004 :     case 10405:  /* vaesenclast_v64qi */
   14496       780004 :     case 10404:  /* vaesenclast_v16qi */
   14497       780004 :     case 10403:  /* vaesenclast_v32qi */
   14498       780004 :     case 10402:  /* vaesenc_v64qi */
   14499       780004 :     case 10401:  /* vaesenc_v16qi */
   14500       780004 :     case 10400:  /* vaesenc_v32qi */
   14501       780004 :     case 10399:  /* vaesdeclast_v64qi */
   14502       780004 :     case 10398:  /* vaesdeclast_v16qi */
   14503       780004 :     case 10397:  /* vaesdeclast_v32qi */
   14504       780004 :     case 10396:  /* vaesdec_v64qi */
   14505       780004 :     case 10395:  /* vaesdec_v16qi */
   14506       780004 :     case 10394:  /* vaesdec_v32qi */
   14507       780004 :     case 10266:  /* vgf2p8mulb_v16qi */
   14508       780004 :     case 10264:  /* vgf2p8mulb_v32qi */
   14509       780004 :     case 10262:  /* vgf2p8mulb_v64qi */
   14510       780004 :     case 10216:  /* vpmultishiftqbv32qi */
   14511       780004 :     case 10214:  /* vpmultishiftqbv16qi */
   14512       780004 :     case 10212:  /* vpmultishiftqbv64qi */
   14513       780004 :     case 10187:  /* vsm4rnds4_v4si */
   14514       780004 :     case 10186:  /* vsm4rnds4_v8si */
   14515       780004 :     case 10185:  /* vsm4rnds4_v16si */
   14516       780004 :     case 10184:  /* vsm4key4_v4si */
   14517       780004 :     case 10183:  /* vsm4key4_v8si */
   14518       780004 :     case 10182:  /* vsm4key4_v16si */
   14519       780004 :     case 10180:  /* vsha512msg2 */
   14520       780004 :     case 10179:  /* vsha512msg1 */
   14521       780004 :     case 10174:  /* sha256msg2 */
   14522       780004 :     case 10173:  /* sha256msg1 */
   14523       780004 :     case 10171:  /* sha1nexte */
   14524       780004 :     case 10170:  /* sha1msg2 */
   14525       780004 :     case 10169:  /* sha1msg1 */
   14526       780004 :     case 10123:  /* avx512vl_getmantv2df */
   14527       780004 :     case 10119:  /* avx512vl_getmantv4df */
   14528       780004 :     case 10115:  /* avx512f_getmantv8df */
   14529       780004 :     case 10111:  /* avx512vl_getmantv4sf */
   14530       780004 :     case 10107:  /* avx512vl_getmantv8sf */
   14531       780004 :     case 10103:  /* avx512f_getmantv16sf */
   14532       780004 :     case 10099:  /* avx512fp16_getmantv8hf */
   14533       780004 :     case 10095:  /* avx512vl_getmantv16hf */
   14534       780004 :     case 10091:  /* avx512bw_getmantv32hf */
   14535       780004 :     case 10083:  /* avx512dq_fpclassv2df */
   14536       780004 :     case 10081:  /* avx512dq_fpclassv4df */
   14537       780004 :     case 10079:  /* avx512dq_fpclassv8df */
   14538       780004 :     case 10077:  /* avx512dq_fpclassv4sf */
   14539       780004 :     case 10075:  /* avx512dq_fpclassv8sf */
   14540       780004 :     case 10073:  /* avx512dq_fpclassv16sf */
   14541       780004 :     case 10071:  /* avx512dq_fpclassv8hf */
   14542       780004 :     case 10069:  /* avx512dq_fpclassv16hf */
   14543       780004 :     case 10067:  /* avx512dq_fpclassv32hf */
   14544       780004 :     case 9753:  /* *avx512f_vcvtps2ph512 */
   14545       780004 :     case 9749:  /* *avx512f_vcvtps2ph512 */
   14546       780004 :     case 9747:  /* *vcvtps2ph256 */
   14547       780004 :     case 9745:  /* vcvtps2ph256 */
   14548       780004 :     case 9744:  /* *vcvtps2ph_store */
   14549       780004 :     case 9447:  /* avx_vpermilvarv2df3 */
   14550       780004 :     case 9445:  /* avx_vpermilvarv4df3 */
   14551       780004 :     case 9443:  /* avx512f_vpermilvarv8df3 */
   14552       780004 :     case 9441:  /* avx_vpermilvarv4sf3 */
   14553       780004 :     case 9439:  /* avx_vpermilvarv8sf3 */
   14554       780004 :     case 9437:  /* avx512f_vpermilvarv16sf3 */
   14555       780004 :     case 9218:  /* avx512bw_permvarv32bf */
   14556       780004 :     case 9216:  /* avx512vl_permvarv16bf */
   14557       780004 :     case 9214:  /* avx512vl_permvarv8bf */
   14558       780004 :     case 9212:  /* avx512bw_permvarv32hf */
   14559       780004 :     case 9210:  /* avx512vl_permvarv16hf */
   14560       780004 :     case 9208:  /* avx512fp16_permvarv8hf */
   14561       780004 :     case 9206:  /* avx512bw_permvarv32hi */
   14562       780004 :     case 9204:  /* avx512vl_permvarv16hi */
   14563       780004 :     case 9202:  /* avx512vl_permvarv8hi */
   14564       780004 :     case 9200:  /* avx512vl_permvarv32qi */
   14565       780004 :     case 9198:  /* avx512vl_permvarv16qi */
   14566       780004 :     case 9196:  /* avx512bw_permvarv64qi */
   14567       780004 :     case 9194:  /* avx2_permvarv4df */
   14568       780004 :     case 9192:  /* avx2_permvarv4di */
   14569       780004 :     case 9190:  /* avx512f_permvarv8df */
   14570       780004 :     case 9188:  /* avx512f_permvarv8di */
   14571       780004 :     case 9186:  /* avx512f_permvarv16sf */
   14572       780004 :     case 9184:  /* avx512f_permvarv16si */
   14573       780004 :     case 9182:  /* avx2_permvarv8sf */
   14574       780004 :     case 9180:  /* avx2_permvarv8si */
   14575       780004 :     case 9152:  /* aeskeygenassist */
   14576       780004 :     case 9150:  /* aesdeclast */
   14577       780004 :     case 9149:  /* aesdec */
   14578       780004 :     case 9148:  /* aesenclast */
   14579       780004 :     case 9147:  /* aesenc */
   14580       780004 :     case 9036:  /* sse4_1_roundpd */
   14581       780004 :     case 9035:  /* avx_roundpd256 */
   14582       780004 :     case 9034:  /* sse4_1_roundps */
   14583       780004 :     case 9033:  /* avx_roundps256 */
   14584       780004 :     case 8788:  /* sse4_1_packusdw */
   14585       780004 :     case 8786:  /* avx2_packusdw */
   14586       780004 :     case 8784:  /* avx512bw_packusdw */
   14587       780004 :     case 8734:  /* sse4a_insertq */
   14588       780004 :     case 8732:  /* sse4a_extrq */
   14589       780004 :     case 8695:  /* ssse3_psignv2si3 */
   14590       780004 :     case 8694:  /* ssse3_psignv4hi3 */
   14591       780004 :     case 8693:  /* ssse3_psignv8qi3 */
   14592       780004 :     case 8692:  /* ssse3_psignv4si3 */
   14593       780004 :     case 8691:  /* avx2_psignv8si3 */
   14594       780004 :     case 8690:  /* ssse3_psignv8hi3 */
   14595       780004 :     case 8689:  /* avx2_psignv16hi3 */
   14596       780004 :     case 8688:  /* ssse3_psignv16qi3 */
   14597       780004 :     case 8687:  /* avx2_psignv32qi3 */
   14598       780004 :     case 8684:  /* ssse3_pshufbv16qi3 */
   14599       780004 :     case 8682:  /* avx2_pshufbv32qi3 */
   14600       780004 :     case 8680:  /* avx512bw_pshufbv64qi3 */
   14601       780004 :     case 8666:  /* avx512bw_pmaddubsw512v32hi */
   14602       780004 :     case 8664:  /* avx512bw_pmaddubsw512v16hi */
   14603       780004 :     case 8662:  /* avx512bw_pmaddubsw512v8hi */
   14604       780004 :     case 8563:  /* *sse2_psadbw */
   14605       780004 :     case 8562:  /* *avx2_psadbw */
   14606       780004 :     case 8561:  /* *avx512f_psadbw */
   14607       780004 :     case 8505:  /* *avx512bw_pshufhwv32hi */
   14608       780004 :     case 8499:  /* *avx512bw_pshuflwv32hi */
   14609       780004 :     case 8373:  /* sse2_packuswb */
   14610       780004 :     case 8371:  /* avx2_packuswb */
   14611       780004 :     case 8369:  /* avx512bw_packuswb */
   14612       780004 :     case 8211:  /* avx512vl_testnmv2di3 */
   14613       780004 :     case 8209:  /* avx512vl_testnmv4di3 */
   14614       780004 :     case 8207:  /* avx512f_testnmv8di3 */
   14615       780004 :     case 8205:  /* avx512vl_testnmv4si3 */
   14616       780004 :     case 8203:  /* avx512vl_testnmv8si3 */
   14617       780004 :     case 8201:  /* avx512f_testnmv16si3 */
   14618       780004 :     case 8199:  /* avx512vl_testnmv8hi3 */
   14619       780004 :     case 8197:  /* avx512vl_testnmv16hi3 */
   14620       780004 :     case 8195:  /* avx512bw_testnmv32hi3 */
   14621       780004 :     case 8193:  /* avx512vl_testnmv16qi3 */
   14622       780004 :     case 8191:  /* avx512vl_testnmv32qi3 */
   14623       780004 :     case 8189:  /* avx512bw_testnmv64qi3 */
   14624       780004 :     case 8187:  /* avx512vl_testmv2di3 */
   14625       780004 :     case 8185:  /* avx512vl_testmv4di3 */
   14626       780004 :     case 8183:  /* avx512f_testmv8di3 */
   14627       780004 :     case 8181:  /* avx512vl_testmv4si3 */
   14628       780004 :     case 8179:  /* avx512vl_testmv8si3 */
   14629       780004 :     case 8177:  /* avx512f_testmv16si3 */
   14630       780004 :     case 8175:  /* avx512vl_testmv8hi3 */
   14631       780004 :     case 8173:  /* avx512vl_testmv16hi3 */
   14632       780004 :     case 8171:  /* avx512bw_testmv32hi3 */
   14633       780004 :     case 8169:  /* avx512vl_testmv16qi3 */
   14634       780004 :     case 8167:  /* avx512vl_testmv32qi3 */
   14635       780004 :     case 8165:  /* avx512bw_testmv64qi3 */
   14636       780004 :     case 7640:  /* avx512bw_pmaddwd512v8hi */
   14637       780004 :     case 7638:  /* avx512bw_pmaddwd512v16hi */
   14638       780004 :     case 7636:  /* avx512bw_pmaddwd512v32hi */
   14639       780004 :     case 7191:  /* avx512vl_rndscalev2df */
   14640       780004 :     case 7187:  /* avx512vl_rndscalev4df */
   14641       780004 :     case 7183:  /* avx512f_rndscalev8df */
   14642       780004 :     case 7179:  /* avx512vl_rndscalev4sf */
   14643       780004 :     case 7175:  /* avx512vl_rndscalev8sf */
   14644       780004 :     case 7171:  /* avx512f_rndscalev16sf */
   14645       780004 :     case 7167:  /* avx512fp16_rndscalev8hf */
   14646       780004 :     case 7163:  /* avx512vl_rndscalev16hf */
   14647       780004 :     case 7159:  /* avx512bw_rndscalev32hf */
   14648       780004 :     case 5461:  /* avx512vl_scalefv2df */
   14649       780004 :     case 5457:  /* avx512vl_scalefv4df */
   14650       780004 :     case 5453:  /* avx512f_scalefv8df */
   14651       780004 :     case 5449:  /* avx512vl_scalefv4sf */
   14652       780004 :     case 5445:  /* avx512vl_scalefv8sf */
   14653       780004 :     case 5441:  /* avx512f_scalefv16sf */
   14654       780004 :     case 5437:  /* avx512fp16_scalefv8hf */
   14655       780004 :     case 5433:  /* avx512vl_scalefv16hf */
   14656       780004 :     case 5429:  /* avx512bw_scalefv32hf */
   14657       780004 :     case 4411:  /* avx512fp16_fcmulc_v8hf */
   14658       780004 :     case 4409:  /* avx512fp16_fmulc_v8hf */
   14659       780004 :     case 4407:  /* avx512vl_fcmulc_v16hf */
   14660       780004 :     case 4405:  /* avx512vl_fmulc_v16hf */
   14661       780004 :     case 4401:  /* avx512bw_fcmulc_v32hf */
   14662       780004 :     case 4397:  /* avx512bw_fmulc_v32hf */
   14663       780004 :     case 3635:  /* *avx512vl_eqv2di3_1 */
   14664       780004 :     case 3633:  /* *avx512vl_eqv2di3_1 */
   14665       780004 :     case 3631:  /* *avx512vl_eqv4di3_1 */
   14666       780004 :     case 3629:  /* *avx512vl_eqv4di3_1 */
   14667       780004 :     case 3627:  /* *avx512f_eqv8di3_1 */
   14668       780004 :     case 3625:  /* *avx512f_eqv8di3_1 */
   14669       780004 :     case 3623:  /* *avx512vl_eqv4si3_1 */
   14670       780004 :     case 3621:  /* *avx512vl_eqv4si3_1 */
   14671       780004 :     case 3619:  /* *avx512vl_eqv8si3_1 */
   14672       780004 :     case 3617:  /* *avx512vl_eqv8si3_1 */
   14673       780004 :     case 3615:  /* *avx512f_eqv16si3_1 */
   14674       780004 :     case 3613:  /* *avx512f_eqv16si3_1 */
   14675       780004 :     case 3575:  /* *avx512vl_eqv8hi3_1 */
   14676       780004 :     case 3573:  /* *avx512vl_eqv8hi3_1 */
   14677       780004 :     case 3571:  /* *avx512vl_eqv16hi3_1 */
   14678       780004 :     case 3569:  /* *avx512vl_eqv16hi3_1 */
   14679       780004 :     case 3567:  /* *avx512bw_eqv32hi3_1 */
   14680       780004 :     case 3565:  /* *avx512bw_eqv32hi3_1 */
   14681       780004 :     case 3563:  /* *avx512vl_eqv32qi3_1 */
   14682       780004 :     case 3561:  /* *avx512vl_eqv32qi3_1 */
   14683       780004 :     case 3559:  /* *avx512vl_eqv16qi3_1 */
   14684       780004 :     case 3557:  /* *avx512vl_eqv16qi3_1 */
   14685       780004 :     case 3555:  /* *avx512bw_eqv64qi3_1 */
   14686       780004 :     case 3553:  /* *avx512bw_eqv64qi3_1 */
   14687       780004 :     case 3253:  /* *reducepv2df */
   14688       780004 :     case 3249:  /* *reducepv4df */
   14689       780004 :     case 3245:  /* *reducepv8df */
   14690       780004 :     case 3241:  /* *reducepv4sf */
   14691       780004 :     case 3237:  /* *reducepv8sf */
   14692       780004 :     case 3233:  /* *reducepv16sf */
   14693       780004 :     case 3229:  /* *reducepv8hf */
   14694       780004 :     case 3225:  /* *reducepv16hf */
   14695       780004 :     case 3221:  /* *reducepv32hf */
   14696       780004 :     case 3151:  /* ieee_minv2df3 */
   14697       780004 :     case 3149:  /* ieee_maxv2df3 */
   14698       780004 :     case 3147:  /* ieee_minv4df3 */
   14699       780004 :     case 3145:  /* ieee_maxv4df3 */
   14700       780004 :     case 3141:  /* ieee_minv8df3 */
   14701       780004 :     case 3137:  /* ieee_maxv8df3 */
   14702       780004 :     case 3135:  /* ieee_minv4sf3 */
   14703       780004 :     case 3133:  /* ieee_maxv4sf3 */
   14704       780004 :     case 3131:  /* ieee_minv8sf3 */
   14705       780004 :     case 3129:  /* ieee_maxv8sf3 */
   14706       780004 :     case 3125:  /* ieee_minv16sf3 */
   14707       780004 :     case 3121:  /* ieee_maxv16sf3 */
   14708       780004 :     case 3119:  /* ieee_minv8hf3 */
   14709       780004 :     case 3117:  /* ieee_maxv8hf3 */
   14710       780004 :     case 3115:  /* ieee_minv16hf3 */
   14711       780004 :     case 3113:  /* ieee_maxv16hf3 */
   14712       780004 :     case 3109:  /* ieee_minv32hf3 */
   14713       780004 :     case 3105:  /* ieee_maxv32hf3 */
   14714       780004 :     case 2431:  /* *mmx_psadbw */
   14715       780004 :     case 2379:  /* mmx_pshufbv4qi3 */
   14716       780004 :     case 2378:  /* mmx_pshufbv8qi3 */
   14717       780004 :     case 2343:  /* mmx_packusdw */
   14718       780004 :     case 2341:  /* mmx_packuswb */
   14719       780004 :     case 2111:  /* mmx_rsqit1v2sf3 */
   14720       780004 :     case 2109:  /* mmx_rcpit2v2sf3 */
   14721       780004 :     case 2108:  /* mmx_rcpit1v2sf3 */
   14722       780004 :     case 1961:  /* xsaves64 */
   14723       780004 :     case 1960:  /* xsavec64 */
   14724       780004 :     case 1959:  /* xsaveopt64 */
   14725       780004 :     case 1958:  /* xsave64 */
   14726       780004 :     case 1957:  /* xsaves_rex64 */
   14727       780004 :     case 1956:  /* xsavec_rex64 */
   14728       780004 :     case 1955:  /* xsaveopt_rex64 */
   14729       780004 :     case 1954:  /* xsave_rex64 */
   14730       780004 :     case 1938:  /* sse4_2_crc32si */
   14731       780004 :     case 1937:  /* sse4_2_crc32hi */
   14732       780004 :     case 1936:  /* sse4_2_crc32qi */
   14733       780004 :     case 1852:  /* *ieee_smindf3 */
   14734       780004 :     case 1851:  /* *ieee_smaxdf3 */
   14735       780004 :     case 1850:  /* *ieee_sminsf3 */
   14736       780004 :     case 1849:  /* *ieee_smaxsf3 */
   14737       780004 :     case 1848:  /* *ieee_sminhf3 */
   14738       780004 :     case 1847:  /* *ieee_smaxhf3 */
   14739       780004 :     case 1757:  /* sse4_1_rounddf2 */
   14740       780004 :     case 1756:  /* sse4_1_roundsf2 */
   14741       780004 :     case 1755:  /* sse4_1_roundhf2 */
   14742       780004 :     case 1754:  /* avx512f_scalefdf2 */
   14743       780004 :     case 1753:  /* avx512f_scalefsf2 */
   14744       780004 :     case 1629:  /* bmi2_pext_di3 */
   14745       780004 :     case 1628:  /* bmi2_pext_si3 */
   14746       780004 :     case 1627:  /* bmi2_pdep_di3 */
   14747       780004 :     case 1626:  /* bmi2_pdep_si3 */
   14748       780004 :     case 1478:  /* *setcc_si_slp */
   14749       780004 :     case 163:  /* push2_di */
   14750       780004 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14751       780004 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
   14752       780004 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
   14753       780004 :       break;
   14754              : 
   14755       379628 :     case 155:  /* *insvdi_lowpart_1 */
   14756       379628 :     case 154:  /* *insvdi_lowpart_1 */
   14757       379628 :     case 153:  /* *insvdi_lowpart_1 */
   14758       379628 :     case 152:  /* *insvti_lowpart_1 */
   14759       379628 :     case 151:  /* *insvti_lowpart_1 */
   14760       379628 :     case 150:  /* *insvti_lowpart_1 */
   14761       379628 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14762       379628 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   14763       379628 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   14764       379628 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   14765       379628 :       break;
   14766              : 
   14767      1264065 :     case 149:  /* *insvti_highpart_1 */
   14768      1264065 :     case 148:  /* *insvti_highpart_1 */
   14769      1264065 :     case 147:  /* *insvti_highpart_1 */
   14770      1264065 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14771      1264065 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   14772      1264065 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
   14773      1264065 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   14774      1264065 :       break;
   14775              : 
   14776          471 :     case 140:  /* *insvqi_2 */
   14777          471 :     case 139:  /* *insvqi_2 */
   14778          471 :     case 138:  /* *insvqi_2 */
   14779          471 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 0), 0));
   14780          471 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
   14781          471 :       ro[2] = *(ro_loc[2] = &XEXP (pat, 1));
   14782          471 :       break;
   14783              : 
   14784         5696 :     case 1075:  /* *one_cmplhi_1_slp */
   14785         5696 :     case 1074:  /* *one_cmplqi_1_slp */
   14786         5696 :     case 146:  /* *insvqi_3 */
   14787         5696 :     case 145:  /* *insvqi_3 */
   14788         5696 :     case 144:  /* *insvqi_3 */
   14789         5696 :     case 143:  /* *insvqi_3 */
   14790         5696 :     case 142:  /* *insvqi_3 */
   14791         5696 :     case 141:  /* *insvqi_3 */
   14792         5696 :     case 137:  /* *insvqi_1 */
   14793         5696 :     case 136:  /* *insvqi_1 */
   14794         5696 :     case 135:  /* *insvqi_1 */
   14795         5696 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 0), 0));
   14796         5696 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
   14797         5696 :       break;
   14798              : 
   14799        35948 :     case 131:  /* *extzvqi */
   14800        35948 :     case 130:  /* *extzvqi */
   14801        35948 :     case 129:  /* *extzvqi */
   14802        35948 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14803        35948 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   14804        35948 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
   14805        35948 :       break;
   14806              : 
   14807      1330801 :     case 2649:  /* knotdi */
   14808      1330801 :     case 2648:  /* knotsi */
   14809      1330801 :     case 2647:  /* knothi */
   14810      1330801 :     case 2646:  /* knotqi */
   14811      1330801 :     case 2171:  /* negv2qi2 */
   14812      1330801 :     case 2129:  /* mmx_floatv2siv2sf2 */
   14813      1330801 :     case 2128:  /* mmx_fix_truncv2sfv2si2 */
   14814      1330801 :     case 1828:  /* *x86_movdicc_0_m1_neg */
   14815      1330801 :     case 1827:  /* *x86_movsicc_0_m1_neg */
   14816      1330801 :     case 1826:  /* *x86_movhicc_0_m1_neg */
   14817      1330801 :     case 1825:  /* *x86_movqicc_0_m1_neg */
   14818      1330801 :     case 1824:  /* *x86_movdicc_0_m1_se */
   14819      1330801 :     case 1823:  /* *x86_movsicc_0_m1_se */
   14820      1330801 :     case 1822:  /* *x86_movdicc_0_m1 */
   14821      1330801 :     case 1821:  /* *x86_movsicc_0_m1 */
   14822      1330801 :     case 1665:  /* popcounthi2 */
   14823      1330801 :     case 1653:  /* popcountdi2 */
   14824      1330801 :     case 1652:  /* popcountsi2 */
   14825      1330801 :     case 1561:  /* clzdi2_lzcnt */
   14826      1330801 :     case 1560:  /* clzsi2_lzcnt */
   14827      1330801 :     case 1539:  /* ctzdi2 */
   14828      1330801 :     case 1538:  /* ctzsi2 */
   14829      1330801 :     case 1047:  /* *negxf2_i387_1 */
   14830      1330801 :     case 1046:  /* *absxf2_i387_1 */
   14831      1330801 :     case 1045:  /* *negdf2_i387_1 */
   14832      1330801 :     case 1044:  /* *absdf2_i387_1 */
   14833      1330801 :     case 1043:  /* *negsf2_i387_1 */
   14834      1330801 :     case 1042:  /* *abssf2_i387_1 */
   14835      1330801 :     case 1034:  /* *absdi2_1 */
   14836      1330801 :     case 1033:  /* *abssi2_1 */
   14837      1330801 :     case 1032:  /* *abshi2_1 */
   14838      1330801 :     case 1031:  /* *absqi2_1 */
   14839      1330801 :     case 1028:  /* *absti2_doubleword */
   14840      1330801 :     case 1027:  /* *absdi2_doubleword */
   14841      1330801 :     case 993:  /* *negdi_1 */
   14842      1330801 :     case 991:  /* *negsi_1 */
   14843      1330801 :     case 989:  /* *neghi_1 */
   14844      1330801 :     case 987:  /* *negqi_1 */
   14845      1330801 :     case 985:  /* *negti2_doubleword */
   14846      1330801 :     case 984:  /* *negdi2_doubleword */
   14847      1330801 :     case 238:  /* *fix_truncdi_i387_1 */
   14848      1330801 :     case 237:  /* *fix_truncsi_i387_1 */
   14849      1330801 :     case 236:  /* *fix_trunchi_i387_1 */
   14850      1330801 :     case 186:  /* zero_extendqihi2_and */
   14851      1330801 :     case 183:  /* zero_extendhisi2_and */
   14852      1330801 :     case 182:  /* zero_extendqisi2_and */
   14853      1330801 :     case 125:  /* *extvdi_1_0 */
   14854      1330801 :     case 124:  /* *extvsi_1_0 */
   14855      1330801 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14856      1330801 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14857      1330801 :       break;
   14858              : 
   14859          247 :     case 1083:  /* *one_cmplqi_extdi_1 */
   14860          247 :     case 1082:  /* *one_cmplqi_extsi_1 */
   14861          247 :     case 1081:  /* *one_cmplqi_exthi_1 */
   14862          247 :     case 121:  /* *movstrictqi_extdi_1 */
   14863          247 :     case 120:  /* *movstrictqi_extsi_1 */
   14864          247 :     case 119:  /* *movstrictqi_exthi_1 */
   14865          247 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 0), 0));
   14866          247 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   14867          247 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
   14868          247 :       break;
   14869              : 
   14870        15097 :     case 1495:  /* *sibcall_memory */
   14871        15097 :     case 1494:  /* *sibcall_memory */
   14872        15097 :     case 118:  /* *movstricthi_xor */
   14873        15097 :     case 117:  /* *movstrictqi_xor */
   14874        15097 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   14875        15097 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 1));
   14876        15097 :       break;
   14877              : 
   14878       120489 :     case 177:  /* *swapxf */
   14879       120489 :     case 114:  /* *swaphi */
   14880       120489 :     case 113:  /* *swapqi */
   14881       120489 :     case 112:  /* swapdi */
   14882       120489 :     case 111:  /* swapsi */
   14883       120489 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14884       120489 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 1));
   14885       120489 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0);
   14886       120489 :       recog_data.dup_num[0] = 1;
   14887       120489 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 1);
   14888       120489 :       recog_data.dup_num[1] = 0;
   14889       120489 :       break;
   14890              : 
   14891     35518801 :     case 10771:  /* avx10_2_sqrtbf16_v8bf */
   14892     35518801 :     case 10769:  /* avx10_2_sqrtbf16_v16bf */
   14893     35518801 :     case 10767:  /* avx10_2_sqrtbf16_v32bf */
   14894     35518801 :     case 10434:  /* avx512f_cvtneps2bf16_v8sf */
   14895     35518801 :     case 10432:  /* avx512f_cvtneps2bf16_v16sf */
   14896     35518801 :     case 10431:  /* vcvtneps2bf16_v8sf */
   14897     35518801 :     case 10248:  /* vpopcountv8hi */
   14898     35518801 :     case 10246:  /* vpopcountv16hi */
   14899     35518801 :     case 10244:  /* vpopcountv32hi */
   14900     35518801 :     case 10242:  /* vpopcountv32qi */
   14901     35518801 :     case 10240:  /* vpopcountv16qi */
   14902     35518801 :     case 10238:  /* vpopcountv64qi */
   14903     35518801 :     case 10228:  /* vpopcountv2di */
   14904     35518801 :     case 10226:  /* vpopcountv4di */
   14905     35518801 :     case 10224:  /* vpopcountv8di */
   14906     35518801 :     case 10222:  /* vpopcountv4si */
   14907     35518801 :     case 10220:  /* vpopcountv8si */
   14908     35518801 :     case 10218:  /* vpopcountv16si */
   14909     35518801 :     case 10193:  /* avx512f_pd512_256pd */
   14910     35518801 :     case 10192:  /* avx512f_ps512_256ps */
   14911     35518801 :     case 10191:  /* avx512f_si512_256si */
   14912     35518801 :     case 10155:  /* clzv2di2 */
   14913     35518801 :     case 10153:  /* clzv4di2 */
   14914     35518801 :     case 10151:  /* clzv8di2 */
   14915     35518801 :     case 10149:  /* clzv4si2 */
   14916     35518801 :     case 10147:  /* clzv8si2 */
   14917     35518801 :     case 10145:  /* clzv16si2 */
   14918     35518801 :     case 9637:  /* avx_pd256_pd */
   14919     35518801 :     case 9636:  /* avx_ps256_ps */
   14920     35518801 :     case 9635:  /* avx_si256_si */
   14921     35518801 :     case 9429:  /* *avx512dq_broadcastv4df_1 */
   14922     35518801 :     case 9427:  /* *avx512dq_broadcastv4di_1 */
   14923     35518801 :     case 9425:  /* *avx512dq_broadcastv8df_1 */
   14924     35518801 :     case 9423:  /* *avx512dq_broadcastv8di_1 */
   14925     35518801 :     case 9421:  /* *avx512dq_broadcastv16si_1 */
   14926     35518801 :     case 9419:  /* *avx512dq_broadcastv16sf_1 */
   14927     35518801 :     case 9417:  /* *avx512vl_broadcastv8sf_1 */
   14928     35518801 :     case 9415:  /* *avx512vl_broadcastv8si_1 */
   14929     35518801 :     case 9388:  /* vec_dupv4df */
   14930     35518801 :     case 9387:  /* vec_dupv4di */
   14931     35518801 :     case 9386:  /* vec_dupv8sf */
   14932     35518801 :     case 9385:  /* vec_dupv8si */
   14933     35518801 :     case 9384:  /* *vec_dupv8bf */
   14934     35518801 :     case 9383:  /* *vec_dupv16bf */
   14935     35518801 :     case 9382:  /* *vec_dupv8hf */
   14936     35518801 :     case 9381:  /* *vec_dupv16hf */
   14937     35518801 :     case 9380:  /* *vec_dupv4si */
   14938     35518801 :     case 9379:  /* *vec_dupv8si */
   14939     35518801 :     case 9378:  /* *vec_dupv8hi */
   14940     35518801 :     case 9377:  /* *vec_dupv16hi */
   14941     35518801 :     case 9376:  /* *vec_dupv16qi */
   14942     35518801 :     case 9375:  /* *vec_dupv32qi */
   14943     35518801 :     case 9369:  /* *vec_dupv2di */
   14944     35518801 :     case 9368:  /* *vec_dupv4si */
   14945     35518801 :     case 9367:  /* vec_dupv4sf */
   14946     35518801 :     case 9365:  /* *avx512vl_vec_dup_gprv2df */
   14947     35518801 :     case 9363:  /* *avx512vl_vec_dup_gprv4df */
   14948     35518801 :     case 9361:  /* *avx512f_vec_dup_gprv8df */
   14949     35518801 :     case 9359:  /* *avx512vl_vec_dup_gprv4sf */
   14950     35518801 :     case 9357:  /* *avx512vl_vec_dup_gprv8sf */
   14951     35518801 :     case 9355:  /* *avx512f_vec_dup_gprv16sf */
   14952     35518801 :     case 9353:  /* *avx512vl_vec_dup_gprv2di */
   14953     35518801 :     case 9351:  /* *avx512vl_vec_dup_gprv4di */
   14954     35518801 :     case 9349:  /* *avx512f_vec_dup_gprv8di */
   14955     35518801 :     case 9347:  /* *avx512vl_vec_dup_gprv4si */
   14956     35518801 :     case 9345:  /* *avx512vl_vec_dup_gprv8si */
   14957     35518801 :     case 9343:  /* *avx512f_vec_dup_gprv16si */
   14958     35518801 :     case 9341:  /* *avx512vl_vec_dup_gprv8bf */
   14959     35518801 :     case 9339:  /* *avx512vl_vec_dup_gprv16bf */
   14960     35518801 :     case 9337:  /* *avx512bw_vec_dup_gprv32bf */
   14961     35518801 :     case 9335:  /* *avx512fp16_vec_dup_gprv8hf */
   14962     35518801 :     case 9333:  /* *avx512vl_vec_dup_gprv16hf */
   14963     35518801 :     case 9331:  /* *avx512bw_vec_dup_gprv32hf */
   14964     35518801 :     case 9329:  /* *avx512vl_vec_dup_gprv8hi */
   14965     35518801 :     case 9327:  /* *avx512vl_vec_dup_gprv16hi */
   14966     35518801 :     case 9325:  /* *avx512bw_vec_dup_gprv32hi */
   14967     35518801 :     case 9323:  /* *avx512vl_vec_dup_gprv32qi */
   14968     35518801 :     case 9321:  /* *avx512vl_vec_dup_gprv16qi */
   14969     35518801 :     case 9319:  /* *avx512bw_vec_dup_gprv64qi */
   14970     35518801 :     case 9317:  /* *avx512f_broadcastv8di */
   14971     35518801 :     case 9315:  /* *avx512f_broadcastv8df */
   14972     35518801 :     case 9313:  /* *avx512f_broadcastv16si */
   14973     35518801 :     case 9311:  /* *avx512f_broadcastv16sf */
   14974     35518801 :     case 8984:  /* *sse4_1_zero_extendv2siv2di2_1 */
   14975     35518801 :     case 8982:  /* *sse4_1_sign_extendv2siv2di2_1 */
   14976     35518801 :     case 8974:  /* avx2_zero_extendv4siv4di2 */
   14977     35518801 :     case 8972:  /* avx2_sign_extendv4siv4di2 */
   14978     35518801 :     case 8968:  /* avx512f_zero_extendv8siv8di2 */
   14979     35518801 :     case 8966:  /* avx512f_sign_extendv8siv8di2 */
   14980     35518801 :     case 8960:  /* *sse4_1_zero_extendv2hiv2di2_1 */
   14981     35518801 :     case 8958:  /* *sse4_1_sign_extendv2hiv2di2_1 */
   14982     35518801 :     case 8948:  /* *avx2_zero_extendv4hiv4di2_1 */
   14983     35518801 :     case 8946:  /* *avx2_sign_extendv4hiv4di2_1 */
   14984     35518801 :     case 8940:  /* avx512f_zero_extendv8hiv8di2 */
   14985     35518801 :     case 8938:  /* avx512f_sign_extendv8hiv8di2 */
   14986     35518801 :     case 8933:  /* *sse4_1_zero_extendv2qiv2di2_1 */
   14987     35518801 :     case 8931:  /* *sse4_1_sign_extendv2qiv2di2_1 */
   14988     35518801 :     case 8921:  /* *avx2_zero_extendv4qiv4di2_1 */
   14989     35518801 :     case 8919:  /* *avx2_sign_extendv4qiv4di2_1 */
   14990     35518801 :     case 8909:  /* *avx512f_zero_extendv8qiv8di2_1 */
   14991     35518801 :     case 8907:  /* *avx512f_sign_extendv8qiv8di2_1 */
   14992     35518801 :     case 8893:  /* *sse4_1_zero_extendv4hiv4si2_1 */
   14993     35518801 :     case 8891:  /* *sse4_1_sign_extendv4hiv4si2_1 */
   14994     35518801 :     case 8881:  /* avx2_zero_extendv8hiv8si2 */
   14995     35518801 :     case 8879:  /* avx2_sign_extendv8hiv8si2 */
   14996     35518801 :     case 8873:  /* avx512f_zero_extendv16hiv16si2 */
   14997     35518801 :     case 8871:  /* avx512f_sign_extendv16hiv16si2 */
   14998     35518801 :     case 8863:  /* *sse4_1_zero_extendv4qiv4si2_1 */
   14999     35518801 :     case 8861:  /* *sse4_1_sign_extendv4qiv4si2_1 */
   15000     35518801 :     case 8851:  /* *avx2_zero_extendv8qiv8si2_1 */
   15001     35518801 :     case 8849:  /* *avx2_sign_extendv8qiv8si2_1 */
   15002     35518801 :     case 8843:  /* *avx512f_zero_extendv16qiv16si2 */
   15003     35518801 :     case 8841:  /* *avx512f_sign_extendv16qiv16si2 */
   15004     35518801 :     case 8831:  /* *sse4_1_zero_extendv8qiv8hi2_1 */
   15005     35518801 :     case 8829:  /* *sse4_1_sign_extendv8qiv8hi2_1 */
   15006     35518801 :     case 8819:  /* avx512bw_zero_extendv32qiv32hi2 */
   15007     35518801 :     case 8817:  /* avx512bw_sign_extendv32qiv32hi2 */
   15008     35518801 :     case 8811:  /* avx2_zero_extendv16qiv16hi2 */
   15009     35518801 :     case 8809:  /* avx2_sign_extendv16qiv16hi2 */
   15010     35518801 :     case 8714:  /* *absv2di2 */
   15011     35518801 :     case 8713:  /* *absv4di2 */
   15012     35518801 :     case 8712:  /* *absv8di2 */
   15013     35518801 :     case 8711:  /* *absv4si2 */
   15014     35518801 :     case 8710:  /* *absv8si2 */
   15015     35518801 :     case 8709:  /* *absv16si2 */
   15016     35518801 :     case 8708:  /* *absv8hi2 */
   15017     35518801 :     case 8707:  /* *absv16hi2 */
   15018     35518801 :     case 8706:  /* *absv32hi2 */
   15019     35518801 :     case 8705:  /* *absv16qi2 */
   15020     35518801 :     case 8704:  /* *absv32qi2 */
   15021     35518801 :     case 8703:  /* *absv64qi2 */
   15022     35518801 :     case 8532:  /* *vec_extractv2di_1 */
   15023     35518801 :     case 8525:  /* *vec_extractv2di_0_sse */
   15024     35518801 :     case 8524:  /* *vec_extractv2di_0 */
   15025     35518801 :     case 8523:  /* *vec_extractv4si_0 */
   15026     35518801 :     case 8513:  /* *vec_extractv8hi_0_mem */
   15027     35518801 :     case 8512:  /* *vec_extractv16qi_0_mem */
   15028     35518801 :     case 7473:  /* *avx512f_us_truncatev8div16qi2_store_1 */
   15029     35518801 :     case 7472:  /* *avx512f_truncatev8div16qi2_store_1 */
   15030     35518801 :     case 7471:  /* *avx512f_ss_truncatev8div16qi2_store_1 */
   15031     35518801 :     case 7455:  /* *avx512vl_us_truncatev2div2si2_store_1 */
   15032     35518801 :     case 7454:  /* *avx512vl_truncatev2div2si2_store_1 */
   15033     35518801 :     case 7453:  /* *avx512vl_ss_truncatev2div2si2_store_1 */
   15034     35518801 :     case 7436:  /* *avx512vl_us_truncatev2div2hi2_store_1 */
   15035     35518801 :     case 7435:  /* *avx512vl_truncatev2div2hi2_store_1 */
   15036     35518801 :     case 7434:  /* *avx512vl_ss_truncatev2div2hi2_store_1 */
   15037     35518801 :     case 7409:  /* *avx512vl_us_truncatev4div4hi2_store_1 */
   15038     35518801 :     case 7408:  /* *avx512vl_truncatev4div4hi2_store_1 */
   15039     35518801 :     case 7407:  /* *avx512vl_ss_truncatev4div4hi2_store_1 */
   15040     35518801 :     case 7406:  /* *avx512vl_us_truncatev4siv4hi2_store_1 */
   15041     35518801 :     case 7405:  /* *avx512vl_truncatev4siv4hi2_store_1 */
   15042     35518801 :     case 7404:  /* *avx512vl_ss_truncatev4siv4hi2_store_1 */
   15043     35518801 :     case 7369:  /* *avx512vl_us_truncatev8siv8qi2_store_1 */
   15044     35518801 :     case 7368:  /* *avx512vl_truncatev8siv8qi2_store_1 */
   15045     35518801 :     case 7367:  /* *avx512vl_ss_truncatev8siv8qi2_store_1 */
   15046     35518801 :     case 7366:  /* *avx512vl_us_truncatev8hiv8qi2_store_1 */
   15047     35518801 :     case 7365:  /* *avx512vl_truncatev8hiv8qi2_store_1 */
   15048     35518801 :     case 7364:  /* *avx512vl_ss_truncatev8hiv8qi2_store_1 */
   15049     35518801 :     case 7339:  /* *avx512vl_us_truncatev4div4qi2_store_1 */
   15050     35518801 :     case 7338:  /* *avx512vl_truncatev4div4qi2_store_1 */
   15051     35518801 :     case 7337:  /* *avx512vl_ss_truncatev4div4qi2_store_1 */
   15052     35518801 :     case 7336:  /* *avx512vl_us_truncatev4siv4qi2_store_1 */
   15053     35518801 :     case 7335:  /* *avx512vl_truncatev4siv4qi2_store_1 */
   15054     35518801 :     case 7334:  /* *avx512vl_ss_truncatev4siv4qi2_store_1 */
   15055     35518801 :     case 7321:  /* *avx512vl_us_truncatev2div2qi2_store_1 */
   15056     35518801 :     case 7320:  /* *avx512vl_truncatev2div2qi2_store_1 */
   15057     35518801 :     case 7319:  /* *avx512vl_ss_truncatev2div2qi2_store_1 */
   15058     35518801 :     case 7291:  /* *avx512vl_us_truncatev16hiv16qi2 */
   15059     35518801 :     case 7290:  /* *avx512vl_truncatev16hiv16qi2 */
   15060     35518801 :     case 7289:  /* *avx512vl_ss_truncatev16hiv16qi2 */
   15061     35518801 :     case 7288:  /* *avx512vl_us_truncatev8siv8hi2 */
   15062     35518801 :     case 7287:  /* *avx512vl_truncatev8siv8hi2 */
   15063     35518801 :     case 7286:  /* *avx512vl_ss_truncatev8siv8hi2 */
   15064     35518801 :     case 7285:  /* *avx512vl_us_truncatev4div4si2 */
   15065     35518801 :     case 7284:  /* *avx512vl_truncatev4div4si2 */
   15066     35518801 :     case 7283:  /* *avx512vl_ss_truncatev4div4si2 */
   15067     35518801 :     case 7278:  /* avx512bw_us_truncatev32hiv32qi2 */
   15068     35518801 :     case 7277:  /* avx512bw_truncatev32hiv32qi2 */
   15069     35518801 :     case 7276:  /* avx512bw_ss_truncatev32hiv32qi2 */
   15070     35518801 :     case 7258:  /* *avx512f_us_truncatev8div8hi2 */
   15071     35518801 :     case 7257:  /* *avx512f_truncatev8div8hi2 */
   15072     35518801 :     case 7256:  /* *avx512f_ss_truncatev8div8hi2 */
   15073     35518801 :     case 7255:  /* *avx512f_us_truncatev8div8si2 */
   15074     35518801 :     case 7254:  /* *avx512f_truncatev8div8si2 */
   15075     35518801 :     case 7253:  /* *avx512f_ss_truncatev8div8si2 */
   15076     35518801 :     case 7252:  /* *avx512f_us_truncatev16siv16hi2 */
   15077     35518801 :     case 7251:  /* *avx512f_truncatev16siv16hi2 */
   15078     35518801 :     case 7250:  /* *avx512f_ss_truncatev16siv16hi2 */
   15079     35518801 :     case 7249:  /* *avx512f_us_truncatev16siv16qi2 */
   15080     35518801 :     case 7248:  /* *avx512f_truncatev16siv16qi2 */
   15081     35518801 :     case 7247:  /* *avx512f_ss_truncatev16siv16qi2 */
   15082     35518801 :     case 7242:  /* vec_dupv2df */
   15083     35518801 :     case 7237:  /* *vec_extractv2df_0_sse */
   15084     35518801 :     case 7236:  /* sse2_storelpd */
   15085     35518801 :     case 7235:  /* *vec_extractv2df_1_sse */
   15086     35518801 :     case 7234:  /* sse2_storehpd */
   15087     35518801 :     case 5398:  /* *vec_extractv8bf_0 */
   15088     35518801 :     case 5397:  /* *vec_extractv16bf_0 */
   15089     35518801 :     case 5396:  /* *vec_extractv32bf_0 */
   15090     35518801 :     case 5395:  /* *vec_extractv8hf_0 */
   15091     35518801 :     case 5394:  /* *vec_extractv16hf_0 */
   15092     35518801 :     case 5393:  /* *vec_extractv32hf_0 */
   15093     35518801 :     case 5392:  /* vec_extract_hi_v32qi */
   15094     35518801 :     case 5391:  /* vec_extract_lo_v32qi */
   15095     35518801 :     case 5390:  /* vec_extract_hi_v64qi */
   15096     35518801 :     case 5389:  /* vec_extract_lo_v64qi */
   15097     35518801 :     case 5388:  /* vec_extract_hi_v16bf */
   15098     35518801 :     case 5387:  /* vec_extract_hi_v16hf */
   15099     35518801 :     case 5386:  /* vec_extract_hi_v16hi */
   15100     35518801 :     case 5385:  /* vec_extract_lo_v16bf */
   15101     35518801 :     case 5384:  /* vec_extract_lo_v16hf */
   15102     35518801 :     case 5383:  /* vec_extract_lo_v16hi */
   15103     35518801 :     case 5382:  /* vec_extract_hi_v32bf */
   15104     35518801 :     case 5381:  /* vec_extract_hi_v32hf */
   15105     35518801 :     case 5380:  /* vec_extract_hi_v32hi */
   15106     35518801 :     case 5379:  /* vec_extract_lo_v32bf */
   15107     35518801 :     case 5378:  /* vec_extract_lo_v32hf */
   15108     35518801 :     case 5377:  /* vec_extract_lo_v32hi */
   15109     35518801 :     case 5376:  /* vec_extract_hi_v8sf */
   15110     35518801 :     case 5375:  /* vec_extract_hi_v8si */
   15111     35518801 :     case 5372:  /* vec_extract_lo_v8sf */
   15112     35518801 :     case 5371:  /* vec_extract_lo_v8si */
   15113     35518801 :     case 5368:  /* vec_extract_hi_v4df */
   15114     35518801 :     case 5367:  /* vec_extract_hi_v4di */
   15115     35518801 :     case 5364:  /* vec_extract_lo_v4df */
   15116     35518801 :     case 5363:  /* vec_extract_lo_v4di */
   15117     35518801 :     case 5360:  /* vec_extract_lo_v16si */
   15118     35518801 :     case 5359:  /* vec_extract_lo_v16sf */
   15119     35518801 :     case 5356:  /* vec_extract_hi_v16si */
   15120     35518801 :     case 5355:  /* vec_extract_hi_v16sf */
   15121     35518801 :     case 5352:  /* vec_extract_hi_v8di */
   15122     35518801 :     case 5351:  /* vec_extract_hi_v8df */
   15123     35518801 :     case 5348:  /* vec_extract_lo_v8di */
   15124     35518801 :     case 5347:  /* vec_extract_lo_v8df */
   15125     35518801 :     case 5334:  /* *vec_extractv4sf_0 */
   15126     35518801 :     case 5278:  /* sse_storelps */
   15127     35518801 :     case 5276:  /* sse_storehps */
   15128     35518801 :     case 5240:  /* sse2_cvtps2pd_1 */
   15129     35518801 :     case 5192:  /* avx_cvtps2pd256 */
   15130     35518801 :     case 5188:  /* avx512f_cvtps2pd512 */
   15131     35518801 :     case 5185:  /* truncv2dfv2sf2 */
   15132     35518801 :     case 5182:  /* avx_cvtpd2ps256 */
   15133     35518801 :     case 5178:  /* *avx512f_cvtpd2ps512 */
   15134     35518801 :     case 5161:  /* *fixuns_truncv4sfv4si2 */
   15135     35518801 :     case 5159:  /* *fixuns_truncv8sfv8si2 */
   15136     35518801 :     case 5145:  /* fixuns_truncv4sfv4di2 */
   15137     35518801 :     case 5143:  /* fix_truncv4sfv4di2 */
   15138     35518801 :     case 5139:  /* fixuns_truncv8sfv8di2 */
   15139     35518801 :     case 5135:  /* fix_truncv8sfv8di2 */
   15140     35518801 :     case 5105:  /* fixuns_truncv2dfv2di2 */
   15141     35518801 :     case 5103:  /* fix_truncv2dfv2di2 */
   15142     35518801 :     case 5101:  /* fixuns_truncv4dfv4di2 */
   15143     35518801 :     case 5099:  /* fix_truncv4dfv4di2 */
   15144     35518801 :     case 5095:  /* fixuns_truncv8dfv8di2 */
   15145     35518801 :     case 5091:  /* fix_truncv8dfv8di2 */
   15146     35518801 :     case 5073:  /* fixuns_truncv4dfv4si2 */
   15147     35518801 :     case 5069:  /* fix_truncv4dfv4si2 */
   15148     35518801 :     case 5058:  /* fixuns_truncv8dfv8si2 */
   15149     35518801 :     case 5054:  /* fix_truncv8dfv8si2 */
   15150     35518801 :     case 5017:  /* floatunsv4siv4df2 */
   15151     35518801 :     case 5015:  /* floatunsv8siv8df2 */
   15152     35518801 :     case 5007:  /* floatunsv4div4sf2 */
   15153     35518801 :     case 5005:  /* floatv4div4sf2 */
   15154     35518801 :     case 5001:  /* floatunsv8div8sf2 */
   15155     35518801 :     case 4997:  /* floatv8div8sf2 */
   15156     35518801 :     case 4993:  /* floatunsv2div2df2 */
   15157     35518801 :     case 4989:  /* floatv2div2df2 */
   15158     35518801 :     case 4985:  /* floatunsv4div4df2 */
   15159     35518801 :     case 4981:  /* floatv4div4df2 */
   15160     35518801 :     case 4977:  /* floatunsv8div8df2 */
   15161     35518801 :     case 4973:  /* floatv8div8df2 */
   15162     35518801 :     case 4971:  /* floatv4siv4df2 */
   15163     35518801 :     case 4969:  /* floatv8siv8df2 */
   15164     35518801 :     case 4927:  /* fixuns_truncv2dfv2si2 */
   15165     35518801 :     case 4925:  /* sse2_cvttpd2pi */
   15166     35518801 :     case 4922:  /* floatunsv2siv2df2 */
   15167     35518801 :     case 4921:  /* sse2_cvtpi2pd */
   15168     35518801 :     case 4919:  /* fix_truncv4sfv4si2 */
   15169     35518801 :     case 4915:  /* fix_truncv8sfv8si2 */
   15170     35518801 :     case 4909:  /* fixuns_truncv16sfv16si2 */
   15171     35518801 :     case 4905:  /* fix_truncv16sfv16si2 */
   15172     35518801 :     case 4857:  /* *floatunsv4siv4sf2 */
   15173     35518801 :     case 4853:  /* *floatunsv8siv8sf2 */
   15174     35518801 :     case 4849:  /* *floatunsv16siv16sf2 */
   15175     35518801 :     case 4847:  /* floatv4siv4sf2 */
   15176     35518801 :     case 4845:  /* floatv8siv8sf2 */
   15177     35518801 :     case 4841:  /* floatv16siv16sf2 */
   15178     35518801 :     case 4775:  /* avx512fp16_vcvtps2ph_v8sf */
   15179     35518801 :     case 4771:  /* avx512fp16_vcvtps2ph_v16sf */
   15180     35518801 :     case 4767:  /* avx512fp16_vcvtpd2ph_v8df */
   15181     35518801 :     case 4765:  /* *avx512fp16_float_extend_phv2df2_load */
   15182     35518801 :     case 4761:  /* *avx512fp16_float_extend_phv4sf2_load */
   15183     35518801 :     case 4759:  /* *avx512fp16_float_extend_phv4df2_load */
   15184     35518801 :     case 4751:  /* avx512fp16_float_extend_phv8sf2 */
   15185     35518801 :     case 4747:  /* avx512fp16_float_extend_phv16sf2 */
   15186     35518801 :     case 4743:  /* avx512fp16_float_extend_phv8df2 */
   15187     35518801 :     case 4742:  /* avx512fp16_fixuns_truncdi2_mem */
   15188     35518801 :     case 4741:  /* avx512fp16_fix_truncdi2_mem */
   15189     35518801 :     case 4740:  /* avx512fp16_fixuns_truncsi2_mem */
   15190     35518801 :     case 4739:  /* avx512fp16_fix_truncsi2_mem */
   15191     35518801 :     case 4721:  /* *avx512fp16_fixuns_truncv2di2_load */
   15192     35518801 :     case 4719:  /* *avx512fp16_fix_truncv2di2_load */
   15193     35518801 :     case 4709:  /* *avx512fp16_fixuns_truncv4di2_load */
   15194     35518801 :     case 4707:  /* *avx512fp16_fix_truncv4di2_load */
   15195     35518801 :     case 4705:  /* *avx512fp16_fixuns_truncv4si2_load */
   15196     35518801 :     case 4703:  /* *avx512fp16_fix_truncv4si2_load */
   15197     35518801 :     case 4683:  /* avx512fp16_fixuns_truncv8di2 */
   15198     35518801 :     case 4679:  /* avx512fp16_fix_truncv8di2 */
   15199     35518801 :     case 4675:  /* avx512fp16_fixuns_truncv16si2 */
   15200     35518801 :     case 4671:  /* avx512fp16_fix_truncv16si2 */
   15201     35518801 :     case 4667:  /* avx512fp16_fixuns_truncv8si2 */
   15202     35518801 :     case 4663:  /* avx512fp16_fix_truncv8si2 */
   15203     35518801 :     case 4659:  /* avx512fp16_fixuns_truncv32hi2 */
   15204     35518801 :     case 4655:  /* avx512fp16_fix_truncv32hi2 */
   15205     35518801 :     case 4651:  /* avx512fp16_fixuns_truncv16hi2 */
   15206     35518801 :     case 4647:  /* avx512fp16_fix_truncv16hi2 */
   15207     35518801 :     case 4643:  /* avx512fp16_fixuns_truncv8hi2 */
   15208     35518801 :     case 4639:  /* avx512fp16_fix_truncv8hi2 */
   15209     35518801 :     case 4549:  /* avx512fp16_vcvtuqq2ph_v8di */
   15210     35518801 :     case 4545:  /* avx512fp16_vcvtqq2ph_v8di */
   15211     35518801 :     case 4541:  /* avx512fp16_vcvtudq2ph_v16si */
   15212     35518801 :     case 4537:  /* avx512fp16_vcvtdq2ph_v16si */
   15213     35518801 :     case 4533:  /* avx512fp16_vcvtudq2ph_v8si */
   15214     35518801 :     case 4529:  /* avx512fp16_vcvtdq2ph_v8si */
   15215     35518801 :     case 4525:  /* avx512fp16_vcvtuw2ph_v32hi */
   15216     35518801 :     case 4521:  /* avx512fp16_vcvtw2ph_v32hi */
   15217     35518801 :     case 4517:  /* avx512fp16_vcvtuw2ph_v16hi */
   15218     35518801 :     case 4513:  /* avx512fp16_vcvtw2ph_v16hi */
   15219     35518801 :     case 4509:  /* avx512fp16_vcvtuw2ph_v8hi */
   15220     35518801 :     case 4505:  /* avx512fp16_vcvtw2ph_v8hi */
   15221     35518801 :     case 2980:  /* sse2_sqrtv2df2 */
   15222     35518801 :     case 2978:  /* avx_sqrtv4df2 */
   15223     35518801 :     case 2974:  /* avx512f_sqrtv8df2 */
   15224     35518801 :     case 2972:  /* sse_sqrtv4sf2 */
   15225     35518801 :     case 2970:  /* avx_sqrtv8sf2 */
   15226     35518801 :     case 2966:  /* avx512f_sqrtv16sf2 */
   15227     35518801 :     case 2964:  /* avx512fp16_sqrtv8hf2 */
   15228     35518801 :     case 2962:  /* avx512fp16_sqrtv16hf2 */
   15229     35518801 :     case 2958:  /* avx512fp16_sqrtv32hf2 */
   15230     35518801 :     case 2442:  /* popcountv2si2 */
   15231     35518801 :     case 2441:  /* popcountv2hi2 */
   15232     35518801 :     case 2440:  /* popcountv4hi2 */
   15233     35518801 :     case 2439:  /* popcountv2qi2 */
   15234     35518801 :     case 2438:  /* popcountv4qi2 */
   15235     35518801 :     case 2437:  /* popcountv8qi2 */
   15236     35518801 :     case 2425:  /* *vec_dupv2hi */
   15237     35518801 :     case 2424:  /* *vec_dupv2bf */
   15238     35518801 :     case 2423:  /* *vec_dupv2hf */
   15239     35518801 :     case 2400:  /* *vec_extractv2si_1 */
   15240     35518801 :     case 2397:  /* *vec_extractv2si_0 */
   15241     35518801 :     case 2395:  /* *vec_dupv2si */
   15242     35518801 :     case 2394:  /* *vec_dupv4hi */
   15243     35518801 :     case 2393:  /* *vec_dupv4bf */
   15244     35518801 :     case 2392:  /* *vec_dupv4hf */
   15245     35518801 :     case 2390:  /* mmx_pswapdv2si2 */
   15246     35518801 :     case 2363:  /* avx512vl_truncv2siv2hi2 */
   15247     35518801 :     case 2362:  /* avx512vl_truncv2siv2qi2 */
   15248     35518801 :     case 2361:  /* avx512vl_truncv2hiv2qi2 */
   15249     35518801 :     case 2360:  /* avx512vl_truncv4hiv4qi2 */
   15250     35518801 :     case 2315:  /* one_cmplv2hi2 */
   15251     35518801 :     case 2314:  /* one_cmplv2qi2 */
   15252     35518801 :     case 2313:  /* one_cmplv4qi2 */
   15253     35518801 :     case 2245:  /* absv2hi2 */
   15254     35518801 :     case 2244:  /* absv2qi2 */
   15255     35518801 :     case 2243:  /* absv4qi2 */
   15256     35518801 :     case 2242:  /* ssse3_absv2si2 */
   15257     35518801 :     case 2241:  /* ssse3_absv4hi2 */
   15258     35518801 :     case 2240:  /* ssse3_absv8qi2 */
   15259     35518801 :     case 2142:  /* *vec_extractv2sf_1 */
   15260     35518801 :     case 2141:  /* *vec_extractv2sf_0 */
   15261     35518801 :     case 2137:  /* *vec_dupv2sf */
   15262     35518801 :     case 2134:  /* *mmx_movsldup */
   15263     35518801 :     case 2133:  /* *mmx_movshdup */
   15264     35518801 :     case 2132:  /* mmx_pswapdv2sf2 */
   15265     35518801 :     case 1739:  /* *sqrtdf2_sse */
   15266     35518801 :     case 1738:  /* *sqrtsf2_sse */
   15267     35518801 :     case 1737:  /* sqrthf2 */
   15268     35518801 :     case 1734:  /* sqrtxf2 */
   15269     35518801 :     case 1671:  /* *bswaphi2 */
   15270     35518801 :     case 1670:  /* *bswaphi2_movbe */
   15271     35518801 :     case 1669:  /* *bswapdi2 */
   15272     35518801 :     case 1668:  /* *bswapsi2 */
   15273     35518801 :     case 1667:  /* *bswapdi2_movbe */
   15274     35518801 :     case 1666:  /* *bswapsi2_movbe */
   15275     35518801 :     case 1664:  /* popcounthi2_nf */
   15276     35518801 :     case 1651:  /* popcountdi2_nf */
   15277     35518801 :     case 1650:  /* popcountsi2_nf */
   15278     35518801 :     case 1559:  /* clzdi2_lzcnt_nf */
   15279     35518801 :     case 1558:  /* clzsi2_lzcnt_nf */
   15280     35518801 :     case 1371:  /* rotr64ti2_doubleword */
   15281     35518801 :     case 1370:  /* rotl64ti2_doubleword */
   15282     35518801 :     case 1369:  /* rotr32di2_doubleword */
   15283     35518801 :     case 1368:  /* rotl32di2_doubleword */
   15284     35518801 :     case 1073:  /* *one_cmplqi2_1 */
   15285     35518801 :     case 1066:  /* *one_cmpldi2_1 */
   15286     35518801 :     case 1065:  /* *one_cmplsi2_1 */
   15287     35518801 :     case 1064:  /* *one_cmplhi2_1 */
   15288     35518801 :     case 1063:  /* *one_cmplti2_doubleword */
   15289     35518801 :     case 1062:  /* *one_cmpldi2_doubleword */
   15290     35518801 :     case 1061:  /* *negxf2_i387 */
   15291     35518801 :     case 1060:  /* *absxf2_i387 */
   15292     35518801 :     case 1059:  /* *negdf2_i387 */
   15293     35518801 :     case 1058:  /* *absdf2_i387 */
   15294     35518801 :     case 1057:  /* *negsf2_i387 */
   15295     35518801 :     case 1056:  /* *abssf2_i387 */
   15296     35518801 :     case 992:  /* *negdi_1_nf */
   15297     35518801 :     case 990:  /* *negsi_1_nf */
   15298     35518801 :     case 988:  /* *neghi_1_nf */
   15299     35518801 :     case 986:  /* *negqi_1_nf */
   15300     35518801 :     case 264:  /* *floatunsdidf2_avx512 */
   15301     35518801 :     case 263:  /* *floatunssidf2_avx512 */
   15302     35518801 :     case 262:  /* *floatunsdisf2_avx512 */
   15303     35518801 :     case 261:  /* *floatunssisf2_avx512 */
   15304     35518801 :     case 257:  /* *floatdidf2_i387 */
   15305     35518801 :     case 256:  /* *floatdisf2_i387 */
   15306     35518801 :     case 255:  /* floatunsdihf2 */
   15307     35518801 :     case 254:  /* floatdihf2 */
   15308     35518801 :     case 253:  /* floatunssihf2 */
   15309     35518801 :     case 252:  /* floatsihf2 */
   15310     35518801 :     case 251:  /* *floatdidf2 */
   15311     35518801 :     case 250:  /* *floatsidf2 */
   15312     35518801 :     case 249:  /* *floatdisf2 */
   15313     35518801 :     case 248:  /* *floatsisf2 */
   15314     35518801 :     case 247:  /* floatdixf2 */
   15315     35518801 :     case 246:  /* floatsixf2 */
   15316     35518801 :     case 245:  /* floathixf2 */
   15317     35518801 :     case 244:  /* floathidf2 */
   15318     35518801 :     case 243:  /* floathisf2 */
   15319     35518801 :     case 232:  /* fix_truncdfdi_sse */
   15320     35518801 :     case 231:  /* fix_truncdfsi_sse */
   15321     35518801 :     case 230:  /* fix_truncsfdi_sse */
   15322     35518801 :     case 229:  /* fix_truncsfsi_sse */
   15323     35518801 :     case 223:  /* fixuns_truncdfsi2_avx512f */
   15324     35518801 :     case 222:  /* fixuns_truncsfsi2_avx512f */
   15325     35518801 :     case 221:  /* fixuns_truncdfdi2 */
   15326     35518801 :     case 220:  /* fixuns_truncsfdi2 */
   15327     35518801 :     case 219:  /* fixuns_trunchfdi2 */
   15328     35518801 :     case 218:  /* fix_trunchfdi2 */
   15329     35518801 :     case 217:  /* fixuns_trunchfsi2 */
   15330     35518801 :     case 216:  /* fix_trunchfsi2 */
   15331     35518801 :     case 215:  /* truncsfbf2 */
   15332     35518801 :     case 214:  /* *truncdfhf2 */
   15333     35518801 :     case 213:  /* *truncsfhf2 */
   15334     35518801 :     case 212:  /* truncxfdf2 */
   15335     35518801 :     case 211:  /* truncxfsf2 */
   15336     35518801 :     case 210:  /* truncdfsf2 */
   15337     35518801 :     case 209:  /* *extenddfxf2_i387 */
   15338     35518801 :     case 208:  /* *extendsfxf2_i387 */
   15339     35518801 :     case 206:  /* *extendhfdf2 */
   15340     35518801 :     case 205:  /* *extendhfsf2 */
   15341     35518801 :     case 204:  /* *extendsfdf2 */
   15342     35518801 :     case 197:  /* extendqihi2 */
   15343     35518801 :     case 195:  /* extendqisi2 */
   15344     35518801 :     case 193:  /* extendhisi2 */
   15345     35518801 :     case 192:  /* extendhidi2 */
   15346     35518801 :     case 191:  /* extendqidi2 */
   15347     35518801 :     case 188:  /* *extendsidi2_rex64 */
   15348     35518801 :     case 187:  /* *zero_extendqihi2 */
   15349     35518801 :     case 185:  /* *zero_extendhisi2 */
   15350     35518801 :     case 184:  /* *zero_extendqisi2 */
   15351     35518801 :     case 181:  /* zero_extendhidi2 */
   15352     35518801 :     case 180:  /* zero_extendqidi2 */
   15353     35518801 :     case 179:  /* *zero_extendsidi2 */
   15354     35518801 :     case 178:  /* zero_extendditi2 */
   15355     35518801 :     case 128:  /* *extzvdi */
   15356     35518801 :     case 127:  /* *extzvsi */
   15357     35518801 :     case 126:  /* *extzvhi */
   15358     35518801 :     case 123:  /* *extvsi */
   15359     35518801 :     case 122:  /* *extvhi */
   15360     35518801 :     case 110:  /* *movabsdi_2 */
   15361     35518801 :     case 109:  /* *movabssi_2 */
   15362     35518801 :     case 108:  /* *movabshi_2 */
   15363     35518801 :     case 107:  /* *movabsqi_2 */
   15364     35518801 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   15365     35518801 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
   15366     35518801 :       break;
   15367              : 
   15368     55768195 :     case 1493:  /* *sibcall */
   15369     55768195 :     case 1492:  /* *sibcall */
   15370     55768195 :     case 1489:  /* *call */
   15371     55768195 :     case 1488:  /* *call */
   15372     55768195 :     case 1477:  /* *setcc_qi_slp */
   15373     55768195 :     case 134:  /* insvdi_1 */
   15374     55768195 :     case 133:  /* insvsi_1 */
   15375     55768195 :     case 132:  /* insvhi_1 */
   15376     55768195 :     case 116:  /* *movstricthi_1 */
   15377     55768195 :     case 115:  /* *movstrictqi_1 */
   15378     55768195 :     case 106:  /* *movabsdi_1 */
   15379     55768195 :     case 105:  /* *movabssi_1 */
   15380     55768195 :     case 104:  /* *movabshi_1 */
   15381     55768195 :     case 103:  /* *movabsqi_1 */
   15382     55768195 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 0), 0));
   15383     55768195 :       ro[1] = *(ro_loc[1] = &XEXP (pat, 1));
   15384     55768195 :       break;
   15385              : 
   15386       341542 :     case 11084:  /* storedi_via_sse */
   15387       341542 :     case 11083:  /* loaddi_via_sse */
   15388       341542 :     case 11082:  /* storedi_via_fpu */
   15389       341542 :     case 11081:  /* loaddi_via_fpu */
   15390       341542 :     case 11070:  /* avx512bmm_vbitrevb_v32qi */
   15391       341542 :     case 11069:  /* avx512bmm_vbitrevb_v16qi */
   15392       341542 :     case 11068:  /* avx512bmm_vbitrevb_v64qi */
   15393       341542 :     case 11059:  /* avx10_2_vmovrsqv2di */
   15394       341542 :     case 11057:  /* avx10_2_vmovrsqv4di */
   15395       341542 :     case 11055:  /* avx10_2_vmovrsqv8di */
   15396       341542 :     case 11053:  /* avx10_2_vmovrsdv4si */
   15397       341542 :     case 11051:  /* avx10_2_vmovrsdv8si */
   15398       341542 :     case 11049:  /* avx10_2_vmovrsdv16si */
   15399       341542 :     case 11047:  /* avx10_2_vmovrswv8hi */
   15400       341542 :     case 11045:  /* avx10_2_vmovrswv16hi */
   15401       341542 :     case 11043:  /* avx10_2_vmovrswv32hi */
   15402       341542 :     case 11041:  /* avx10_2_vmovrsbv16qi */
   15403       341542 :     case 11039:  /* avx10_2_vmovrsbv32qi */
   15404       341542 :     case 11037:  /* avx10_2_vmovrsbv64qi */
   15405       341542 :     case 10965:  /* avx10_2_vcvttps2uqqsv2di */
   15406       341542 :     case 10963:  /* avx10_2_vcvttps2qqsv2di */
   15407       341542 :     case 10961:  /* avx10_2_vcvttps2uqqsv4di */
   15408       341542 :     case 10959:  /* avx10_2_vcvttps2qqsv4di */
   15409       341542 :     case 10955:  /* avx10_2_vcvttps2uqqsv8di */
   15410       341542 :     case 10951:  /* avx10_2_vcvttps2qqsv8di */
   15411       341542 :     case 10949:  /* avx10_2_vcvttpd2uqqsv2df */
   15412       341542 :     case 10947:  /* avx10_2_vcvttpd2qqsv2df */
   15413       341542 :     case 10945:  /* avx10_2_vcvttpd2uqqsv4df */
   15414       341542 :     case 10943:  /* avx10_2_vcvttpd2qqsv4df */
   15415       341542 :     case 10939:  /* avx10_2_vcvttpd2uqqsv8df */
   15416       341542 :     case 10935:  /* avx10_2_vcvttpd2qqsv8df */
   15417       341542 :     case 10933:  /* avx10_2_vcvttpd2udqsv2df */
   15418       341542 :     case 10931:  /* avx10_2_vcvttpd2dqsv2df */
   15419       341542 :     case 10929:  /* avx10_2_vcvttpd2udqsv4df */
   15420       341542 :     case 10927:  /* avx10_2_vcvttpd2dqsv4df */
   15421       341542 :     case 10923:  /* avx10_2_vcvttpd2udqsv8df */
   15422       341542 :     case 10919:  /* avx10_2_vcvttpd2dqsv8df */
   15423       341542 :     case 10917:  /* avx10_2_vcvttps2udqsv4sf */
   15424       341542 :     case 10915:  /* avx10_2_vcvttps2dqsv4sf */
   15425       341542 :     case 10913:  /* avx10_2_vcvttps2udqsv8sf */
   15426       341542 :     case 10911:  /* avx10_2_vcvttps2dqsv8sf */
   15427       341542 :     case 10907:  /* avx10_2_vcvttps2udqsv16sf */
   15428       341542 :     case 10903:  /* avx10_2_vcvttps2dqsv16sf */
   15429       341542 :     case 10901:  /* avx10_2_cvttps2iubsv4sf */
   15430       341542 :     case 10899:  /* avx10_2_cvttps2ibsv4sf */
   15431       341542 :     case 10897:  /* avx10_2_cvttps2iubsv8sf */
   15432       341542 :     case 10895:  /* avx10_2_cvttps2ibsv8sf */
   15433       341542 :     case 10891:  /* avx10_2_cvttps2iubsv16sf */
   15434       341542 :     case 10887:  /* avx10_2_cvttps2ibsv16sf */
   15435       341542 :     case 10885:  /* avx10_2_cvtps2iubsv4sf */
   15436       341542 :     case 10883:  /* avx10_2_cvtps2ibsv4sf */
   15437       341542 :     case 10881:  /* avx10_2_cvtps2iubsv8sf */
   15438       341542 :     case 10879:  /* avx10_2_cvtps2ibsv8sf */
   15439       341542 :     case 10875:  /* avx10_2_cvtps2iubsv16sf */
   15440       341542 :     case 10871:  /* avx10_2_cvtps2ibsv16sf */
   15441       341542 :     case 10869:  /* avx10_2_cvttph2iubsv8hf */
   15442       341542 :     case 10867:  /* avx10_2_cvttph2ibsv8hf */
   15443       341542 :     case 10865:  /* avx10_2_cvttph2iubsv16hf */
   15444       341542 :     case 10863:  /* avx10_2_cvttph2ibsv16hf */
   15445       341542 :     case 10859:  /* avx10_2_cvttph2iubsv32hf */
   15446       341542 :     case 10855:  /* avx10_2_cvttph2ibsv32hf */
   15447       341542 :     case 10853:  /* avx10_2_cvtph2iubsv8hf */
   15448       341542 :     case 10851:  /* avx10_2_cvtph2ibsv8hf */
   15449       341542 :     case 10849:  /* avx10_2_cvtph2iubsv16hf */
   15450       341542 :     case 10847:  /* avx10_2_cvtph2ibsv16hf */
   15451       341542 :     case 10843:  /* avx10_2_cvtph2iubsv32hf */
   15452       341542 :     case 10839:  /* avx10_2_cvtph2ibsv32hf */
   15453       341542 :     case 10837:  /* avx10_2_cvttbf162iubsv8bf */
   15454       341542 :     case 10835:  /* avx10_2_cvttbf162ibsv8bf */
   15455       341542 :     case 10833:  /* avx10_2_cvtbf162iubsv8bf */
   15456       341542 :     case 10831:  /* avx10_2_cvtbf162ibsv8bf */
   15457       341542 :     case 10829:  /* avx10_2_cvttbf162iubsv16bf */
   15458       341542 :     case 10827:  /* avx10_2_cvttbf162ibsv16bf */
   15459       341542 :     case 10825:  /* avx10_2_cvtbf162iubsv16bf */
   15460       341542 :     case 10823:  /* avx10_2_cvtbf162ibsv16bf */
   15461       341542 :     case 10821:  /* avx10_2_cvttbf162iubsv32bf */
   15462       341542 :     case 10819:  /* avx10_2_cvttbf162ibsv32bf */
   15463       341542 :     case 10817:  /* avx10_2_cvtbf162iubsv32bf */
   15464       341542 :     case 10815:  /* avx10_2_cvtbf162ibsv32bf */
   15465       341542 :     case 10783:  /* avx10_2_getexpbf16_v8bf */
   15466       341542 :     case 10781:  /* avx10_2_getexpbf16_v16bf */
   15467       341542 :     case 10779:  /* avx10_2_getexpbf16_v32bf */
   15468       341542 :     case 10777:  /* avx10_2_rcpbf16_v8bf */
   15469       341542 :     case 10775:  /* avx10_2_rcpbf16_v16bf */
   15470       341542 :     case 10773:  /* avx10_2_rcpbf16_v32bf */
   15471       341542 :     case 10765:  /* avx10_2_rsqrtbf16_v8bf */
   15472       341542 :     case 10763:  /* avx10_2_rsqrtbf16_v16bf */
   15473       341542 :     case 10761:  /* avx10_2_rsqrtbf16_v32bf */
   15474       341542 :     case 10606:  /* vcvthf82phv8hf */
   15475       341542 :     case 10604:  /* vcvthf82phv16hf */
   15476       341542 :     case 10602:  /* vcvthf82phv32hf */
   15477       341542 :     case 10600:  /* vcvtph2hf8sv32hf */
   15478       341542 :     case 10598:  /* vcvtph2hf8v32hf */
   15479       341542 :     case 10596:  /* vcvtph2bf8sv32hf */
   15480       341542 :     case 10594:  /* vcvtph2bf8v32hf */
   15481       341542 :     case 10592:  /* vcvtph2hf8sv16hf */
   15482       341542 :     case 10590:  /* vcvtph2hf8v16hf */
   15483       341542 :     case 10588:  /* vcvtph2bf8sv16hf */
   15484       341542 :     case 10586:  /* vcvtph2bf8v16hf */
   15485       341542 :     case 10167:  /* *conflictv2di */
   15486       341542 :     case 10165:  /* *conflictv4di */
   15487       341542 :     case 10163:  /* *conflictv8di */
   15488       341542 :     case 10161:  /* *conflictv4si */
   15489       341542 :     case 10159:  /* *conflictv8si */
   15490       341542 :     case 10157:  /* *conflictv16si */
   15491       341542 :     case 9738:  /* *avx512f_vcvtph2ps512 */
   15492       341542 :     case 9736:  /* vcvtph2ps256 */
   15493       341542 :     case 9734:  /* *vcvtph2ps_load */
   15494       341542 :     case 9151:  /* aesimc */
   15495       341542 :     case 9124:  /* xop_frczv4df2 */
   15496       341542 :     case 9123:  /* xop_frczv8sf2 */
   15497       341542 :     case 9122:  /* xop_frczv2df2 */
   15498       341542 :     case 9121:  /* xop_frczv4sf2 */
   15499       341542 :     case 9120:  /* xop_frczdf2 */
   15500       341542 :     case 9119:  /* xop_frczsf2 */
   15501       341542 :     case 8808:  /* sse4_1_phminposuw */
   15502       341542 :     case 8775:  /* sse4_1_movntdqa */
   15503       341542 :     case 8774:  /* avx2_movntdqa */
   15504       341542 :     case 8773:  /* avx512f_movntdqa */
   15505       341542 :     case 8728:  /* sse4a_movntdf */
   15506       341542 :     case 8727:  /* sse4a_movntsf */
   15507       341542 :     case 8613:  /* sse2_pmovmskb */
   15508       341542 :     case 8612:  /* avx2_pmovmskb */
   15509       341542 :     case 8567:  /* sse2_movmskpd */
   15510       341542 :     case 8566:  /* avx_movmskpd256 */
   15511       341542 :     case 8565:  /* sse_movmskps */
   15512       341542 :     case 8564:  /* avx_movmskps256 */
   15513       341542 :     case 7075:  /* avx512vl_getexpv2df */
   15514       341542 :     case 7071:  /* avx512vl_getexpv4df */
   15515       341542 :     case 7067:  /* avx512f_getexpv8df */
   15516       341542 :     case 7063:  /* avx512vl_getexpv4sf */
   15517       341542 :     case 7059:  /* avx512vl_getexpv8sf */
   15518       341542 :     case 7055:  /* avx512f_getexpv16sf */
   15519       341542 :     case 7051:  /* avx512fp16_getexpv8hf */
   15520       341542 :     case 7047:  /* avx512vl_getexpv16hf */
   15521       341542 :     case 7043:  /* avx512bw_getexpv32hf */
   15522       341542 :     case 5207:  /* avx512vl_cvtq2maskv2di */
   15523       341542 :     case 5206:  /* avx512vl_cvtq2maskv4di */
   15524       341542 :     case 5205:  /* avx512f_cvtq2maskv8di */
   15525       341542 :     case 5204:  /* avx512vl_cvtd2maskv4si */
   15526       341542 :     case 5203:  /* avx512vl_cvtd2maskv8si */
   15527       341542 :     case 5202:  /* avx512f_cvtd2maskv16si */
   15528       341542 :     case 5201:  /* avx512vl_cvtw2maskv8hi */
   15529       341542 :     case 5200:  /* avx512vl_cvtw2maskv16hi */
   15530       341542 :     case 5199:  /* avx512bw_cvtw2maskv32hi */
   15531       341542 :     case 5198:  /* avx512vl_cvtb2maskv32qi */
   15532       341542 :     case 5197:  /* avx512vl_cvtb2maskv16qi */
   15533       341542 :     case 5196:  /* avx512bw_cvtb2maskv64qi */
   15534       341542 :     case 5163:  /* unspec_sse2_cvttpd2dq */
   15535       341542 :     case 5157:  /* *unspec_fixuns_truncv4sfv4si2 */
   15536       341542 :     case 5155:  /* *unspec_fixuns_truncv8sfv8si2 */
   15537       341542 :     case 5149:  /* unspec_avx512dq_fixuns_truncv2sfv2di2 */
   15538       341542 :     case 5147:  /* unspec_avx512dq_fix_truncv2sfv2di2 */
   15539       341542 :     case 5133:  /* unspec_fixuns_truncv4sfv4di2 */
   15540       341542 :     case 5131:  /* unspec_fix_truncv4sfv4di2 */
   15541       341542 :     case 5127:  /* unspec_fixuns_truncv8sfv8di2 */
   15542       341542 :     case 5123:  /* unspec_fix_truncv8sfv8di2 */
   15543       341542 :     case 5121:  /* fixuns_notruncv2dfv2di2 */
   15544       341542 :     case 5119:  /* fixuns_notruncv4dfv4di2 */
   15545       341542 :     case 5115:  /* fixuns_notruncv8dfv8di2 */
   15546       341542 :     case 5113:  /* fix_notruncv2dfv2di2 */
   15547       341542 :     case 5111:  /* fix_notruncv4dfv4di2 */
   15548       341542 :     case 5107:  /* fix_notruncv8dfv8di2 */
   15549       341542 :     case 5089:  /* unspec_fixuns_truncv2dfv2di2 */
   15550       341542 :     case 5087:  /* unspec_fix_truncv2dfv2di2 */
   15551       341542 :     case 5085:  /* unspec_fixuns_truncv4dfv4di2 */
   15552       341542 :     case 5083:  /* unspec_fix_truncv4dfv4di2 */
   15553       341542 :     case 5079:  /* unspec_fixuns_truncv8dfv8di2 */
   15554       341542 :     case 5075:  /* unspec_fix_truncv8dfv8di2 */
   15555       341542 :     case 5071:  /* unspec_fixuns_truncv4dfv4si2 */
   15556       341542 :     case 5067:  /* unspec_fix_truncv4dfv4si2 */
   15557       341542 :     case 5050:  /* unspec_fixuns_truncv8dfv8si2 */
   15558       341542 :     case 5046:  /* unspec_fix_truncv8dfv8si2 */
   15559       341542 :     case 5039:  /* fixuns_notruncv4dfv4si2 */
   15560       341542 :     case 5035:  /* fixuns_notruncv8dfv8si2 */
   15561       341542 :     case 5029:  /* avx_cvtpd2dq256 */
   15562       341542 :     case 5025:  /* avx512f_cvtpd2dq512 */
   15563       341542 :     case 4963:  /* unspec_sse2_cvttsd2siq */
   15564       341542 :     case 4961:  /* unspec_sse2_cvttsd2si */
   15565       341542 :     case 4960:  /* sse2_cvtsd2siq_2 */
   15566       341542 :     case 4959:  /* sse2_cvtsd2si_2 */
   15567       341542 :     case 4949:  /* unspec_avx512f_vcvttsd2usiq */
   15568       341542 :     case 4947:  /* unspec_avx512f_vcvttsd2usi */
   15569       341542 :     case 4937:  /* unspec_avx512f_vcvttss2usiq */
   15570       341542 :     case 4935:  /* unspec_avx512f_vcvttss2usi */
   15571       341542 :     case 4926:  /* unspec_fixuns_truncv2dfv2si2 */
   15572       341542 :     case 4924:  /* unspec_sse2_cvttpd2pi */
   15573       341542 :     case 4923:  /* sse2_cvtpd2pi */
   15574       341542 :     case 4917:  /* unspec_fix_truncv4sfv4si2 */
   15575       341542 :     case 4913:  /* unspec_fix_truncv8sfv8si2 */
   15576       341542 :     case 4901:  /* unspec_fixuns_truncv16sfv16si2 */
   15577       341542 :     case 4897:  /* unspec_fix_truncv16sfv16si2 */
   15578       341542 :     case 4893:  /* *avx512dq_cvtps2uqqv4di */
   15579       341542 :     case 4889:  /* *avx512dq_cvtps2uqqv8di */
   15580       341542 :     case 4885:  /* *avx512dq_cvtps2qqv4di */
   15581       341542 :     case 4881:  /* *avx512dq_cvtps2qqv8di */
   15582       341542 :     case 4877:  /* *avx512vl_fixuns_notruncv4sfv4si */
   15583       341542 :     case 4873:  /* *avx512vl_fixuns_notruncv8sfv8si */
   15584       341542 :     case 4869:  /* *avx512f_fixuns_notruncv16sfv16si */
   15585       341542 :     case 4865:  /* avx512f_fix_notruncv16sfv16si */
   15586       341542 :     case 4863:  /* sse2_fix_notruncv4sfv4si */
   15587       341542 :     case 4861:  /* avx_fix_notruncv8sfv8si */
   15588       341542 :     case 4828:  /* unspec_sse_cvttss2siq */
   15589       341542 :     case 4826:  /* unspec_sse_cvttss2si */
   15590       341542 :     case 4825:  /* sse_cvtss2siq_2 */
   15591       341542 :     case 4824:  /* sse_cvtss2si_2 */
   15592       341542 :     case 4814:  /* unspec_sse_cvttps2pi */
   15593       341542 :     case 4729:  /* unspec_avx512fp16_fixuns_truncdi2 */
   15594       341542 :     case 4727:  /* unspec_avx512fp16_fix_truncdi2 */
   15595       341542 :     case 4725:  /* unspec_avx512fp16_fixuns_truncsi2 */
   15596       341542 :     case 4723:  /* unspec_avx512fp16_fix_truncsi2 */
   15597       341542 :     case 4713:  /* unspec_avx512fp16_fixuns_truncv2di2 */
   15598       341542 :     case 4711:  /* unspec_avx512fp16_fix_truncv2di2 */
   15599       341542 :     case 4693:  /* unspec_avx512fp16_fixuns_truncv4di2 */
   15600       341542 :     case 4691:  /* unspec_avx512fp16_fix_truncv4di2 */
   15601       341542 :     case 4689:  /* unspec_avx512fp16_fixuns_truncv4si2 */
   15602       341542 :     case 4687:  /* unspec_avx512fp16_fix_truncv4si2 */
   15603       341542 :     case 4635:  /* unspec_avx512fp16_fixuns_truncv8di2 */
   15604       341542 :     case 4631:  /* unspec_avx512fp16_fix_truncv8di2 */
   15605       341542 :     case 4627:  /* unspec_avx512fp16_fixuns_truncv16si2 */
   15606       341542 :     case 4623:  /* unspec_avx512fp16_fix_truncv16si2 */
   15607       341542 :     case 4619:  /* unspec_avx512fp16_fixuns_truncv8si2 */
   15608       341542 :     case 4615:  /* unspec_avx512fp16_fix_truncv8si2 */
   15609       341542 :     case 4611:  /* unspec_avx512fp16_fixuns_truncv32hi2 */
   15610       341542 :     case 4607:  /* unspec_avx512fp16_fix_truncv32hi2 */
   15611       341542 :     case 4603:  /* unspec_avx512fp16_fixuns_truncv16hi2 */
   15612       341542 :     case 4599:  /* unspec_avx512fp16_fix_truncv16hi2 */
   15613       341542 :     case 4595:  /* unspec_avx512fp16_fixuns_truncv8hi2 */
   15614       341542 :     case 4591:  /* unspec_avx512fp16_fix_truncv8hi2 */
   15615       341542 :     case 4582:  /* avx512fp16_vcvtsh2siq_2 */
   15616       341542 :     case 4581:  /* avx512fp16_vcvtsh2usiq_2 */
   15617       341542 :     case 4580:  /* avx512fp16_vcvtsh2si_2 */
   15618       341542 :     case 4579:  /* avx512fp16_vcvtsh2usi_2 */
   15619       341542 :     case 4501:  /* avx512fp16_vcvtph2qq_v2di */
   15620       341542 :     case 4497:  /* avx512fp16_vcvtph2uqq_v2di */
   15621       341542 :     case 4493:  /* avx512fp16_vcvtph2dq_v4si */
   15622       341542 :     case 4489:  /* avx512fp16_vcvtph2udq_v4si */
   15623       341542 :     case 4485:  /* avx512fp16_vcvtph2w_v8hi */
   15624       341542 :     case 4481:  /* avx512fp16_vcvtph2uw_v8hi */
   15625       341542 :     case 4477:  /* avx512fp16_vcvtph2qq_v4di */
   15626       341542 :     case 4473:  /* avx512fp16_vcvtph2uqq_v4di */
   15627       341542 :     case 4469:  /* avx512fp16_vcvtph2dq_v8si */
   15628       341542 :     case 4465:  /* avx512fp16_vcvtph2udq_v8si */
   15629       341542 :     case 4461:  /* avx512fp16_vcvtph2w_v16hi */
   15630       341542 :     case 4457:  /* avx512fp16_vcvtph2uw_v16hi */
   15631       341542 :     case 4453:  /* avx512fp16_vcvtph2qq_v8di */
   15632       341542 :     case 4449:  /* avx512fp16_vcvtph2uqq_v8di */
   15633       341542 :     case 4445:  /* avx512fp16_vcvtph2dq_v16si */
   15634       341542 :     case 4441:  /* avx512fp16_vcvtph2udq_v16si */
   15635       341542 :     case 4437:  /* avx512fp16_vcvtph2w_v32hi */
   15636       341542 :     case 4433:  /* avx512fp16_vcvtph2uw_v32hi */
   15637       341542 :     case 3024:  /* *rsqrt14v2df */
   15638       341542 :     case 3022:  /* *rsqrt14v4df */
   15639       341542 :     case 3020:  /* *rsqrt14v8df */
   15640       341542 :     case 3018:  /* *rsqrt14v4sf */
   15641       341542 :     case 3016:  /* *rsqrt14v8sf */
   15642       341542 :     case 3014:  /* *rsqrt14v16sf */
   15643       341542 :     case 3012:  /* avx512fp16_rsqrtv8hf2 */
   15644       341542 :     case 3010:  /* avx512fp16_rsqrtv16hf2 */
   15645       341542 :     case 3008:  /* avx512fp16_rsqrtv32hf2 */
   15646       341542 :     case 3007:  /* sse_rsqrtv4sf2 */
   15647       341542 :     case 3006:  /* avx_rsqrtv8sf2 */
   15648       341542 :     case 2952:  /* *rcp14v2df */
   15649       341542 :     case 2950:  /* *rcp14v4df */
   15650       341542 :     case 2948:  /* *rcp14v8df */
   15651       341542 :     case 2946:  /* *rcp14v4sf */
   15652       341542 :     case 2944:  /* *rcp14v8sf */
   15653       341542 :     case 2942:  /* *rcp14v16sf */
   15654       341542 :     case 2937:  /* avx512fp16_rcpv8hf2 */
   15655       341542 :     case 2935:  /* avx512fp16_rcpv16hf2 */
   15656       341542 :     case 2933:  /* avx512fp16_rcpv32hf2 */
   15657       341542 :     case 2930:  /* sse_rcpv4sf2 */
   15658       341542 :     case 2929:  /* avx_rcpv8sf2 */
   15659       341542 :     case 2625:  /* sse2_movntv2di */
   15660       341542 :     case 2624:  /* avx_movntv4di */
   15661       341542 :     case 2623:  /* avx512f_movntv8di */
   15662       341542 :     case 2622:  /* sse2_movntv2df */
   15663       341542 :     case 2621:  /* avx_movntv4df */
   15664       341542 :     case 2620:  /* avx512f_movntv8df */
   15665       341542 :     case 2619:  /* sse_movntv4sf */
   15666       341542 :     case 2618:  /* avx_movntv8sf */
   15667       341542 :     case 2617:  /* avx512f_movntv16sf */
   15668       341542 :     case 2616:  /* sse2_movntidi */
   15669       341542 :     case 2615:  /* sse2_movntisi */
   15670       341542 :     case 2614:  /* sse3_lddqu */
   15671       341542 :     case 2613:  /* avx_lddqu256 */
   15672       341542 :     case 2550:  /* *avx512vl_loadv8bf */
   15673       341542 :     case 2549:  /* *avx512vl_loadv16bf */
   15674       341542 :     case 2548:  /* *avx512bw_loadv32bf */
   15675       341542 :     case 2547:  /* *avx512fp16_loadv8hf */
   15676       341542 :     case 2546:  /* *avx512vl_loadv16hf */
   15677       341542 :     case 2545:  /* *avx512bw_loadv32hf */
   15678       341542 :     case 2544:  /* *avx512vl_loadv8hi */
   15679       341542 :     case 2543:  /* *avx512vl_loadv16hi */
   15680       341542 :     case 2542:  /* *avx512bw_loadv32hi */
   15681       341542 :     case 2541:  /* *avx512vl_loadv32qi */
   15682       341542 :     case 2540:  /* *avx512vl_loadv16qi */
   15683       341542 :     case 2539:  /* *avx512bw_loadv64qi */
   15684       341542 :     case 2520:  /* *avx512vl_loadv2df */
   15685       341542 :     case 2519:  /* *avx512vl_loadv4df */
   15686       341542 :     case 2518:  /* *avx512f_loadv8df */
   15687       341542 :     case 2517:  /* *avx512vl_loadv4sf */
   15688       341542 :     case 2516:  /* *avx512vl_loadv8sf */
   15689       341542 :     case 2515:  /* *avx512f_loadv16sf */
   15690       341542 :     case 2514:  /* *avx512vl_loadv2di */
   15691       341542 :     case 2513:  /* *avx512vl_loadv4di */
   15692       341542 :     case 2512:  /* *avx512f_loadv8di */
   15693       341542 :     case 2511:  /* *avx512vl_loadv4si */
   15694       341542 :     case 2510:  /* *avx512vl_loadv8si */
   15695       341542 :     case 2509:  /* *avx512f_loadv16si */
   15696       341542 :     case 2432:  /* mmx_pmovmskb */
   15697       341542 :     case 2110:  /* mmx_rsqrtv2sf2 */
   15698       341542 :     case 2107:  /* mmx_rcpv2sf2 */
   15699       341542 :     case 2096:  /* sse_movntq */
   15700       341542 :     case 2063:  /* movrsdi */
   15701       341542 :     case 2062:  /* movrssi */
   15702       341542 :     case 2061:  /* movrshi */
   15703       341542 :     case 2060:  /* movrsqi */
   15704       341542 :     case 2056:  /* urdmsr */
   15705       341542 :     case 2032:  /* movdiridi */
   15706       341542 :     case 2031:  /* movdirisi */
   15707       341542 :     case 2002:  /* rdsspdi */
   15708       341542 :     case 2001:  /* rdsspsi */
   15709       341542 :     case 1970:  /* xgetbv */
   15710       341542 :     case 1953:  /* xsaves */
   15711       341542 :     case 1952:  /* xsavec */
   15712       341542 :     case 1951:  /* xsaveopt */
   15713       341542 :     case 1950:  /* xsave */
   15714       341542 :     case 1940:  /* rdpmc */
   15715       341542 :     case 1785:  /* movmsk_df */
   15716       341542 :     case 1784:  /* fxamxf2_i387 */
   15717       341542 :     case 1783:  /* fxamdf2_i387 */
   15718       341542 :     case 1782:  /* fxamsf2_i387 */
   15719       341542 :     case 1761:  /* lrintxfsi2 */
   15720       341542 :     case 1760:  /* lrintxfhi2 */
   15721       341542 :     case 1758:  /* rintxf2 */
   15722       341542 :     case 1751:  /* *f2xm1xf2_i387 */
   15723       341542 :     case 1744:  /* cosxf2 */
   15724       341542 :     case 1743:  /* sinxf2 */
   15725       341542 :     case 1736:  /* rsqrthf2 */
   15726       341542 :     case 1735:  /* *rsqrtsf2_sse */
   15727       341542 :     case 1733:  /* truncxfdf2_i387_noop_unspec */
   15728       341542 :     case 1732:  /* truncxfsf2_i387_noop_unspec */
   15729       341542 :     case 1707:  /* rcphf2 */
   15730       341542 :     case 1706:  /* *rcpsf2_sse */
   15731       341542 :     case 1694:  /* *tls_dynamic_gnu2_lea_64_di */
   15732       341542 :     case 1693:  /* *tls_dynamic_gnu2_lea_64_si */
   15733       341542 :     case 1590:  /* lzcnt_hi_nf */
   15734       341542 :     case 1588:  /* tzcnt_hi_nf */
   15735       341542 :     case 1575:  /* lzcnt_di_nf */
   15736       341542 :     case 1574:  /* tzcnt_di_nf */
   15737       341542 :     case 1573:  /* lzcnt_si_nf */
   15738       341542 :     case 1572:  /* tzcnt_si_nf */
   15739       341542 :     case 207:  /* extendbfsf2_1 */
   15740       341542 :     case 87:  /* popfldi1 */
   15741       341542 :     case 86:  /* popflsi1 */
   15742       341542 :     case 85:  /* pushfldi2 */
   15743       341542 :     case 84:  /* pushflsi2 */
   15744       341542 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   15745       341542 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
   15746       341542 :       break;
   15747              : 
   15748     16718554 :     case 1473:  /* *setcc_si_1_and */
   15749     16718554 :     case 1472:  /* *setcc_hi_1_and */
   15750     16718554 :     case 166:  /* popp_di */
   15751     16718554 :     case 165:  /* pushp_di */
   15752     16718554 :     case 95:  /* *movdi_or */
   15753     16718554 :     case 94:  /* *movsi_or */
   15754     16718554 :     case 93:  /* *movhi_or */
   15755     16718554 :     case 92:  /* *movdi_and */
   15756     16718554 :     case 91:  /* *movsi_and */
   15757     16718554 :     case 90:  /* *movhi_and */
   15758     16718554 :     case 89:  /* *movdi_xor */
   15759     16718554 :     case 88:  /* *movsi_xor */
   15760     16718554 :     case 83:  /* *popdi1_epilogue */
   15761     16718554 :     case 82:  /* *popsi1_epilogue */
   15762     16718554 :     case 79:  /* *pushdi2_prologue */
   15763     16718554 :     case 78:  /* *pushsi2_prologue */
   15764     16718554 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   15765     16718554 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 1));
   15766     16718554 :       break;
   15767              : 
   15768   1462915382 :     case 10416:  /* *movp2hi_internal */
   15769   1462915382 :     case 10415:  /* *movp2qi_internal */
   15770   1462915382 :     case 5524:  /* *avx512vl_vpternlogv2df_0 */
   15771   1462915382 :     case 5523:  /* *avx512vl_vpternlogv4df_0 */
   15772   1462915382 :     case 5522:  /* *avx512f_vpternlogv8df_0 */
   15773   1462915382 :     case 5521:  /* *avx512vl_vpternlogv4sf_0 */
   15774   1462915382 :     case 5520:  /* *avx512vl_vpternlogv8sf_0 */
   15775   1462915382 :     case 5519:  /* *avx512f_vpternlogv16sf_0 */
   15776   1462915382 :     case 5518:  /* *avx512vl_vpternlogv8bf_0 */
   15777   1462915382 :     case 5517:  /* *avx512vl_vpternlogv16bf_0 */
   15778   1462915382 :     case 5516:  /* *avx512bw_vpternlogv32bf_0 */
   15779   1462915382 :     case 5515:  /* *avx512fp16_vpternlogv8hf_0 */
   15780   1462915382 :     case 5514:  /* *avx512vl_vpternlogv16hf_0 */
   15781   1462915382 :     case 5513:  /* *avx512bw_vpternlogv32hf_0 */
   15782   1462915382 :     case 5512:  /* *avx512vl_vpternlogv2di_0 */
   15783   1462915382 :     case 5511:  /* *avx512vl_vpternlogv4di_0 */
   15784   1462915382 :     case 5510:  /* *avx512f_vpternlogv8di_0 */
   15785   1462915382 :     case 5509:  /* *avx512vl_vpternlogv4si_0 */
   15786   1462915382 :     case 5508:  /* *avx512vl_vpternlogv8si_0 */
   15787   1462915382 :     case 5507:  /* *avx512f_vpternlogv16si_0 */
   15788   1462915382 :     case 5506:  /* *avx512vl_vpternlogv8hi_0 */
   15789   1462915382 :     case 5505:  /* *avx512vl_vpternlogv16hi_0 */
   15790   1462915382 :     case 5504:  /* *avx512bw_vpternlogv32hi_0 */
   15791   1462915382 :     case 5503:  /* *avx512vl_vpternlogv16qi_0 */
   15792   1462915382 :     case 5502:  /* *avx512vl_vpternlogv32qi_0 */
   15793   1462915382 :     case 5501:  /* *avx512bw_vpternlogv64qi_0 */
   15794   1462915382 :     case 2469:  /* movv2df_internal */
   15795   1462915382 :     case 2468:  /* movv4df_internal */
   15796   1462915382 :     case 2467:  /* movv8df_internal */
   15797   1462915382 :     case 2466:  /* movv4sf_internal */
   15798   1462915382 :     case 2465:  /* movv8sf_internal */
   15799   1462915382 :     case 2464:  /* movv16sf_internal */
   15800   1462915382 :     case 2463:  /* movv8bf_internal */
   15801   1462915382 :     case 2462:  /* movv16bf_internal */
   15802   1462915382 :     case 2461:  /* movv32bf_internal */
   15803   1462915382 :     case 2460:  /* movv8hf_internal */
   15804   1462915382 :     case 2459:  /* movv16hf_internal */
   15805   1462915382 :     case 2458:  /* movv32hf_internal */
   15806   1462915382 :     case 2457:  /* movv1ti_internal */
   15807   1462915382 :     case 2456:  /* movv2ti_internal */
   15808   1462915382 :     case 2455:  /* movv4ti_internal */
   15809   1462915382 :     case 2454:  /* movv2di_internal */
   15810   1462915382 :     case 2453:  /* movv4di_internal */
   15811   1462915382 :     case 2452:  /* movv8di_internal */
   15812   1462915382 :     case 2451:  /* movv4si_internal */
   15813   1462915382 :     case 2450:  /* movv8si_internal */
   15814   1462915382 :     case 2449:  /* movv16si_internal */
   15815   1462915382 :     case 2448:  /* movv8hi_internal */
   15816   1462915382 :     case 2447:  /* movv16hi_internal */
   15817   1462915382 :     case 2446:  /* movv32hi_internal */
   15818   1462915382 :     case 2445:  /* movv16qi_internal */
   15819   1462915382 :     case 2444:  /* movv32qi_internal */
   15820   1462915382 :     case 2443:  /* movv64qi_internal */
   15821   1462915382 :     case 2095:  /* *pushv2qi2 */
   15822   1462915382 :     case 2094:  /* *movv1di_imm */
   15823   1462915382 :     case 2093:  /* *movv2sf_imm */
   15824   1462915382 :     case 2092:  /* *movv2si_imm */
   15825   1462915382 :     case 2091:  /* *movv4bf_imm */
   15826   1462915382 :     case 2090:  /* *movv4hf_imm */
   15827   1462915382 :     case 2089:  /* *movv4hi_imm */
   15828   1462915382 :     case 2088:  /* *movv8qi_imm */
   15829   1462915382 :     case 2087:  /* *movv2bf_imm */
   15830   1462915382 :     case 2086:  /* *movv2hf_imm */
   15831   1462915382 :     case 2085:  /* *movv1si_imm */
   15832   1462915382 :     case 2084:  /* *movv2hi_imm */
   15833   1462915382 :     case 2083:  /* *movv4qi_imm */
   15834   1462915382 :     case 2082:  /* *movv2qi_imm */
   15835   1462915382 :     case 2081:  /* *movv2qi_internal */
   15836   1462915382 :     case 2080:  /* *pushv2bf2_rex64 */
   15837   1462915382 :     case 2079:  /* *pushv2hf2_rex64 */
   15838   1462915382 :     case 2078:  /* *pushv1si2_rex64 */
   15839   1462915382 :     case 2077:  /* *pushv2hi2_rex64 */
   15840   1462915382 :     case 2076:  /* *pushv4qi2_rex64 */
   15841   1462915382 :     case 2075:  /* *movv2bf_internal */
   15842   1462915382 :     case 2074:  /* *movv2hf_internal */
   15843   1462915382 :     case 2073:  /* *movv1si_internal */
   15844   1462915382 :     case 2072:  /* *movv2hi_internal */
   15845   1462915382 :     case 2071:  /* *movv4qi_internal */
   15846   1462915382 :     case 2070:  /* *movv4bf_internal */
   15847   1462915382 :     case 2069:  /* *movv4hf_internal */
   15848   1462915382 :     case 2068:  /* *movv2sf_internal */
   15849   1462915382 :     case 2067:  /* *movv1di_internal */
   15850   1462915382 :     case 2066:  /* *movv2si_internal */
   15851   1462915382 :     case 2065:  /* *movv4hi_internal */
   15852   1462915382 :     case 2064:  /* *movv8qi_internal */
   15853   1462915382 :     case 1933:  /* *prefetch_3dnow */
   15854   1462915382 :     case 1476:  /* *setcc_qi */
   15855   1462915382 :     case 1475:  /* *setcc_si_1_movzbl */
   15856   1462915382 :     case 1474:  /* *setcc_hi_1_movzbl */
   15857   1462915382 :     case 1471:  /* *setcc_di_1 */
   15858   1462915382 :     case 1470:  /* *setcc_di_zu */
   15859   1462915382 :     case 1469:  /* *setcc_si_zu */
   15860   1462915382 :     case 1468:  /* *setcc_hi_zu */
   15861   1462915382 :     case 269:  /* *leadi */
   15862   1462915382 :     case 268:  /* *leasi */
   15863   1462915382 :     case 176:  /* *movbf_internal */
   15864   1462915382 :     case 175:  /* *movhf_internal */
   15865   1462915382 :     case 174:  /* *movsf_internal */
   15866   1462915382 :     case 173:  /* *movdf_internal */
   15867   1462915382 :     case 172:  /* *movxf_internal */
   15868   1462915382 :     case 171:  /* *movtf_internal */
   15869   1462915382 :     case 170:  /* *pushsf */
   15870   1462915382 :     case 169:  /* *pushsf_rex64 */
   15871   1462915382 :     case 162:  /* *pushbf */
   15872   1462915382 :     case 161:  /* *pushhf */
   15873   1462915382 :     case 160:  /* *pushbf_rex64 */
   15874   1462915382 :     case 159:  /* *pushhf_rex64 */
   15875   1462915382 :     case 158:  /* *pushdf */
   15876   1462915382 :     case 157:  /* *pushxf */
   15877   1462915382 :     case 156:  /* *pushtf */
   15878   1462915382 :     case 102:  /* *movqi_internal */
   15879   1462915382 :     case 101:  /* *movhi_internal */
   15880   1462915382 :     case 100:  /* *movsi_internal */
   15881   1462915382 :     case 99:  /* *movdi_internal */
   15882   1462915382 :     case 98:  /* *movti_internal */
   15883   1462915382 :     case 97:  /* *movoi_internal_avx */
   15884   1462915382 :     case 96:  /* *movxi_internal_avx512f */
   15885   1462915382 :     case 81:  /* *popdi1 */
   15886   1462915382 :     case 80:  /* *popsi1 */
   15887   1462915382 :     case 77:  /* *pushhi2 */
   15888   1462915382 :     case 76:  /* *pushqi2 */
   15889   1462915382 :     case 75:  /* *pushsi2 */
   15890   1462915382 :     case 74:  /* *pushsi2_rex64 */
   15891   1462915382 :     case 73:  /* *pushdi2_rex64 */
   15892   1462915382 :     case 72:  /* *pushti2 */
   15893   1462915382 :     case 71:  /* *pushdi2 */
   15894   1462915382 :     case 70:  /* *pushv1ti2 */
   15895   1462915382 :     case 69:  /* *pushv1ti2 */
   15896   1462915382 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   15897   1462915382 :       ro[1] = *(ro_loc[1] = &XEXP (pat, 1));
   15898   1462915382 :       break;
   15899              : 
   15900              :     case 9155:  /* avx_vzeroupper_callee_abi */
   15901              :     case 2436:  /* *mmx_femms */
   15902              :     case 2435:  /* *mmx_emms */
   15903              :     case 2053:  /* serialize */
   15904              :     case 2052:  /* speculation_barrier */
   15905              :     case 2043:  /* testui */
   15906              :     case 2042:  /* stui */
   15907              :     case 2041:  /* clui */
   15908              :     case 2036:  /* xresldtrk */
   15909              :     case 2035:  /* xsusldtrk */
   15910              :     case 2030:  /* wbnoinvd */
   15911              :     case 2029:  /* wbinvd */
   15912              :     case 2017:  /* xtest_1 */
   15913              :     case 2015:  /* xend */
   15914              :     case 2013:  /* nop_endbr */
   15915              :     case 2011:  /* setssbsy */
   15916              :     case 2005:  /* saveprevssp */
   15917              :     case 1975:  /* fnclex */
   15918              :     case 1931:  /* ud2 */
   15919              :     case 1930:  /* trap */
   15920              :     case 1786:  /* cld */
   15921              :     case 1529:  /* *leave_rex64 */
   15922              :     case 1528:  /* *leave */
   15923              :     case 1527:  /* eh_return_internal */
   15924              :     case 1519:  /* nop */
   15925              :     case 1515:  /* simple_return_internal_long */
   15926              :     case 1514:  /* interrupt_return */
   15927              :     case 1513:  /* simple_return_internal */
   15928              :     case 1510:  /* blockage */
   15929              :     case 561:  /* *setcc_qi_negqi_ccc_2_ccc */
   15930              :     case 560:  /* *setcc_qi_negqi_ccc_2_cc */
   15931              :     case 559:  /* *setcc_qi_negqi_ccc_1_ccc */
   15932              :     case 558:  /* *setcc_qi_negqi_ccc_1_cc */
   15933              :     case 557:  /* *setccc */
   15934              :     case 556:  /* *setcc_qi_addqi3_cconly_overflow_1_ccc */
   15935              :     case 555:  /* *setcc_qi_addqi3_cconly_overflow_1_cc */
   15936              :     case 68:  /* *x86_cmc */
   15937              :     case 67:  /* x86_stc */
   15938              :       break;
   15939              : 
   15940        17819 :     case 59:  /* *cmpxuhf */
   15941        17819 :     case 57:  /* *cmpxudf */
   15942        17819 :     case 55:  /* *cmpxusf */
   15943        17819 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 0));
   15944        17819 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 1));
   15945        17819 :       break;
   15946              : 
   15947      6405396 :     case 65:  /* *cmpiuhf */
   15948      6405396 :     case 63:  /* *cmpiudf */
   15949      6405396 :     case 61:  /* *cmpiusf */
   15950      6405396 :     case 58:  /* *cmpxhf */
   15951      6405396 :     case 56:  /* *cmpxdf */
   15952      6405396 :     case 54:  /* *cmpxsf */
   15953      6405396 :     case 53:  /* *cmpiuxf_i387 */
   15954      6405396 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
   15955      6405396 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
   15956      6405396 :       break;
   15957              : 
   15958          934 :     case 1674:  /* parityqi2_cmp */
   15959          934 :     case 51:  /* x86_sahf_1 */
   15960          934 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (pat, 1), 0, 0));
   15961          934 :       break;
   15962              : 
   15963            0 :     case 50:  /* *cmpuxf_i387 */
   15964            0 :     case 49:  /* *cmpudf_i387 */
   15965            0 :     case 48:  /* *cmpusf_i387 */
   15966            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   15967            0 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 0));
   15968            0 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 1));
   15969            0 :       break;
   15970              : 
   15971            0 :     case 47:  /* *cmpxf_si_i387 */
   15972            0 :     case 46:  /* *cmpdf_si_i387 */
   15973            0 :     case 45:  /* *cmpsf_si_i387 */
   15974            0 :     case 44:  /* *cmpxf_hi_i387 */
   15975            0 :     case 43:  /* *cmpdf_hi_i387 */
   15976            0 :     case 42:  /* *cmpsf_hi_i387 */
   15977            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   15978            0 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
   15979            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1), 0));
   15980            0 :       break;
   15981              : 
   15982           76 :     case 8619:  /* *sse2_pmovmskb_lt */
   15983           76 :     case 8618:  /* *avx2_pmovmskb_lt */
   15984           76 :     case 8579:  /* *sse2_movmskpd_lt */
   15985           76 :     case 8578:  /* *avx_movmskpd256_lt */
   15986           76 :     case 8577:  /* *sse_movmskps_lt */
   15987           76 :     case 8576:  /* *avx_movmskps256_lt */
   15988           76 :     case 41:  /* *cmpdf_i387 */
   15989           76 :     case 40:  /* *cmpsf_i387 */
   15990           76 :     case 39:  /* *cmpxf_i387 */
   15991           76 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   15992           76 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
   15993           76 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
   15994           76 :       break;
   15995              : 
   15996          808 :     case 36:  /* *cmpqi_extdi_4 */
   15997          808 :     case 35:  /* *cmpqi_extsi_4 */
   15998          808 :     case 34:  /* *cmpqi_exthi_4 */
   15999          808 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   16000          808 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
   16001          808 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   16002          808 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   16003          808 :       break;
   16004              : 
   16005         6408 :     case 33:  /* *cmpqi_extdi_3 */
   16006         6408 :     case 32:  /* *cmpqi_extsi_3 */
   16007         6408 :     case 31:  /* *cmpqi_exthi_3 */
   16008         6408 :     case 30:  /* *cmpqi_extdi_2 */
   16009         6408 :     case 29:  /* *cmpqi_extsi_2 */
   16010         6408 :     case 28:  /* *cmpqi_exthi_2 */
   16011         6408 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   16012         6408 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
   16013         6408 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   16014         6408 :       break;
   16015              : 
   16016           52 :     case 27:  /* *cmpqi_extdi_1 */
   16017           52 :     case 26:  /* *cmpqi_extsi_1 */
   16018           52 :     case 25:  /* *cmpqi_exthi_1 */
   16019           52 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 1), 0));
   16020           52 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
   16021           52 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   16022           52 :       break;
   16023              : 
   16024      2833391 :     case 721:  /* *testti_doubleword */
   16025      2833391 :     case 714:  /* *testsi_1 */
   16026      2833391 :     case 713:  /* *testhi_1 */
   16027      2833391 :     case 712:  /* *testqi_1 */
   16028      2833391 :     case 711:  /* *testqi_1_maybe_si */
   16029      2833391 :     case 710:  /* *testdi_1 */
   16030      2833391 :     case 24:  /* *cmpdi_plus_1 */
   16031      2833391 :     case 23:  /* *cmpsi_plus_1 */
   16032      2833391 :     case 22:  /* *cmphi_plus_1 */
   16033      2833391 :     case 21:  /* *cmpqi_plus_1 */
   16034      2833391 :     case 20:  /* *cmpdi_minus_1 */
   16035      2833391 :     case 19:  /* *cmpsi_minus_1 */
   16036      2833391 :     case 18:  /* *cmphi_minus_1 */
   16037      2833391 :     case 17:  /* *cmpqi_minus_1 */
   16038      2833391 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   16039      2833391 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   16040      2833391 :       break;
   16041              : 
   16042    134795278 :     case 66:  /* *cmpibf */
   16043    134795278 :     case 64:  /* *cmpihf */
   16044    134795278 :     case 62:  /* *cmpidf */
   16045    134795278 :     case 60:  /* *cmpisf */
   16046    134795278 :     case 52:  /* *cmpixf_i387 */
   16047    134795278 :     case 38:  /* *cmpti_doubleword */
   16048    134795278 :     case 37:  /* *cmpdi_doubleword */
   16049    134795278 :     case 16:  /* *cmpdi_1 */
   16050    134795278 :     case 15:  /* *cmpsi_1 */
   16051    134795278 :     case 14:  /* *cmphi_1 */
   16052    134795278 :     case 13:  /* *cmpqi_1 */
   16053    134795278 :     case 12:  /* *cmpdi_ccno_1 */
   16054    134795278 :     case 11:  /* *cmpsi_ccno_1 */
   16055    134795278 :     case 10:  /* *cmphi_ccno_1 */
   16056    134795278 :     case 9:  /* *cmpqi_ccno_1 */
   16057    134795278 :     case 8:  /* *cmpdi_ccz_1 */
   16058    134795278 :     case 7:  /* *cmpsi_ccz_1 */
   16059    134795278 :     case 6:  /* *cmphi_ccz_1 */
   16060    134795278 :     case 5:  /* *cmpqi_ccz_1 */
   16061    134795278 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 1), 0));
   16062    134795278 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
   16063    134795278 :       break;
   16064              : 
   16065          443 :     case 4:  /* ccmpdi */
   16066          443 :     case 3:  /* ccmpsi */
   16067          443 :     case 2:  /* ccmphi */
   16068          443 :     case 1:  /* ccmpqi */
   16069          443 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   16070          443 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
   16071          443 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
   16072          443 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1));
   16073          443 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 0));
   16074          443 :       break;
   16075              : 
   16076              :     }
   16077   2249279443 : }
        

Generated by: LCOV version 2.4-beta

LCOV profile is generated on x86_64 machine using following configure options: configure --disable-bootstrap --enable-coverage=opt --enable-languages=c,c++,fortran,go,jit,lto,rust,m2 --enable-host-shared. GCC test suite is run with the built compiler.