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 % 15344 14097
Test Date: 2026-05-11 19:44:49 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   2240472525 : insn_extract (rtx_insn *insn)
      20              : {
      21   2240472525 :   rtx *ro = recog_data.operand;
      22   2240472525 :   rtx **ro_loc = recog_data.operand_loc;
      23   2240472525 :   rtx pat = PATTERN (insn);
      24   2240472525 :   int i ATTRIBUTE_UNUSED; /* only for peepholes */
      25              : 
      26   2240472525 :   if (flag_checking)
      27              :     {
      28   2240453966 :       memset (ro, 0xab, sizeof (*ro) * MAX_RECOG_OPERANDS);
      29   2240453966 :       memset (ro_loc, 0xab, sizeof (*ro_loc) * MAX_RECOG_OPERANDS);
      30              :     }
      31              : 
      32   2240472525 :   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 11137:  /* cmpccxadd_di */
      45         2139 :     case 11136:  /* 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        35540 :     case 11135:  /* atomic_xor_fetch_cmp_0di_1 */
      60        35540 :     case 11134:  /* atomic_or_fetch_cmp_0di_1 */
      61        35540 :     case 11133:  /* atomic_and_fetch_cmp_0di_1 */
      62        35540 :     case 11132:  /* atomic_xor_fetch_cmp_0si_1 */
      63        35540 :     case 11131:  /* atomic_or_fetch_cmp_0si_1 */
      64        35540 :     case 11130:  /* atomic_and_fetch_cmp_0si_1 */
      65        35540 :     case 11129:  /* atomic_xor_fetch_cmp_0hi_1 */
      66        35540 :     case 11128:  /* atomic_or_fetch_cmp_0hi_1 */
      67        35540 :     case 11127:  /* atomic_and_fetch_cmp_0hi_1 */
      68        35540 :     case 11126:  /* atomic_xor_fetch_cmp_0qi_1 */
      69        35540 :     case 11125:  /* atomic_or_fetch_cmp_0qi_1 */
      70        35540 :     case 11124:  /* atomic_and_fetch_cmp_0qi_1 */
      71        35540 :     case 11123:  /* atomic_sub_fetch_cmp_0di_1 */
      72        35540 :     case 11122:  /* atomic_sub_fetch_cmp_0si_1 */
      73        35540 :     case 11121:  /* atomic_sub_fetch_cmp_0hi_1 */
      74        35540 :     case 11120:  /* atomic_sub_fetch_cmp_0qi_1 */
      75        35540 :     case 11119:  /* atomic_add_fetch_cmp_0di_1 */
      76        35540 :     case 11118:  /* atomic_add_fetch_cmp_0si_1 */
      77        35540 :     case 11117:  /* atomic_add_fetch_cmp_0hi_1 */
      78        35540 :     case 11116:  /* atomic_add_fetch_cmp_0qi_1 */
      79        35540 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0, 0));
      80        35540 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
      81        35540 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0, 1));
      82        35540 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0);
      83        35540 :       recog_data.dup_num[0] = 0;
      84        35540 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
      85        35540 :       recog_data.dup_num[1] = 0;
      86        35540 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
      87        35540 :       recog_data.dup_num[2] = 1;
      88        35540 :       break;
      89              : 
      90         2522 :     case 11112:  /* atomic_bit_test_and_complementdi_1 */
      91         2522 :     case 11111:  /* atomic_bit_test_and_complementsi_1 */
      92         2522 :     case 11110:  /* 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 11115:  /* atomic_bit_test_and_resetdi_1 */
     105         4803 :     case 11114:  /* atomic_bit_test_and_resetsi_1 */
     106         4803 :     case 11113:  /* atomic_bit_test_and_resethi_1 */
     107         4803 :     case 11109:  /* atomic_bit_test_and_setdi_1 */
     108         4803 :     case 11108:  /* atomic_bit_test_and_setsi_1 */
     109         4803 :     case 11107:  /* 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       237411 :     case 11106:  /* atomic_xordi */
     118       237411 :     case 11105:  /* atomic_ordi */
     119       237411 :     case 11104:  /* atomic_anddi */
     120       237411 :     case 11103:  /* atomic_xorsi */
     121       237411 :     case 11102:  /* atomic_orsi */
     122       237411 :     case 11101:  /* atomic_andsi */
     123       237411 :     case 11100:  /* atomic_xorhi */
     124       237411 :     case 11099:  /* atomic_orhi */
     125       237411 :     case 11098:  /* atomic_andhi */
     126       237411 :     case 11097:  /* atomic_xorqi */
     127       237411 :     case 11096:  /* atomic_orqi */
     128       237411 :     case 11095:  /* atomic_andqi */
     129       237411 :     case 11094:  /* atomic_subdi */
     130       237411 :     case 11093:  /* atomic_subsi */
     131       237411 :     case 11092:  /* atomic_subhi */
     132       237411 :     case 11091:  /* atomic_subqi */
     133       237411 :     case 11090:  /* atomic_adddi */
     134       237411 :     case 11089:  /* atomic_addsi */
     135       237411 :     case 11088:  /* atomic_addhi */
     136       237411 :     case 11087:  /* atomic_addqi */
     137       237411 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     138       237411 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0), 1));
     139       237411 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     140       237411 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0), 0);
     141       237411 :       recog_data.dup_num[0] = 0;
     142       237411 :       break;
     143              : 
     144         2339 :     case 11086:  /* rao_aadddi */
     145         2339 :     case 11085:  /* rao_axordi */
     146         2339 :     case 11084:  /* rao_aordi */
     147         2339 :     case 11083:  /* rao_aanddi */
     148         2339 :     case 11082:  /* rao_aaddsi */
     149         2339 :     case 11081:  /* rao_axorsi */
     150         2339 :     case 11080:  /* rao_aorsi */
     151         2339 :     case 11079:  /* 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 11078:  /* atomic_exchangedi */
     159       265550 :     case 11077:  /* atomic_exchangesi */
     160       265550 :     case 11076:  /* atomic_exchangehi */
     161       265550 :     case 11075:  /* 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 11074:  /* *atomic_fetch_add_cmpdi */
     171           16 :     case 11073:  /* *atomic_fetch_add_cmpsi */
     172           16 :     case 11072:  /* *atomic_fetch_add_cmphi */
     173           16 :     case 11071:  /* *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       257782 :     case 11070:  /* atomic_fetch_adddi */
     185       257782 :     case 11069:  /* atomic_fetch_addsi */
     186       257782 :     case 11068:  /* atomic_fetch_addhi */
     187       257782 :     case 11067:  /* atomic_fetch_addqi */
     188       257782 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     189       257782 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
     190       257782 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
     191       257782 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     192       257782 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0);
     193       257782 :       recog_data.dup_num[0] = 1;
     194       257782 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
     195       257782 :       recog_data.dup_num[1] = 1;
     196       257782 :       break;
     197              : 
     198       456576 :     case 11066:  /* atomic_compare_and_swapdi_1 */
     199       456576 :     case 11065:  /* atomic_compare_and_swapsi_1 */
     200       456576 :     case 11064:  /* atomic_compare_and_swaphi_1 */
     201       456576 :     case 11063:  /* atomic_compare_and_swapqi_1 */
     202       456576 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
     203       456576 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
     204       456576 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
     205       456576 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
     206       456576 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 3));
     207       456576 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0);
     208       456576 :       recog_data.dup_num[0] = 1;
     209       456576 :       break;
     210              : 
     211        21128 :     case 11062:  /* atomic_compare_and_swapti_doubleword */
     212        21128 :     case 11061:  /* 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 11050:  /* 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 10561:  /* *vcvtph2hf8sv8hf_mask */
     230         1876 :     case 10560:  /* *vcvtph2hf8v8hf_mask */
     231         1876 :     case 10559:  /* *vcvtph2bf8sv8hf_mask */
     232         1876 :     case 10558:  /* *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 10537:  /* *vcvtbiasph2hf8sv8hf_mask */
     241         1676 :     case 10536:  /* *vcvtbiasph2hf8v8hf_mask */
     242         1676 :     case 10535:  /* *vcvtbiasph2bf8sv8hf_mask */
     243         1676 :     case 10534:  /* *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 10501:  /* 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 10499:  /* 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 10637:  /* *vpdpwuuds_v4si_maskz */
     269         8036 :     case 10636:  /* *vpdpwuud_v4si_maskz */
     270         8036 :     case 10635:  /* *vpdpwsuds_v4si_maskz */
     271         8036 :     case 10634:  /* *vpdpwsud_v4si_maskz */
     272         8036 :     case 10633:  /* *vpdpwusds_v4si_maskz */
     273         8036 :     case 10632:  /* *vpdpwusd_v4si_maskz */
     274         8036 :     case 10631:  /* *vpdpwuuds_v8si_maskz */
     275         8036 :     case 10630:  /* *vpdpwuud_v8si_maskz */
     276         8036 :     case 10629:  /* *vpdpwsuds_v8si_maskz */
     277         8036 :     case 10628:  /* *vpdpwsud_v8si_maskz */
     278         8036 :     case 10627:  /* *vpdpwusds_v8si_maskz */
     279         8036 :     case 10626:  /* *vpdpwusd_v8si_maskz */
     280         8036 :     case 10625:  /* *vpdpwuuds_v16si_maskz */
     281         8036 :     case 10624:  /* *vpdpwuud_v16si_maskz */
     282         8036 :     case 10623:  /* *vpdpwsuds_v16si_maskz */
     283         8036 :     case 10622:  /* *vpdpwsud_v16si_maskz */
     284         8036 :     case 10621:  /* *vpdpwusds_v16si_maskz */
     285         8036 :     case 10620:  /* *vpdpwusd_v16si_maskz */
     286         8036 :     case 10485:  /* *vpdpbuuds_v4si_maskz */
     287         8036 :     case 10484:  /* *vpdpbuud_v4si_maskz */
     288         8036 :     case 10483:  /* *vpdpbsuds_v4si_maskz */
     289         8036 :     case 10482:  /* *vpdpbsud_v4si_maskz */
     290         8036 :     case 10481:  /* *vpdpbssds_v4si_maskz */
     291         8036 :     case 10480:  /* *vpdpbssd_v4si_maskz */
     292         8036 :     case 10479:  /* *vpdpbuuds_v8si_maskz */
     293         8036 :     case 10478:  /* *vpdpbuud_v8si_maskz */
     294         8036 :     case 10477:  /* *vpdpbsuds_v8si_maskz */
     295         8036 :     case 10476:  /* *vpdpbsud_v8si_maskz */
     296         8036 :     case 10475:  /* *vpdpbssds_v8si_maskz */
     297         8036 :     case 10474:  /* *vpdpbssd_v8si_maskz */
     298         8036 :     case 10473:  /* *vpdpbuuds_v16si_maskz */
     299         8036 :     case 10472:  /* *vpdpbuud_v16si_maskz */
     300         8036 :     case 10471:  /* *vpdpbsuds_v16si_maskz */
     301         8036 :     case 10470:  /* *vpdpbsud_v16si_maskz */
     302         8036 :     case 10469:  /* *vpdpbssds_v16si_maskz */
     303         8036 :     case 10468:  /* *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 10431:  /* *aesencwide256klu8 */
     313          628 :     case 10430:  /* *aesencwide128klu8 */
     314          628 :     case 10429:  /* *aesdecwide256klu8 */
     315          628 :     case 10428:  /* *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 10427:  /* aesenc256klu8 */
     321          760 :     case 10426:  /* aesenc128klu8 */
     322          760 :     case 10425:  /* aesdec256klu8 */
     323          760 :     case 10424:  /* 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 10423:  /* *encodekey256u32 */
     334          344 :     case 10422:  /* *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 10421:  /* 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 10505:  /* avx10_2_cvt2ps2phx_v8hf_mask */
     348         2352 :     case 10503:  /* avx10_2_cvt2ps2phx_v16hf_mask */
     349         2352 :     case 10500:  /* avx10_2_cvt2ps2phx_v32hf_mask */
     350         2352 :     case 10404:  /* avx512f_cvtne2ps2bf16_v8bf_mask */
     351         2352 :     case 10402:  /* avx512f_cvtne2ps2bf16_v16bf_mask */
     352         2352 :     case 10400:  /* 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 10504:  /* avx10_2_cvt2ps2phx_v8hf */
     361          744 :     case 10502:  /* avx10_2_cvt2ps2phx_v16hf */
     362          744 :     case 10498:  /* avx10_2_cvt2ps2phx_v32hf */
     363          744 :     case 10403:  /* avx512f_cvtne2ps2bf16_v8bf */
     364          744 :     case 10401:  /* avx512f_cvtne2ps2bf16_v16bf */
     365          744 :     case 10399:  /* 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 10213:  /* *restore_multiple_leave_returndi */
     372         1638 :     case 10212:  /* *restore_multiple_leave_returnsi */
     373         1638 :     case 10211:  /* *restore_multiple_and_returndi */
     374         1638 :     case 10210:  /* *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 10209:  /* *restore_multipledi */
     380        22190 :     case 10208:  /* *restore_multiplesi */
     381        22190 :     case 10207:  /* *save_multipledi */
     382        22190 :     case 10206:  /* *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 10066:  /* avx512dq_vmfpclassv2df_mask */
     388          504 :     case 10064:  /* avx512dq_vmfpclassv4sf_mask */
     389          504 :     case 10062:  /* 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 9946:  /* *avx512f_scatterdiv2df */
     397        17290 :     case 9945:  /* *avx512f_scatterdiv2di */
     398        17290 :     case 9944:  /* *avx512f_scatterdiv4sf */
     399        17290 :     case 9943:  /* *avx512f_scatterdiv4si */
     400        17290 :     case 9942:  /* *avx512f_scatterdiv4df */
     401        17290 :     case 9941:  /* *avx512f_scatterdiv4di */
     402        17290 :     case 9940:  /* *avx512f_scatterdiv8sf */
     403        17290 :     case 9939:  /* *avx512f_scatterdiv8si */
     404        17290 :     case 9938:  /* *avx512f_scatterdiv8df */
     405        17290 :     case 9937:  /* *avx512f_scatterdiv8di */
     406        17290 :     case 9936:  /* *avx512f_scatterdiv16sf */
     407        17290 :     case 9935:  /* *avx512f_scatterdiv16si */
     408        17290 :     case 9934:  /* *avx512f_scatterdiv2df */
     409        17290 :     case 9933:  /* *avx512f_scatterdiv2di */
     410        17290 :     case 9932:  /* *avx512f_scatterdiv4sf */
     411        17290 :     case 9931:  /* *avx512f_scatterdiv4si */
     412        17290 :     case 9930:  /* *avx512f_scatterdiv4df */
     413        17290 :     case 9929:  /* *avx512f_scatterdiv4di */
     414        17290 :     case 9928:  /* *avx512f_scatterdiv8sf */
     415        17290 :     case 9927:  /* *avx512f_scatterdiv8si */
     416        17290 :     case 9926:  /* *avx512f_scatterdiv8df */
     417        17290 :     case 9925:  /* *avx512f_scatterdiv8di */
     418        17290 :     case 9924:  /* *avx512f_scatterdiv16sf */
     419        17290 :     case 9923:  /* *avx512f_scatterdiv16si */
     420        17290 :     case 9922:  /* *avx512f_scattersiv2df */
     421        17290 :     case 9921:  /* *avx512f_scattersiv2di */
     422        17290 :     case 9920:  /* *avx512f_scattersiv4sf */
     423        17290 :     case 9919:  /* *avx512f_scattersiv4si */
     424        17290 :     case 9918:  /* *avx512f_scattersiv4df */
     425        17290 :     case 9917:  /* *avx512f_scattersiv4di */
     426        17290 :     case 9916:  /* *avx512f_scattersiv8sf */
     427        17290 :     case 9915:  /* *avx512f_scattersiv8si */
     428        17290 :     case 9914:  /* *avx512f_scattersiv8df */
     429        17290 :     case 9913:  /* *avx512f_scattersiv8di */
     430        17290 :     case 9912:  /* *avx512f_scattersiv16sf */
     431        17290 :     case 9911:  /* *avx512f_scattersiv16si */
     432        17290 :     case 9910:  /* *avx512f_scattersiv2df */
     433        17290 :     case 9909:  /* *avx512f_scattersiv2di */
     434        17290 :     case 9908:  /* *avx512f_scattersiv4sf */
     435        17290 :     case 9907:  /* *avx512f_scattersiv4si */
     436        17290 :     case 9906:  /* *avx512f_scattersiv4df */
     437        17290 :     case 9905:  /* *avx512f_scattersiv4di */
     438        17290 :     case 9904:  /* *avx512f_scattersiv8sf */
     439        17290 :     case 9903:  /* *avx512f_scattersiv8si */
     440        17290 :     case 9902:  /* *avx512f_scattersiv8df */
     441        17290 :     case 9901:  /* *avx512f_scattersiv8di */
     442        17290 :     case 9900:  /* *avx512f_scattersiv16sf */
     443        17290 :     case 9899:  /* *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 9898:  /* *avx512f_gatherdiv2df_2 */
     456         5373 :     case 9897:  /* *avx512f_gatherdiv2di_2 */
     457         5373 :     case 9896:  /* *avx512f_gatherdiv4sf_2 */
     458         5373 :     case 9895:  /* *avx512f_gatherdiv4si_2 */
     459         5373 :     case 9894:  /* *avx512f_gatherdiv4df_2 */
     460         5373 :     case 9893:  /* *avx512f_gatherdiv4di_2 */
     461         5373 :     case 9892:  /* *avx512f_gatherdiv8sf_2 */
     462         5373 :     case 9891:  /* *avx512f_gatherdiv8si_2 */
     463         5373 :     case 9890:  /* *avx512f_gatherdiv8df_2 */
     464         5373 :     case 9889:  /* *avx512f_gatherdiv8di_2 */
     465         5373 :     case 9888:  /* *avx512f_gatherdiv16sf_2 */
     466         5373 :     case 9887:  /* *avx512f_gatherdiv16si_2 */
     467         5373 :     case 9886:  /* *avx512f_gatherdiv2df_2 */
     468         5373 :     case 9885:  /* *avx512f_gatherdiv2di_2 */
     469         5373 :     case 9884:  /* *avx512f_gatherdiv4sf_2 */
     470         5373 :     case 9883:  /* *avx512f_gatherdiv4si_2 */
     471         5373 :     case 9882:  /* *avx512f_gatherdiv4df_2 */
     472         5373 :     case 9881:  /* *avx512f_gatherdiv4di_2 */
     473         5373 :     case 9880:  /* *avx512f_gatherdiv8sf_2 */
     474         5373 :     case 9879:  /* *avx512f_gatherdiv8si_2 */
     475         5373 :     case 9878:  /* *avx512f_gatherdiv8df_2 */
     476         5373 :     case 9877:  /* *avx512f_gatherdiv8di_2 */
     477         5373 :     case 9876:  /* *avx512f_gatherdiv16sf_2 */
     478         5373 :     case 9875:  /* *avx512f_gatherdiv16si_2 */
     479         5373 :     case 9850:  /* *avx512f_gathersiv2df_2 */
     480         5373 :     case 9849:  /* *avx512f_gathersiv2di_2 */
     481         5373 :     case 9848:  /* *avx512f_gathersiv4sf_2 */
     482         5373 :     case 9847:  /* *avx512f_gathersiv4si_2 */
     483         5373 :     case 9846:  /* *avx512f_gathersiv4df_2 */
     484         5373 :     case 9845:  /* *avx512f_gathersiv4di_2 */
     485         5373 :     case 9844:  /* *avx512f_gathersiv8sf_2 */
     486         5373 :     case 9843:  /* *avx512f_gathersiv8si_2 */
     487         5373 :     case 9842:  /* *avx512f_gathersiv8df_2 */
     488         5373 :     case 9841:  /* *avx512f_gathersiv8di_2 */
     489         5373 :     case 9840:  /* *avx512f_gathersiv16sf_2 */
     490         5373 :     case 9839:  /* *avx512f_gathersiv16si_2 */
     491         5373 :     case 9838:  /* *avx512f_gathersiv2df_2 */
     492         5373 :     case 9837:  /* *avx512f_gathersiv2di_2 */
     493         5373 :     case 9836:  /* *avx512f_gathersiv4sf_2 */
     494         5373 :     case 9835:  /* *avx512f_gathersiv4si_2 */
     495         5373 :     case 9834:  /* *avx512f_gathersiv4df_2 */
     496         5373 :     case 9833:  /* *avx512f_gathersiv4di_2 */
     497         5373 :     case 9832:  /* *avx512f_gathersiv8sf_2 */
     498         5373 :     case 9831:  /* *avx512f_gathersiv8si_2 */
     499         5373 :     case 9830:  /* *avx512f_gathersiv8df_2 */
     500         5373 :     case 9829:  /* *avx512f_gathersiv8di_2 */
     501         5373 :     case 9828:  /* *avx512f_gathersiv16sf_2 */
     502         5373 :     case 9827:  /* *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 9874:  /* *avx512f_gatherdiv2df */
     513        10487 :     case 9873:  /* *avx512f_gatherdiv2di */
     514        10487 :     case 9872:  /* *avx512f_gatherdiv4sf */
     515        10487 :     case 9871:  /* *avx512f_gatherdiv4si */
     516        10487 :     case 9870:  /* *avx512f_gatherdiv4df */
     517        10487 :     case 9869:  /* *avx512f_gatherdiv4di */
     518        10487 :     case 9868:  /* *avx512f_gatherdiv8sf */
     519        10487 :     case 9867:  /* *avx512f_gatherdiv8si */
     520        10487 :     case 9866:  /* *avx512f_gatherdiv8df */
     521        10487 :     case 9865:  /* *avx512f_gatherdiv8di */
     522        10487 :     case 9864:  /* *avx512f_gatherdiv16sf */
     523        10487 :     case 9863:  /* *avx512f_gatherdiv16si */
     524        10487 :     case 9862:  /* *avx512f_gatherdiv2df */
     525        10487 :     case 9861:  /* *avx512f_gatherdiv2di */
     526        10487 :     case 9860:  /* *avx512f_gatherdiv4sf */
     527        10487 :     case 9859:  /* *avx512f_gatherdiv4si */
     528        10487 :     case 9858:  /* *avx512f_gatherdiv4df */
     529        10487 :     case 9857:  /* *avx512f_gatherdiv4di */
     530        10487 :     case 9856:  /* *avx512f_gatherdiv8sf */
     531        10487 :     case 9855:  /* *avx512f_gatherdiv8si */
     532        10487 :     case 9854:  /* *avx512f_gatherdiv8df */
     533        10487 :     case 9853:  /* *avx512f_gatherdiv8di */
     534        10487 :     case 9852:  /* *avx512f_gatherdiv16sf */
     535        10487 :     case 9851:  /* *avx512f_gatherdiv16si */
     536        10487 :     case 9826:  /* *avx512f_gathersiv2df */
     537        10487 :     case 9825:  /* *avx512f_gathersiv2di */
     538        10487 :     case 9824:  /* *avx512f_gathersiv4sf */
     539        10487 :     case 9823:  /* *avx512f_gathersiv4si */
     540        10487 :     case 9822:  /* *avx512f_gathersiv4df */
     541        10487 :     case 9821:  /* *avx512f_gathersiv4di */
     542        10487 :     case 9820:  /* *avx512f_gathersiv8sf */
     543        10487 :     case 9819:  /* *avx512f_gathersiv8si */
     544        10487 :     case 9818:  /* *avx512f_gathersiv8df */
     545        10487 :     case 9817:  /* *avx512f_gathersiv8di */
     546        10487 :     case 9816:  /* *avx512f_gathersiv16sf */
     547        10487 :     case 9815:  /* *avx512f_gathersiv16si */
     548        10487 :     case 9814:  /* *avx512f_gathersiv2df */
     549        10487 :     case 9813:  /* *avx512f_gathersiv2di */
     550        10487 :     case 9812:  /* *avx512f_gathersiv4sf */
     551        10487 :     case 9811:  /* *avx512f_gathersiv4si */
     552        10487 :     case 9810:  /* *avx512f_gathersiv4df */
     553        10487 :     case 9809:  /* *avx512f_gathersiv4di */
     554        10487 :     case 9808:  /* *avx512f_gathersiv8sf */
     555        10487 :     case 9807:  /* *avx512f_gathersiv8si */
     556        10487 :     case 9806:  /* *avx512f_gathersiv8df */
     557        10487 :     case 9805:  /* *avx512f_gathersiv8di */
     558        10487 :     case 9804:  /* *avx512f_gathersiv16sf */
     559        10487 :     case 9803:  /* *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 9802:  /* *avx2_gatherdiv8sf_4 */
     571          389 :     case 9801:  /* *avx2_gatherdiv8si_4 */
     572          389 :     case 9800:  /* *avx2_gatherdiv8sf_4 */
     573          389 :     case 9799:  /* *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 9798:  /* *avx2_gatherdiv8sf_3 */
     584          446 :     case 9797:  /* *avx2_gatherdiv8si_3 */
     585          446 :     case 9796:  /* *avx2_gatherdiv8sf_3 */
     586          446 :     case 9795:  /* *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 9794:  /* *avx2_gatherdiv8sf_2 */
     598         5927 :     case 9793:  /* *avx2_gatherdiv8si_2 */
     599         5927 :     case 9792:  /* *avx2_gatherdiv4sf_2 */
     600         5927 :     case 9791:  /* *avx2_gatherdiv4si_2 */
     601         5927 :     case 9790:  /* *avx2_gatherdiv4df_2 */
     602         5927 :     case 9789:  /* *avx2_gatherdiv4di_2 */
     603         5927 :     case 9788:  /* *avx2_gatherdiv2df_2 */
     604         5927 :     case 9787:  /* *avx2_gatherdiv2di_2 */
     605         5927 :     case 9786:  /* *avx2_gatherdiv8sf_2 */
     606         5927 :     case 9785:  /* *avx2_gatherdiv8si_2 */
     607         5927 :     case 9784:  /* *avx2_gatherdiv4sf_2 */
     608         5927 :     case 9783:  /* *avx2_gatherdiv4si_2 */
     609         5927 :     case 9782:  /* *avx2_gatherdiv4df_2 */
     610         5927 :     case 9781:  /* *avx2_gatherdiv4di_2 */
     611         5927 :     case 9780:  /* *avx2_gatherdiv2df_2 */
     612         5927 :     case 9779:  /* *avx2_gatherdiv2di_2 */
     613         5927 :     case 9762:  /* *avx2_gathersiv8sf_2 */
     614         5927 :     case 9761:  /* *avx2_gathersiv8si_2 */
     615         5927 :     case 9760:  /* *avx2_gathersiv4sf_2 */
     616         5927 :     case 9759:  /* *avx2_gathersiv4si_2 */
     617         5927 :     case 9758:  /* *avx2_gathersiv4df_2 */
     618         5927 :     case 9757:  /* *avx2_gathersiv4di_2 */
     619         5927 :     case 9756:  /* *avx2_gathersiv2df_2 */
     620         5927 :     case 9755:  /* *avx2_gathersiv2di_2 */
     621         5927 :     case 9754:  /* *avx2_gathersiv8sf_2 */
     622         5927 :     case 9753:  /* *avx2_gathersiv8si_2 */
     623         5927 :     case 9752:  /* *avx2_gathersiv4sf_2 */
     624         5927 :     case 9751:  /* *avx2_gathersiv4si_2 */
     625         5927 :     case 9750:  /* *avx2_gathersiv4df_2 */
     626         5927 :     case 9749:  /* *avx2_gathersiv4di_2 */
     627         5927 :     case 9748:  /* *avx2_gathersiv2df_2 */
     628         5927 :     case 9747:  /* *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 9778:  /* *avx2_gatherdiv8sf */
     639         6573 :     case 9777:  /* *avx2_gatherdiv8si */
     640         6573 :     case 9776:  /* *avx2_gatherdiv4sf */
     641         6573 :     case 9775:  /* *avx2_gatherdiv4si */
     642         6573 :     case 9774:  /* *avx2_gatherdiv4df */
     643         6573 :     case 9773:  /* *avx2_gatherdiv4di */
     644         6573 :     case 9772:  /* *avx2_gatherdiv2df */
     645         6573 :     case 9771:  /* *avx2_gatherdiv2di */
     646         6573 :     case 9770:  /* *avx2_gatherdiv8sf */
     647         6573 :     case 9769:  /* *avx2_gatherdiv8si */
     648         6573 :     case 9768:  /* *avx2_gatherdiv4sf */
     649         6573 :     case 9767:  /* *avx2_gatherdiv4si */
     650         6573 :     case 9766:  /* *avx2_gatherdiv4df */
     651         6573 :     case 9765:  /* *avx2_gatherdiv4di */
     652         6573 :     case 9764:  /* *avx2_gatherdiv2df */
     653         6573 :     case 9763:  /* *avx2_gatherdiv2di */
     654         6573 :     case 9746:  /* *avx2_gathersiv8sf */
     655         6573 :     case 9745:  /* *avx2_gathersiv8si */
     656         6573 :     case 9744:  /* *avx2_gathersiv4sf */
     657         6573 :     case 9743:  /* *avx2_gathersiv4si */
     658         6573 :     case 9742:  /* *avx2_gathersiv4df */
     659         6573 :     case 9741:  /* *avx2_gathersiv4di */
     660         6573 :     case 9740:  /* *avx2_gathersiv2df */
     661         6573 :     case 9739:  /* *avx2_gathersiv2di */
     662         6573 :     case 9738:  /* *avx2_gathersiv8sf */
     663         6573 :     case 9737:  /* *avx2_gathersiv8si */
     664         6573 :     case 9736:  /* *avx2_gathersiv4sf */
     665         6573 :     case 9735:  /* *avx2_gathersiv4si */
     666         6573 :     case 9734:  /* *avx2_gathersiv4df */
     667         6573 :     case 9733:  /* *avx2_gathersiv4di */
     668         6573 :     case 9732:  /* *avx2_gathersiv2df */
     669         6573 :     case 9731:  /* *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 9730:  /* *avx512f_vcvtps2ph512_merge_mask */
     681            0 :     case 9724:  /* *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 9719:  /* *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 9709:  /* 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        24302 :     case 9982:  /* compressstorev8hi_mask */
     707        24302 :     case 9981:  /* compressstorev16hi_mask */
     708        24302 :     case 9980:  /* compressstorev32hi_mask */
     709        24302 :     case 9979:  /* compressstorev32qi_mask */
     710        24302 :     case 9978:  /* compressstorev16qi_mask */
     711        24302 :     case 9977:  /* compressstorev64qi_mask */
     712        24302 :     case 9976:  /* avx512vl_compressstorev2df_mask */
     713        24302 :     case 9975:  /* avx512vl_compressstorev2di_mask */
     714        24302 :     case 9974:  /* avx512vl_compressstorev4sf_mask */
     715        24302 :     case 9973:  /* avx512vl_compressstorev4si_mask */
     716        24302 :     case 9972:  /* avx512vl_compressstorev4df_mask */
     717        24302 :     case 9971:  /* avx512vl_compressstorev4di_mask */
     718        24302 :     case 9970:  /* avx512vl_compressstorev8sf_mask */
     719        24302 :     case 9969:  /* avx512vl_compressstorev8si_mask */
     720        24302 :     case 9968:  /* avx512f_compressstorev8df_mask */
     721        24302 :     case 9967:  /* avx512f_compressstorev8di_mask */
     722        24302 :     case 9966:  /* avx512f_compressstorev16sf_mask */
     723        24302 :     case 9965:  /* avx512f_compressstorev16si_mask */
     724        24302 :     case 9610:  /* *avx512vl_storev2df_mask_1 */
     725        24302 :     case 9609:  /* *avx512vl_storev4df_mask_1 */
     726        24302 :     case 9608:  /* *avx512f_storev8df_mask_1 */
     727        24302 :     case 9607:  /* *avx512vl_storev4sf_mask_1 */
     728        24302 :     case 9606:  /* *avx512vl_storev8sf_mask_1 */
     729        24302 :     case 9605:  /* *avx512f_storev16sf_mask_1 */
     730        24302 :     case 9604:  /* *avx512vl_storev8bf_mask_1 */
     731        24302 :     case 9603:  /* *avx512vl_storev16bf_mask_1 */
     732        24302 :     case 9602:  /* *avx512bw_storev32bf_mask_1 */
     733        24302 :     case 9601:  /* *avx512fp16_storev8hf_mask_1 */
     734        24302 :     case 9600:  /* *avx512vl_storev16hf_mask_1 */
     735        24302 :     case 9599:  /* *avx512bw_storev32hf_mask_1 */
     736        24302 :     case 9598:  /* *avx512vl_storev2di_mask_1 */
     737        24302 :     case 9597:  /* *avx512vl_storev4di_mask_1 */
     738        24302 :     case 9596:  /* *avx512f_storev8di_mask_1 */
     739        24302 :     case 9595:  /* *avx512vl_storev4si_mask_1 */
     740        24302 :     case 9594:  /* *avx512vl_storev8si_mask_1 */
     741        24302 :     case 9593:  /* *avx512f_storev16si_mask_1 */
     742        24302 :     case 9592:  /* *avx512vl_storev8hi_mask_1 */
     743        24302 :     case 9591:  /* *avx512vl_storev16hi_mask_1 */
     744        24302 :     case 9590:  /* *avx512bw_storev32hi_mask_1 */
     745        24302 :     case 9589:  /* *avx512vl_storev16qi_mask_1 */
     746        24302 :     case 9588:  /* *avx512vl_storev32qi_mask_1 */
     747        24302 :     case 9587:  /* *avx512bw_storev64qi_mask_1 */
     748        24302 :     case 9586:  /* avx512vl_storev8bf_mask */
     749        24302 :     case 9585:  /* avx512vl_storev16bf_mask */
     750        24302 :     case 9584:  /* avx512bw_storev32bf_mask */
     751        24302 :     case 9583:  /* avx512fp16_storev8hf_mask */
     752        24302 :     case 9582:  /* avx512vl_storev16hf_mask */
     753        24302 :     case 9581:  /* avx512bw_storev32hf_mask */
     754        24302 :     case 9580:  /* avx512vl_storev8hi_mask */
     755        24302 :     case 9579:  /* avx512vl_storev16hi_mask */
     756        24302 :     case 9578:  /* avx512bw_storev32hi_mask */
     757        24302 :     case 9577:  /* avx512vl_storev32qi_mask */
     758        24302 :     case 9576:  /* avx512vl_storev16qi_mask */
     759        24302 :     case 9575:  /* avx512bw_storev64qi_mask */
     760        24302 :     case 9574:  /* avx512vl_storev2df_mask */
     761        24302 :     case 9573:  /* avx512vl_storev4df_mask */
     762        24302 :     case 9572:  /* avx512f_storev8df_mask */
     763        24302 :     case 9571:  /* avx512vl_storev4sf_mask */
     764        24302 :     case 9570:  /* avx512vl_storev8sf_mask */
     765        24302 :     case 9569:  /* avx512f_storev16sf_mask */
     766        24302 :     case 9568:  /* avx512vl_storev2di_mask */
     767        24302 :     case 9567:  /* avx512vl_storev4di_mask */
     768        24302 :     case 9566:  /* avx512f_storev8di_mask */
     769        24302 :     case 9565:  /* avx512vl_storev4si_mask */
     770        24302 :     case 9564:  /* avx512vl_storev8si_mask */
     771        24302 :     case 9563:  /* avx512f_storev16si_mask */
     772        24302 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     773        24302 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
     774        24302 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 2));
     775        24302 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (pat, 1), 0, 1);
     776        24302 :       recog_data.dup_num[0] = 0;
     777        24302 :       break;
     778              : 
     779         6451 :     case 9562:  /* avx2_maskstored */
     780         6451 :     case 9561:  /* avx2_maskstored256 */
     781         6451 :     case 9560:  /* avx_maskstorepd256 */
     782         6451 :     case 9559:  /* avx_maskstoreps256 */
     783         6451 :     case 9558:  /* avx2_maskstoreq */
     784         6451 :     case 9557:  /* avx2_maskstoreq256 */
     785         6451 :     case 9556:  /* avx_maskstorepd */
     786         6451 :     case 9555:  /* avx_maskstoreps */
     787         6451 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     788         6451 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
     789         6451 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
     790         6451 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (pat, 1), 0, 2);
     791         6451 :       recog_data.dup_num[0] = 0;
     792         6451 :       break;
     793              : 
     794         9944 :     case 9554:  /* avx2_maskloadd */
     795         9944 :     case 9553:  /* avx2_maskloadd256 */
     796         9944 :     case 9552:  /* avx_maskloadpd256 */
     797         9944 :     case 9551:  /* avx_maskloadps256 */
     798         9944 :     case 9550:  /* avx2_maskloadq */
     799         9944 :     case 9549:  /* avx2_maskloadq256 */
     800         9944 :     case 9548:  /* avx_maskloadpd */
     801         9944 :     case 9547:  /* avx_maskloadps */
     802         9944 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     803         9944 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 1));
     804         9944 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 0));
     805         9944 :       break;
     806              : 
     807         5770 :     case 9508:  /* avx512vl_vpermt2varv16qi3_mask */
     808         5770 :     case 9507:  /* avx512vl_vpermt2varv32qi3_mask */
     809         5770 :     case 9506:  /* avx512bw_vpermt2varv64qi3_mask */
     810         5770 :     case 9505:  /* avx512vl_vpermt2varv8hi3_mask */
     811         5770 :     case 9504:  /* avx512vl_vpermt2varv16hi3_mask */
     812         5770 :     case 9503:  /* avx512bw_vpermt2varv32hi3_mask */
     813         5770 :     case 9502:  /* avx512vl_vpermt2varv2df3_mask */
     814         5770 :     case 9501:  /* avx512vl_vpermt2varv2di3_mask */
     815         5770 :     case 9500:  /* avx512vl_vpermt2varv4sf3_mask */
     816         5770 :     case 9499:  /* avx512vl_vpermt2varv4si3_mask */
     817         5770 :     case 9498:  /* avx512vl_vpermt2varv4df3_mask */
     818         5770 :     case 9497:  /* avx512vl_vpermt2varv4di3_mask */
     819         5770 :     case 9496:  /* avx512vl_vpermt2varv8sf3_mask */
     820         5770 :     case 9495:  /* avx512vl_vpermt2varv8si3_mask */
     821         5770 :     case 9494:  /* avx512f_vpermt2varv8df3_mask */
     822         5770 :     case 9493:  /* avx512f_vpermt2varv8di3_mask */
     823         5770 :     case 9492:  /* avx512f_vpermt2varv16sf3_mask */
     824         5770 :     case 9491:  /* 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 9442:  /* *avx512vl_vpermi2varv2df3_mask */
     835         1606 :     case 9441:  /* *avx512vl_vpermi2varv4df3_mask */
     836         1606 :     case 9440:  /* *avx512f_vpermi2varv8df3_mask */
     837         1606 :     case 9439:  /* *avx512vl_vpermi2varv4sf3_mask */
     838         1606 :     case 9438:  /* *avx512vl_vpermi2varv8sf3_mask */
     839         1606 :     case 9437:  /* *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 9436:  /* *avx512vl_vpermi2varv16qi3_mask */
     850         3626 :     case 9435:  /* *avx512vl_vpermi2varv32qi3_mask */
     851         3626 :     case 9434:  /* *avx512bw_vpermi2varv64qi3_mask */
     852         3626 :     case 9433:  /* *avx512vl_vpermi2varv8hi3_mask */
     853         3626 :     case 9432:  /* *avx512vl_vpermi2varv16hi3_mask */
     854         3626 :     case 9431:  /* *avx512bw_vpermi2varv32hi3_mask */
     855         3626 :     case 9430:  /* *avx512vl_vpermi2varv2di3_mask */
     856         3626 :     case 9429:  /* *avx512vl_vpermi2varv4di3_mask */
     857         3626 :     case 9428:  /* *avx512vl_vpermi2varv4si3_mask */
     858         3626 :     case 9427:  /* *avx512vl_vpermi2varv8si3_mask */
     859         3626 :     case 9426:  /* *avx512f_vpermi2varv8di3_mask */
     860         3626 :     case 9425:  /* *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 9350:  /* 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 9372:  /* avx_vbroadcastf128_v16bf */
     878        20061 :     case 9371:  /* avx_vbroadcastf128_v16hf */
     879        20061 :     case 9370:  /* avx_vbroadcastf128_v4df */
     880        20061 :     case 9369:  /* avx_vbroadcastf128_v8sf */
     881        20061 :     case 9368:  /* avx_vbroadcastf128_v4di */
     882        20061 :     case 9367:  /* avx_vbroadcastf128_v8si */
     883        20061 :     case 9366:  /* avx_vbroadcastf128_v16hi */
     884        20061 :     case 9365:  /* avx_vbroadcastf128_v32qi */
     885        20061 :     case 9349:  /* avx2_vbroadcasti128_v4di */
     886        20061 :     case 9348:  /* avx2_vbroadcasti128_v8si */
     887        20061 :     case 9347:  /* avx2_vbroadcasti128_v16hi */
     888        20061 :     case 9346:  /* 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 9222:  /* *avx_vpermilpv2df_mask */
     896         2686 :     case 9220:  /* *avx_vpermilpv4df_mask */
     897         2686 :     case 9218:  /* *avx512f_vpermilpv8df_mask */
     898         2686 :     case 9216:  /* *avx_vpermilpv4sf_mask */
     899         2686 :     case 9214:  /* *avx_vpermilpv8sf_mask */
     900         2686 :     case 9212:  /* *avx512f_vpermilpv16sf_mask */
     901         2686 :     case 9210:  /* *avx512vl_vpermilpv2di_mask */
     902         2686 :     case 9208:  /* *avx512vl_vpermilpv4di_mask */
     903         2686 :     case 9206:  /* *avx512f_vpermilpv8di_mask */
     904         2686 :     case 9204:  /* *sse2_vpermilpv4si_mask */
     905         2686 :     case 9202:  /* *avx_vpermilpv8si_mask */
     906         2686 :     case 9200:  /* *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        96082 :     case 9522:  /* *ssse3_palignrv2df_perm */
     916        96082 :     case 9521:  /* *ssse3_palignrv4sf_perm */
     917        96082 :     case 9520:  /* *ssse3_palignrv2di_perm */
     918        96082 :     case 9519:  /* *ssse3_palignrv4si_perm */
     919        96082 :     case 9518:  /* *ssse3_palignrv8bf_perm */
     920        96082 :     case 9517:  /* *ssse3_palignrv8hf_perm */
     921        96082 :     case 9516:  /* *ssse3_palignrv8hi_perm */
     922        96082 :     case 9515:  /* *ssse3_palignrv16qi_perm */
     923        96082 :     case 9221:  /* *avx_vpermilpv2df */
     924        96082 :     case 9219:  /* *avx_vpermilpv4df */
     925        96082 :     case 9217:  /* *avx512f_vpermilpv8df */
     926        96082 :     case 9215:  /* *avx_vpermilpv4sf */
     927        96082 :     case 9213:  /* *avx_vpermilpv8sf */
     928        96082 :     case 9211:  /* *avx512f_vpermilpv16sf */
     929        96082 :     case 9209:  /* *avx512vl_vpermilpv2di */
     930        96082 :     case 9207:  /* *avx512vl_vpermilpv4di */
     931        96082 :     case 9205:  /* *avx512f_vpermilpv8di */
     932        96082 :     case 9203:  /* *sse2_vpermilpv4si */
     933        96082 :     case 9201:  /* *avx_vpermilpv8si */
     934        96082 :     case 9199:  /* *avx512f_vpermilpv16si */
     935        96082 :     case 9198:  /* *avx_vperm_broadcast_v4df */
     936        96082 :     case 9197:  /* *avx_vperm_broadcast_v8sf */
     937        96082 :     case 9196:  /* *avx_vperm_broadcast_v4sf */
     938        96082 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     939        96082 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
     940        96082 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
     941        96082 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
     942        96082 :       break;
     943              : 
     944         1799 :     case 9130:  /* *avx_vzeroall */
     945         1799 :       ro[0] = *(ro_loc[0] = &PATTERN (insn));
     946         1799 :       break;
     947              : 
     948         1036 :     case 9114:  /* xop_maskcmp_uns2v2di3 */
     949         1036 :     case 9113:  /* xop_maskcmp_uns2v4si3 */
     950         1036 :     case 9112:  /* xop_maskcmp_uns2v8hi3 */
     951         1036 :     case 9111:  /* 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        12821 :     case 9093:  /* xop_shlv2di3 */
     959        12821 :     case 9092:  /* xop_shlv4si3 */
     960        12821 :     case 9091:  /* xop_shlv8hi3 */
     961        12821 :     case 9090:  /* xop_shlv16qi3 */
     962        12821 :     case 9089:  /* xop_shav2di3 */
     963        12821 :     case 9088:  /* xop_shav4si3 */
     964        12821 :     case 9087:  /* xop_shav8hi3 */
     965        12821 :     case 9086:  /* xop_shav16qi3 */
     966        12821 :     case 9085:  /* xop_vrotlv2di3 */
     967        12821 :     case 9084:  /* xop_vrotlv4si3 */
     968        12821 :     case 9083:  /* xop_vrotlv8hi3 */
     969        12821 :     case 9082:  /* xop_vrotlv16qi3 */
     970        12821 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
     971        12821 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
     972        12821 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
     973        12821 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 1), 1);
     974        12821 :       recog_data.dup_num[0] = 2;
     975        12821 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 2), 0);
     976        12821 :       recog_data.dup_num[1] = 1;
     977        12821 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 2), 1), 0);
     978        12821 :       recog_data.dup_num[2] = 2;
     979        12821 :       break;
     980              : 
     981            0 :     case 9073:  /* xop_pperm_pack_v8hi_v16qi */
     982            0 :     case 9072:  /* xop_pperm_pack_v4si_v8hi */
     983            0 :     case 9071:  /* 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 9060:  /* xop_phaddubq */
     991          260 :     case 9059:  /* 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 9064:  /* xop_phadduwq */
    1011          520 :     case 9063:  /* xop_phaddwq */
    1012          520 :     case 9058:  /* xop_phaddubd */
    1013          520 :     case 9057:  /* 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 9069:  /* xop_phsubdq */
    1025         1332 :     case 9068:  /* xop_phsubwd */
    1026         1332 :     case 9067:  /* xop_phsubbw */
    1027         1332 :     case 9066:  /* xop_phaddudq */
    1028         1332 :     case 9065:  /* xop_phadddq */
    1029         1332 :     case 9062:  /* xop_phadduwd */
    1030         1332 :     case 9061:  /* xop_phaddwd */
    1031         1332 :     case 9056:  /* xop_phaddubw */
    1032         1332 :     case 9055:  /* 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 9038:  /* xop_pmadcsswd */
    1040          416 :     case 9037:  /* 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 9036:  /* xop_pmacsswd */
    1052         2849 :     case 9035:  /* xop_pmacswd */
    1053         2849 :     case 9034:  /* xop_pmacssdqh */
    1054         2849 :     case 9033:  /* xop_pmacsdqh */
    1055         2849 :     case 9032:  /* xop_pmacssdql */
    1056         2849 :     case 9031:  /* 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 9026:  /* 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 9025:  /* sse4_2_pcmpistrm */
    1072         1976 :     case 9024:  /* 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 9023:  /* 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 9022:  /* 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 9021:  /* sse4_2_pcmpestrm */
    1116         1810 :     case 9020:  /* 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 9019:  /* 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 9008:  /* *ptestv2di_ccz */
    1166           12 :     case 9007:  /* *ptestv4di_ccz */
    1167           12 :     case 9006:  /* *ptestv4si_ccz */
    1168           12 :     case 9005:  /* *ptestv8si_ccz */
    1169           12 :     case 9004:  /* *ptestv8hi_ccz */
    1170           12 :     case 9003:  /* *ptestv16hi_ccz */
    1171           12 :     case 9002:  /* *ptestv16qi_ccz */
    1172           12 :     case 9001:  /* *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 9000:  /* *ptestv4df_and */
    1185            7 :     case 8999:  /* *ptestv8sf_and */
    1186            7 :     case 8998:  /* *ptestv2ti_and */
    1187            7 :     case 8997:  /* *ptestv4di_and */
    1188            7 :     case 8996:  /* *ptestv8si_and */
    1189            7 :     case 8995:  /* *ptestv16hi_and */
    1190            7 :     case 8994:  /* *ptestv32qi_and */
    1191            7 :     case 8993:  /* *ptestv2df_and */
    1192            7 :     case 8992:  /* *ptestv4sf_and */
    1193            7 :     case 8991:  /* *ptestv1ti_and */
    1194            7 :     case 8990:  /* *ptestv2di_and */
    1195            7 :     case 8989:  /* *ptestv4si_and */
    1196            7 :     case 8988:  /* *ptestv8hi_and */
    1197            7 :     case 8987:  /* *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 8967:  /* *sse4_1_zero_extendv2siv2di2_4 */
    1207           39 :     case 8953:  /* *avx2_zero_extendv4siv4di2_2 */
    1208           39 :     case 8947:  /* *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 8913:  /* *sse4_1_zero_extendv2qiv2di2_2 */
    1218           10 :     case 8912:  /* *sse4_1_zero_extendv2qiv2di2_2 */
    1219           10 :     case 8911:  /* *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 8941:  /* *avx512vl_zero_extendv2hiv2di2_mask_2 */
    1226           27 :     case 8940:  /* *avx512vl_sign_extendv2hiv2di2_mask_2 */
    1227           27 :     case 8902:  /* *avx512vl_zero_extendv4qiv4di2_mask_2 */
    1228           27 :     case 8901:  /* *avx512vl_sign_extendv4qiv4di2_mask_2 */
    1229           27 :     case 8846:  /* *avx512vl_zero_extendv4qiv4si2_mask_2 */
    1230           27 :     case 8845:  /* *avx512vl_sign_extendv4qiv4si2_mask_2 */
    1231           27 :     case 8844:  /* *sse4_1_zero_extendv4qiv4si2_2 */
    1232           27 :     case 8842:  /* *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 8939:  /* *sse4_1_zero_extendv2hiv2di2_2 */
    1240           20 :     case 8938:  /* *sse4_1_sign_extendv2hiv2di2_2 */
    1241           20 :     case 8900:  /* *avx2_zero_extendv4qiv4di2_2 */
    1242           20 :     case 8899:  /* *avx2_sign_extendv4qiv4di2_2 */
    1243           20 :     case 8843:  /* *sse4_1_zero_extendv4qiv4si2_2 */
    1244           20 :     case 8841:  /* *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 8965:  /* *avx512vl_zero_extendv2siv2di2_mask_2 */
    1250           54 :     case 8964:  /* *avx512vl_sign_extendv2siv2di2_mask_2 */
    1251           54 :     case 8929:  /* *avx512vl_zero_extendv4hiv4di2_mask_2 */
    1252           54 :     case 8928:  /* *avx512vl_sign_extendv4hiv4di2_mask_2 */
    1253           54 :     case 8890:  /* *avx512f_zero_extendv8qiv8di2_mask_2 */
    1254           54 :     case 8889:  /* *avx512f_sign_extendv8qiv8di2_mask_2 */
    1255           54 :     case 8874:  /* *avx512vl_zero_extendv4hiv4si2_mask_2 */
    1256           54 :     case 8873:  /* *avx512vl_sign_extendv4hiv4si2_mask_2 */
    1257           54 :     case 8832:  /* *avx512vl_zero_extendv8qiv8si2_mask_2 */
    1258           54 :     case 8831:  /* *avx512vl_sign_extendv8qiv8si2_mask_2 */
    1259           54 :     case 8812:  /* *avx512vl_zero_extendv8qiv8hi2_mask_2 */
    1260           54 :     case 8811:  /* *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 8963:  /* *sse4_1_zero_extendv2siv2di2_2 */
    1268           36 :     case 8962:  /* *sse4_1_sign_extendv2siv2di2_2 */
    1269           36 :     case 8927:  /* *avx2_zero_extendv4hiv4di2_2 */
    1270           36 :     case 8926:  /* *avx2_sign_extendv4hiv4di2_2 */
    1271           36 :     case 8888:  /* *avx512f_zero_extendv8qiv8di2_2 */
    1272           36 :     case 8887:  /* *avx512f_sign_extendv8qiv8di2_2 */
    1273           36 :     case 8872:  /* *sse4_1_zero_extendv4hiv4si2_2 */
    1274           36 :     case 8871:  /* *sse4_1_sign_extendv4hiv4si2_2 */
    1275           36 :     case 8830:  /* *avx2_zero_extendv8qiv8si2_2 */
    1276           36 :     case 8829:  /* *avx2_sign_extendv8qiv8si2_2 */
    1277           36 :     case 8810:  /* *sse4_1_zero_extendv8qiv8hi2_2 */
    1278           36 :     case 8809:  /* *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 8878:  /* *sse4_1_zero_extendv4hiv4si2_4 */
    1284          114 :     case 8877:  /* *sse4_1_zero_extendv4hiv4si2_4 */
    1285          114 :     case 8876:  /* *sse4_1_zero_extendv4hiv4si2_4 */
    1286          114 :     case 8862:  /* *avx2_zero_extendv8hiv8si2_2 */
    1287          114 :     case 8861:  /* *avx2_zero_extendv8hiv8si2_2 */
    1288          114 :     case 8860:  /* *avx2_zero_extendv8hiv8si2_2 */
    1289          114 :     case 8854:  /* *avx512f_zero_extendv16hiv16si2_2 */
    1290          114 :     case 8853:  /* *avx512f_zero_extendv16hiv16si2_2 */
    1291          114 :     case 8852:  /* *avx512f_zero_extendv16hiv16si2_2 */
    1292          114 :     case 8816:  /* *sse4_1_zero_extendv8qiv8hi2_4 */
    1293          114 :     case 8815:  /* *sse4_1_zero_extendv8qiv8hi2_4 */
    1294          114 :     case 8814:  /* *sse4_1_zero_extendv8qiv8hi2_4 */
    1295          114 :     case 8800:  /* *avx512bw_zero_extendv32qiv32hi2_2 */
    1296          114 :     case 8799:  /* *avx512bw_zero_extendv32qiv32hi2_2 */
    1297          114 :     case 8798:  /* *avx512bw_zero_extendv32qiv32hi2_2 */
    1298          114 :     case 8792:  /* *avx2_zero_extendv16qiv16hi2_2 */
    1299          114 :     case 8791:  /* *avx2_zero_extendv16qiv16hi2_2 */
    1300          114 :     case 8790:  /* *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        33889 :     case 9707:  /* *vec_concatv2df_0_1 */
    1310        33889 :     case 9706:  /* *vec_concatv4df_0_1 */
    1311        33889 :     case 9705:  /* *vec_concatv8df_0_1 */
    1312        33889 :     case 9704:  /* *vec_concatv4sf_0_1 */
    1313        33889 :     case 9703:  /* *vec_concatv8sf_0_1 */
    1314        33889 :     case 9702:  /* *vec_concatv16sf_0_1 */
    1315        33889 :     case 9701:  /* *vec_concatv8bf_0_1 */
    1316        33889 :     case 9700:  /* *vec_concatv16bf_0_1 */
    1317        33889 :     case 9699:  /* *vec_concatv32bf_0_1 */
    1318        33889 :     case 9698:  /* *vec_concatv8hf_0_1 */
    1319        33889 :     case 9697:  /* *vec_concatv16hf_0_1 */
    1320        33889 :     case 9696:  /* *vec_concatv32hf_0_1 */
    1321        33889 :     case 9695:  /* *vec_concatv2di_0_1 */
    1322        33889 :     case 9694:  /* *vec_concatv4di_0_1 */
    1323        33889 :     case 9693:  /* *vec_concatv8di_0_1 */
    1324        33889 :     case 9692:  /* *vec_concatv4si_0_1 */
    1325        33889 :     case 9691:  /* *vec_concatv8si_0_1 */
    1326        33889 :     case 9690:  /* *vec_concatv16si_0_1 */
    1327        33889 :     case 9689:  /* *vec_concatv8hi_0_1 */
    1328        33889 :     case 9688:  /* *vec_concatv16hi_0_1 */
    1329        33889 :     case 9687:  /* *vec_concatv32hi_0_1 */
    1330        33889 :     case 9686:  /* *vec_concatv16qi_0_1 */
    1331        33889 :     case 9685:  /* *vec_concatv32qi_0_1 */
    1332        33889 :     case 9684:  /* *vec_concatv64qi_0_1 */
    1333        33889 :     case 9514:  /* *avx_vperm2f128v4df_nozero */
    1334        33889 :     case 9513:  /* *avx_vperm2f128v8sf_nozero */
    1335        33889 :     case 9512:  /* *avx_vperm2f128v8si_nozero */
    1336        33889 :     case 9380:  /* *avx_vbroadcastf128_v16bf_perm */
    1337        33889 :     case 9379:  /* *avx_vbroadcastf128_v16hf_perm */
    1338        33889 :     case 9378:  /* *avx_vbroadcastf128_v4df_perm */
    1339        33889 :     case 9377:  /* *avx_vbroadcastf128_v8sf_perm */
    1340        33889 :     case 9376:  /* *avx_vbroadcastf128_v4di_perm */
    1341        33889 :     case 9375:  /* *avx_vbroadcastf128_v8si_perm */
    1342        33889 :     case 9374:  /* *avx_vbroadcastf128_v16hi_perm */
    1343        33889 :     case 9373:  /* *avx_vbroadcastf128_v32qi_perm */
    1344        33889 :     case 8966:  /* *sse4_1_zero_extendv2siv2di2_3 */
    1345        33889 :     case 8952:  /* *avx2_zero_extendv4siv4di2_1 */
    1346        33889 :     case 8946:  /* *avx512f_zero_extendv8siv8di2_1 */
    1347        33889 :     case 8875:  /* *sse4_1_zero_extendv4hiv4si2_3 */
    1348        33889 :     case 8859:  /* avx2_zero_extendv8hiv8si2_1 */
    1349        33889 :     case 8851:  /* avx512f_zero_extendv16hiv16si2_1 */
    1350        33889 :     case 8813:  /* *sse4_1_zero_extendv8qiv8hi2_3 */
    1351        33889 :     case 8797:  /* *avx512bw_zero_extendv32qiv32hi2_1 */
    1352        33889 :     case 8789:  /* *avx2_zero_extendv16qiv16hi2_1 */
    1353        33889 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1354        33889 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    1355        33889 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    1356        33889 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    1357        33889 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    1358        33889 :       break;
    1359              : 
    1360            8 :     case 8775:  /* *sse4_1_pblendvb_gt_subreg_not */
    1361            8 :     case 8774:  /* *avx2_pblendvb_gt_subreg_not */
    1362            8 :     case 8773:  /* *sse4_1_pblendvb_lt_subreg_not */
    1363            8 :     case 8772:  /* *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 8744:  /* *avx_blendvpd256_not_gtint */
    1372           24 :     case 8743:  /* *avx_blendvps256_not_gtint */
    1373           24 :     case 8742:  /* *sse4_1_blendvpd_not_gtint */
    1374           24 :     case 8741:  /* *sse4_1_blendvps_not_gtint */
    1375           24 :     case 8740:  /* *avx_blendvpd256_not_ltint */
    1376           24 :     case 8739:  /* *avx_blendvps256_not_ltint */
    1377           24 :     case 8738:  /* *sse4_1_blendvpd_not_ltint */
    1378           24 :     case 8737:  /* *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 8736:  /* *avx_blendvpd256_gtint */
    1387          813 :     case 8735:  /* *avx_blendvps256_gtint */
    1388          813 :     case 8734:  /* *sse4_1_blendvpd_gtint */
    1389          813 :     case 8733:  /* *sse4_1_blendvps_gtint */
    1390          813 :     case 8732:  /* *avx_blendvpd256_ltint */
    1391          813 :     case 8731:  /* *avx_blendvps256_ltint */
    1392          813 :     case 8730:  /* *sse4_1_blendvpd_ltint */
    1393          813 :     case 8729:  /* *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 8662:  /* *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 8653:  /* *ssse3_pmulhrswv8hi3_mask */
    1410          959 :     case 8651:  /* *avx2_pmulhrswv16hi3_mask */
    1411          959 :     case 8649:  /* *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 8655:  /* *smulhrsv2hi3 */
    1421          965 :     case 8654:  /* *ssse3_pmulhrswv4hi3 */
    1422          965 :     case 8652:  /* *ssse3_pmulhrswv8hi3 */
    1423          965 :     case 8650:  /* *avx2_pmulhrswv16hi3 */
    1424          965 :     case 8648:  /* *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 8645:  /* 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 8644:  /* 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 8636:  /* ssse3_phsubdv2si3 */
    1446         5032 :     case 8635:  /* ssse3_phadddv2si3 */
    1447         5032 :     case 8634:  /* ssse3_phsubdv4si3 */
    1448         5032 :     case 8633:  /* ssse3_phadddv4si3 */
    1449         5032 :     case 8632:  /* avx2_phsubdv8si3 */
    1450         5032 :     case 8631:  /* avx2_phadddv8si3 */
    1451         5032 :     case 8630:  /* ssse3_phsubswv4hi3 */
    1452         5032 :     case 8629:  /* ssse3_phsubwv4hi3 */
    1453         5032 :     case 8628:  /* ssse3_phaddswv4hi3 */
    1454         5032 :     case 8627:  /* ssse3_phaddwv4hi3 */
    1455         5032 :     case 8626:  /* ssse3_phsubswv8hi3 */
    1456         5032 :     case 8625:  /* ssse3_phsubwv8hi3 */
    1457         5032 :     case 8624:  /* ssse3_phaddswv8hi3 */
    1458         5032 :     case 8623:  /* ssse3_phaddwv8hi3 */
    1459         5032 :     case 8622:  /* avx2_phsubswv16hi3 */
    1460         5032 :     case 8621:  /* avx2_phsubwv16hi3 */
    1461         5032 :     case 8620:  /* avx2_phaddswv16hi3 */
    1462         5032 :     case 8619:  /* 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 8610:  /* *pmovsk_ptest_v16qi_avx512 */
    1473            2 :     case 8609:  /* *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 8608:  /* *pmovsk_mask_cmp_v16qi_avx512 */
    1482            0 :     case 8607:  /* *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 8606:  /* *pmovsk_mask_v32qi_avx512 */
    1490            0 :     case 8605:  /* *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 8604:  /* *sse2_pmovmskb_ext_lt_avx512 */
    1498            0 :     case 8603:  /* *sse2_pmovmskb_ext_lt_avx512 */
    1499            0 :     case 8601:  /* *sse2_pmovmskb_zext_lt_avx512 */
    1500            0 :     case 8600:  /* *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 8597:  /* *sse2_pmovmskb_lt_avx512 */
    1509            0 :     case 8596:  /* *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 8593:  /* *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 8587:  /* *sse2_movmskpd_uext_shift */
    1523           26 :     case 8586:  /* *sse2_movmskpd_ext_shift */
    1524           26 :     case 8585:  /* *avx_movmskpd256_uext_shift */
    1525           26 :     case 8584:  /* *avx_movmskpd256_ext_shift */
    1526           26 :     case 8583:  /* *sse_movmskps_uext_shift */
    1527           26 :     case 8582:  /* *sse_movmskps_ext_shift */
    1528           26 :     case 8581:  /* *avx_movmskps256_uext_shift */
    1529           26 :     case 8580:  /* *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 8579:  /* *sse2_movmskpd_shift */
    1536          134 :     case 8578:  /* *avx_movmskpd256_shift */
    1537          134 :     case 8577:  /* *sse_movmskps_shift */
    1538          134 :     case 8576:  /* *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 8575:  /* *sse2_movmskpd_uext_lt_avx512 */
    1545            0 :     case 8574:  /* *sse2_movmskpd_ext_lt_avx512 */
    1546            0 :     case 8573:  /* *avx_movmskpd256_uext_lt_avx512 */
    1547            0 :     case 8572:  /* *avx_movmskpd256_ext_lt_avx512 */
    1548            0 :     case 8571:  /* *sse_movmskps_uext_lt_avx512 */
    1549            0 :     case 8570:  /* *sse_movmskps_ext_lt_avx512 */
    1550            0 :     case 8569:  /* *avx_movmskps256_uext_lt_avx512 */
    1551            0 :     case 8568:  /* *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 8602:  /* *sse2_pmovmskb_ext_lt */
    1560           24 :     case 8599:  /* *sse2_pmovmskb_zext_lt */
    1561           24 :     case 8598:  /* *avx2_pmovmskb_zext_lt */
    1562           24 :     case 8567:  /* *sse2_movmskpd_uext_lt */
    1563           24 :     case 8566:  /* *sse2_movmskpd_ext_lt */
    1564           24 :     case 8565:  /* *avx_movmskpd256_uext_lt */
    1565           24 :     case 8564:  /* *avx_movmskpd256_ext_lt */
    1566           24 :     case 8563:  /* *sse_movmskps_uext_lt */
    1567           24 :     case 8562:  /* *sse_movmskps_ext_lt */
    1568           24 :     case 8561:  /* *avx_movmskps256_uext_lt */
    1569           24 :     case 8560:  /* *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 8559:  /* *sse2_movmskpd_lt_avx512 */
    1576            0 :     case 8558:  /* *avx_movmskpd256_lt_avx512 */
    1577            0 :     case 8557:  /* *sse_movmskps_lt_avx512 */
    1578            0 :     case 8556:  /* *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 8536:  /* *sse2_uavgv8hi3_mask */
    1587         3113 :     case 8534:  /* *avx2_uavgv16hi3_mask */
    1588         3113 :     case 8532:  /* *avx512bw_uavgv32hi3_mask */
    1589         3113 :     case 8530:  /* *sse2_uavgv16qi3_mask */
    1590         3113 :     case 8528:  /* *avx2_uavgv32qi3_mask */
    1591         3113 :     case 8526:  /* *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 8535:  /* *sse2_uavgv8hi3 */
    1601         1754 :     case 8533:  /* *avx2_uavgv16hi3 */
    1602         1754 :     case 8531:  /* *avx512bw_uavgv32hi3 */
    1603         1754 :     case 8529:  /* *sse2_uavgv16qi3 */
    1604         1754 :     case 8527:  /* *avx2_uavgv32qi3 */
    1605         1754 :     case 8525:  /* *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 8517:  /* *vec_concatv8hi_permt2 */
    1613            2 :     case 8516:  /* *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 8486:  /* 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 8485:  /* 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 8484:  /* 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 8483:  /* 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 8478:  /* 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 8477:  /* 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 8470:  /* avx512f_pshufd_1_mask */
    1696          507 :     case 8468:  /* *avx512f_shuf_i32x4_1_mask_1 */
    1697          507 :     case 8466:  /* *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 8469:  /* avx512f_pshufd_1 */
    1721         1363 :     case 8467:  /* *avx512f_shuf_i32x4_1_1 */
    1722         1363 :     case 8465:  /* *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 9230:  /* avx512f_permv8di_1_mask */
    1744         1658 :     case 9228:  /* avx512f_permv8df_1_mask */
    1745         1658 :     case 8472:  /* avx2_pshufd_1_mask */
    1746         1658 :     case 8456:  /* *avx512f_shuf_i64x2_1_mask_1 */
    1747         1658 :     case 8454:  /* *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        15101 :     case 9229:  /* avx512f_permv8di_1 */
    1763        15101 :     case 9227:  /* avx512f_permv8df_1 */
    1764        15101 :     case 8471:  /* avx2_pshufd_1 */
    1765        15101 :     case 8455:  /* *avx512f_shuf_i64x2_1_1 */
    1766        15101 :     case 8453:  /* *avx512f_shuf_f64x2_1_1 */
    1767        15101 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    1768        15101 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    1769        15101 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    1770        15101 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    1771        15101 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 2));
    1772        15101 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 3));
    1773        15101 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 4));
    1774        15101 :       ro[7] = *(ro_loc[7] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 5));
    1775        15101 :       ro[8] = *(ro_loc[8] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 6));
    1776        15101 :       ro[9] = *(ro_loc[9] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 7));
    1777        15101 :       break;
    1778              : 
    1779          321 :     case 9534:  /* vec_set_lo_v8sf_mask */
    1780          321 :     case 9532:  /* vec_set_lo_v8si_mask */
    1781          321 :     case 9526:  /* vec_set_lo_v4df_mask */
    1782          321 :     case 9524:  /* vec_set_lo_v4di_mask */
    1783          321 :     case 8440:  /* vec_set_lo_v8di_mask */
    1784          321 :     case 8438:  /* vec_set_lo_v8df_mask */
    1785          321 :     case 8432:  /* vec_set_lo_v16si_mask */
    1786          321 :     case 8430:  /* 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 8428:  /* avx512f_vinserti32x4_1_mask */
    1795         1973 :     case 8426:  /* avx512f_vinsertf32x4_1_mask */
    1796         1973 :     case 8424:  /* avx512dq_vinserti64x2_1_mask */
    1797         1973 :     case 8422:  /* 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 8427:  /* *avx512f_vinserti32x4_1 */
    1807          965 :     case 8425:  /* *avx512f_vinsertf32x4_1 */
    1808          965 :     case 8423:  /* *avx512dq_vinserti64x2_1 */
    1809          965 :     case 8421:  /* *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 8344:  /* avx512bw_packssdw_mask */
    1817         2293 :     case 8342:  /* avx2_packssdw_mask */
    1818         2293 :     case 8338:  /* avx512bw_packsswb_mask */
    1819         2293 :     case 8336:  /* 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 8343:  /* avx512bw_packssdw */
    1828          928 :     case 8341:  /* avx2_packssdw */
    1829          928 :     case 8337:  /* avx512bw_packsswb */
    1830          928 :     case 8335:  /* 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 8340:  /* sse2_packssdw_mask */
    1837          984 :     case 8334:  /* 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 8332:  /* *avx512vl_testnmv2di3_zext_mask */
    1846            0 :     case 8331:  /* *avx512vl_testnmv2di3_zext_mask */
    1847            0 :     case 8330:  /* *avx512vl_testnmv2di3_zext_mask */
    1848            0 :     case 8329:  /* *avx512vl_testnmv4di3_zext_mask */
    1849            0 :     case 8328:  /* *avx512vl_testnmv4di3_zext_mask */
    1850            0 :     case 8327:  /* *avx512vl_testnmv4di3_zext_mask */
    1851            0 :     case 8326:  /* *avx512f_testnmv8di3_zext_mask */
    1852            0 :     case 8325:  /* *avx512f_testnmv8di3_zext_mask */
    1853            0 :     case 8324:  /* *avx512f_testnmv8di3_zext_mask */
    1854            0 :     case 8323:  /* *avx512vl_testnmv4si3_zext_mask */
    1855            0 :     case 8322:  /* *avx512vl_testnmv4si3_zext_mask */
    1856            0 :     case 8321:  /* *avx512vl_testnmv4si3_zext_mask */
    1857            0 :     case 8320:  /* *avx512vl_testnmv8si3_zext_mask */
    1858            0 :     case 8319:  /* *avx512vl_testnmv8si3_zext_mask */
    1859            0 :     case 8318:  /* *avx512vl_testnmv8si3_zext_mask */
    1860            0 :     case 8317:  /* *avx512f_testnmv16si3_zext_mask */
    1861            0 :     case 8316:  /* *avx512f_testnmv16si3_zext_mask */
    1862            0 :     case 8315:  /* *avx512f_testnmv16si3_zext_mask */
    1863            0 :     case 8314:  /* *avx512vl_testnmv8hi3_zext_mask */
    1864            0 :     case 8313:  /* *avx512vl_testnmv8hi3_zext_mask */
    1865            0 :     case 8312:  /* *avx512vl_testnmv8hi3_zext_mask */
    1866            0 :     case 8311:  /* *avx512vl_testnmv16hi3_zext_mask */
    1867            0 :     case 8310:  /* *avx512vl_testnmv16hi3_zext_mask */
    1868            0 :     case 8309:  /* *avx512vl_testnmv16hi3_zext_mask */
    1869            0 :     case 8308:  /* *avx512bw_testnmv32hi3_zext_mask */
    1870            0 :     case 8307:  /* *avx512bw_testnmv32hi3_zext_mask */
    1871            0 :     case 8306:  /* *avx512bw_testnmv32hi3_zext_mask */
    1872            0 :     case 8305:  /* *avx512vl_testnmv16qi3_zext_mask */
    1873            0 :     case 8304:  /* *avx512vl_testnmv16qi3_zext_mask */
    1874            0 :     case 8303:  /* *avx512vl_testnmv16qi3_zext_mask */
    1875            0 :     case 8302:  /* *avx512vl_testnmv32qi3_zext_mask */
    1876            0 :     case 8301:  /* *avx512vl_testnmv32qi3_zext_mask */
    1877            0 :     case 8300:  /* *avx512vl_testnmv32qi3_zext_mask */
    1878            0 :     case 8299:  /* *avx512bw_testnmv64qi3_zext_mask */
    1879            0 :     case 8298:  /* *avx512bw_testnmv64qi3_zext_mask */
    1880            0 :     case 8297:  /* *avx512bw_testnmv64qi3_zext_mask */
    1881            0 :     case 8260:  /* *avx512vl_testmv2di3_zext_mask */
    1882            0 :     case 8259:  /* *avx512vl_testmv2di3_zext_mask */
    1883            0 :     case 8258:  /* *avx512vl_testmv2di3_zext_mask */
    1884            0 :     case 8257:  /* *avx512vl_testmv4di3_zext_mask */
    1885            0 :     case 8256:  /* *avx512vl_testmv4di3_zext_mask */
    1886            0 :     case 8255:  /* *avx512vl_testmv4di3_zext_mask */
    1887            0 :     case 8254:  /* *avx512f_testmv8di3_zext_mask */
    1888            0 :     case 8253:  /* *avx512f_testmv8di3_zext_mask */
    1889            0 :     case 8252:  /* *avx512f_testmv8di3_zext_mask */
    1890            0 :     case 8251:  /* *avx512vl_testmv4si3_zext_mask */
    1891            0 :     case 8250:  /* *avx512vl_testmv4si3_zext_mask */
    1892            0 :     case 8249:  /* *avx512vl_testmv4si3_zext_mask */
    1893            0 :     case 8248:  /* *avx512vl_testmv8si3_zext_mask */
    1894            0 :     case 8247:  /* *avx512vl_testmv8si3_zext_mask */
    1895            0 :     case 8246:  /* *avx512vl_testmv8si3_zext_mask */
    1896            0 :     case 8245:  /* *avx512f_testmv16si3_zext_mask */
    1897            0 :     case 8244:  /* *avx512f_testmv16si3_zext_mask */
    1898            0 :     case 8243:  /* *avx512f_testmv16si3_zext_mask */
    1899            0 :     case 8242:  /* *avx512vl_testmv8hi3_zext_mask */
    1900            0 :     case 8241:  /* *avx512vl_testmv8hi3_zext_mask */
    1901            0 :     case 8240:  /* *avx512vl_testmv8hi3_zext_mask */
    1902            0 :     case 8239:  /* *avx512vl_testmv16hi3_zext_mask */
    1903            0 :     case 8238:  /* *avx512vl_testmv16hi3_zext_mask */
    1904            0 :     case 8237:  /* *avx512vl_testmv16hi3_zext_mask */
    1905            0 :     case 8236:  /* *avx512bw_testmv32hi3_zext_mask */
    1906            0 :     case 8235:  /* *avx512bw_testmv32hi3_zext_mask */
    1907            0 :     case 8234:  /* *avx512bw_testmv32hi3_zext_mask */
    1908            0 :     case 8233:  /* *avx512vl_testmv16qi3_zext_mask */
    1909            0 :     case 8232:  /* *avx512vl_testmv16qi3_zext_mask */
    1910            0 :     case 8231:  /* *avx512vl_testmv16qi3_zext_mask */
    1911            0 :     case 8230:  /* *avx512vl_testmv32qi3_zext_mask */
    1912            0 :     case 8229:  /* *avx512vl_testmv32qi3_zext_mask */
    1913            0 :     case 8228:  /* *avx512vl_testmv32qi3_zext_mask */
    1914            0 :     case 8227:  /* *avx512bw_testmv64qi3_zext_mask */
    1915            0 :     case 8226:  /* *avx512bw_testmv64qi3_zext_mask */
    1916            0 :     case 8225:  /* *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 8017:  /* *one_cmplv2di2_pternlog_false_dep */
    1924           21 :     case 8016:  /* *one_cmplv4di2_pternlog_false_dep */
    1925           21 :     case 8015:  /* *one_cmplv4si2_pternlog_false_dep */
    1926           21 :     case 8014:  /* *one_cmplv8si2_pternlog_false_dep */
    1927           21 :     case 8013:  /* *one_cmplv8hi2_pternlog_false_dep */
    1928           21 :     case 8012:  /* *one_cmplv16hi2_pternlog_false_dep */
    1929           21 :     case 8011:  /* *one_cmplv32hi2_pternlog_false_dep */
    1930           21 :     case 8010:  /* *one_cmplv16qi2_pternlog_false_dep */
    1931           21 :     case 8009:  /* *one_cmplv32qi2_pternlog_false_dep */
    1932           21 :     case 8008:  /* *one_cmplv64qi2_pternlog_false_dep */
    1933           21 :     case 8007:  /* *one_cmplv8di2_pternlog_false_dep */
    1934           21 :     case 8006:  /* *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 7943:  /* *avx2_pcmpv16qi3_5 */
    1942            0 :     case 7942:  /* *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 7666:  /* *avx512_ashrv2di3_1 */
    1952            0 :     case 7665:  /* *avx512_ashrv4di3_1 */
    1953            0 :     case 7664:  /* *avx512_ashrv8di3_1 */
    1954            0 :     case 7663:  /* *avx512_ashrv4si3_1 */
    1955            0 :     case 7662:  /* *avx512_ashrv8si3_1 */
    1956            0 :     case 7661:  /* *avx512_ashrv16si3_1 */
    1957            0 :     case 7660:  /* *avx512_ashrv8hi3_1 */
    1958            0 :     case 7659:  /* *avx512_ashrv16hi3_1 */
    1959            0 :     case 7658:  /* *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 7611:  /* *sse4_1_mulv2siv2di3_mask */
    1968         3028 :     case 7609:  /* *vec_widen_smult_even_v8si_mask */
    1969         3028 :     case 7607:  /* *vec_widen_smult_even_v16si_mask */
    1970         3028 :     case 7605:  /* *vec_widen_umult_even_v4si_mask */
    1971         3028 :     case 7603:  /* *vec_widen_umult_even_v8si_mask */
    1972         3028 :     case 7601:  /* *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 7599:  /* *umulv8hi3_highpart_mask */
    1981         3004 :     case 7597:  /* *smulv8hi3_highpart_mask */
    1982         3004 :     case 7595:  /* *umulv16hi3_highpart_mask */
    1983         3004 :     case 7593:  /* *smulv16hi3_highpart_mask */
    1984         3004 :     case 7591:  /* *umulv32hi3_highpart_mask */
    1985         3004 :     case 7589:  /* *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 8464:  /* avx512f_shuf_i32x4_1_mask */
    2050         1576 :     case 8462:  /* 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 8463:  /* avx512f_shuf_i32x4_1 */
    2076         1842 :     case 8461:  /* 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 9018:  /* *sse4_1_roundsd */
    2110          387 :     case 9017:  /* *sse4_1_roundss */
    2111          387 :     case 9016:  /* *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 9015:  /* sse4_1_roundsd */
    2155         1743 :     case 9014:  /* sse4_1_roundss */
    2156         1743 :     case 9013:  /* 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         2369 :     case 7145:  /* avx512vl_fixupimmv2df_mask */
    2293         2369 :     case 7143:  /* avx512vl_fixupimmv4df_mask */
    2294         2369 :     case 7141:  /* avx512f_fixupimmv8df_mask */
    2295         2369 :     case 7139:  /* avx512vl_fixupimmv4sf_mask */
    2296         2369 :     case 7137:  /* avx512vl_fixupimmv8sf_mask */
    2297         2369 :     case 7135:  /* avx512f_fixupimmv16sf_mask */
    2298         2369 :     case 7042:  /* *avx512vl_vternlogv2di_mask */
    2299         2369 :     case 7041:  /* *avx512vl_vternlogv4di_mask */
    2300         2369 :     case 7040:  /* *avx512f_vternlogv8di_mask */
    2301         2369 :     case 7039:  /* *avx512vl_vternlogv4si_mask */
    2302         2369 :     case 7038:  /* *avx512vl_vternlogv8si_mask */
    2303         2369 :     case 7037:  /* *avx512f_vternlogv16si_mask */
    2304         2369 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2305         2369 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    2306         2369 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    2307         2369 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    2308         2369 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 3));
    2309         2369 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 2));
    2310         2369 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    2311         2369 :       recog_data.dup_num[0] = 1;
    2312         2369 :       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         2280 :     case 7133:  /* avx512vl_fixupimmv2df_maskz_1 */
    2970         2280 :     case 7129:  /* avx512vl_fixupimmv4df_maskz_1 */
    2971         2280 :     case 7125:  /* avx512f_fixupimmv8df_maskz_1 */
    2972         2280 :     case 7121:  /* avx512vl_fixupimmv4sf_maskz_1 */
    2973         2280 :     case 7117:  /* avx512vl_fixupimmv8sf_maskz_1 */
    2974         2280 :     case 7113:  /* avx512f_fixupimmv16sf_maskz_1 */
    2975         2280 :     case 5476:  /* avx512vl_vternlogv2di_maskz_1 */
    2976         2280 :     case 5474:  /* avx512vl_vternlogv4di_maskz_1 */
    2977         2280 :     case 5472:  /* avx512f_vternlogv8di_maskz_1 */
    2978         2280 :     case 5470:  /* avx512vl_vternlogv4si_maskz_1 */
    2979         2280 :     case 5468:  /* avx512vl_vternlogv8si_maskz_1 */
    2980         2280 :     case 5466:  /* avx512f_vternlogv16si_maskz_1 */
    2981         2280 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    2982         2280 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    2983         2280 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    2984         2280 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    2985         2280 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 3));
    2986         2280 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (pat, 1), 1));
    2987         2280 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (pat, 1), 2));
    2988         2280 :       break;
    2989              : 
    2990        41508 :     case 10154:  /* vsm3rnds2 */
    2991        41508 :     case 9122:  /* xop_vpermil2v2df3 */
    2992        41508 :     case 9121:  /* xop_vpermil2v4df3 */
    2993        41508 :     case 9120:  /* xop_vpermil2v4sf3 */
    2994        41508 :     case 9119:  /* xop_vpermil2v8sf3 */
    2995        41508 :     case 8709:  /* sse4a_insertqi */
    2996        41508 :     case 7131:  /* avx512vl_fixupimmv2df */
    2997        41508 :     case 7127:  /* avx512vl_fixupimmv4df */
    2998        41508 :     case 7123:  /* avx512f_fixupimmv8df */
    2999        41508 :     case 7119:  /* avx512vl_fixupimmv4sf */
    3000        41508 :     case 7115:  /* avx512vl_fixupimmv8sf */
    3001        41508 :     case 7111:  /* avx512f_fixupimmv16sf */
    3002        41508 :     case 5500:  /* *avx512vl_vternlogv2df_all */
    3003        41508 :     case 5499:  /* *avx512vl_vternlogv4df_all */
    3004        41508 :     case 5498:  /* *avx512f_vternlogv8df_all */
    3005        41508 :     case 5497:  /* *avx512vl_vternlogv4sf_all */
    3006        41508 :     case 5496:  /* *avx512vl_vternlogv8sf_all */
    3007        41508 :     case 5495:  /* *avx512f_vternlogv16sf_all */
    3008        41508 :     case 5494:  /* *avx512vl_vternlogv8bf_all */
    3009        41508 :     case 5493:  /* *avx512vl_vternlogv16bf_all */
    3010        41508 :     case 5492:  /* *avx512bw_vternlogv32bf_all */
    3011        41508 :     case 5491:  /* *avx512fp16_vternlogv8hf_all */
    3012        41508 :     case 5490:  /* *avx512vl_vternlogv16hf_all */
    3013        41508 :     case 5489:  /* *avx512bw_vternlogv32hf_all */
    3014        41508 :     case 5488:  /* *avx512vl_vternlogv2di_all */
    3015        41508 :     case 5487:  /* *avx512vl_vternlogv4di_all */
    3016        41508 :     case 5486:  /* *avx512f_vternlogv8di_all */
    3017        41508 :     case 5485:  /* *avx512vl_vternlogv4si_all */
    3018        41508 :     case 5484:  /* *avx512vl_vternlogv8si_all */
    3019        41508 :     case 5483:  /* *avx512f_vternlogv16si_all */
    3020        41508 :     case 5482:  /* *avx512vl_vternlogv8hi_all */
    3021        41508 :     case 5481:  /* *avx512vl_vternlogv16hi_all */
    3022        41508 :     case 5480:  /* *avx512bw_vternlogv32hi_all */
    3023        41508 :     case 5479:  /* *avx512vl_vternlogv16qi_all */
    3024        41508 :     case 5478:  /* *avx512vl_vternlogv32qi_all */
    3025        41508 :     case 5477:  /* *avx512bw_vternlogv64qi_all */
    3026        41508 :     case 5475:  /* avx512vl_vternlogv2di */
    3027        41508 :     case 5473:  /* avx512vl_vternlogv4di */
    3028        41508 :     case 5471:  /* avx512f_vternlogv8di */
    3029        41508 :     case 5469:  /* avx512vl_vternlogv4si */
    3030        41508 :     case 5467:  /* avx512vl_vternlogv8si */
    3031        41508 :     case 5465:  /* avx512f_vternlogv16si */
    3032        41508 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3033        41508 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
    3034        41508 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    3035        41508 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 2));
    3036        41508 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 3));
    3037        41508 :       break;
    3038              : 
    3039         2829 :     case 9226:  /* avx2_permv4df_1_mask */
    3040         2829 :     case 9224:  /* avx2_permv4di_1_mask */
    3041         2829 :     case 8480:  /* sse2_pshuflw_1_mask */
    3042         2829 :     case 8474:  /* 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       628329 :     case 8524:  /* vec_setv4di_0 */
    3066       628329 :     case 8523:  /* vec_setv8di_0 */
    3067       628329 :     case 8487:  /* sse2_loadld */
    3068       628329 :     case 7246:  /* vec_setv4df_0 */
    3069       628329 :     case 7245:  /* vec_setv8df_0 */
    3070       628329 :     case 5333:  /* vec_setv2df_0 */
    3071       628329 :     case 5326:  /* vec_setv16sf_0 */
    3072       628329 :     case 5325:  /* vec_setv16si_0 */
    3073       628329 :     case 5324:  /* vec_setv8sf_0 */
    3074       628329 :     case 5323:  /* vec_setv8si_0 */
    3075       628329 :     case 5311:  /* vec_setv32bf_0 */
    3076       628329 :     case 5310:  /* vec_setv16bf_0 */
    3077       628329 :     case 5309:  /* vec_setv32hf_0 */
    3078       628329 :     case 5308:  /* vec_setv16hf_0 */
    3079       628329 :     case 5307:  /* vec_setv32hi_0 */
    3080       628329 :     case 5306:  /* vec_setv16hi_0 */
    3081       628329 :     case 5302:  /* vec_setv8bf_0 */
    3082       628329 :     case 5301:  /* vec_setv8hf_0 */
    3083       628329 :     case 5300:  /* vec_setv8hi_0 */
    3084       628329 :     case 5299:  /* vec_setv4sf_0 */
    3085       628329 :     case 5298:  /* vec_setv4si_0 */
    3086       628329 :     case 5297:  /* *vec_concatv8hi_movss */
    3087       628329 :     case 5296:  /* *vec_concatv8bf_movss */
    3088       628329 :     case 5295:  /* *vec_concatv8hf_movss */
    3089       628329 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3090       628329 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    3091       628329 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    3092       628329 :       break;
    3093              : 
    3094         2056 :     case 9545:  /* vec_set_lo_v32qi */
    3095         2056 :     case 9541:  /* vec_set_lo_v16bf */
    3096         2056 :     case 9540:  /* vec_set_lo_v16hf */
    3097         2056 :     case 9539:  /* vec_set_lo_v16hi */
    3098         2056 :     case 9533:  /* vec_set_lo_v8sf */
    3099         2056 :     case 9531:  /* vec_set_lo_v8si */
    3100         2056 :     case 9525:  /* vec_set_lo_v4df */
    3101         2056 :     case 9523:  /* vec_set_lo_v4di */
    3102         2056 :     case 8439:  /* vec_set_lo_v8di */
    3103         2056 :     case 8437:  /* vec_set_lo_v8df */
    3104         2056 :     case 8431:  /* vec_set_lo_v16si */
    3105         2056 :     case 8429:  /* vec_set_lo_v16sf */
    3106         2056 :     case 7239:  /* sse2_loadlpd */
    3107         2056 :     case 5279:  /* sse_loadlps */
    3108         2056 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3109         2056 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    3110         2056 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
    3111         2056 :       break;
    3112              : 
    3113       999924 :     case 8447:  /* *avx512dq_shuf_f64x2_1 */
    3114       999924 :     case 8445:  /* *avx512dq_shuf_i64x2_1 */
    3115       999924 :     case 7217:  /* avx_shufpd256_1 */
    3116       999924 :     case 5275:  /* sse_shufps_v4sf */
    3117       999924 :     case 5274:  /* sse_shufps_v4si */
    3118       999924 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3119       999924 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    3120       999924 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    3121       999924 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    3122       999924 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    3123       999924 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 2));
    3124       999924 :       ro[6] = *(ro_loc[6] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 3));
    3125       999924 :       break;
    3126              : 
    3127         1768 :     case 8448:  /* avx512dq_shuf_f64x2_1_mask */
    3128         1768 :     case 8446:  /* 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 8460:  /* avx512vl_shuf_f32x4_1_mask */
    3143         3396 :     case 8458:  /* avx512vl_shuf_i32x4_1_mask */
    3144         3396 :     case 8452:  /* avx512f_shuf_i64x2_1_mask */
    3145         3396 :     case 8450:  /* 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 8459:  /* avx512vl_shuf_f32x4_1 */
    3164        27632 :     case 8457:  /* avx512vl_shuf_i32x4_1 */
    3165        27632 :     case 8451:  /* avx512f_shuf_i64x2_1 */
    3166        27632 :     case 8449:  /* 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 8410:  /* vec_interleave_lowv4si_mask */
    3213        19600 :     case 8408:  /* avx512f_interleave_lowv16si_mask */
    3214        19600 :     case 8406:  /* avx2_interleave_lowv8si_mask */
    3215        19600 :     case 8404:  /* vec_interleave_highv4si_mask */
    3216        19600 :     case 8402:  /* avx512f_interleave_highv16si_mask */
    3217        19600 :     case 8400:  /* avx2_interleave_highv8si_mask */
    3218        19600 :     case 8398:  /* vec_interleave_lowv8bf_mask */
    3219        19600 :     case 8396:  /* vec_interleave_lowv8hf_mask */
    3220        19600 :     case 8394:  /* vec_interleave_lowv8hi_mask */
    3221        19600 :     case 8392:  /* avx2_interleave_lowv16bf_mask */
    3222        19600 :     case 8390:  /* avx2_interleave_lowv16hf_mask */
    3223        19600 :     case 8388:  /* avx2_interleave_lowv16hi_mask */
    3224        19600 :     case 8386:  /* avx512bw_interleave_lowv32bf_mask */
    3225        19600 :     case 8384:  /* avx512bw_interleave_lowv32hf_mask */
    3226        19600 :     case 8382:  /* avx512bw_interleave_lowv32hi_mask */
    3227        19600 :     case 8380:  /* vec_interleave_highv8bf_mask */
    3228        19600 :     case 8378:  /* vec_interleave_highv8hf_mask */
    3229        19600 :     case 8376:  /* vec_interleave_highv8hi_mask */
    3230        19600 :     case 8374:  /* avx2_interleave_highv16bf_mask */
    3231        19600 :     case 8372:  /* avx2_interleave_highv16hf_mask */
    3232        19600 :     case 8370:  /* avx2_interleave_highv16hi_mask */
    3233        19600 :     case 8368:  /* avx512bw_interleave_highv32bf_mask */
    3234        19600 :     case 8366:  /* avx512bw_interleave_highv32hf_mask */
    3235        19600 :     case 8364:  /* avx512bw_interleave_highv32hi_mask */
    3236        19600 :     case 8362:  /* vec_interleave_lowv16qi_mask */
    3237        19600 :     case 8360:  /* avx2_interleave_lowv32qi_mask */
    3238        19600 :     case 8358:  /* avx512bw_interleave_lowv64qi_mask */
    3239        19600 :     case 8356:  /* vec_interleave_highv16qi_mask */
    3240        19600 :     case 8354:  /* avx2_interleave_highv32qi_mask */
    3241        19600 :     case 8352:  /* 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         7042 :     case 5231:  /* *avx512vl_cvtmask2qv2di_not */
    3281         7042 :     case 5230:  /* *avx512vl_cvtmask2qv4di_not */
    3282         7042 :     case 5229:  /* *avx512f_cvtmask2qv8di_not */
    3283         7042 :     case 5228:  /* *avx512vl_cvtmask2dv4si_not */
    3284         7042 :     case 5227:  /* *avx512vl_cvtmask2dv8si_not */
    3285         7042 :     case 5226:  /* *avx512f_cvtmask2dv16si_not */
    3286         7042 :     case 5225:  /* *avx512vl_cvtmask2wv8hi_not */
    3287         7042 :     case 5224:  /* *avx512vl_cvtmask2wv16hi_not */
    3288         7042 :     case 5223:  /* *avx512bw_cvtmask2wv32hi_not */
    3289         7042 :     case 5222:  /* *avx512vl_cvtmask2bv16qi_not */
    3290         7042 :     case 5221:  /* *avx512vl_cvtmask2bv32qi_not */
    3291         7042 :     case 5220:  /* *avx512bw_cvtmask2bv64qi_not */
    3292         7042 :     case 5219:  /* *avx512vl_cvtmask2qv2di */
    3293         7042 :     case 5218:  /* *avx512vl_cvtmask2qv4di */
    3294         7042 :     case 5217:  /* *avx512f_cvtmask2qv8di */
    3295         7042 :     case 5216:  /* *avx512vl_cvtmask2dv4si */
    3296         7042 :     case 5215:  /* *avx512vl_cvtmask2dv8si */
    3297         7042 :     case 5214:  /* *avx512f_cvtmask2dv16si */
    3298         7042 :     case 5213:  /* *avx512vl_cvtmask2wv8hi */
    3299         7042 :     case 5212:  /* *avx512vl_cvtmask2wv16hi */
    3300         7042 :     case 5211:  /* *avx512bw_cvtmask2wv32hi */
    3301         7042 :     case 5210:  /* *avx512vl_cvtmask2bv32qi */
    3302         7042 :     case 5209:  /* *avx512vl_cvtmask2bv16qi */
    3303         7042 :     case 5208:  /* *avx512bw_cvtmask2bv64qi */
    3304         7042 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3305         7042 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 2));
    3306         7042 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
    3307         7042 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    3308         7042 :       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 9708:  /* vcvtph2ps */
    3429         2327 :     case 8592:  /* *sse2_pmovmskb_ext */
    3430         2327 :     case 8591:  /* *sse2_pmovmskb_zext */
    3431         2327 :     case 8590:  /* *avx2_pmovmskb_zext */
    3432         2327 :     case 8551:  /* *sse2_movmskpd_uext */
    3433         2327 :     case 8550:  /* *sse2_movmskpd_ext */
    3434         2327 :     case 8549:  /* *avx_movmskpd256_uext */
    3435         2327 :     case 8548:  /* *avx_movmskpd256_ext */
    3436         2327 :     case 8547:  /* *sse_movmskps_uext */
    3437         2327 :     case 8546:  /* *sse_movmskps_ext */
    3438         2327 :     case 8545:  /* *avx_movmskps256_uext */
    3439         2327 :     case 8544:  /* *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 9390:  /* avx512dq_broadcastv8sf_mask */
    3515        24866 :     case 9388:  /* avx512dq_broadcastv16sf_mask */
    3516        24866 :     case 9386:  /* avx512dq_broadcastv4si_mask */
    3517        24866 :     case 9384:  /* avx512dq_broadcastv8si_mask */
    3518        24866 :     case 9382:  /* avx512dq_broadcastv16si_mask */
    3519        24866 :     case 9286:  /* avx512vl_vec_dupv8bf_mask */
    3520        24866 :     case 9284:  /* avx512vl_vec_dupv16bf_mask */
    3521        24866 :     case 9282:  /* avx512bw_vec_dupv32bf_mask */
    3522        24866 :     case 9280:  /* avx512fp16_vec_dupv8hf_mask */
    3523        24866 :     case 9278:  /* avx512vl_vec_dupv16hf_mask */
    3524        24866 :     case 9276:  /* avx512bw_vec_dupv32hf_mask */
    3525        24866 :     case 9274:  /* avx512vl_vec_dupv8hi_mask */
    3526        24866 :     case 9272:  /* avx512vl_vec_dupv16hi_mask */
    3527        24866 :     case 9270:  /* avx512bw_vec_dupv32hi_mask */
    3528        24866 :     case 9268:  /* avx512vl_vec_dupv32qi_mask */
    3529        24866 :     case 9266:  /* avx512vl_vec_dupv16qi_mask */
    3530        24866 :     case 9264:  /* avx512bw_vec_dupv64qi_mask */
    3531        24866 :     case 9262:  /* avx512vl_vec_dupv2df_mask */
    3532        24866 :     case 9260:  /* avx512vl_vec_dupv4df_mask */
    3533        24866 :     case 9258:  /* avx512f_vec_dupv8df_mask */
    3534        24866 :     case 9256:  /* avx512vl_vec_dupv4sf_mask */
    3535        24866 :     case 9254:  /* avx512vl_vec_dupv8sf_mask */
    3536        24866 :     case 9252:  /* avx512f_vec_dupv16sf_mask */
    3537        24866 :     case 9250:  /* avx512vl_vec_dupv2di_mask */
    3538        24866 :     case 9248:  /* avx512vl_vec_dupv4di_mask */
    3539        24866 :     case 9246:  /* avx512f_vec_dupv8di_mask */
    3540        24866 :     case 9244:  /* avx512vl_vec_dupv4si_mask */
    3541        24866 :     case 9242:  /* avx512vl_vec_dupv8si_mask */
    3542        24866 :     case 9240:  /* avx512f_vec_dupv16si_mask */
    3543        24866 :     case 8957:  /* sse4_1_zero_extendv2siv2di2_mask */
    3544        24866 :     case 8955:  /* sse4_1_sign_extendv2siv2di2_mask */
    3545        24866 :     case 8933:  /* sse4_1_zero_extendv2hiv2di2_mask */
    3546        24866 :     case 8931:  /* sse4_1_sign_extendv2hiv2di2_mask */
    3547        24866 :     case 8921:  /* avx2_zero_extendv4hiv4di2_mask */
    3548        24866 :     case 8919:  /* avx2_sign_extendv4hiv4di2_mask */
    3549        24866 :     case 8906:  /* sse4_1_zero_extendv2qiv2di2_mask */
    3550        24866 :     case 8904:  /* sse4_1_sign_extendv2qiv2di2_mask */
    3551        24866 :     case 8894:  /* avx2_zero_extendv4qiv4di2_mask */
    3552        24866 :     case 8892:  /* avx2_sign_extendv4qiv4di2_mask */
    3553        24866 :     case 8882:  /* avx512f_zero_extendv8qiv8di2_mask */
    3554        24866 :     case 8880:  /* avx512f_sign_extendv8qiv8di2_mask */
    3555        24866 :     case 8866:  /* sse4_1_zero_extendv4hiv4si2_mask */
    3556        24866 :     case 8864:  /* sse4_1_sign_extendv4hiv4si2_mask */
    3557        24866 :     case 8836:  /* sse4_1_zero_extendv4qiv4si2_mask */
    3558        24866 :     case 8834:  /* sse4_1_sign_extendv4qiv4si2_mask */
    3559        24866 :     case 8824:  /* avx2_zero_extendv8qiv8si2_mask */
    3560        24866 :     case 8822:  /* avx2_sign_extendv8qiv8si2_mask */
    3561        24866 :     case 8804:  /* sse4_1_zero_extendv8qiv8hi2_mask */
    3562        24866 :     case 8802:  /* 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      1153535 :     case 5305:  /* *vec_setv8bf_0_1 */
    3602      1153535 :     case 5304:  /* *vec_setv8hf_0_1 */
    3603      1153535 :     case 5303:  /* *vec_setv8hi_0_1 */
    3604      1153535 :     case 5177:  /* *sse2_vd_cvtss2sd */
    3605      1153535 :     case 5173:  /* sse2_cvtss2sd */
    3606      1153535 :     case 5172:  /* *sse2_vd_cvtsd2ss */
    3607      1153535 :     case 5168:  /* sse2_cvtsd2ss */
    3608      1153535 :     case 4929:  /* sse2_cvtsi2sdq */
    3609      1153535 :     case 4928:  /* sse2_cvtsi2sd */
    3610      1153535 :     case 4839:  /* cvtusi2sd64 */
    3611      1153535 :     case 4837:  /* cvtusi2ss64 */
    3612      1153535 :     case 4836:  /* cvtusi2sd32 */
    3613      1153535 :     case 4834:  /* cvtusi2ss32 */
    3614      1153535 :     case 4818:  /* sse_cvtsi2ssq */
    3615      1153535 :     case 4816:  /* sse_cvtsi2ss */
    3616      1153535 :     case 4589:  /* avx512fp16_vcvtusi2shq */
    3617      1153535 :     case 4587:  /* avx512fp16_vcvtsi2shq */
    3618      1153535 :     case 4585:  /* avx512fp16_vcvtusi2sh */
    3619      1153535 :     case 4583:  /* avx512fp16_vcvtsi2sh */
    3620      1153535 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    3621      1153535 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    3622      1153535 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    3623      1153535 :       break;
    3624              : 
    3625         5524 :     case 10958:  /* avx10_2_vcvttss2usisdi_round */
    3626         5524 :     case 10956:  /* avx10_2_vcvttss2sisdi_round */
    3627         5524 :     case 10954:  /* avx10_2_vcvttss2usissi_round */
    3628         5524 :     case 10952:  /* avx10_2_vcvttss2sissi_round */
    3629         5524 :     case 10950:  /* avx10_2_vcvttsd2usisdi_round */
    3630         5524 :     case 10948:  /* avx10_2_vcvttsd2sisdi_round */
    3631         5524 :     case 10946:  /* avx10_2_vcvttsd2usissi_round */
    3632         5524 :     case 10944:  /* 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 10406:  /* 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 10934:  /* avx10_2_vcvttps2uqqsv8di_mask_round */
    3690        32203 :     case 10930:  /* avx10_2_vcvttps2qqsv8di_mask_round */
    3691        32203 :     case 10918:  /* avx10_2_vcvttpd2uqqsv8df_mask_round */
    3692        32203 :     case 10914:  /* avx10_2_vcvttpd2qqsv8df_mask_round */
    3693        32203 :     case 10902:  /* avx10_2_vcvttpd2udqsv8df_mask_round */
    3694        32203 :     case 10898:  /* avx10_2_vcvttpd2dqsv8df_mask_round */
    3695        32203 :     case 10886:  /* avx10_2_vcvttps2udqsv16sf_mask_round */
    3696        32203 :     case 10882:  /* avx10_2_vcvttps2dqsv16sf_mask_round */
    3697        32203 :     case 10870:  /* avx10_2_cvttps2iubsv16sf_mask_round */
    3698        32203 :     case 10866:  /* avx10_2_cvttps2ibsv16sf_mask_round */
    3699        32203 :     case 10854:  /* avx10_2_cvtps2iubsv16sf_mask_round */
    3700        32203 :     case 10850:  /* avx10_2_cvtps2ibsv16sf_mask_round */
    3701        32203 :     case 10838:  /* avx10_2_cvttph2iubsv32hf_mask_round */
    3702        32203 :     case 10834:  /* avx10_2_cvttph2ibsv32hf_mask_round */
    3703        32203 :     case 10822:  /* avx10_2_cvtph2iubsv32hf_mask_round */
    3704        32203 :     case 10818:  /* avx10_2_cvtph2ibsv32hf_mask_round */
    3705        32203 :     case 9717:  /* 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 10932:  /* avx10_2_vcvttps2uqqsv8di_round */
    3772        13153 :     case 10928:  /* avx10_2_vcvttps2qqsv8di_round */
    3773        13153 :     case 10916:  /* avx10_2_vcvttpd2uqqsv8df_round */
    3774        13153 :     case 10912:  /* avx10_2_vcvttpd2qqsv8df_round */
    3775        13153 :     case 10900:  /* avx10_2_vcvttpd2udqsv8df_round */
    3776        13153 :     case 10896:  /* avx10_2_vcvttpd2dqsv8df_round */
    3777        13153 :     case 10884:  /* avx10_2_vcvttps2udqsv16sf_round */
    3778        13153 :     case 10880:  /* avx10_2_vcvttps2dqsv16sf_round */
    3779        13153 :     case 10868:  /* avx10_2_cvttps2iubsv16sf_round */
    3780        13153 :     case 10864:  /* avx10_2_cvttps2ibsv16sf_round */
    3781        13153 :     case 10852:  /* avx10_2_cvtps2iubsv16sf_round */
    3782        13153 :     case 10848:  /* avx10_2_cvtps2ibsv16sf_round */
    3783        13153 :     case 10836:  /* avx10_2_cvttph2iubsv32hf_round */
    3784        13153 :     case 10832:  /* avx10_2_cvttph2ibsv32hf_round */
    3785        13153 :     case 10820:  /* avx10_2_cvtph2iubsv32hf_round */
    3786        13153 :     case 10816:  /* avx10_2_cvtph2ibsv32hf_round */
    3787        13153 :     case 9715:  /* *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         1729 :     case 4207:  /* *fma_fmsubadd_v2df */
    4619         1729 :     case 4205:  /* *fma_fmsubadd_v4df */
    4620         1729 :     case 4201:  /* *fma_fmsubadd_v8df */
    4621         1729 :     case 4199:  /* *fma_fmsubadd_v4sf */
    4622         1729 :     case 4197:  /* *fma_fmsubadd_v8sf */
    4623         1729 :     case 4193:  /* *fma_fmsubadd_v16sf */
    4624         1729 :     case 4191:  /* *fma_fmsubadd_v8hf */
    4625         1729 :     case 4189:  /* *fma_fmsubadd_v16hf */
    4626         1729 :     case 4185:  /* *fma_fmsubadd_v32hf */
    4627         1729 :     case 4184:  /* *fma_fmsubadd_v2df */
    4628         1729 :     case 4183:  /* *fma_fmsubadd_v4df */
    4629         1729 :     case 4182:  /* *fma_fmsubadd_v4sf */
    4630         1729 :     case 4181:  /* *fma_fmsubadd_v8sf */
    4631         1729 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4632         1729 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
    4633         1729 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
    4634         1729 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 2), 0));
    4635         1729 :       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        20638 :     case 10643:  /* vdpphps_v4sf_mask */
    4694        20638 :     case 10642:  /* vdpphps_v8sf_mask */
    4695        20638 :     case 10641:  /* vdpphps_v16sf_mask */
    4696        20638 :     case 10619:  /* vpdpwuuds_v4si_mask */
    4697        20638 :     case 10618:  /* vpdpwuud_v4si_mask */
    4698        20638 :     case 10617:  /* vpdpwsuds_v4si_mask */
    4699        20638 :     case 10616:  /* vpdpwsud_v4si_mask */
    4700        20638 :     case 10615:  /* vpdpwusds_v4si_mask */
    4701        20638 :     case 10614:  /* vpdpwusd_v4si_mask */
    4702        20638 :     case 10613:  /* vpdpwuuds_v8si_mask */
    4703        20638 :     case 10612:  /* vpdpwuud_v8si_mask */
    4704        20638 :     case 10611:  /* vpdpwsuds_v8si_mask */
    4705        20638 :     case 10610:  /* vpdpwsud_v8si_mask */
    4706        20638 :     case 10609:  /* vpdpwusds_v8si_mask */
    4707        20638 :     case 10608:  /* vpdpwusd_v8si_mask */
    4708        20638 :     case 10607:  /* vpdpwuuds_v16si_mask */
    4709        20638 :     case 10606:  /* vpdpwuud_v16si_mask */
    4710        20638 :     case 10605:  /* vpdpwsuds_v16si_mask */
    4711        20638 :     case 10604:  /* vpdpwsud_v16si_mask */
    4712        20638 :     case 10603:  /* vpdpwusds_v16si_mask */
    4713        20638 :     case 10602:  /* vpdpwusd_v16si_mask */
    4714        20638 :     case 10467:  /* vpdpbuuds_v4si_mask */
    4715        20638 :     case 10466:  /* vpdpbuud_v4si_mask */
    4716        20638 :     case 10465:  /* vpdpbsuds_v4si_mask */
    4717        20638 :     case 10464:  /* vpdpbsud_v4si_mask */
    4718        20638 :     case 10463:  /* vpdpbssds_v4si_mask */
    4719        20638 :     case 10462:  /* vpdpbssd_v4si_mask */
    4720        20638 :     case 10461:  /* vpdpbuuds_v8si_mask */
    4721        20638 :     case 10460:  /* vpdpbuud_v8si_mask */
    4722        20638 :     case 10459:  /* vpdpbsuds_v8si_mask */
    4723        20638 :     case 10458:  /* vpdpbsud_v8si_mask */
    4724        20638 :     case 10457:  /* vpdpbssds_v8si_mask */
    4725        20638 :     case 10456:  /* vpdpbssd_v8si_mask */
    4726        20638 :     case 10455:  /* vpdpbuuds_v16si_mask */
    4727        20638 :     case 10454:  /* vpdpbuud_v16si_mask */
    4728        20638 :     case 10453:  /* vpdpbsuds_v16si_mask */
    4729        20638 :     case 10452:  /* vpdpbsud_v16si_mask */
    4730        20638 :     case 10451:  /* vpdpbssds_v16si_mask */
    4731        20638 :     case 10450:  /* vpdpbssd_v16si_mask */
    4732        20638 :     case 10420:  /* avx512f_dpbf16ps_v4sf_mask */
    4733        20638 :     case 10419:  /* avx512f_dpbf16ps_v8sf_mask */
    4734        20638 :     case 10418:  /* avx512f_dpbf16ps_v16sf_mask */
    4735        20638 :     case 10366:  /* vpdpwssds_v4si_mask */
    4736        20638 :     case 10365:  /* vpdpwssds_v8si_mask */
    4737        20638 :     case 10364:  /* vpdpwssds_v16si_mask */
    4738        20638 :     case 10357:  /* vpdpwssd_v4si_mask */
    4739        20638 :     case 10356:  /* vpdpwssd_v8si_mask */
    4740        20638 :     case 10355:  /* vpdpwssd_v16si_mask */
    4741        20638 :     case 10348:  /* vpdpbusds_v4si_mask */
    4742        20638 :     case 10347:  /* vpdpbusds_v8si_mask */
    4743        20638 :     case 10346:  /* vpdpbusds_v16si_mask */
    4744        20638 :     case 10339:  /* vpdpbusd_v4si_mask */
    4745        20638 :     case 10338:  /* vpdpbusd_v8si_mask */
    4746        20638 :     case 10337:  /* vpdpbusd_v16si_mask */
    4747        20638 :     case 10324:  /* vpshldv_v2di_mask */
    4748        20638 :     case 10323:  /* vpshldv_v4si_mask */
    4749        20638 :     case 10322:  /* vpshldv_v8hi_mask */
    4750        20638 :     case 10321:  /* vpshldv_v4di_mask */
    4751        20638 :     case 10320:  /* vpshldv_v8si_mask */
    4752        20638 :     case 10319:  /* vpshldv_v16hi_mask */
    4753        20638 :     case 10318:  /* vpshldv_v8di_mask */
    4754        20638 :     case 10317:  /* vpshldv_v16si_mask */
    4755        20638 :     case 10316:  /* vpshldv_v32hi_mask */
    4756        20638 :     case 10297:  /* vpshrdv_v2di_mask */
    4757        20638 :     case 10296:  /* vpshrdv_v4si_mask */
    4758        20638 :     case 10295:  /* vpshrdv_v8hi_mask */
    4759        20638 :     case 10294:  /* vpshrdv_v4di_mask */
    4760        20638 :     case 10293:  /* vpshrdv_v8si_mask */
    4761        20638 :     case 10292:  /* vpshrdv_v16hi_mask */
    4762        20638 :     case 10291:  /* vpshrdv_v8di_mask */
    4763        20638 :     case 10290:  /* vpshrdv_v16si_mask */
    4764        20638 :     case 10289:  /* vpshrdv_v32hi_mask */
    4765        20638 :     case 10187:  /* vpmadd52huqv2di_mask */
    4766        20638 :     case 10186:  /* vpmadd52luqv2di_mask */
    4767        20638 :     case 10185:  /* vpmadd52huqv4di_mask */
    4768        20638 :     case 10184:  /* vpmadd52luqv4di_mask */
    4769        20638 :     case 10183:  /* vpmadd52huqv8di_mask */
    4770        20638 :     case 10182:  /* vpmadd52luqv8di_mask */
    4771        20638 :     case 4161:  /* avx512vl_fmaddsub_v2df_mask */
    4772        20638 :     case 4159:  /* avx512vl_fmaddsub_v4df_mask */
    4773        20638 :     case 4157:  /* avx512f_fmaddsub_v8df_mask */
    4774        20638 :     case 4155:  /* avx512vl_fmaddsub_v4sf_mask */
    4775        20638 :     case 4153:  /* avx512vl_fmaddsub_v8sf_mask */
    4776        20638 :     case 4151:  /* avx512f_fmaddsub_v16sf_mask */
    4777        20638 :     case 4149:  /* avx512fp16_fmaddsub_v8hf_mask */
    4778        20638 :     case 4147:  /* avx512vl_fmaddsub_v16hf_mask */
    4779        20638 :     case 4145:  /* avx512bw_fmaddsub_v32hf_mask */
    4780        20638 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    4781        20638 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    4782        20638 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    4783        20638 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    4784        20638 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    4785        20638 :       recog_data.dup_loc[0] = &XEXP (XEXP (pat, 1), 1);
    4786        20638 :       recog_data.dup_num[0] = 1;
    4787        20638 :       break;
    4788              : 
    4789         2840 :     case 11000:  /* avx10_2_minmaxpv2df_mask_round */
    4790         2840 :     case 10996:  /* avx10_2_minmaxpv4df_mask_round */
    4791         2840 :     case 10992:  /* avx10_2_minmaxpv8df_mask_round */
    4792         2840 :     case 10988:  /* avx10_2_minmaxpv4sf_mask_round */
    4793         2840 :     case 10984:  /* avx10_2_minmaxpv8sf_mask_round */
    4794         2840 :     case 10980:  /* avx10_2_minmaxpv16sf_mask_round */
    4795         2840 :     case 10976:  /* avx10_2_minmaxpv8hf_mask_round */
    4796         2840 :     case 10972:  /* avx10_2_minmaxpv16hf_mask_round */
    4797         2840 :     case 10968:  /* avx10_2_minmaxpv32hf_mask_round */
    4798         2840 :     case 10030:  /* avx512dq_rangepv8df_mask_round */
    4799         2840 :     case 10022:  /* 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 10999:  /* avx10_2_minmaxpv2df_mask */
    4813        44720 :     case 10995:  /* avx10_2_minmaxpv4df_mask */
    4814        44720 :     case 10991:  /* avx10_2_minmaxpv8df_mask */
    4815        44720 :     case 10987:  /* avx10_2_minmaxpv4sf_mask */
    4816        44720 :     case 10983:  /* avx10_2_minmaxpv8sf_mask */
    4817        44720 :     case 10979:  /* avx10_2_minmaxpv16sf_mask */
    4818        44720 :     case 10975:  /* avx10_2_minmaxpv8hf_mask */
    4819        44720 :     case 10971:  /* avx10_2_minmaxpv16hf_mask */
    4820        44720 :     case 10967:  /* avx10_2_minmaxpv32hf_mask */
    4821        44720 :     case 10964:  /* avx10_2_minmaxbf16_v8bf_mask */
    4822        44720 :     case 10962:  /* avx10_2_minmaxbf16_v16bf_mask */
    4823        44720 :     case 10960:  /* avx10_2_minmaxbf16_v32bf_mask */
    4824        44720 :     case 10646:  /* vdpphps_v4sf_maskz_1 */
    4825        44720 :     case 10645:  /* vdpphps_v8sf_maskz_1 */
    4826        44720 :     case 10644:  /* vdpphps_v16sf_maskz_1 */
    4827        44720 :     case 10417:  /* avx512f_dpbf16ps_v4sf_maskz_1 */
    4828        44720 :     case 10415:  /* avx512f_dpbf16ps_v8sf_maskz_1 */
    4829        44720 :     case 10413:  /* avx512f_dpbf16ps_v16sf_maskz_1 */
    4830        44720 :     case 10369:  /* vpdpwssds_v4si_maskz_1 */
    4831        44720 :     case 10368:  /* vpdpwssds_v8si_maskz_1 */
    4832        44720 :     case 10367:  /* vpdpwssds_v16si_maskz_1 */
    4833        44720 :     case 10360:  /* vpdpwssd_v4si_maskz_1 */
    4834        44720 :     case 10359:  /* vpdpwssd_v8si_maskz_1 */
    4835        44720 :     case 10358:  /* vpdpwssd_v16si_maskz_1 */
    4836        44720 :     case 10351:  /* vpdpbusds_v4si_maskz_1 */
    4837        44720 :     case 10350:  /* vpdpbusds_v8si_maskz_1 */
    4838        44720 :     case 10349:  /* vpdpbusds_v16si_maskz_1 */
    4839        44720 :     case 10342:  /* vpdpbusd_v4si_maskz_1 */
    4840        44720 :     case 10341:  /* vpdpbusd_v8si_maskz_1 */
    4841        44720 :     case 10340:  /* vpdpbusd_v16si_maskz_1 */
    4842        44720 :     case 10333:  /* vpshldv_v2di_maskz_1 */
    4843        44720 :     case 10332:  /* vpshldv_v4si_maskz_1 */
    4844        44720 :     case 10331:  /* vpshldv_v8hi_maskz_1 */
    4845        44720 :     case 10330:  /* vpshldv_v4di_maskz_1 */
    4846        44720 :     case 10329:  /* vpshldv_v8si_maskz_1 */
    4847        44720 :     case 10328:  /* vpshldv_v16hi_maskz_1 */
    4848        44720 :     case 10327:  /* vpshldv_v8di_maskz_1 */
    4849        44720 :     case 10326:  /* vpshldv_v16si_maskz_1 */
    4850        44720 :     case 10325:  /* vpshldv_v32hi_maskz_1 */
    4851        44720 :     case 10306:  /* vpshrdv_v2di_maskz_1 */
    4852        44720 :     case 10305:  /* vpshrdv_v4si_maskz_1 */
    4853        44720 :     case 10304:  /* vpshrdv_v8hi_maskz_1 */
    4854        44720 :     case 10303:  /* vpshrdv_v4di_maskz_1 */
    4855        44720 :     case 10302:  /* vpshrdv_v8si_maskz_1 */
    4856        44720 :     case 10301:  /* vpshrdv_v16hi_maskz_1 */
    4857        44720 :     case 10300:  /* vpshrdv_v8di_maskz_1 */
    4858        44720 :     case 10299:  /* vpshrdv_v16si_maskz_1 */
    4859        44720 :     case 10298:  /* vpshrdv_v32hi_maskz_1 */
    4860        44720 :     case 10279:  /* vpshld_v2di_mask */
    4861        44720 :     case 10277:  /* vpshld_v4si_mask */
    4862        44720 :     case 10275:  /* vpshld_v8hi_mask */
    4863        44720 :     case 10273:  /* vpshld_v4di_mask */
    4864        44720 :     case 10271:  /* vpshld_v8si_mask */
    4865        44720 :     case 10269:  /* vpshld_v16hi_mask */
    4866        44720 :     case 10267:  /* vpshld_v8di_mask */
    4867        44720 :     case 10265:  /* vpshld_v16si_mask */
    4868        44720 :     case 10263:  /* vpshld_v32hi_mask */
    4869        44720 :     case 10261:  /* vpshrd_v2di_mask */
    4870        44720 :     case 10259:  /* vpshrd_v4si_mask */
    4871        44720 :     case 10257:  /* vpshrd_v8hi_mask */
    4872        44720 :     case 10255:  /* vpshrd_v4di_mask */
    4873        44720 :     case 10253:  /* vpshrd_v8si_mask */
    4874        44720 :     case 10251:  /* vpshrd_v16hi_mask */
    4875        44720 :     case 10249:  /* vpshrd_v8di_mask */
    4876        44720 :     case 10247:  /* vpshrd_v16si_mask */
    4877        44720 :     case 10245:  /* vpshrd_v32hi_mask */
    4878        44720 :     case 10237:  /* vgf2p8affineqb_v16qi_mask */
    4879        44720 :     case 10235:  /* vgf2p8affineqb_v32qi_mask */
    4880        44720 :     case 10233:  /* vgf2p8affineqb_v64qi_mask */
    4881        44720 :     case 10231:  /* vgf2p8affineinvqb_v16qi_mask */
    4882        44720 :     case 10229:  /* vgf2p8affineinvqb_v32qi_mask */
    4883        44720 :     case 10227:  /* vgf2p8affineinvqb_v64qi_mask */
    4884        44720 :     case 10181:  /* vpmadd52huqv2di_maskz_1 */
    4885        44720 :     case 10180:  /* vpmadd52luqv2di_maskz_1 */
    4886        44720 :     case 10179:  /* vpmadd52huqv4di_maskz_1 */
    4887        44720 :     case 10178:  /* vpmadd52luqv4di_maskz_1 */
    4888        44720 :     case 10177:  /* vpmadd52huqv8di_maskz_1 */
    4889        44720 :     case 10176:  /* vpmadd52luqv8di_maskz_1 */
    4890        44720 :     case 10120:  /* avx512bw_dbpsadbwv32hi_mask */
    4891        44720 :     case 10118:  /* avx512bw_dbpsadbwv16hi_mask */
    4892        44720 :     case 10116:  /* avx512bw_dbpsadbwv8hi_mask */
    4893        44720 :     case 10034:  /* avx512dq_rangepv2df_mask */
    4894        44720 :     case 10032:  /* avx512dq_rangepv4df_mask */
    4895        44720 :     case 10029:  /* avx512dq_rangepv8df_mask */
    4896        44720 :     case 10026:  /* avx512dq_rangepv4sf_mask */
    4897        44720 :     case 10024:  /* avx512dq_rangepv8sf_mask */
    4898        44720 :     case 10021:  /* avx512dq_rangepv16sf_mask */
    4899        44720 :     case 9490:  /* avx512vl_vpermt2varv8bf3_maskz_1 */
    4900        44720 :     case 9488:  /* avx512vl_vpermt2varv16bf3_maskz_1 */
    4901        44720 :     case 9486:  /* avx512bw_vpermt2varv32bf3_maskz_1 */
    4902        44720 :     case 9484:  /* avx512fp16_vpermt2varv8hf3_maskz_1 */
    4903        44720 :     case 9482:  /* avx512vl_vpermt2varv16hf3_maskz_1 */
    4904        44720 :     case 9480:  /* avx512bw_vpermt2varv32hf3_maskz_1 */
    4905        44720 :     case 9478:  /* avx512vl_vpermt2varv16qi3_maskz_1 */
    4906        44720 :     case 9476:  /* avx512vl_vpermt2varv32qi3_maskz_1 */
    4907        44720 :     case 9474:  /* avx512bw_vpermt2varv64qi3_maskz_1 */
    4908        44720 :     case 9472:  /* avx512vl_vpermt2varv8hi3_maskz_1 */
    4909        44720 :     case 9470:  /* avx512vl_vpermt2varv16hi3_maskz_1 */
    4910        44720 :     case 9468:  /* avx512bw_vpermt2varv32hi3_maskz_1 */
    4911        44720 :     case 9466:  /* avx512vl_vpermt2varv2df3_maskz_1 */
    4912        44720 :     case 9464:  /* avx512vl_vpermt2varv2di3_maskz_1 */
    4913        44720 :     case 9462:  /* avx512vl_vpermt2varv4sf3_maskz_1 */
    4914        44720 :     case 9460:  /* avx512vl_vpermt2varv4si3_maskz_1 */
    4915        44720 :     case 9458:  /* avx512vl_vpermt2varv4df3_maskz_1 */
    4916        44720 :     case 9456:  /* avx512vl_vpermt2varv4di3_maskz_1 */
    4917        44720 :     case 9454:  /* avx512vl_vpermt2varv8sf3_maskz_1 */
    4918        44720 :     case 9452:  /* avx512vl_vpermt2varv8si3_maskz_1 */
    4919        44720 :     case 9450:  /* avx512f_vpermt2varv8df3_maskz_1 */
    4920        44720 :     case 9448:  /* avx512f_vpermt2varv8di3_maskz_1 */
    4921        44720 :     case 9446:  /* avx512f_vpermt2varv16sf3_maskz_1 */
    4922        44720 :     case 9444:  /* avx512f_vpermt2varv16si3_maskz_1 */
    4923        44720 :     case 8759:  /* sse4_1_mpsadbw_mask */
    4924        44720 :     case 8757:  /* avx2_mpsadbw_mask */
    4925        44720 :     case 8755:  /* avx10_2_mpsadbw_mask */
    4926        44720 :     case 8674:  /* ssse3_palignrv16qi_mask */
    4927        44720 :     case 8673:  /* avx2_palignrv32qi_mask */
    4928        44720 :     case 8672:  /* 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 10736:  /* avx10_2_fnmsubbf16_v8bf_mask3 */
    4972         3147 :     case 10735:  /* avx10_2_fnmsubbf16_v16bf_mask3 */
    4973         3147 :     case 10734:  /* 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 10733:  /* avx10_2_fnmsubbf16_v8bf_mask */
    5006         3588 :     case 10732:  /* avx10_2_fnmsubbf16_v16bf_mask */
    5007         3588 :     case 10731:  /* 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 10730:  /* avx10_2_fnmsubbf16_v8bf_maskz_1 */
    5043         3392 :     case 10728:  /* avx10_2_fnmsubbf16_v16bf_maskz_1 */
    5044         3392 :     case 10726:  /* 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 10729:  /* avx10_2_fnmsubbf16_v8bf */
    5083        20458 :     case 10727:  /* avx10_2_fnmsubbf16_v16bf */
    5084        20458 :     case 10725:  /* 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 10712:  /* avx10_2_fnmaddbf16_v8bf_mask3 */
    5123         3147 :     case 10711:  /* avx10_2_fnmaddbf16_v16bf_mask3 */
    5124         3147 :     case 10710:  /* 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 10709:  /* avx10_2_fnmaddbf16_v8bf_mask */
    5157         3590 :     case 10708:  /* avx10_2_fnmaddbf16_v16bf_mask */
    5158         3590 :     case 10707:  /* 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 10706:  /* avx10_2_fnmaddbf16_v8bf_maskz_1 */
    5190         3437 :     case 10704:  /* avx10_2_fnmaddbf16_v16bf_maskz_1 */
    5191         3437 :     case 10702:  /* 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 10724:  /* avx10_2_fmsubbf16_v8bf_mask3 */
    5223         3149 :     case 10723:  /* avx10_2_fmsubbf16_v16bf_mask3 */
    5224         3149 :     case 10722:  /* 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 10721:  /* avx10_2_fmsubbf16_v8bf_mask */
    5263         3590 :     case 10720:  /* avx10_2_fmsubbf16_v16bf_mask */
    5264         3590 :     case 10719:  /* 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 10718:  /* avx10_2_fmsubbf16_v8bf_maskz_1 */
    5306         3476 :     case 10716:  /* avx10_2_fmsubbf16_v16bf_maskz_1 */
    5307         3476 :     case 10714:  /* 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 10717:  /* avx10_2_fmsubbf16_v8bf */
    5326        52173 :     case 10715:  /* avx10_2_fmsubbf16_v16bf */
    5327        52173 :     case 10713:  /* 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 10700:  /* avx10_2_fmaddbf16_v8bf_mask3 */
    5372         3343 :     case 10699:  /* avx10_2_fmaddbf16_v16bf_mask3 */
    5373         3343 :     case 10698:  /* 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 10697:  /* avx10_2_fmaddbf16_v8bf_mask */
    5406         3608 :     case 10696:  /* avx10_2_fmaddbf16_v16bf_mask */
    5407         3608 :     case 10695:  /* 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 10694:  /* avx10_2_fmaddbf16_v8bf_maskz_1 */
    5449         3699 :     case 10692:  /* avx10_2_fmaddbf16_v16bf_maskz_1 */
    5450         3699 :     case 10690:  /* 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 9538:  /* vec_set_hi_v8sf_mask */
    5469        10516 :     case 9536:  /* vec_set_hi_v8si_mask */
    5470        10516 :     case 9530:  /* vec_set_hi_v4df_mask */
    5471        10516 :     case 9528:  /* vec_set_hi_v4di_mask */
    5472        10516 :     case 8444:  /* vec_set_hi_v8di_mask */
    5473        10516 :     case 8442:  /* vec_set_hi_v8df_mask */
    5474        10516 :     case 8436:  /* vec_set_hi_v16si_mask */
    5475        10516 :     case 8434:  /* vec_set_hi_v16sf_mask */
    5476        10516 :     case 8035:  /* *andnotv2di3_mask */
    5477        10516 :     case 8034:  /* *andnotv4di3_mask */
    5478        10516 :     case 8033:  /* *andnotv8di3_mask */
    5479        10516 :     case 8032:  /* *andnotv4si3_mask */
    5480        10516 :     case 8031:  /* *andnotv8si3_mask */
    5481        10516 :     case 8030:  /* *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        13894 :     case 10784:  /* avx10_2_fpclassbf16_v8bf_mask */
    5607        13894 :     case 10782:  /* avx10_2_fpclassbf16_v16bf_mask */
    5608        13894 :     case 10780:  /* avx10_2_fpclassbf16_v32bf_mask */
    5609        13894 :     case 10533:  /* *vcvtbiasph2hf8sv8hf */
    5610        13894 :     case 10532:  /* *vcvtbiasph2hf8v8hf */
    5611        13894 :     case 10531:  /* *vcvtbiasph2bf8sv8hf */
    5612        13894 :     case 10530:  /* *vcvtbiasph2bf8v8hf */
    5613        13894 :     case 10390:  /* avx512vl_vpshufbitqmbv32qi_mask */
    5614        13894 :     case 10388:  /* avx512vl_vpshufbitqmbv16qi_mask */
    5615        13894 :     case 10386:  /* avx512vl_vpshufbitqmbv64qi_mask */
    5616        13894 :     case 10060:  /* avx512dq_fpclassv2df_mask */
    5617        13894 :     case 10058:  /* avx512dq_fpclassv4df_mask */
    5618        13894 :     case 10056:  /* avx512dq_fpclassv8df_mask */
    5619        13894 :     case 10054:  /* avx512dq_fpclassv4sf_mask */
    5620        13894 :     case 10052:  /* avx512dq_fpclassv8sf_mask */
    5621        13894 :     case 10050:  /* avx512dq_fpclassv16sf_mask */
    5622        13894 :     case 10048:  /* avx512dq_fpclassv8hf_mask */
    5623        13894 :     case 10046:  /* avx512dq_fpclassv16hf_mask */
    5624        13894 :     case 10044:  /* avx512dq_fpclassv32hf_mask */
    5625        13894 :     case 9718:  /* *vcvtps2ph */
    5626        13894 :     case 8188:  /* avx512vl_testnmv2di3_mask */
    5627        13894 :     case 8186:  /* avx512vl_testnmv4di3_mask */
    5628        13894 :     case 8184:  /* avx512f_testnmv8di3_mask */
    5629        13894 :     case 8182:  /* avx512vl_testnmv4si3_mask */
    5630        13894 :     case 8180:  /* avx512vl_testnmv8si3_mask */
    5631        13894 :     case 8178:  /* avx512f_testnmv16si3_mask */
    5632        13894 :     case 8176:  /* avx512vl_testnmv8hi3_mask */
    5633        13894 :     case 8174:  /* avx512vl_testnmv16hi3_mask */
    5634        13894 :     case 8172:  /* avx512bw_testnmv32hi3_mask */
    5635        13894 :     case 8170:  /* avx512vl_testnmv16qi3_mask */
    5636        13894 :     case 8168:  /* avx512vl_testnmv32qi3_mask */
    5637        13894 :     case 8166:  /* avx512bw_testnmv64qi3_mask */
    5638        13894 :     case 8164:  /* avx512vl_testmv2di3_mask */
    5639        13894 :     case 8162:  /* avx512vl_testmv4di3_mask */
    5640        13894 :     case 8160:  /* avx512f_testmv8di3_mask */
    5641        13894 :     case 8158:  /* avx512vl_testmv4si3_mask */
    5642        13894 :     case 8156:  /* avx512vl_testmv8si3_mask */
    5643        13894 :     case 8154:  /* avx512f_testmv16si3_mask */
    5644        13894 :     case 8152:  /* avx512vl_testmv8hi3_mask */
    5645        13894 :     case 8150:  /* avx512vl_testmv16hi3_mask */
    5646        13894 :     case 8148:  /* avx512bw_testmv32hi3_mask */
    5647        13894 :     case 8146:  /* avx512vl_testmv16qi3_mask */
    5648        13894 :     case 8144:  /* avx512vl_testmv32qi3_mask */
    5649        13894 :     case 8142:  /* avx512bw_testmv64qi3_mask */
    5650        13894 :     case 4370:  /* fma_v8hf_fadd_fcmul */
    5651        13894 :     case 4369:  /* fma_v16hf_fadd_fcmul */
    5652        13894 :     case 4368:  /* fma_v32hf_fadd_fcmul */
    5653        13894 :     case 4367:  /* fma_v8hf_fadd_fmul */
    5654        13894 :     case 4366:  /* fma_v16hf_fadd_fmul */
    5655        13894 :     case 4365:  /* fma_v32hf_fadd_fmul */
    5656        13894 :     case 3636:  /* *avx512vl_eqv2di3_mask_1 */
    5657        13894 :     case 3634:  /* *avx512vl_eqv2di3_mask_1 */
    5658        13894 :     case 3632:  /* *avx512vl_eqv4di3_mask_1 */
    5659        13894 :     case 3630:  /* *avx512vl_eqv4di3_mask_1 */
    5660        13894 :     case 3628:  /* *avx512f_eqv8di3_mask_1 */
    5661        13894 :     case 3626:  /* *avx512f_eqv8di3_mask_1 */
    5662        13894 :     case 3624:  /* *avx512vl_eqv4si3_mask_1 */
    5663        13894 :     case 3622:  /* *avx512vl_eqv4si3_mask_1 */
    5664        13894 :     case 3620:  /* *avx512vl_eqv8si3_mask_1 */
    5665        13894 :     case 3618:  /* *avx512vl_eqv8si3_mask_1 */
    5666        13894 :     case 3616:  /* *avx512f_eqv16si3_mask_1 */
    5667        13894 :     case 3614:  /* *avx512f_eqv16si3_mask_1 */
    5668        13894 :     case 3576:  /* *avx512vl_eqv8hi3_mask_1 */
    5669        13894 :     case 3574:  /* *avx512vl_eqv8hi3_mask_1 */
    5670        13894 :     case 3572:  /* *avx512vl_eqv16hi3_mask_1 */
    5671        13894 :     case 3570:  /* *avx512vl_eqv16hi3_mask_1 */
    5672        13894 :     case 3568:  /* *avx512bw_eqv32hi3_mask_1 */
    5673        13894 :     case 3566:  /* *avx512bw_eqv32hi3_mask_1 */
    5674        13894 :     case 3564:  /* *avx512vl_eqv32qi3_mask_1 */
    5675        13894 :     case 3562:  /* *avx512vl_eqv32qi3_mask_1 */
    5676        13894 :     case 3560:  /* *avx512vl_eqv16qi3_mask_1 */
    5677        13894 :     case 3558:  /* *avx512vl_eqv16qi3_mask_1 */
    5678        13894 :     case 3556:  /* *avx512bw_eqv64qi3_mask_1 */
    5679        13894 :     case 3554:  /* *avx512bw_eqv64qi3_mask_1 */
    5680        13894 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5681        13894 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    5682        13894 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    5683        13894 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    5684        13894 :       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        15673 :     case 3719:  /* avx512f_vmcmpv2df3 */
    5799        15673 :     case 3717:  /* avx512f_vmcmpv4sf3 */
    5800        15673 :     case 3715:  /* avx512f_vmcmpv8hf3 */
    5801        15673 :     case 3702:  /* *avx512vl_ucmpv2di3 */
    5802        15673 :     case 3701:  /* *avx512vl_ucmpv4di3 */
    5803        15673 :     case 3700:  /* *avx512f_ucmpv8di3 */
    5804        15673 :     case 3699:  /* *avx512vl_ucmpv4si3 */
    5805        15673 :     case 3698:  /* *avx512vl_ucmpv8si3 */
    5806        15673 :     case 3697:  /* *avx512f_ucmpv16si3 */
    5807        15673 :     case 3678:  /* *avx512vl_ucmpv2di3_zero_extenddi */
    5808        15673 :     case 3677:  /* *avx512vl_ucmpv4di3_zero_extenddi */
    5809        15673 :     case 3676:  /* *avx512f_ucmpv8di3_zero_extenddi */
    5810        15673 :     case 3675:  /* *avx512vl_ucmpv4si3_zero_extenddi */
    5811        15673 :     case 3674:  /* *avx512vl_ucmpv8si3_zero_extenddi */
    5812        15673 :     case 3673:  /* *avx512f_ucmpv16si3_zero_extenddi */
    5813        15673 :     case 3672:  /* *avx512vl_ucmpv2di3_zero_extendsi */
    5814        15673 :     case 3671:  /* *avx512vl_ucmpv4di3_zero_extendsi */
    5815        15673 :     case 3670:  /* *avx512f_ucmpv8di3_zero_extendsi */
    5816        15673 :     case 3669:  /* *avx512vl_ucmpv4si3_zero_extendsi */
    5817        15673 :     case 3668:  /* *avx512vl_ucmpv8si3_zero_extendsi */
    5818        15673 :     case 3667:  /* *avx512f_ucmpv16si3_zero_extendsi */
    5819        15673 :     case 3666:  /* *avx512vl_ucmpv2di3_zero_extendhi */
    5820        15673 :     case 3665:  /* *avx512vl_ucmpv4di3_zero_extendhi */
    5821        15673 :     case 3664:  /* *avx512f_ucmpv8di3_zero_extendhi */
    5822        15673 :     case 3663:  /* *avx512vl_ucmpv4si3_zero_extendhi */
    5823        15673 :     case 3662:  /* *avx512vl_ucmpv8si3_zero_extendhi */
    5824        15673 :     case 3661:  /* *avx512f_ucmpv16si3_zero_extendhi */
    5825        15673 :     case 3594:  /* *avx512vl_ucmpv8hi3_zero_extenddi */
    5826        15673 :     case 3593:  /* *avx512vl_ucmpv8hi3_zero_extendsi */
    5827        15673 :     case 3592:  /* *avx512vl_ucmpv8hi3_zero_extendhi */
    5828        15673 :     case 3591:  /* *avx512vl_ucmpv16hi3_zero_extenddi */
    5829        15673 :     case 3590:  /* *avx512vl_ucmpv16hi3_zero_extendsi */
    5830        15673 :     case 3589:  /* *avx512vl_ucmpv16hi3_zero_extendhi */
    5831        15673 :     case 3588:  /* *avx512bw_ucmpv32hi3_zero_extenddi */
    5832        15673 :     case 3587:  /* *avx512bw_ucmpv32hi3_zero_extendsi */
    5833        15673 :     case 3586:  /* *avx512bw_ucmpv32hi3_zero_extendhi */
    5834        15673 :     case 3585:  /* *avx512vl_ucmpv32qi3_zero_extenddi */
    5835        15673 :     case 3584:  /* *avx512vl_ucmpv32qi3_zero_extendsi */
    5836        15673 :     case 3583:  /* *avx512vl_ucmpv32qi3_zero_extendhi */
    5837        15673 :     case 3582:  /* *avx512vl_ucmpv16qi3_zero_extenddi */
    5838        15673 :     case 3581:  /* *avx512vl_ucmpv16qi3_zero_extendsi */
    5839        15673 :     case 3580:  /* *avx512vl_ucmpv16qi3_zero_extendhi */
    5840        15673 :     case 3579:  /* *avx512bw_ucmpv64qi3_zero_extenddi */
    5841        15673 :     case 3578:  /* *avx512bw_ucmpv64qi3_zero_extendsi */
    5842        15673 :     case 3577:  /* *avx512bw_ucmpv64qi3_zero_extendhi */
    5843        15673 :     case 3528:  /* *avx512vl_cmpv8hi3 */
    5844        15673 :     case 3527:  /* *avx512vl_cmpv8hi3 */
    5845        15673 :     case 3526:  /* *avx512vl_cmpv16hi3 */
    5846        15673 :     case 3525:  /* *avx512vl_cmpv16hi3 */
    5847        15673 :     case 3524:  /* *avx512bw_cmpv32hi3 */
    5848        15673 :     case 3523:  /* *avx512bw_cmpv32hi3 */
    5849        15673 :     case 3522:  /* *avx512vl_cmpv32qi3 */
    5850        15673 :     case 3521:  /* *avx512vl_cmpv32qi3 */
    5851        15673 :     case 3520:  /* *avx512vl_cmpv16qi3 */
    5852        15673 :     case 3519:  /* *avx512vl_cmpv16qi3 */
    5853        15673 :     case 3518:  /* *avx512bw_cmpv64qi3 */
    5854        15673 :     case 3517:  /* *avx512bw_cmpv64qi3 */
    5855        15673 :     case 3498:  /* *avx512vl_cmpv8hi3_zero_extenddi */
    5856        15673 :     case 3497:  /* *avx512vl_cmpv8hi3_zero_extendsi */
    5857        15673 :     case 3496:  /* *avx512vl_cmpv8hi3_zero_extendhi */
    5858        15673 :     case 3495:  /* *avx512vl_cmpv16hi3_zero_extenddi */
    5859        15673 :     case 3494:  /* *avx512vl_cmpv16hi3_zero_extendsi */
    5860        15673 :     case 3493:  /* *avx512vl_cmpv16hi3_zero_extendhi */
    5861        15673 :     case 3492:  /* *avx512bw_cmpv32hi3_zero_extenddi */
    5862        15673 :     case 3491:  /* *avx512bw_cmpv32hi3_zero_extendsi */
    5863        15673 :     case 3490:  /* *avx512bw_cmpv32hi3_zero_extendhi */
    5864        15673 :     case 3489:  /* *avx512vl_cmpv32qi3_zero_extenddi */
    5865        15673 :     case 3488:  /* *avx512vl_cmpv32qi3_zero_extendsi */
    5866        15673 :     case 3487:  /* *avx512vl_cmpv32qi3_zero_extendhi */
    5867        15673 :     case 3486:  /* *avx512vl_cmpv16qi3_zero_extenddi */
    5868        15673 :     case 3485:  /* *avx512vl_cmpv16qi3_zero_extendsi */
    5869        15673 :     case 3484:  /* *avx512vl_cmpv16qi3_zero_extendhi */
    5870        15673 :     case 3483:  /* *avx512bw_cmpv64qi3_zero_extenddi */
    5871        15673 :     case 3482:  /* *avx512bw_cmpv64qi3_zero_extendsi */
    5872        15673 :     case 3481:  /* *avx512bw_cmpv64qi3_zero_extendhi */
    5873        15673 :     case 3454:  /* *avx512vl_ucmpv2di3_and3 */
    5874        15673 :     case 3453:  /* *avx512vl_cmpv2di3_and3 */
    5875        15673 :     case 3452:  /* *avx512vl_cmpv2df3_and3 */
    5876        15673 :     case 3447:  /* *avx512vl_ucmpv4di3_and15 */
    5877        15673 :     case 3446:  /* *avx512vl_ucmpv4si3_and15 */
    5878        15673 :     case 3445:  /* *avx512vl_cmpv4di3_and15 */
    5879        15673 :     case 3444:  /* *avx512vl_cmpv4si3_and15 */
    5880        15673 :     case 3443:  /* *avx512vl_cmpv4df3_and15 */
    5881        15673 :     case 3442:  /* *avx512vl_cmpv4sf3_and15 */
    5882        15673 :     case 3441:  /* *avx512vl_cmpv2df3 */
    5883        15673 :     case 3440:  /* *avx512vl_cmpv4df3 */
    5884        15673 :     case 3439:  /* *avx512f_cmpv8df3 */
    5885        15673 :     case 3438:  /* *avx512vl_cmpv4sf3 */
    5886        15673 :     case 3437:  /* *avx512vl_cmpv8sf3 */
    5887        15673 :     case 3436:  /* *avx512f_cmpv16sf3 */
    5888        15673 :     case 3435:  /* *avx512fp16_cmpv8hf3 */
    5889        15673 :     case 3434:  /* *avx512vl_cmpv16hf3 */
    5890        15673 :     case 3433:  /* *avx512bw_cmpv32hf3 */
    5891        15673 :     case 3432:  /* *avx512vl_cmpv2di3 */
    5892        15673 :     case 3431:  /* *avx512vl_cmpv4di3 */
    5893        15673 :     case 3430:  /* *avx512f_cmpv8di3 */
    5894        15673 :     case 3429:  /* *avx512vl_cmpv4si3 */
    5895        15673 :     case 3428:  /* *avx512vl_cmpv8si3 */
    5896        15673 :     case 3427:  /* *avx512f_cmpv16si3 */
    5897        15673 :     case 3381:  /* *avx512vl_cmpv2df3_zero_extenddi */
    5898        15673 :     case 3380:  /* *avx512vl_cmpv2df3_zero_extendsi */
    5899        15673 :     case 3379:  /* *avx512vl_cmpv2df3_zero_extendhi */
    5900        15673 :     case 3378:  /* *avx512vl_cmpv4df3_zero_extenddi */
    5901        15673 :     case 3377:  /* *avx512vl_cmpv4df3_zero_extendsi */
    5902        15673 :     case 3376:  /* *avx512vl_cmpv4df3_zero_extendhi */
    5903        15673 :     case 3375:  /* *avx512f_cmpv8df3_zero_extenddi */
    5904        15673 :     case 3374:  /* *avx512f_cmpv8df3_zero_extendsi */
    5905        15673 :     case 3373:  /* *avx512f_cmpv8df3_zero_extendhi */
    5906        15673 :     case 3372:  /* *avx512vl_cmpv4sf3_zero_extenddi */
    5907        15673 :     case 3371:  /* *avx512vl_cmpv4sf3_zero_extendsi */
    5908        15673 :     case 3370:  /* *avx512vl_cmpv4sf3_zero_extendhi */
    5909        15673 :     case 3369:  /* *avx512vl_cmpv8sf3_zero_extenddi */
    5910        15673 :     case 3368:  /* *avx512vl_cmpv8sf3_zero_extendsi */
    5911        15673 :     case 3367:  /* *avx512vl_cmpv8sf3_zero_extendhi */
    5912        15673 :     case 3366:  /* *avx512f_cmpv16sf3_zero_extenddi */
    5913        15673 :     case 3365:  /* *avx512f_cmpv16sf3_zero_extendsi */
    5914        15673 :     case 3364:  /* *avx512f_cmpv16sf3_zero_extendhi */
    5915        15673 :     case 3363:  /* *avx512fp16_cmpv8hf3_zero_extenddi */
    5916        15673 :     case 3362:  /* *avx512fp16_cmpv8hf3_zero_extendsi */
    5917        15673 :     case 3361:  /* *avx512fp16_cmpv8hf3_zero_extendhi */
    5918        15673 :     case 3360:  /* *avx512vl_cmpv16hf3_zero_extenddi */
    5919        15673 :     case 3359:  /* *avx512vl_cmpv16hf3_zero_extendsi */
    5920        15673 :     case 3358:  /* *avx512vl_cmpv16hf3_zero_extendhi */
    5921        15673 :     case 3357:  /* *avx512bw_cmpv32hf3_zero_extenddi */
    5922        15673 :     case 3356:  /* *avx512bw_cmpv32hf3_zero_extendsi */
    5923        15673 :     case 3355:  /* *avx512bw_cmpv32hf3_zero_extendhi */
    5924        15673 :     case 3354:  /* *avx512vl_cmpv2di3_zero_extenddi */
    5925        15673 :     case 3353:  /* *avx512vl_cmpv2di3_zero_extendsi */
    5926        15673 :     case 3352:  /* *avx512vl_cmpv2di3_zero_extendhi */
    5927        15673 :     case 3351:  /* *avx512vl_cmpv4di3_zero_extenddi */
    5928        15673 :     case 3350:  /* *avx512vl_cmpv4di3_zero_extendsi */
    5929        15673 :     case 3349:  /* *avx512vl_cmpv4di3_zero_extendhi */
    5930        15673 :     case 3348:  /* *avx512f_cmpv8di3_zero_extenddi */
    5931        15673 :     case 3347:  /* *avx512f_cmpv8di3_zero_extendsi */
    5932        15673 :     case 3346:  /* *avx512f_cmpv8di3_zero_extendhi */
    5933        15673 :     case 3345:  /* *avx512vl_cmpv4si3_zero_extenddi */
    5934        15673 :     case 3344:  /* *avx512vl_cmpv4si3_zero_extendsi */
    5935        15673 :     case 3343:  /* *avx512vl_cmpv4si3_zero_extendhi */
    5936        15673 :     case 3342:  /* *avx512vl_cmpv8si3_zero_extenddi */
    5937        15673 :     case 3341:  /* *avx512vl_cmpv8si3_zero_extendsi */
    5938        15673 :     case 3340:  /* *avx512vl_cmpv8si3_zero_extendhi */
    5939        15673 :     case 3339:  /* *avx512f_cmpv16si3_zero_extenddi */
    5940        15673 :     case 3338:  /* *avx512f_cmpv16si3_zero_extendsi */
    5941        15673 :     case 3337:  /* *avx512f_cmpv16si3_zero_extendhi */
    5942        15673 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    5943        15673 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    5944        15673 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    5945        15673 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    5946        15673 :       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        66130 :     case 10790:  /* avx10_2_cmpbf16_v8bf_mask */
    5960        66130 :     case 10788:  /* avx10_2_cmpbf16_v16bf_mask */
    5961        66130 :     case 10786:  /* avx10_2_cmpbf16_v32bf_mask */
    5962        66130 :     case 4376:  /* fma_fcmaddc_v8hf_fma_zero */
    5963        66130 :     case 4375:  /* fma_fmaddc_v8hf_fma_zero */
    5964        66130 :     case 4374:  /* fma_fcmaddc_v16hf_fma_zero */
    5965        66130 :     case 4373:  /* fma_fmaddc_v16hf_fma_zero */
    5966        66130 :     case 4372:  /* fma_fcmaddc_v32hf_fma_zero */
    5967        66130 :     case 4371:  /* fma_fmaddc_v32hf_fma_zero */
    5968        66130 :     case 3660:  /* avx512vl_ucmpv2di3_mask */
    5969        66130 :     case 3658:  /* avx512vl_ucmpv4di3_mask */
    5970        66130 :     case 3656:  /* avx512f_ucmpv8di3_mask */
    5971        66130 :     case 3654:  /* avx512vl_ucmpv4si3_mask */
    5972        66130 :     case 3652:  /* avx512vl_ucmpv8si3_mask */
    5973        66130 :     case 3650:  /* avx512f_ucmpv16si3_mask */
    5974        66130 :     case 3648:  /* avx512vl_ucmpv8hi3_mask */
    5975        66130 :     case 3646:  /* avx512vl_ucmpv16hi3_mask */
    5976        66130 :     case 3644:  /* avx512bw_ucmpv32hi3_mask */
    5977        66130 :     case 3642:  /* avx512vl_ucmpv16qi3_mask */
    5978        66130 :     case 3640:  /* avx512vl_ucmpv32qi3_mask */
    5979        66130 :     case 3638:  /* avx512bw_ucmpv64qi3_mask */
    5980        66130 :     case 3480:  /* avx512vl_cmpv2di3_mask */
    5981        66130 :     case 3478:  /* avx512vl_cmpv4di3_mask */
    5982        66130 :     case 3476:  /* avx512f_cmpv8di3_mask */
    5983        66130 :     case 3474:  /* avx512vl_cmpv4si3_mask */
    5984        66130 :     case 3472:  /* avx512vl_cmpv8si3_mask */
    5985        66130 :     case 3470:  /* avx512f_cmpv16si3_mask */
    5986        66130 :     case 3468:  /* avx512vl_cmpv8hi3_mask */
    5987        66130 :     case 3466:  /* avx512vl_cmpv16hi3_mask */
    5988        66130 :     case 3464:  /* avx512bw_cmpv32hi3_mask */
    5989        66130 :     case 3462:  /* avx512vl_cmpv16qi3_mask */
    5990        66130 :     case 3460:  /* avx512vl_cmpv32qi3_mask */
    5991        66130 :     case 3458:  /* avx512bw_cmpv64qi3_mask */
    5992        66130 :     case 3336:  /* avx512vl_cmpv2df3_mask */
    5993        66130 :     case 3334:  /* avx512vl_cmpv4df3_mask */
    5994        66130 :     case 3331:  /* avx512f_cmpv8df3_mask */
    5995        66130 :     case 3328:  /* avx512vl_cmpv4sf3_mask */
    5996        66130 :     case 3326:  /* avx512vl_cmpv8sf3_mask */
    5997        66130 :     case 3323:  /* avx512f_cmpv16sf3_mask */
    5998        66130 :     case 3320:  /* avx512fp16_cmpv8hf3_mask */
    5999        66130 :     case 3318:  /* avx512vl_cmpv16hf3_mask */
    6000        66130 :     case 3315:  /* avx512bw_cmpv32hf3_mask */
    6001        66130 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6002        66130 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    6003        66130 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    6004        66130 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 2));
    6005        66130 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    6006        66130 :       break;
    6007              : 
    6008         4791 :     case 10998:  /* avx10_2_minmaxpv2df_round */
    6009         4791 :     case 10994:  /* avx10_2_minmaxpv4df_round */
    6010         4791 :     case 10990:  /* avx10_2_minmaxpv8df_round */
    6011         4791 :     case 10986:  /* avx10_2_minmaxpv4sf_round */
    6012         4791 :     case 10982:  /* avx10_2_minmaxpv8sf_round */
    6013         4791 :     case 10978:  /* avx10_2_minmaxpv16sf_round */
    6014         4791 :     case 10974:  /* avx10_2_minmaxpv8hf_round */
    6015         4791 :     case 10970:  /* avx10_2_minmaxpv16hf_round */
    6016         4791 :     case 10966:  /* avx10_2_minmaxpv32hf_round */
    6017         4791 :     case 10028:  /* avx512dq_rangepv8df_round */
    6018         4791 :     case 10020:  /* 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 7941:  /* *avx2_pcmpv16qi3_4 */
    6045           42 :     case 7940:  /* *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 7937:  /* *avx2_pcmpv4di3_2 */
    6059            0 :     case 7936:  /* *avx2_pcmpv8si3_2 */
    6060            0 :     case 7935:  /* *avx2_pcmpv16hi3_2 */
    6061            0 :     case 7934:  /* *avx2_pcmpv32qi3_2 */
    6062            0 :     case 7933:  /* *avx2_pcmpv2di3_2 */
    6063            0 :     case 7932:  /* *avx2_pcmpv4si3_2 */
    6064            0 :     case 7931:  /* *avx2_pcmpv8hi3_2 */
    6065            0 :     case 7930:  /* *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 11012:  /* avx10_2_minmaxsv2df_mask_round */
    6083         3537 :     case 11008:  /* avx10_2_minmaxsv4sf_mask_round */
    6084         3537 :     case 11004:  /* avx10_2_minmaxsv8hf_mask_round */
    6085         3537 :     case 10114:  /* avx512f_vgetmantv2df_mask_round */
    6086         3537 :     case 10110:  /* avx512f_vgetmantv4sf_mask_round */
    6087         3537 :     case 10106:  /* avx512f_vgetmantv8hf_mask_round */
    6088         3537 :     case 10042:  /* avx512dq_rangesv2df_mask_round */
    6089         3537 :     case 10038:  /* 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         3579 :     case 11011:  /* avx10_2_minmaxsv2df_round */
    6105         3579 :     case 11007:  /* avx10_2_minmaxsv4sf_round */
    6106         3579 :     case 11003:  /* avx10_2_minmaxsv8hf_round */
    6107         3579 :     case 10113:  /* avx512f_vgetmantv2df_round */
    6108         3579 :     case 10109:  /* avx512f_vgetmantv4sf_round */
    6109         3579 :     case 10105:  /* avx512f_vgetmantv8hf_round */
    6110         3579 :     case 10041:  /* avx512dq_rangesv2df_round */
    6111         3579 :     case 10037:  /* avx512dq_rangesv4sf_round */
    6112         3579 :     case 3267:  /* reducesv2df_round */
    6113         3579 :     case 3263:  /* reducesv4sf_round */
    6114         3579 :     case 3259:  /* reducesv8hf_round */
    6115         3579 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6116         3579 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 0));
    6117         3579 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 1));
    6118         3579 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0, 2));
    6119         3579 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (pat, 1), 0, 1));
    6120         3579 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    6121         3579 :       recog_data.dup_num[0] = 1;
    6122         3579 :       break;
    6123              : 
    6124         5470 :     case 11010:  /* avx10_2_minmaxsv2df_mask */
    6125         5470 :     case 11006:  /* avx10_2_minmaxsv4sf_mask */
    6126         5470 :     case 11002:  /* avx10_2_minmaxsv8hf_mask */
    6127         5470 :     case 10112:  /* avx512f_vgetmantv2df_mask */
    6128         5470 :     case 10108:  /* avx512f_vgetmantv4sf_mask */
    6129         5470 :     case 10104:  /* avx512f_vgetmantv8hf_mask */
    6130         5470 :     case 10040:  /* avx512dq_rangesv2df_mask */
    6131         5470 :     case 10036:  /* 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 11009:  /* avx10_2_minmaxsv2df */
    6146         4778 :     case 11005:  /* avx10_2_minmaxsv4sf */
    6147         4778 :     case 11001:  /* avx10_2_minmaxsv8hf */
    6148         4778 :     case 10111:  /* avx512f_vgetmantv2df */
    6149         4778 :     case 10107:  /* avx512f_vgetmantv4sf */
    6150         4778 :     case 10103:  /* avx512f_vgetmantv8hf */
    6151         4778 :     case 10039:  /* avx512dq_rangesv2df */
    6152         4778 :     case 10035:  /* 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 10102:  /* avx512vl_getmantv2df_mask_round */
    6352        13209 :     case 10098:  /* avx512vl_getmantv4df_mask_round */
    6353        13209 :     case 10094:  /* avx512f_getmantv8df_mask_round */
    6354        13209 :     case 10090:  /* avx512vl_getmantv4sf_mask_round */
    6355        13209 :     case 10086:  /* avx512vl_getmantv8sf_mask_round */
    6356        13209 :     case 10082:  /* avx512f_getmantv16sf_mask_round */
    6357        13209 :     case 10078:  /* avx512fp16_getmantv8hf_mask_round */
    6358        13209 :     case 10074:  /* avx512vl_getmantv16hf_mask_round */
    6359        13209 :     case 10070:  /* avx512bw_getmantv32hf_mask_round */
    6360        13209 :     case 9728:  /* 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        65117 :     case 10778:  /* avx10_2_getmantbf16_v8bf_mask */
    6403        65117 :     case 10776:  /* avx10_2_reducebf16_v8bf_mask */
    6404        65117 :     case 10774:  /* avx10_2_rndscalebf16_v8bf_mask */
    6405        65117 :     case 10772:  /* avx10_2_getmantbf16_v16bf_mask */
    6406        65117 :     case 10770:  /* avx10_2_reducebf16_v16bf_mask */
    6407        65117 :     case 10768:  /* avx10_2_rndscalebf16_v16bf_mask */
    6408        65117 :     case 10766:  /* avx10_2_getmantbf16_v32bf_mask */
    6409        65117 :     case 10764:  /* avx10_2_reducebf16_v32bf_mask */
    6410        65117 :     case 10762:  /* avx10_2_rndscalebf16_v32bf_mask */
    6411        65117 :     case 10652:  /* avx10_2_scalefbf16_v8bf_mask */
    6412        65117 :     case 10650:  /* avx10_2_scalefbf16_v16bf_mask */
    6413        65117 :     case 10648:  /* avx10_2_scalefbf16_v32bf_mask */
    6414        65117 :     case 10553:  /* vcvtbiasph2hf8sv16hf_mask */
    6415        65117 :     case 10551:  /* vcvtbiasph2hf8v16hf_mask */
    6416        65117 :     case 10549:  /* vcvtbiasph2bf8sv16hf_mask */
    6417        65117 :     case 10547:  /* vcvtbiasph2bf8v16hf_mask */
    6418        65117 :     case 10545:  /* vcvtbiasph2hf8sv32hf_mask */
    6419        65117 :     case 10543:  /* vcvtbiasph2hf8v32hf_mask */
    6420        65117 :     case 10541:  /* vcvtbiasph2bf8sv32hf_mask */
    6421        65117 :     case 10539:  /* vcvtbiasph2bf8v32hf_mask */
    6422        65117 :     case 10529:  /* vcvt2ph2hf8sv8hf_mask */
    6423        65117 :     case 10527:  /* vcvt2ph2hf8v8hf_mask */
    6424        65117 :     case 10525:  /* vcvt2ph2bf8sv8hf_mask */
    6425        65117 :     case 10523:  /* vcvt2ph2bf8v8hf_mask */
    6426        65117 :     case 10521:  /* vcvt2ph2hf8sv16hf_mask */
    6427        65117 :     case 10519:  /* vcvt2ph2hf8v16hf_mask */
    6428        65117 :     case 10517:  /* vcvt2ph2bf8sv16hf_mask */
    6429        65117 :     case 10515:  /* vcvt2ph2bf8v16hf_mask */
    6430        65117 :     case 10513:  /* vcvt2ph2hf8sv32hf_mask */
    6431        65117 :     case 10511:  /* vcvt2ph2hf8v32hf_mask */
    6432        65117 :     case 10509:  /* vcvt2ph2bf8sv32hf_mask */
    6433        65117 :     case 10507:  /* vcvt2ph2bf8v32hf_mask */
    6434        65117 :     case 10243:  /* vgf2p8mulb_v16qi_mask */
    6435        65117 :     case 10241:  /* vgf2p8mulb_v32qi_mask */
    6436        65117 :     case 10239:  /* vgf2p8mulb_v64qi_mask */
    6437        65117 :     case 10193:  /* vpmultishiftqbv32qi_mask */
    6438        65117 :     case 10191:  /* vpmultishiftqbv16qi_mask */
    6439        65117 :     case 10189:  /* vpmultishiftqbv64qi_mask */
    6440        65117 :     case 10101:  /* avx512vl_getmantv2df_mask */
    6441        65117 :     case 10097:  /* avx512vl_getmantv4df_mask */
    6442        65117 :     case 10093:  /* avx512f_getmantv8df_mask */
    6443        65117 :     case 10089:  /* avx512vl_getmantv4sf_mask */
    6444        65117 :     case 10085:  /* avx512vl_getmantv8sf_mask */
    6445        65117 :     case 10081:  /* avx512f_getmantv16sf_mask */
    6446        65117 :     case 10077:  /* avx512fp16_getmantv8hf_mask */
    6447        65117 :     case 10073:  /* avx512vl_getmantv16hf_mask */
    6448        65117 :     case 10069:  /* avx512bw_getmantv32hf_mask */
    6449        65117 :     case 9727:  /* avx512f_vcvtps2ph512_mask */
    6450        65117 :     case 9722:  /* vcvtps2ph256_mask */
    6451        65117 :     case 9424:  /* avx_vpermilvarv2df3_mask */
    6452        65117 :     case 9422:  /* avx_vpermilvarv4df3_mask */
    6453        65117 :     case 9420:  /* avx512f_vpermilvarv8df3_mask */
    6454        65117 :     case 9418:  /* avx_vpermilvarv4sf3_mask */
    6455        65117 :     case 9416:  /* avx_vpermilvarv8sf3_mask */
    6456        65117 :     case 9414:  /* avx512f_vpermilvarv16sf3_mask */
    6457        65117 :     case 9195:  /* avx512bw_permvarv32bf_mask */
    6458        65117 :     case 9193:  /* avx512vl_permvarv16bf_mask */
    6459        65117 :     case 9191:  /* avx512vl_permvarv8bf_mask */
    6460        65117 :     case 9189:  /* avx512bw_permvarv32hf_mask */
    6461        65117 :     case 9187:  /* avx512vl_permvarv16hf_mask */
    6462        65117 :     case 9185:  /* avx512fp16_permvarv8hf_mask */
    6463        65117 :     case 9183:  /* avx512bw_permvarv32hi_mask */
    6464        65117 :     case 9181:  /* avx512vl_permvarv16hi_mask */
    6465        65117 :     case 9179:  /* avx512vl_permvarv8hi_mask */
    6466        65117 :     case 9177:  /* avx512vl_permvarv32qi_mask */
    6467        65117 :     case 9175:  /* avx512vl_permvarv16qi_mask */
    6468        65117 :     case 9173:  /* avx512bw_permvarv64qi_mask */
    6469        65117 :     case 9171:  /* avx2_permvarv4df_mask */
    6470        65117 :     case 9169:  /* avx2_permvarv4di_mask */
    6471        65117 :     case 9167:  /* avx512f_permvarv8df_mask */
    6472        65117 :     case 9165:  /* avx512f_permvarv8di_mask */
    6473        65117 :     case 9163:  /* avx512f_permvarv16sf_mask */
    6474        65117 :     case 9161:  /* avx512f_permvarv16si_mask */
    6475        65117 :     case 9159:  /* avx2_permvarv8sf_mask */
    6476        65117 :     case 9157:  /* avx2_permvarv8si_mask */
    6477        65117 :     case 8765:  /* sse4_1_packusdw_mask */
    6478        65117 :     case 8763:  /* avx2_packusdw_mask */
    6479        65117 :     case 8761:  /* avx512bw_packusdw_mask */
    6480        65117 :     case 8661:  /* ssse3_pshufbv16qi3_mask */
    6481        65117 :     case 8659:  /* avx2_pshufbv32qi3_mask */
    6482        65117 :     case 8657:  /* avx512bw_pshufbv64qi3_mask */
    6483        65117 :     case 8643:  /* avx512bw_pmaddubsw512v32hi_mask */
    6484        65117 :     case 8641:  /* avx512bw_pmaddubsw512v16hi_mask */
    6485        65117 :     case 8639:  /* avx512bw_pmaddubsw512v8hi_mask */
    6486        65117 :     case 8482:  /* avx512bw_pshufhwv32hi_mask */
    6487        65117 :     case 8476:  /* avx512bw_pshuflwv32hi_mask */
    6488        65117 :     case 8350:  /* sse2_packuswb_mask */
    6489        65117 :     case 8348:  /* avx2_packuswb_mask */
    6490        65117 :     case 8346:  /* avx512bw_packuswb_mask */
    6491        65117 :     case 7617:  /* avx512bw_pmaddwd512v8hi_mask */
    6492        65117 :     case 7615:  /* avx512bw_pmaddwd512v16hi_mask */
    6493        65117 :     case 7613:  /* avx512bw_pmaddwd512v32hi_mask */
    6494        65117 :     case 7193:  /* avx512vl_rndscalev2df_mask */
    6495        65117 :     case 7189:  /* avx512vl_rndscalev4df_mask */
    6496        65117 :     case 7185:  /* avx512f_rndscalev8df_mask */
    6497        65117 :     case 7181:  /* avx512vl_rndscalev4sf_mask */
    6498        65117 :     case 7177:  /* avx512vl_rndscalev8sf_mask */
    6499        65117 :     case 7173:  /* avx512f_rndscalev16sf_mask */
    6500        65117 :     case 7169:  /* avx512fp16_rndscalev8hf_mask */
    6501        65117 :     case 7165:  /* avx512vl_rndscalev16hf_mask */
    6502        65117 :     case 7161:  /* avx512bw_rndscalev32hf_mask */
    6503        65117 :     case 5463:  /* avx512vl_scalefv2df_mask */
    6504        65117 :     case 5459:  /* avx512vl_scalefv4df_mask */
    6505        65117 :     case 5455:  /* avx512f_scalefv8df_mask */
    6506        65117 :     case 5451:  /* avx512vl_scalefv4sf_mask */
    6507        65117 :     case 5447:  /* avx512vl_scalefv8sf_mask */
    6508        65117 :     case 5443:  /* avx512f_scalefv16sf_mask */
    6509        65117 :     case 5439:  /* avx512fp16_scalefv8hf_mask */
    6510        65117 :     case 5435:  /* avx512vl_scalefv16hf_mask */
    6511        65117 :     case 5431:  /* avx512bw_scalefv32hf_mask */
    6512        65117 :     case 3255:  /* reducepv2df_mask */
    6513        65117 :     case 3251:  /* reducepv4df_mask */
    6514        65117 :     case 3247:  /* reducepv8df_mask */
    6515        65117 :     case 3243:  /* reducepv4sf_mask */
    6516        65117 :     case 3239:  /* reducepv8sf_mask */
    6517        65117 :     case 3235:  /* reducepv16sf_mask */
    6518        65117 :     case 3231:  /* reducepv8hf_mask */
    6519        65117 :     case 3227:  /* reducepv16hf_mask */
    6520        65117 :     case 3223:  /* reducepv32hf_mask */
    6521        65117 :     case 3152:  /* ieee_minv2df3_mask */
    6522        65117 :     case 3150:  /* ieee_maxv2df3_mask */
    6523        65117 :     case 3148:  /* ieee_minv4df3_mask */
    6524        65117 :     case 3146:  /* ieee_maxv4df3_mask */
    6525        65117 :     case 3143:  /* ieee_minv8df3_mask */
    6526        65117 :     case 3139:  /* ieee_maxv8df3_mask */
    6527        65117 :     case 3136:  /* ieee_minv4sf3_mask */
    6528        65117 :     case 3134:  /* ieee_maxv4sf3_mask */
    6529        65117 :     case 3132:  /* ieee_minv8sf3_mask */
    6530        65117 :     case 3130:  /* ieee_maxv8sf3_mask */
    6531        65117 :     case 3127:  /* ieee_minv16sf3_mask */
    6532        65117 :     case 3123:  /* ieee_maxv16sf3_mask */
    6533        65117 :     case 3120:  /* ieee_minv8hf3_mask */
    6534        65117 :     case 3118:  /* ieee_maxv8hf3_mask */
    6535        65117 :     case 3116:  /* ieee_minv16hf3_mask */
    6536        65117 :     case 3114:  /* ieee_maxv16hf3_mask */
    6537        65117 :     case 3111:  /* ieee_minv32hf3_mask */
    6538        65117 :     case 3107:  /* ieee_maxv32hf3_mask */
    6539        65117 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6540        65117 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    6541        65117 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 1));
    6542        65117 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    6543        65117 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    6544        65117 :       break;
    6545              : 
    6546         5079 :     case 10100:  /* avx512vl_getmantv2df_round */
    6547         5079 :     case 10096:  /* avx512vl_getmantv4df_round */
    6548         5079 :     case 10092:  /* avx512f_getmantv8df_round */
    6549         5079 :     case 10088:  /* avx512vl_getmantv4sf_round */
    6550         5079 :     case 10084:  /* avx512vl_getmantv8sf_round */
    6551         5079 :     case 10080:  /* avx512f_getmantv16sf_round */
    6552         5079 :     case 10076:  /* avx512fp16_getmantv8hf_round */
    6553         5079 :     case 10072:  /* avx512vl_getmantv16hf_round */
    6554         5079 :     case 10068:  /* avx512bw_getmantv32hf_round */
    6555         5079 :     case 9726:  /* *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           54 :     case 3104:  /* *minmaxv2df3_4 */
    6598           54 :     case 3103:  /* *minmaxv4df3_4 */
    6599           54 :     case 3102:  /* *minmaxv4sf3_4 */
    6600           54 :     case 3101:  /* *minmaxv8sf3_4 */
    6601           54 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    6602           54 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    6603           54 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    6604           54 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    6605           54 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 1));
    6606           54 :       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 7975:  /* *avx2_pcmpv4di3_8 */
    6620         4158 :     case 7974:  /* *avx2_pcmpv8si3_8 */
    6621         4158 :     case 7973:  /* *avx2_pcmpv16hi3_8 */
    6622         4158 :     case 7972:  /* *avx2_pcmpv32qi3_8 */
    6623         4158 :     case 7971:  /* *avx2_pcmpv2di3_8 */
    6624         4158 :     case 7970:  /* *avx2_pcmpv4si3_8 */
    6625         4158 :     case 7969:  /* *avx2_pcmpv8hi3_8 */
    6626         4158 :     case 7968:  /* *avx2_pcmpv16qi3_8 */
    6627         4158 :     case 7967:  /* *avx2_pcmpv4di3_7 */
    6628         4158 :     case 7966:  /* *avx2_pcmpv8si3_7 */
    6629         4158 :     case 7965:  /* *avx2_pcmpv16hi3_7 */
    6630         4158 :     case 7964:  /* *avx2_pcmpv32qi3_7 */
    6631         4158 :     case 7963:  /* *avx2_pcmpv2di3_7 */
    6632         4158 :     case 7962:  /* *avx2_pcmpv4si3_7 */
    6633         4158 :     case 7961:  /* *avx2_pcmpv8hi3_7 */
    6634         4158 :     case 7960:  /* *avx2_pcmpv16qi3_7 */
    6635         4158 :     case 7959:  /* *avx2_pcmpv4di3_6 */
    6636         4158 :     case 7958:  /* *avx2_pcmpv4di3_6 */
    6637         4158 :     case 7957:  /* *avx2_pcmpv8si3_6 */
    6638         4158 :     case 7956:  /* *avx2_pcmpv8si3_6 */
    6639         4158 :     case 7955:  /* *avx2_pcmpv16hi3_6 */
    6640         4158 :     case 7954:  /* *avx2_pcmpv16hi3_6 */
    6641         4158 :     case 7953:  /* *avx2_pcmpv32qi3_6 */
    6642         4158 :     case 7952:  /* *avx2_pcmpv32qi3_6 */
    6643         4158 :     case 7951:  /* *avx2_pcmpv2di3_6 */
    6644         4158 :     case 7950:  /* *avx2_pcmpv2di3_6 */
    6645         4158 :     case 7949:  /* *avx2_pcmpv4si3_6 */
    6646         4158 :     case 7948:  /* *avx2_pcmpv4si3_6 */
    6647         4158 :     case 7947:  /* *avx2_pcmpv8hi3_6 */
    6648         4158 :     case 7946:  /* *avx2_pcmpv8hi3_6 */
    6649         4158 :     case 7945:  /* *avx2_pcmpv16qi3_6 */
    6650         4158 :     case 7944:  /* *avx2_pcmpv16qi3_6 */
    6651         4158 :     case 7939:  /* *avx2_pcmpv16qi3_3 */
    6652         4158 :     case 7938:  /* *avx2_pcmpv32qi3_3 */
    6653         4158 :     case 7929:  /* *avx2_pcmpv4di3_1 */
    6654         4158 :     case 7928:  /* *avx2_pcmpv8si3_1 */
    6655         4158 :     case 7927:  /* *avx2_pcmpv16hi3_1 */
    6656         4158 :     case 7926:  /* *avx2_pcmpv32qi3_1 */
    6657         4158 :     case 7925:  /* *avx2_pcmpv2di3_1 */
    6658         4158 :     case 7924:  /* *avx2_pcmpv4si3_1 */
    6659         4158 :     case 7923:  /* *avx2_pcmpv8hi3_1 */
    6660         4158 :     case 7922:  /* *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 10748:  /* avx10_2_sqrtbf16_v8bf_mask */
    6832       196112 :     case 10746:  /* avx10_2_sqrtbf16_v16bf_mask */
    6833       196112 :     case 10744:  /* avx10_2_sqrtbf16_v32bf_mask */
    6834       196112 :     case 10705:  /* avx10_2_fnmaddbf16_v8bf */
    6835       196112 :     case 10703:  /* avx10_2_fnmaddbf16_v16bf */
    6836       196112 :     case 10701:  /* avx10_2_fnmaddbf16_v32bf */
    6837       196112 :     case 10411:  /* avx512f_cvtneps2bf16_v8sf_mask */
    6838       196112 :     case 10409:  /* avx512f_cvtneps2bf16_v16sf_mask */
    6839       196112 :     case 10225:  /* vpopcountv8hi_mask */
    6840       196112 :     case 10223:  /* vpopcountv16hi_mask */
    6841       196112 :     case 10221:  /* vpopcountv32hi_mask */
    6842       196112 :     case 10219:  /* vpopcountv32qi_mask */
    6843       196112 :     case 10217:  /* vpopcountv16qi_mask */
    6844       196112 :     case 10215:  /* vpopcountv64qi_mask */
    6845       196112 :     case 10205:  /* vpopcountv2di_mask */
    6846       196112 :     case 10203:  /* vpopcountv4di_mask */
    6847       196112 :     case 10201:  /* vpopcountv8di_mask */
    6848       196112 :     case 10199:  /* vpopcountv4si_mask */
    6849       196112 :     case 10197:  /* vpopcountv8si_mask */
    6850       196112 :     case 10195:  /* vpopcountv16si_mask */
    6851       196112 :     case 10132:  /* clzv2di2_mask */
    6852       196112 :     case 10130:  /* clzv4di2_mask */
    6853       196112 :     case 10128:  /* clzv8di2_mask */
    6854       196112 :     case 10126:  /* clzv4si2_mask */
    6855       196112 :     case 10124:  /* clzv8si2_mask */
    6856       196112 :     case 10122:  /* clzv16si2_mask */
    6857       196112 :     case 9406:  /* avx512dq_broadcastv4df_mask_1 */
    6858       196112 :     case 9404:  /* avx512dq_broadcastv4di_mask_1 */
    6859       196112 :     case 9402:  /* avx512dq_broadcastv8df_mask_1 */
    6860       196112 :     case 9400:  /* avx512dq_broadcastv8di_mask_1 */
    6861       196112 :     case 9398:  /* avx512dq_broadcastv16si_mask_1 */
    6862       196112 :     case 9396:  /* avx512dq_broadcastv16sf_mask_1 */
    6863       196112 :     case 9394:  /* avx512vl_broadcastv8sf_mask_1 */
    6864       196112 :     case 9392:  /* avx512vl_broadcastv8si_mask_1 */
    6865       196112 :     case 9342:  /* avx512vl_vec_dup_gprv2df_mask */
    6866       196112 :     case 9340:  /* avx512vl_vec_dup_gprv4df_mask */
    6867       196112 :     case 9338:  /* avx512f_vec_dup_gprv8df_mask */
    6868       196112 :     case 9336:  /* avx512vl_vec_dup_gprv4sf_mask */
    6869       196112 :     case 9334:  /* avx512vl_vec_dup_gprv8sf_mask */
    6870       196112 :     case 9332:  /* avx512f_vec_dup_gprv16sf_mask */
    6871       196112 :     case 9330:  /* avx512vl_vec_dup_gprv2di_mask */
    6872       196112 :     case 9328:  /* avx512vl_vec_dup_gprv4di_mask */
    6873       196112 :     case 9326:  /* avx512f_vec_dup_gprv8di_mask */
    6874       196112 :     case 9324:  /* avx512vl_vec_dup_gprv4si_mask */
    6875       196112 :     case 9322:  /* avx512vl_vec_dup_gprv8si_mask */
    6876       196112 :     case 9320:  /* avx512f_vec_dup_gprv16si_mask */
    6877       196112 :     case 9318:  /* avx512vl_vec_dup_gprv8bf_mask */
    6878       196112 :     case 9316:  /* avx512vl_vec_dup_gprv16bf_mask */
    6879       196112 :     case 9314:  /* avx512bw_vec_dup_gprv32bf_mask */
    6880       196112 :     case 9312:  /* avx512fp16_vec_dup_gprv8hf_mask */
    6881       196112 :     case 9310:  /* avx512vl_vec_dup_gprv16hf_mask */
    6882       196112 :     case 9308:  /* avx512bw_vec_dup_gprv32hf_mask */
    6883       196112 :     case 9306:  /* avx512vl_vec_dup_gprv8hi_mask */
    6884       196112 :     case 9304:  /* avx512vl_vec_dup_gprv16hi_mask */
    6885       196112 :     case 9302:  /* avx512bw_vec_dup_gprv32hi_mask */
    6886       196112 :     case 9300:  /* avx512vl_vec_dup_gprv32qi_mask */
    6887       196112 :     case 9298:  /* avx512vl_vec_dup_gprv16qi_mask */
    6888       196112 :     case 9296:  /* avx512bw_vec_dup_gprv64qi_mask */
    6889       196112 :     case 9294:  /* avx512f_broadcastv8di_mask */
    6890       196112 :     case 9292:  /* avx512f_broadcastv8df_mask */
    6891       196112 :     case 9290:  /* avx512f_broadcastv16si_mask */
    6892       196112 :     case 9288:  /* avx512f_broadcastv16sf_mask */
    6893       196112 :     case 8961:  /* *sse4_1_zero_extendv2siv2di2_mask_1 */
    6894       196112 :     case 8959:  /* *sse4_1_sign_extendv2siv2di2_mask_1 */
    6895       196112 :     case 8951:  /* avx2_zero_extendv4siv4di2_mask */
    6896       196112 :     case 8949:  /* avx2_sign_extendv4siv4di2_mask */
    6897       196112 :     case 8945:  /* avx512f_zero_extendv8siv8di2_mask */
    6898       196112 :     case 8943:  /* avx512f_sign_extendv8siv8di2_mask */
    6899       196112 :     case 8937:  /* *sse4_1_zero_extendv2hiv2di2_mask_1 */
    6900       196112 :     case 8935:  /* *sse4_1_sign_extendv2hiv2di2_mask_1 */
    6901       196112 :     case 8925:  /* *avx2_zero_extendv4hiv4di2_mask_1 */
    6902       196112 :     case 8923:  /* *avx2_sign_extendv4hiv4di2_mask_1 */
    6903       196112 :     case 8917:  /* avx512f_zero_extendv8hiv8di2_mask */
    6904       196112 :     case 8915:  /* avx512f_sign_extendv8hiv8di2_mask */
    6905       196112 :     case 8910:  /* *sse4_1_zero_extendv2qiv2di2_mask_1 */
    6906       196112 :     case 8908:  /* *sse4_1_sign_extendv2qiv2di2_mask_1 */
    6907       196112 :     case 8898:  /* *avx2_zero_extendv4qiv4di2_mask_1 */
    6908       196112 :     case 8896:  /* *avx2_sign_extendv4qiv4di2_mask_1 */
    6909       196112 :     case 8886:  /* *avx512f_zero_extendv8qiv8di2_mask_1 */
    6910       196112 :     case 8884:  /* *avx512f_sign_extendv8qiv8di2_mask_1 */
    6911       196112 :     case 8870:  /* *sse4_1_zero_extendv4hiv4si2_mask_1 */
    6912       196112 :     case 8868:  /* *sse4_1_sign_extendv4hiv4si2_mask_1 */
    6913       196112 :     case 8858:  /* avx2_zero_extendv8hiv8si2_mask */
    6914       196112 :     case 8856:  /* avx2_sign_extendv8hiv8si2_mask */
    6915       196112 :     case 8850:  /* avx512f_zero_extendv16hiv16si2_mask */
    6916       196112 :     case 8848:  /* avx512f_sign_extendv16hiv16si2_mask */
    6917       196112 :     case 8840:  /* *sse4_1_zero_extendv4qiv4si2_mask_1 */
    6918       196112 :     case 8838:  /* *sse4_1_sign_extendv4qiv4si2_mask_1 */
    6919       196112 :     case 8828:  /* *avx2_zero_extendv8qiv8si2_mask_1 */
    6920       196112 :     case 8826:  /* *avx2_sign_extendv8qiv8si2_mask_1 */
    6921       196112 :     case 8820:  /* avx512f_zero_extendv16qiv16si2_mask */
    6922       196112 :     case 8818:  /* avx512f_sign_extendv16qiv16si2_mask */
    6923       196112 :     case 8808:  /* *sse4_1_zero_extendv8qiv8hi2_mask_1 */
    6924       196112 :     case 8806:  /* *sse4_1_sign_extendv8qiv8hi2_mask_1 */
    6925       196112 :     case 8796:  /* avx512bw_zero_extendv32qiv32hi2_mask */
    6926       196112 :     case 8794:  /* avx512bw_sign_extendv32qiv32hi2_mask */
    6927       196112 :     case 8788:  /* avx2_zero_extendv16qiv16hi2_mask */
    6928       196112 :     case 8786:  /* avx2_sign_extendv16qiv16hi2_mask */
    6929       196112 :     case 8702:  /* absv8hi2_mask */
    6930       196112 :     case 8701:  /* absv16hi2_mask */
    6931       196112 :     case 8700:  /* absv32hi2_mask */
    6932       196112 :     case 8699:  /* absv32qi2_mask */
    6933       196112 :     case 8698:  /* absv16qi2_mask */
    6934       196112 :     case 8697:  /* absv64qi2_mask */
    6935       196112 :     case 8696:  /* absv2di2_mask */
    6936       196112 :     case 8695:  /* absv4di2_mask */
    6937       196112 :     case 8694:  /* absv8di2_mask */
    6938       196112 :     case 8693:  /* absv4si2_mask */
    6939       196112 :     case 8692:  /* absv8si2_mask */
    6940       196112 :     case 8691:  /* absv16si2_mask */
    6941       196112 :     case 8420:  /* *avx512f_vinserti32x4_0 */
    6942       196112 :     case 8419:  /* *avx512f_vinsertf32x4_0 */
    6943       196112 :     case 8418:  /* *avx512dq_vinserti64x2_0 */
    6944       196112 :     case 8417:  /* *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 10557:  /* *vcvtph2hf8sv8hf */
    7186         2538 :     case 10556:  /* *vcvtph2hf8v8hf */
    7187         2538 :     case 10555:  /* *vcvtph2bf8sv8hf */
    7188         2538 :     case 10554:  /* *vcvtph2bf8v8hf */
    7189         2538 :     case 9102:  /* *xop_vmfrczv2df2 */
    7190         2538 :     case 9101:  /* *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         4770 :     case 3181:  /* *sse2_vmsminv2df3_round */
    7261         4770 :     case 3177:  /* *sse2_vmsmaxv2df3_round */
    7262         4770 :     case 3173:  /* *sse_vmsminv4sf3_round */
    7263         4770 :     case 3169:  /* *sse_vmsmaxv4sf3_round */
    7264         4770 :     case 3165:  /* *avx512fp16_vmsminv8hf3_round */
    7265         4770 :     case 3161:  /* *avx512fp16_vmsmaxv8hf3_round */
    7266         4770 :     case 2902:  /* sse2_vmdivv2df3_round */
    7267         4770 :     case 2898:  /* sse2_vmmulv2df3_round */
    7268         4770 :     case 2894:  /* sse_vmdivv4sf3_round */
    7269         4770 :     case 2890:  /* sse_vmmulv4sf3_round */
    7270         4770 :     case 2886:  /* avx512fp16_vmdivv8hf3_round */
    7271         4770 :     case 2882:  /* avx512fp16_vmmulv8hf3_round */
    7272         4770 :     case 2836:  /* sse2_vmsubv2df3_round */
    7273         4770 :     case 2832:  /* sse2_vmaddv2df3_round */
    7274         4770 :     case 2828:  /* sse_vmsubv4sf3_round */
    7275         4770 :     case 2824:  /* sse_vmaddv4sf3_round */
    7276         4770 :     case 2820:  /* avx512fp16_vmsubv8hf3_round */
    7277         4770 :     case 2816:  /* avx512fp16_vmaddv8hf3_round */
    7278         4770 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7279         4770 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 0));
    7280         4770 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0), 1));
    7281         4770 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 1));
    7282         4770 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1);
    7283         4770 :       recog_data.dup_num[0] = 1;
    7284         4770 :       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       209977 :     case 10688:  /* avx10_2_divbf16_v8bf_mask */
    7375       209977 :     case 10686:  /* avx10_2_mulbf16_v8bf_mask */
    7376       209977 :     case 10684:  /* avx10_2_subbf16_v8bf_mask */
    7377       209977 :     case 10682:  /* avx10_2_addbf16_v8bf_mask */
    7378       209977 :     case 10680:  /* avx10_2_divbf16_v16bf_mask */
    7379       209977 :     case 10678:  /* avx10_2_mulbf16_v16bf_mask */
    7380       209977 :     case 10676:  /* avx10_2_subbf16_v16bf_mask */
    7381       209977 :     case 10674:  /* avx10_2_addbf16_v16bf_mask */
    7382       209977 :     case 10672:  /* avx10_2_divbf16_v32bf_mask */
    7383       209977 :     case 10670:  /* avx10_2_mulbf16_v32bf_mask */
    7384       209977 :     case 10668:  /* avx10_2_subbf16_v32bf_mask */
    7385       209977 :     case 10666:  /* avx10_2_addbf16_v32bf_mask */
    7386       209977 :     case 10664:  /* avx10_2_sminbf16_v8bf_mask */
    7387       209977 :     case 10662:  /* avx10_2_smaxbf16_v8bf_mask */
    7388       209977 :     case 10660:  /* avx10_2_sminbf16_v16bf_mask */
    7389       209977 :     case 10658:  /* avx10_2_smaxbf16_v16bf_mask */
    7390       209977 :     case 10656:  /* avx10_2_sminbf16_v32bf_mask */
    7391       209977 :     case 10654:  /* avx10_2_smaxbf16_v32bf_mask */
    7392       209977 :     case 9667:  /* avx512bw_lshrvv32hi_mask */
    7393       209977 :     case 9665:  /* avx512bw_ashlvv32hi_mask */
    7394       209977 :     case 9663:  /* avx512vl_lshrvv16hi_mask */
    7395       209977 :     case 9661:  /* avx512vl_ashlvv16hi_mask */
    7396       209977 :     case 9659:  /* avx512vl_lshrvv8hi_mask */
    7397       209977 :     case 9657:  /* avx512vl_ashlvv8hi_mask */
    7398       209977 :     case 9655:  /* avx2_lshrvv2di_mask */
    7399       209977 :     case 9653:  /* avx2_ashlvv2di_mask */
    7400       209977 :     case 9651:  /* avx2_lshrvv4di_mask */
    7401       209977 :     case 9649:  /* avx2_ashlvv4di_mask */
    7402       209977 :     case 9647:  /* avx512f_lshrvv8di_mask */
    7403       209977 :     case 9645:  /* avx512f_ashlvv8di_mask */
    7404       209977 :     case 9643:  /* avx2_lshrvv4si_mask */
    7405       209977 :     case 9641:  /* avx2_ashlvv4si_mask */
    7406       209977 :     case 9639:  /* avx2_lshrvv8si_mask */
    7407       209977 :     case 9637:  /* avx2_ashlvv8si_mask */
    7408       209977 :     case 9635:  /* avx512f_lshrvv16si_mask */
    7409       209977 :     case 9633:  /* avx512f_ashlvv16si_mask */
    7410       209977 :     case 9631:  /* avx512bw_ashrvv32hi_mask */
    7411       209977 :     case 9629:  /* avx512vl_ashrvv16hi_mask */
    7412       209977 :     case 9627:  /* avx512vl_ashrvv8hi_mask */
    7413       209977 :     case 9625:  /* avx512f_ashrvv8di_mask */
    7414       209977 :     case 9623:  /* avx2_ashrvv4di_mask */
    7415       209977 :     case 9621:  /* avx2_ashrvv2di_mask */
    7416       209977 :     case 9619:  /* avx512f_ashrvv16si_mask */
    7417       209977 :     case 9617:  /* avx2_ashrvv8si_mask */
    7418       209977 :     case 9615:  /* avx2_ashrvv4si_mask */
    7419       209977 :     case 8071:  /* *xorv2di3_mask */
    7420       209977 :     case 8069:  /* *iorv2di3_mask */
    7421       209977 :     case 8067:  /* *andv2di3_mask */
    7422       209977 :     case 8065:  /* *xorv4di3_mask */
    7423       209977 :     case 8063:  /* *iorv4di3_mask */
    7424       209977 :     case 8061:  /* *andv4di3_mask */
    7425       209977 :     case 8059:  /* *xorv8di3_mask */
    7426       209977 :     case 8057:  /* *iorv8di3_mask */
    7427       209977 :     case 8055:  /* *andv8di3_mask */
    7428       209977 :     case 8053:  /* *xorv4si3_mask */
    7429       209977 :     case 8051:  /* *iorv4si3_mask */
    7430       209977 :     case 8049:  /* *andv4si3_mask */
    7431       209977 :     case 8047:  /* *xorv8si3_mask */
    7432       209977 :     case 8045:  /* *iorv8si3_mask */
    7433       209977 :     case 8043:  /* *andv8si3_mask */
    7434       209977 :     case 8041:  /* *xorv16si3_mask */
    7435       209977 :     case 8039:  /* *iorv16si3_mask */
    7436       209977 :     case 8037:  /* *andv16si3_mask */
    7437       209977 :     case 8005:  /* one_cmplv2di2_mask */
    7438       209977 :     case 8003:  /* one_cmplv4di2_mask */
    7439       209977 :     case 8001:  /* one_cmplv4si2_mask */
    7440       209977 :     case 7999:  /* one_cmplv8si2_mask */
    7441       209977 :     case 7991:  /* one_cmplv8di2_mask */
    7442       209977 :     case 7989:  /* one_cmplv16si2_mask */
    7443       209977 :     case 7907:  /* *sse4_1_uminv4si3_mask */
    7444       209977 :     case 7905:  /* *sse4_1_umaxv4si3_mask */
    7445       209977 :     case 7903:  /* *sse4_1_uminv8hi3_mask */
    7446       209977 :     case 7901:  /* *sse4_1_umaxv8hi3_mask */
    7447       209977 :     case 7897:  /* *sse4_1_sminv4si3_mask */
    7448       209977 :     case 7895:  /* *sse4_1_smaxv4si3_mask */
    7449       209977 :     case 7893:  /* *sse4_1_sminv16qi3_mask */
    7450       209977 :     case 7891:  /* *sse4_1_smaxv16qi3_mask */
    7451       209977 :     case 7889:  /* *avx512bw_uminv8hi3_mask */
    7452       209977 :     case 7887:  /* *avx512bw_umaxv8hi3_mask */
    7453       209977 :     case 7885:  /* *avx512bw_sminv8hi3_mask */
    7454       209977 :     case 7883:  /* *avx512bw_smaxv8hi3_mask */
    7455       209977 :     case 7881:  /* *avx512bw_uminv16hi3_mask */
    7456       209977 :     case 7879:  /* *avx512bw_umaxv16hi3_mask */
    7457       209977 :     case 7877:  /* *avx512bw_sminv16hi3_mask */
    7458       209977 :     case 7875:  /* *avx512bw_smaxv16hi3_mask */
    7459       209977 :     case 7873:  /* *avx512bw_uminv32hi3_mask */
    7460       209977 :     case 7871:  /* *avx512bw_umaxv32hi3_mask */
    7461       209977 :     case 7869:  /* *avx512bw_sminv32hi3_mask */
    7462       209977 :     case 7867:  /* *avx512bw_smaxv32hi3_mask */
    7463       209977 :     case 7865:  /* *avx512bw_uminv32qi3_mask */
    7464       209977 :     case 7863:  /* *avx512bw_umaxv32qi3_mask */
    7465       209977 :     case 7861:  /* *avx512bw_sminv32qi3_mask */
    7466       209977 :     case 7859:  /* *avx512bw_smaxv32qi3_mask */
    7467       209977 :     case 7857:  /* *avx512bw_uminv16qi3_mask */
    7468       209977 :     case 7855:  /* *avx512bw_umaxv16qi3_mask */
    7469       209977 :     case 7853:  /* *avx512bw_sminv16qi3_mask */
    7470       209977 :     case 7851:  /* *avx512bw_smaxv16qi3_mask */
    7471       209977 :     case 7849:  /* *avx512bw_uminv64qi3_mask */
    7472       209977 :     case 7847:  /* *avx512bw_umaxv64qi3_mask */
    7473       209977 :     case 7845:  /* *avx512bw_sminv64qi3_mask */
    7474       209977 :     case 7843:  /* *avx512bw_smaxv64qi3_mask */
    7475       209977 :     case 7841:  /* *avx512f_uminv2di3_mask */
    7476       209977 :     case 7839:  /* *avx512f_umaxv2di3_mask */
    7477       209977 :     case 7837:  /* *avx512f_sminv2di3_mask */
    7478       209977 :     case 7835:  /* *avx512f_smaxv2di3_mask */
    7479       209977 :     case 7833:  /* *avx512f_uminv4di3_mask */
    7480       209977 :     case 7831:  /* *avx512f_umaxv4di3_mask */
    7481       209977 :     case 7829:  /* *avx512f_sminv4di3_mask */
    7482       209977 :     case 7827:  /* *avx512f_smaxv4di3_mask */
    7483       209977 :     case 7825:  /* *avx512f_uminv8di3_mask */
    7484       209977 :     case 7823:  /* *avx512f_umaxv8di3_mask */
    7485       209977 :     case 7821:  /* *avx512f_sminv8di3_mask */
    7486       209977 :     case 7819:  /* *avx512f_smaxv8di3_mask */
    7487       209977 :     case 7817:  /* *avx512f_uminv4si3_mask */
    7488       209977 :     case 7815:  /* *avx512f_umaxv4si3_mask */
    7489       209977 :     case 7813:  /* *avx512f_sminv4si3_mask */
    7490       209977 :     case 7811:  /* *avx512f_smaxv4si3_mask */
    7491       209977 :     case 7809:  /* *avx512f_uminv8si3_mask */
    7492       209977 :     case 7807:  /* *avx512f_umaxv8si3_mask */
    7493       209977 :     case 7805:  /* *avx512f_sminv8si3_mask */
    7494       209977 :     case 7803:  /* *avx512f_smaxv8si3_mask */
    7495       209977 :     case 7801:  /* *avx512f_uminv16si3_mask */
    7496       209977 :     case 7799:  /* *avx512f_umaxv16si3_mask */
    7497       209977 :     case 7797:  /* *avx512f_sminv16si3_mask */
    7498       209977 :     case 7795:  /* *avx512f_smaxv16si3_mask */
    7499       209977 :     case 7781:  /* avx512vl_rorv2di_mask */
    7500       209977 :     case 7779:  /* avx512vl_rolv2di_mask */
    7501       209977 :     case 7777:  /* avx512vl_rorv4di_mask */
    7502       209977 :     case 7775:  /* avx512vl_rolv4di_mask */
    7503       209977 :     case 7773:  /* avx512f_rorv8di_mask */
    7504       209977 :     case 7771:  /* avx512f_rolv8di_mask */
    7505       209977 :     case 7769:  /* avx512vl_rorv4si_mask */
    7506       209977 :     case 7767:  /* avx512vl_rolv4si_mask */
    7507       209977 :     case 7765:  /* avx512vl_rorv8si_mask */
    7508       209977 :     case 7763:  /* avx512vl_rolv8si_mask */
    7509       209977 :     case 7761:  /* avx512f_rorv16si_mask */
    7510       209977 :     case 7759:  /* avx512f_rolv16si_mask */
    7511       209977 :     case 7757:  /* avx512vl_rorvv2di_mask */
    7512       209977 :     case 7755:  /* avx512vl_rolvv2di_mask */
    7513       209977 :     case 7753:  /* avx512vl_rorvv4di_mask */
    7514       209977 :     case 7751:  /* avx512vl_rolvv4di_mask */
    7515       209977 :     case 7749:  /* avx512f_rorvv8di_mask */
    7516       209977 :     case 7747:  /* avx512f_rolvv8di_mask */
    7517       209977 :     case 7745:  /* avx512vl_rorvv4si_mask */
    7518       209977 :     case 7743:  /* avx512vl_rolvv4si_mask */
    7519       209977 :     case 7741:  /* avx512vl_rorvv8si_mask */
    7520       209977 :     case 7739:  /* avx512vl_rolvv8si_mask */
    7521       209977 :     case 7737:  /* avx512f_rorvv16si_mask */
    7522       209977 :     case 7735:  /* avx512f_rolvv16si_mask */
    7523       209977 :     case 7718:  /* lshrv8di3_mask */
    7524       209977 :     case 7716:  /* ashlv8di3_mask */
    7525       209977 :     case 7714:  /* lshrv16si3_mask */
    7526       209977 :     case 7712:  /* ashlv16si3_mask */
    7527       209977 :     case 7710:  /* lshrv32hi3_mask */
    7528       209977 :     case 7708:  /* ashlv32hi3_mask */
    7529       209977 :     case 7690:  /* lshrv2di3_mask */
    7530       209977 :     case 7688:  /* ashlv2di3_mask */
    7531       209977 :     case 7686:  /* lshrv4di3_mask */
    7532       209977 :     case 7684:  /* ashlv4di3_mask */
    7533       209977 :     case 7682:  /* lshrv4si3_mask */
    7534       209977 :     case 7680:  /* ashlv4si3_mask */
    7535       209977 :     case 7678:  /* lshrv8si3_mask */
    7536       209977 :     case 7676:  /* ashlv8si3_mask */
    7537       209977 :     case 7674:  /* lshrv8hi3_mask */
    7538       209977 :     case 7672:  /* ashlv8hi3_mask */
    7539       209977 :     case 7670:  /* lshrv16hi3_mask */
    7540       209977 :     case 7668:  /* ashlv16hi3_mask */
    7541       209977 :     case 7657:  /* ashrv8di3_mask */
    7542       209977 :     case 7655:  /* ashrv16si3_mask */
    7543       209977 :     case 7653:  /* ashrv4di3_mask */
    7544       209977 :     case 7651:  /* ashrv32hi3_mask */
    7545       209977 :     case 7641:  /* ashrv2di3_mask */
    7546       209977 :     case 7639:  /* ashrv4si3_mask */
    7547       209977 :     case 7637:  /* ashrv8si3_mask */
    7548       209977 :     case 7635:  /* ashrv8hi3_mask */
    7549       209977 :     case 7633:  /* ashrv16hi3_mask */
    7550       209977 :     case 7631:  /* *sse4_1_mulv4si3_mask */
    7551       209977 :     case 7629:  /* *avx2_mulv8si3_mask */
    7552       209977 :     case 7627:  /* *avx512f_mulv16si3_mask */
    7553       209977 :     case 7625:  /* *avx512dq_mulv2di3_mask */
    7554       209977 :     case 7623:  /* *avx512dq_mulv4di3_mask */
    7555       209977 :     case 7621:  /* *avx512dq_mulv8di3_mask */
    7556       209977 :     case 7587:  /* *mulv8hi3_mask */
    7557       209977 :     case 7585:  /* *mulv16hi3_mask */
    7558       209977 :     case 7583:  /* *mulv32hi3_mask */
    7559       209977 :     case 7581:  /* *sse2_ussubv8hi3_mask */
    7560       209977 :     case 7579:  /* *sse2_sssubv8hi3_mask */
    7561       209977 :     case 7577:  /* *sse2_usaddv8hi3_mask */
    7562       209977 :     case 7575:  /* *sse2_ssaddv8hi3_mask */
    7563       209977 :     case 7573:  /* *avx2_ussubv16hi3_mask */
    7564       209977 :     case 7571:  /* *avx2_sssubv16hi3_mask */
    7565       209977 :     case 7569:  /* *avx2_usaddv16hi3_mask */
    7566       209977 :     case 7567:  /* *avx2_ssaddv16hi3_mask */
    7567       209977 :     case 7565:  /* *avx512bw_ussubv32hi3_mask */
    7568       209977 :     case 7563:  /* *avx512bw_sssubv32hi3_mask */
    7569       209977 :     case 7561:  /* *avx512bw_usaddv32hi3_mask */
    7570       209977 :     case 7559:  /* *avx512bw_ssaddv32hi3_mask */
    7571       209977 :     case 7557:  /* *sse2_ussubv16qi3_mask */
    7572       209977 :     case 7555:  /* *sse2_sssubv16qi3_mask */
    7573       209977 :     case 7553:  /* *sse2_usaddv16qi3_mask */
    7574       209977 :     case 7551:  /* *sse2_ssaddv16qi3_mask */
    7575       209977 :     case 7549:  /* *avx2_ussubv32qi3_mask */
    7576       209977 :     case 7547:  /* *avx2_sssubv32qi3_mask */
    7577       209977 :     case 7545:  /* *avx2_usaddv32qi3_mask */
    7578       209977 :     case 7543:  /* *avx2_ssaddv32qi3_mask */
    7579       209977 :     case 7541:  /* *avx512bw_ussubv64qi3_mask */
    7580       209977 :     case 7539:  /* *avx512bw_sssubv64qi3_mask */
    7581       209977 :     case 7537:  /* *avx512bw_usaddv64qi3_mask */
    7582       209977 :     case 7535:  /* *avx512bw_ssaddv64qi3_mask */
    7583       209977 :     case 7533:  /* *subv8hi3_mask */
    7584       209977 :     case 7532:  /* *addv8hi3_mask */
    7585       209977 :     case 7531:  /* *subv16hi3_mask */
    7586       209977 :     case 7530:  /* *addv16hi3_mask */
    7587       209977 :     case 7529:  /* *subv32hi3_mask */
    7588       209977 :     case 7528:  /* *addv32hi3_mask */
    7589       209977 :     case 7527:  /* *subv32qi3_mask */
    7590       209977 :     case 7526:  /* *addv32qi3_mask */
    7591       209977 :     case 7525:  /* *subv16qi3_mask */
    7592       209977 :     case 7524:  /* *addv16qi3_mask */
    7593       209977 :     case 7523:  /* *subv64qi3_mask */
    7594       209977 :     case 7522:  /* *addv64qi3_mask */
    7595       209977 :     case 7521:  /* *subv2di3_mask */
    7596       209977 :     case 7520:  /* *addv2di3_mask */
    7597       209977 :     case 7519:  /* *subv4di3_mask */
    7598       209977 :     case 7518:  /* *addv4di3_mask */
    7599       209977 :     case 7517:  /* *subv8di3_mask */
    7600       209977 :     case 7516:  /* *addv8di3_mask */
    7601       209977 :     case 7515:  /* *subv4si3_mask */
    7602       209977 :     case 7514:  /* *addv4si3_mask */
    7603       209977 :     case 7513:  /* *subv8si3_mask */
    7604       209977 :     case 7512:  /* *addv8si3_mask */
    7605       209977 :     case 7511:  /* *subv16si3_mask */
    7606       209977 :     case 7510:  /* *addv16si3_mask */
    7607       209977 :     case 3823:  /* *xorv8df3_mask */
    7608       209977 :     case 3821:  /* *iorv8df3_mask */
    7609       209977 :     case 3819:  /* *andv8df3_mask */
    7610       209977 :     case 3817:  /* *xorv16sf3_mask */
    7611       209977 :     case 3815:  /* *iorv16sf3_mask */
    7612       209977 :     case 3813:  /* *andv16sf3_mask */
    7613       209977 :     case 3805:  /* *xorv2df3_mask */
    7614       209977 :     case 3803:  /* *iorv2df3_mask */
    7615       209977 :     case 3801:  /* *andv2df3_mask */
    7616       209977 :     case 3799:  /* *xorv4df3_mask */
    7617       209977 :     case 3797:  /* *iorv4df3_mask */
    7618       209977 :     case 3795:  /* *andv4df3_mask */
    7619       209977 :     case 3793:  /* *xorv4sf3_mask */
    7620       209977 :     case 3791:  /* *iorv4sf3_mask */
    7621       209977 :     case 3789:  /* *andv4sf3_mask */
    7622       209977 :     case 3787:  /* *xorv8sf3_mask */
    7623       209977 :     case 3785:  /* *iorv8sf3_mask */
    7624       209977 :     case 3783:  /* *andv8sf3_mask */
    7625       209977 :     case 3083:  /* *sminv2df3_mask */
    7626       209977 :     case 3081:  /* *smaxv2df3_mask */
    7627       209977 :     case 3079:  /* *sminv4df3_mask */
    7628       209977 :     case 3077:  /* *smaxv4df3_mask */
    7629       209977 :     case 3074:  /* *sminv8df3_mask */
    7630       209977 :     case 3070:  /* *smaxv8df3_mask */
    7631       209977 :     case 3067:  /* *sminv4sf3_mask */
    7632       209977 :     case 3065:  /* *smaxv4sf3_mask */
    7633       209977 :     case 3063:  /* *sminv8sf3_mask */
    7634       209977 :     case 3061:  /* *smaxv8sf3_mask */
    7635       209977 :     case 3058:  /* *sminv16sf3_mask */
    7636       209977 :     case 3054:  /* *smaxv16sf3_mask */
    7637       209977 :     case 3051:  /* *sminv8hf3_mask */
    7638       209977 :     case 3049:  /* *smaxv8hf3_mask */
    7639       209977 :     case 3047:  /* *sminv16hf3_mask */
    7640       209977 :     case 3045:  /* *smaxv16hf3_mask */
    7641       209977 :     case 3042:  /* *sminv32hf3_mask */
    7642       209977 :     case 3038:  /* *smaxv32hf3_mask */
    7643       209977 :     case 2928:  /* sse2_divv2df3_mask */
    7644       209977 :     case 2926:  /* avx_divv4df3_mask */
    7645       209977 :     case 2923:  /* avx512f_divv8df3_mask */
    7646       209977 :     case 2920:  /* sse_divv4sf3_mask */
    7647       209977 :     case 2918:  /* avx_divv8sf3_mask */
    7648       209977 :     case 2915:  /* avx512f_divv16sf3_mask */
    7649       209977 :     case 2912:  /* avx512fp16_divv8hf3_mask */
    7650       209977 :     case 2910:  /* avx512fp16_divv16hf3_mask */
    7651       209977 :     case 2907:  /* avx512fp16_divv32hf3_mask */
    7652       209977 :     case 2873:  /* *mulv2df3_mask */
    7653       209977 :     case 2869:  /* *mulv4df3_mask */
    7654       209977 :     case 2865:  /* *mulv8df3_mask */
    7655       209977 :     case 2861:  /* *mulv4sf3_mask */
    7656       209977 :     case 2857:  /* *mulv8sf3_mask */
    7657       209977 :     case 2853:  /* *mulv16sf3_mask */
    7658       209977 :     case 2849:  /* *mulv8hf3_mask */
    7659       209977 :     case 2845:  /* *mulv16hf3_mask */
    7660       209977 :     case 2841:  /* *mulv32hf3_mask */
    7661       209977 :     case 2807:  /* *subv2df3_mask */
    7662       209977 :     case 2803:  /* *addv2df3_mask */
    7663       209977 :     case 2799:  /* *subv4df3_mask */
    7664       209977 :     case 2795:  /* *addv4df3_mask */
    7665       209977 :     case 2791:  /* *subv8df3_mask */
    7666       209977 :     case 2787:  /* *addv8df3_mask */
    7667       209977 :     case 2783:  /* *subv4sf3_mask */
    7668       209977 :     case 2779:  /* *addv4sf3_mask */
    7669       209977 :     case 2775:  /* *subv8sf3_mask */
    7670       209977 :     case 2771:  /* *addv8sf3_mask */
    7671       209977 :     case 2767:  /* *subv16sf3_mask */
    7672       209977 :     case 2763:  /* *addv16sf3_mask */
    7673       209977 :     case 2759:  /* *subv8hf3_mask */
    7674       209977 :     case 2755:  /* *addv8hf3_mask */
    7675       209977 :     case 2751:  /* *subv16hf3_mask */
    7676       209977 :     case 2747:  /* *addv16hf3_mask */
    7677       209977 :     case 2743:  /* *subv32hf3_mask */
    7678       209977 :     case 2739:  /* *addv32hf3_mask */
    7679       209977 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    7680       209977 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    7681       209977 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    7682       209977 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    7683       209977 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (pat, 1), 2));
    7684       209977 :       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        15448 :     case 2706:  /* kunpckdi */
    7729        15448 :     case 2705:  /* kunpcksi */
    7730        15448 :     case 2704:  /* kunpckhi */
    7731        15448 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    7732        15448 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
    7733        15448 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
    7734        15448 :       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       137634 :     case 11043:  /* avx512bmm_vbitrevb_v32qi_mask */
    7853       137634 :     case 11042:  /* avx512bmm_vbitrevb_v16qi_mask */
    7854       137634 :     case 11041:  /* avx512bmm_vbitrevb_v64qi_mask */
    7855       137634 :     case 11036:  /* avx10_2_vmovrsqv2di_mask */
    7856       137634 :     case 11034:  /* avx10_2_vmovrsqv4di_mask */
    7857       137634 :     case 11032:  /* avx10_2_vmovrsqv8di_mask */
    7858       137634 :     case 11030:  /* avx10_2_vmovrsdv4si_mask */
    7859       137634 :     case 11028:  /* avx10_2_vmovrsdv8si_mask */
    7860       137634 :     case 11026:  /* avx10_2_vmovrsdv16si_mask */
    7861       137634 :     case 11024:  /* avx10_2_vmovrswv8hi_mask */
    7862       137634 :     case 11022:  /* avx10_2_vmovrswv16hi_mask */
    7863       137634 :     case 11020:  /* avx10_2_vmovrswv32hi_mask */
    7864       137634 :     case 11018:  /* avx10_2_vmovrsbv16qi_mask */
    7865       137634 :     case 11016:  /* avx10_2_vmovrsbv32qi_mask */
    7866       137634 :     case 11014:  /* avx10_2_vmovrsbv64qi_mask */
    7867       137634 :     case 10942:  /* avx10_2_vcvttps2uqqsv2di_mask */
    7868       137634 :     case 10940:  /* avx10_2_vcvttps2qqsv2di_mask */
    7869       137634 :     case 10938:  /* avx10_2_vcvttps2uqqsv4di_mask */
    7870       137634 :     case 10936:  /* avx10_2_vcvttps2qqsv4di_mask */
    7871       137634 :     case 10933:  /* avx10_2_vcvttps2uqqsv8di_mask */
    7872       137634 :     case 10929:  /* avx10_2_vcvttps2qqsv8di_mask */
    7873       137634 :     case 10926:  /* avx10_2_vcvttpd2uqqsv2df_mask */
    7874       137634 :     case 10924:  /* avx10_2_vcvttpd2qqsv2df_mask */
    7875       137634 :     case 10922:  /* avx10_2_vcvttpd2uqqsv4df_mask */
    7876       137634 :     case 10920:  /* avx10_2_vcvttpd2qqsv4df_mask */
    7877       137634 :     case 10917:  /* avx10_2_vcvttpd2uqqsv8df_mask */
    7878       137634 :     case 10913:  /* avx10_2_vcvttpd2qqsv8df_mask */
    7879       137634 :     case 10910:  /* avx10_2_vcvttpd2udqsv2df_mask */
    7880       137634 :     case 10908:  /* avx10_2_vcvttpd2dqsv2df_mask */
    7881       137634 :     case 10906:  /* avx10_2_vcvttpd2udqsv4df_mask */
    7882       137634 :     case 10904:  /* avx10_2_vcvttpd2dqsv4df_mask */
    7883       137634 :     case 10901:  /* avx10_2_vcvttpd2udqsv8df_mask */
    7884       137634 :     case 10897:  /* avx10_2_vcvttpd2dqsv8df_mask */
    7885       137634 :     case 10894:  /* avx10_2_vcvttps2udqsv4sf_mask */
    7886       137634 :     case 10892:  /* avx10_2_vcvttps2dqsv4sf_mask */
    7887       137634 :     case 10890:  /* avx10_2_vcvttps2udqsv8sf_mask */
    7888       137634 :     case 10888:  /* avx10_2_vcvttps2dqsv8sf_mask */
    7889       137634 :     case 10885:  /* avx10_2_vcvttps2udqsv16sf_mask */
    7890       137634 :     case 10881:  /* avx10_2_vcvttps2dqsv16sf_mask */
    7891       137634 :     case 10878:  /* avx10_2_cvttps2iubsv4sf_mask */
    7892       137634 :     case 10876:  /* avx10_2_cvttps2ibsv4sf_mask */
    7893       137634 :     case 10874:  /* avx10_2_cvttps2iubsv8sf_mask */
    7894       137634 :     case 10872:  /* avx10_2_cvttps2ibsv8sf_mask */
    7895       137634 :     case 10869:  /* avx10_2_cvttps2iubsv16sf_mask */
    7896       137634 :     case 10865:  /* avx10_2_cvttps2ibsv16sf_mask */
    7897       137634 :     case 10862:  /* avx10_2_cvtps2iubsv4sf_mask */
    7898       137634 :     case 10860:  /* avx10_2_cvtps2ibsv4sf_mask */
    7899       137634 :     case 10858:  /* avx10_2_cvtps2iubsv8sf_mask */
    7900       137634 :     case 10856:  /* avx10_2_cvtps2ibsv8sf_mask */
    7901       137634 :     case 10853:  /* avx10_2_cvtps2iubsv16sf_mask */
    7902       137634 :     case 10849:  /* avx10_2_cvtps2ibsv16sf_mask */
    7903       137634 :     case 10846:  /* avx10_2_cvttph2iubsv8hf_mask */
    7904       137634 :     case 10844:  /* avx10_2_cvttph2ibsv8hf_mask */
    7905       137634 :     case 10842:  /* avx10_2_cvttph2iubsv16hf_mask */
    7906       137634 :     case 10840:  /* avx10_2_cvttph2ibsv16hf_mask */
    7907       137634 :     case 10837:  /* avx10_2_cvttph2iubsv32hf_mask */
    7908       137634 :     case 10833:  /* avx10_2_cvttph2ibsv32hf_mask */
    7909       137634 :     case 10830:  /* avx10_2_cvtph2iubsv8hf_mask */
    7910       137634 :     case 10828:  /* avx10_2_cvtph2ibsv8hf_mask */
    7911       137634 :     case 10826:  /* avx10_2_cvtph2iubsv16hf_mask */
    7912       137634 :     case 10824:  /* avx10_2_cvtph2ibsv16hf_mask */
    7913       137634 :     case 10821:  /* avx10_2_cvtph2iubsv32hf_mask */
    7914       137634 :     case 10817:  /* avx10_2_cvtph2ibsv32hf_mask */
    7915       137634 :     case 10814:  /* avx10_2_cvttbf162iubsv8bf_mask */
    7916       137634 :     case 10812:  /* avx10_2_cvttbf162ibsv8bf_mask */
    7917       137634 :     case 10810:  /* avx10_2_cvtbf162iubsv8bf_mask */
    7918       137634 :     case 10808:  /* avx10_2_cvtbf162ibsv8bf_mask */
    7919       137634 :     case 10806:  /* avx10_2_cvttbf162iubsv16bf_mask */
    7920       137634 :     case 10804:  /* avx10_2_cvttbf162ibsv16bf_mask */
    7921       137634 :     case 10802:  /* avx10_2_cvtbf162iubsv16bf_mask */
    7922       137634 :     case 10800:  /* avx10_2_cvtbf162ibsv16bf_mask */
    7923       137634 :     case 10798:  /* avx10_2_cvttbf162iubsv32bf_mask */
    7924       137634 :     case 10796:  /* avx10_2_cvttbf162ibsv32bf_mask */
    7925       137634 :     case 10794:  /* avx10_2_cvtbf162iubsv32bf_mask */
    7926       137634 :     case 10792:  /* avx10_2_cvtbf162ibsv32bf_mask */
    7927       137634 :     case 10760:  /* avx10_2_getexpbf16_v8bf_mask */
    7928       137634 :     case 10758:  /* avx10_2_getexpbf16_v16bf_mask */
    7929       137634 :     case 10756:  /* avx10_2_getexpbf16_v32bf_mask */
    7930       137634 :     case 10754:  /* avx10_2_rcpbf16_v8bf_mask */
    7931       137634 :     case 10752:  /* avx10_2_rcpbf16_v16bf_mask */
    7932       137634 :     case 10750:  /* avx10_2_rcpbf16_v32bf_mask */
    7933       137634 :     case 10742:  /* avx10_2_rsqrtbf16_v8bf_mask */
    7934       137634 :     case 10740:  /* avx10_2_rsqrtbf16_v16bf_mask */
    7935       137634 :     case 10738:  /* avx10_2_rsqrtbf16_v32bf_mask */
    7936       137634 :     case 10583:  /* vcvthf82phv8hf_mask */
    7937       137634 :     case 10581:  /* vcvthf82phv16hf_mask */
    7938       137634 :     case 10579:  /* vcvthf82phv32hf_mask */
    7939       137634 :     case 10577:  /* vcvtph2hf8sv32hf_mask */
    7940       137634 :     case 10575:  /* vcvtph2hf8v32hf_mask */
    7941       137634 :     case 10573:  /* vcvtph2bf8sv32hf_mask */
    7942       137634 :     case 10571:  /* vcvtph2bf8v32hf_mask */
    7943       137634 :     case 10569:  /* vcvtph2hf8sv16hf_mask */
    7944       137634 :     case 10567:  /* vcvtph2hf8v16hf_mask */
    7945       137634 :     case 10565:  /* vcvtph2bf8sv16hf_mask */
    7946       137634 :     case 10563:  /* vcvtph2bf8v16hf_mask */
    7947       137634 :     case 10144:  /* conflictv2di_mask */
    7948       137634 :     case 10142:  /* conflictv4di_mask */
    7949       137634 :     case 10140:  /* conflictv8di_mask */
    7950       137634 :     case 10138:  /* conflictv4si_mask */
    7951       137634 :     case 10136:  /* conflictv8si_mask */
    7952       137634 :     case 10134:  /* conflictv16si_mask */
    7953       137634 :     case 9716:  /* avx512f_vcvtph2ps512_mask */
    7954       137634 :     case 9713:  /* vcvtph2ps256_mask */
    7955       137634 :     case 9711:  /* *vcvtph2ps_load_mask */
    7956       137634 :     case 7077:  /* avx512vl_getexpv2df_mask */
    7957       137634 :     case 7073:  /* avx512vl_getexpv4df_mask */
    7958       137634 :     case 7069:  /* avx512f_getexpv8df_mask */
    7959       137634 :     case 7065:  /* avx512vl_getexpv4sf_mask */
    7960       137634 :     case 7061:  /* avx512vl_getexpv8sf_mask */
    7961       137634 :     case 7057:  /* avx512f_getexpv16sf_mask */
    7962       137634 :     case 7053:  /* avx512fp16_getexpv8hf_mask */
    7963       137634 :     case 7049:  /* avx512vl_getexpv16hf_mask */
    7964       137634 :     case 7045:  /* avx512bw_getexpv32hf_mask */
    7965       137634 :     case 5164:  /* unspec_sse2_cvttpd2dq_mask */
    7966       137634 :     case 5158:  /* unspec_fixuns_truncv4sfv4si2_mask */
    7967       137634 :     case 5156:  /* unspec_fixuns_truncv8sfv8si2_mask */
    7968       137634 :     case 5150:  /* unspec_avx512dq_fixuns_truncv2sfv2di2_mask */
    7969       137634 :     case 5148:  /* unspec_avx512dq_fix_truncv2sfv2di2_mask */
    7970       137634 :     case 5134:  /* unspec_fixuns_truncv4sfv4di2_mask */
    7971       137634 :     case 5132:  /* unspec_fix_truncv4sfv4di2_mask */
    7972       137634 :     case 5129:  /* unspec_fixuns_truncv8sfv8di2_mask */
    7973       137634 :     case 5125:  /* unspec_fix_truncv8sfv8di2_mask */
    7974       137634 :     case 5122:  /* fixuns_notruncv2dfv2di2_mask */
    7975       137634 :     case 5120:  /* fixuns_notruncv4dfv4di2_mask */
    7976       137634 :     case 5117:  /* fixuns_notruncv8dfv8di2_mask */
    7977       137634 :     case 5114:  /* fix_notruncv2dfv2di2_mask */
    7978       137634 :     case 5112:  /* fix_notruncv4dfv4di2_mask */
    7979       137634 :     case 5109:  /* fix_notruncv8dfv8di2_mask */
    7980       137634 :     case 5090:  /* unspec_fixuns_truncv2dfv2di2_mask */
    7981       137634 :     case 5088:  /* unspec_fix_truncv2dfv2di2_mask */
    7982       137634 :     case 5086:  /* unspec_fixuns_truncv4dfv4di2_mask */
    7983       137634 :     case 5084:  /* unspec_fix_truncv4dfv4di2_mask */
    7984       137634 :     case 5081:  /* unspec_fixuns_truncv8dfv8di2_mask */
    7985       137634 :     case 5077:  /* unspec_fix_truncv8dfv8di2_mask */
    7986       137634 :     case 5072:  /* unspec_fixuns_truncv4dfv4si2_mask */
    7987       137634 :     case 5068:  /* unspec_fix_truncv4dfv4si2_mask */
    7988       137634 :     case 5052:  /* unspec_fixuns_truncv8dfv8si2_mask */
    7989       137634 :     case 5048:  /* unspec_fix_truncv8dfv8si2_mask */
    7990       137634 :     case 5041:  /* fixuns_notruncv4dfv4si2_mask */
    7991       137634 :     case 5037:  /* fixuns_notruncv8dfv8si2_mask */
    7992       137634 :     case 5030:  /* avx_cvtpd2dq256_mask */
    7993       137634 :     case 5027:  /* avx512f_cvtpd2dq512_mask */
    7994       137634 :     case 4918:  /* unspec_fix_truncv4sfv4si2_mask */
    7995       137634 :     case 4914:  /* unspec_fix_truncv8sfv8si2_mask */
    7996       137634 :     case 4903:  /* unspec_fixuns_truncv16sfv16si2_mask */
    7997       137634 :     case 4899:  /* unspec_fix_truncv16sfv16si2_mask */
    7998       137634 :     case 4894:  /* avx512dq_cvtps2uqqv4di_mask */
    7999       137634 :     case 4891:  /* avx512dq_cvtps2uqqv8di_mask */
    8000       137634 :     case 4886:  /* avx512dq_cvtps2qqv4di_mask */
    8001       137634 :     case 4883:  /* avx512dq_cvtps2qqv8di_mask */
    8002       137634 :     case 4879:  /* avx512vl_fixuns_notruncv4sfv4si_mask */
    8003       137634 :     case 4875:  /* avx512vl_fixuns_notruncv8sfv8si_mask */
    8004       137634 :     case 4871:  /* avx512f_fixuns_notruncv16sfv16si_mask */
    8005       137634 :     case 4867:  /* avx512f_fix_notruncv16sfv16si_mask */
    8006       137634 :     case 4864:  /* sse2_fix_notruncv4sfv4si_mask */
    8007       137634 :     case 4862:  /* avx_fix_notruncv8sfv8si_mask */
    8008       137634 :     case 4714:  /* unspec_avx512fp16_fixuns_truncv2di2_mask */
    8009       137634 :     case 4712:  /* unspec_avx512fp16_fix_truncv2di2_mask */
    8010       137634 :     case 4694:  /* unspec_avx512fp16_fixuns_truncv4di2_mask */
    8011       137634 :     case 4692:  /* unspec_avx512fp16_fix_truncv4di2_mask */
    8012       137634 :     case 4690:  /* unspec_avx512fp16_fixuns_truncv4si2_mask */
    8013       137634 :     case 4688:  /* unspec_avx512fp16_fix_truncv4si2_mask */
    8014       137634 :     case 4637:  /* unspec_avx512fp16_fixuns_truncv8di2_mask */
    8015       137634 :     case 4633:  /* unspec_avx512fp16_fix_truncv8di2_mask */
    8016       137634 :     case 4629:  /* unspec_avx512fp16_fixuns_truncv16si2_mask */
    8017       137634 :     case 4625:  /* unspec_avx512fp16_fix_truncv16si2_mask */
    8018       137634 :     case 4621:  /* unspec_avx512fp16_fixuns_truncv8si2_mask */
    8019       137634 :     case 4617:  /* unspec_avx512fp16_fix_truncv8si2_mask */
    8020       137634 :     case 4613:  /* unspec_avx512fp16_fixuns_truncv32hi2_mask */
    8021       137634 :     case 4609:  /* unspec_avx512fp16_fix_truncv32hi2_mask */
    8022       137634 :     case 4605:  /* unspec_avx512fp16_fixuns_truncv16hi2_mask */
    8023       137634 :     case 4601:  /* unspec_avx512fp16_fix_truncv16hi2_mask */
    8024       137634 :     case 4597:  /* unspec_avx512fp16_fixuns_truncv8hi2_mask */
    8025       137634 :     case 4593:  /* unspec_avx512fp16_fix_truncv8hi2_mask */
    8026       137634 :     case 4503:  /* avx512fp16_vcvtph2qq_v2di_mask */
    8027       137634 :     case 4499:  /* avx512fp16_vcvtph2uqq_v2di_mask */
    8028       137634 :     case 4495:  /* avx512fp16_vcvtph2dq_v4si_mask */
    8029       137634 :     case 4491:  /* avx512fp16_vcvtph2udq_v4si_mask */
    8030       137634 :     case 4487:  /* avx512fp16_vcvtph2w_v8hi_mask */
    8031       137634 :     case 4483:  /* avx512fp16_vcvtph2uw_v8hi_mask */
    8032       137634 :     case 4479:  /* avx512fp16_vcvtph2qq_v4di_mask */
    8033       137634 :     case 4475:  /* avx512fp16_vcvtph2uqq_v4di_mask */
    8034       137634 :     case 4471:  /* avx512fp16_vcvtph2dq_v8si_mask */
    8035       137634 :     case 4467:  /* avx512fp16_vcvtph2udq_v8si_mask */
    8036       137634 :     case 4463:  /* avx512fp16_vcvtph2w_v16hi_mask */
    8037       137634 :     case 4459:  /* avx512fp16_vcvtph2uw_v16hi_mask */
    8038       137634 :     case 4455:  /* avx512fp16_vcvtph2qq_v8di_mask */
    8039       137634 :     case 4451:  /* avx512fp16_vcvtph2uqq_v8di_mask */
    8040       137634 :     case 4447:  /* avx512fp16_vcvtph2dq_v16si_mask */
    8041       137634 :     case 4443:  /* avx512fp16_vcvtph2udq_v16si_mask */
    8042       137634 :     case 4439:  /* avx512fp16_vcvtph2w_v32hi_mask */
    8043       137634 :     case 4435:  /* avx512fp16_vcvtph2uw_v32hi_mask */
    8044       137634 :     case 3025:  /* rsqrt14v2df_mask */
    8045       137634 :     case 3023:  /* rsqrt14v4df_mask */
    8046       137634 :     case 3021:  /* rsqrt14v8df_mask */
    8047       137634 :     case 3019:  /* rsqrt14v4sf_mask */
    8048       137634 :     case 3017:  /* rsqrt14v8sf_mask */
    8049       137634 :     case 3015:  /* rsqrt14v16sf_mask */
    8050       137634 :     case 3013:  /* avx512fp16_rsqrtv8hf2_mask */
    8051       137634 :     case 3011:  /* avx512fp16_rsqrtv16hf2_mask */
    8052       137634 :     case 3009:  /* avx512fp16_rsqrtv32hf2_mask */
    8053       137634 :     case 2953:  /* rcp14v2df_mask */
    8054       137634 :     case 2951:  /* rcp14v4df_mask */
    8055       137634 :     case 2949:  /* rcp14v8df_mask */
    8056       137634 :     case 2947:  /* rcp14v4sf_mask */
    8057       137634 :     case 2945:  /* rcp14v8sf_mask */
    8058       137634 :     case 2943:  /* rcp14v16sf_mask */
    8059       137634 :     case 2938:  /* avx512fp16_rcpv8hf2_mask */
    8060       137634 :     case 2936:  /* avx512fp16_rcpv16hf2_mask */
    8061       137634 :     case 2934:  /* avx512fp16_rcpv32hf2_mask */
    8062       137634 :     case 2538:  /* *avx512vl_loadv8bf_mask */
    8063       137634 :     case 2537:  /* *avx512vl_loadv16bf_mask */
    8064       137634 :     case 2536:  /* *avx512bw_loadv32bf_mask */
    8065       137634 :     case 2535:  /* *avx512fp16_loadv8hf_mask */
    8066       137634 :     case 2534:  /* *avx512vl_loadv16hf_mask */
    8067       137634 :     case 2533:  /* *avx512bw_loadv32hf_mask */
    8068       137634 :     case 2532:  /* *avx512vl_loadv8hi_mask */
    8069       137634 :     case 2531:  /* *avx512vl_loadv16hi_mask */
    8070       137634 :     case 2530:  /* *avx512bw_loadv32hi_mask */
    8071       137634 :     case 2529:  /* *avx512vl_loadv32qi_mask */
    8072       137634 :     case 2528:  /* *avx512vl_loadv16qi_mask */
    8073       137634 :     case 2527:  /* *avx512bw_loadv64qi_mask */
    8074       137634 :     case 2508:  /* *avx512vl_loadv2df_mask */
    8075       137634 :     case 2507:  /* *avx512vl_loadv4df_mask */
    8076       137634 :     case 2506:  /* *avx512f_loadv8df_mask */
    8077       137634 :     case 2505:  /* *avx512vl_loadv4sf_mask */
    8078       137634 :     case 2504:  /* *avx512vl_loadv8sf_mask */
    8079       137634 :     case 2503:  /* *avx512f_loadv16sf_mask */
    8080       137634 :     case 2502:  /* *avx512vl_loadv2di_mask */
    8081       137634 :     case 2501:  /* *avx512vl_loadv4di_mask */
    8082       137634 :     case 2500:  /* *avx512f_loadv8di_mask */
    8083       137634 :     case 2499:  /* *avx512vl_loadv4si_mask */
    8084       137634 :     case 2498:  /* *avx512vl_loadv8si_mask */
    8085       137634 :     case 2497:  /* *avx512f_loadv16si_mask */
    8086       137634 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8087       137634 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XEXP (pat, 1), 0), 0, 0));
    8088       137634 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    8089       137634 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    8090       137634 :       break;
    8091              : 
    8092         7236 :     case 2496:  /* *vmovv2df_constm1_pternlog_false_dep */
    8093         7236 :     case 2495:  /* *vmovv4df_constm1_pternlog_false_dep */
    8094         7236 :     case 2494:  /* *vmovv8df_constm1_pternlog_false_dep */
    8095         7236 :     case 2493:  /* *vmovv4sf_constm1_pternlog_false_dep */
    8096         7236 :     case 2492:  /* *vmovv8sf_constm1_pternlog_false_dep */
    8097         7236 :     case 2491:  /* *vmovv16sf_constm1_pternlog_false_dep */
    8098         7236 :     case 2490:  /* *vmovv8bf_constm1_pternlog_false_dep */
    8099         7236 :     case 2489:  /* *vmovv16bf_constm1_pternlog_false_dep */
    8100         7236 :     case 2488:  /* *vmovv32bf_constm1_pternlog_false_dep */
    8101         7236 :     case 2487:  /* *vmovv8hf_constm1_pternlog_false_dep */
    8102         7236 :     case 2486:  /* *vmovv16hf_constm1_pternlog_false_dep */
    8103         7236 :     case 2485:  /* *vmovv32hf_constm1_pternlog_false_dep */
    8104         7236 :     case 2484:  /* *vmovv1ti_constm1_pternlog_false_dep */
    8105         7236 :     case 2483:  /* *vmovv2ti_constm1_pternlog_false_dep */
    8106         7236 :     case 2482:  /* *vmovv4ti_constm1_pternlog_false_dep */
    8107         7236 :     case 2481:  /* *vmovv2di_constm1_pternlog_false_dep */
    8108         7236 :     case 2480:  /* *vmovv4di_constm1_pternlog_false_dep */
    8109         7236 :     case 2479:  /* *vmovv8di_constm1_pternlog_false_dep */
    8110         7236 :     case 2478:  /* *vmovv4si_constm1_pternlog_false_dep */
    8111         7236 :     case 2477:  /* *vmovv8si_constm1_pternlog_false_dep */
    8112         7236 :     case 2476:  /* *vmovv16si_constm1_pternlog_false_dep */
    8113         7236 :     case 2475:  /* *vmovv8hi_constm1_pternlog_false_dep */
    8114         7236 :     case 2474:  /* *vmovv16hi_constm1_pternlog_false_dep */
    8115         7236 :     case 2473:  /* *vmovv32hi_constm1_pternlog_false_dep */
    8116         7236 :     case 2472:  /* *vmovv16qi_constm1_pternlog_false_dep */
    8117         7236 :     case 2471:  /* *vmovv32qi_constm1_pternlog_false_dep */
    8118         7236 :     case 2470:  /* *vmovv64qi_constm1_pternlog_false_dep */
    8119         7236 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8120         7236 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 1));
    8121         7236 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    8122         7236 :       break;
    8123              : 
    8124          570 :     case 8612:  /* *sse2_maskmovdqu */
    8125          570 :     case 8611:  /* *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       106607 :     case 7233:  /* sse2_shufpd_v2df */
    8136       106607 :     case 7232:  /* sse2_shufpd_v2di */
    8137       106607 :     case 2418:  /* *punpckwd */
    8138       106607 :     case 2417:  /* *punpckwd */
    8139       106607 :     case 2416:  /* *punpckwd */
    8140       106607 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8141       106607 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    8142       106607 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    8143       106607 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    8144       106607 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    8145       106607 :       break;
    8146              : 
    8147        24049 :     case 5340:  /* *avx512dq_vextracti64x2_1 */
    8148        24049 :     case 5339:  /* *avx512dq_vextractf64x2_1 */
    8149        24049 :     case 2421:  /* *pshufwv2hi_1 */
    8150        24049 :     case 2420:  /* *pshufwv2bf_1 */
    8151        24049 :     case 2419:  /* *pshufwv2hf_1 */
    8152        24049 :     case 2383:  /* *mmx_pshufd_1 */
    8153        24049 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8154        24049 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    8155        24049 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    8156        24049 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    8157        24049 :       break;
    8158              : 
    8159       786323 :     case 9225:  /* avx2_permv4df_1 */
    8160       786323 :     case 9223:  /* avx2_permv4di_1 */
    8161       786323 :     case 8479:  /* sse2_pshuflw_1 */
    8162       786323 :     case 8473:  /* sse2_pshufd_1 */
    8163       786323 :     case 5344:  /* *avx512f_vextracti32x4_1 */
    8164       786323 :     case 5343:  /* *avx512f_vextractf32x4_1 */
    8165       786323 :     case 2382:  /* mmx_pshufwv4hi_1 */
    8166       786323 :     case 2381:  /* mmx_pshufwv4bf_1 */
    8167       786323 :     case 2380:  /* mmx_pshufwv4hf_1 */
    8168       786323 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8169       786323 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    8170       786323 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    8171       786323 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 1));
    8172       786323 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 2));
    8173       786323 :       ro[5] = *(ro_loc[5] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 3));
    8174       786323 :       break;
    8175              : 
    8176       210783 :     case 8507:  /* *vec_extractv4si_zext_mem */
    8177       210783 :     case 8505:  /* *vec_extractv4si_zext */
    8178       210783 :     case 8496:  /* *vec_extractv16qi_zext */
    8179       210783 :     case 8495:  /* *vec_extractv8hi_zext */
    8180       210783 :     case 8494:  /* *vec_extractv8hi_zext */
    8181       210783 :     case 8493:  /* *vec_extractv16qi_zext */
    8182       210783 :     case 8492:  /* *vec_extractv16qi_zext */
    8183       210783 :     case 2415:  /* *pextrb_zext */
    8184       210783 :     case 2414:  /* *pextrb_zext */
    8185       210783 :     case 2413:  /* *pextrb_zext */
    8186       210783 :     case 2411:  /* *pextrw_zext */
    8187       210783 :     case 2410:  /* *pextrw_zext */
    8188       210783 :     case 2402:  /* *vec_extractv2si_zext_mem */
    8189       210783 :     case 2377:  /* *mmx_pextrb_zext */
    8190       210783 :     case 2376:  /* *mmx_pextrb_zext */
    8191       210783 :     case 2375:  /* *mmx_pextrb_zext */
    8192       210783 :     case 2373:  /* *mmx_pextrw_zext */
    8193       210783 :     case 2372:  /* *mmx_pextrw_zext */
    8194       210783 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8195       210783 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    8196       210783 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (XEXP (pat, 1), 0), 1), 0, 0));
    8197       210783 :       break;
    8198              : 
    8199       225390 :     case 8510:  /* *vec_extractv4ti */
    8200       225390 :     case 8509:  /* *vec_extractv2ti */
    8201       225390 :     case 8506:  /* *vec_extractv4si_mem */
    8202       225390 :     case 8504:  /* *vec_extractv4si */
    8203       225390 :     case 8498:  /* *vec_extractv8hi_mem */
    8204       225390 :     case 8497:  /* *vec_extractv16qi_mem */
    8205       225390 :     case 8491:  /* *vec_extractv8hi */
    8206       225390 :     case 8490:  /* *vec_extractv16qi */
    8207       225390 :     case 7110:  /* *vec_extractv4dfdf_valign */
    8208       225390 :     case 7109:  /* *vec_extractv8dfdf_valign */
    8209       225390 :     case 7108:  /* *vec_extractv8sfsf_valign */
    8210       225390 :     case 7107:  /* *vec_extractv16sfsf_valign */
    8211       225390 :     case 7106:  /* *vec_extractv4didi_valign */
    8212       225390 :     case 7105:  /* *vec_extractv8didi_valign */
    8213       225390 :     case 7104:  /* *vec_extractv8sisi_valign */
    8214       225390 :     case 7103:  /* *vec_extractv16sisi_valign */
    8215       225390 :     case 5400:  /* *vec_extractbf */
    8216       225390 :     case 5399:  /* *vec_extracthf */
    8217       225390 :     case 5336:  /* *vec_extractv4sf_mem */
    8218       225390 :     case 5335:  /* *sse4_1_extractps */
    8219       225390 :     case 2412:  /* *pextrb */
    8220       225390 :     case 2409:  /* *pextrwv2bf */
    8221       225390 :     case 2408:  /* *pextrwv2hf */
    8222       225390 :     case 2407:  /* *pextrw */
    8223       225390 :     case 2374:  /* *mmx_pextrb */
    8224       225390 :     case 2371:  /* *mmx_pextrwv4bf */
    8225       225390 :     case 2370:  /* *mmx_pextrwv4hf */
    8226       225390 :     case 2369:  /* *mmx_pextrw */
    8227       225390 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8228       225390 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    8229       225390 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XEXP (pat, 1), 1), 0, 0));
    8230       225390 :       break;
    8231              : 
    8232       175266 :     case 8416:  /* sse4_1_pinsrq */
    8233       175266 :     case 8415:  /* sse4_1_pinsrd */
    8234       175266 :     case 8414:  /* sse2_pinsrbf */
    8235       175266 :     case 8413:  /* sse2_pinsrph */
    8236       175266 :     case 8412:  /* sse2_pinsrw */
    8237       175266 :     case 8411:  /* sse4_1_pinsrb */
    8238       175266 :     case 5322:  /* *vec_setv4sf_sse4_1 */
    8239       175266 :     case 2406:  /* *pinsrb */
    8240       175266 :     case 2405:  /* *pinsrw */
    8241       175266 :     case 2404:  /* *pinsrw */
    8242       175266 :     case 2403:  /* *pinsrw */
    8243       175266 :     case 2368:  /* *mmx_pinsrb */
    8244       175266 :     case 2367:  /* *mmx_pinsrw */
    8245       175266 :     case 2366:  /* *mmx_pinsrw */
    8246       175266 :     case 2365:  /* *mmx_pinsrw */
    8247       175266 :     case 2364:  /* *mmx_pinsrd */
    8248       175266 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8249       175266 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    8250       175266 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    8251       175266 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    8252       175266 :       break;
    8253              : 
    8254          881 :     case 9054:  /* xop_pcmov_v2df */
    8255          881 :     case 9053:  /* xop_pcmov_v4df256 */
    8256          881 :     case 9052:  /* xop_pcmov_v4sf */
    8257          881 :     case 9051:  /* xop_pcmov_v8sf256 */
    8258          881 :     case 9050:  /* xop_pcmov_v8hf */
    8259          881 :     case 9049:  /* xop_pcmov_v16hf256 */
    8260          881 :     case 9048:  /* xop_pcmov_v1ti */
    8261          881 :     case 9047:  /* xop_pcmov_v2ti256 */
    8262          881 :     case 9046:  /* xop_pcmov_v2di */
    8263          881 :     case 9045:  /* xop_pcmov_v4di256 */
    8264          881 :     case 9044:  /* xop_pcmov_v4si */
    8265          881 :     case 9043:  /* xop_pcmov_v8si256 */
    8266          881 :     case 9042:  /* xop_pcmov_v8hi */
    8267          881 :     case 9041:  /* xop_pcmov_v16hi256 */
    8268          881 :     case 9040:  /* xop_pcmov_v16qi */
    8269          881 :     case 9039:  /* 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         7961 :     case 9110:  /* xop_maskcmp_unsv2di3 */
    8311         7961 :     case 9109:  /* xop_maskcmp_unsv4si3 */
    8312         7961 :     case 9108:  /* xop_maskcmp_unsv8hi3 */
    8313         7961 :     case 9107:  /* xop_maskcmp_unsv16qi3 */
    8314         7961 :     case 9106:  /* xop_maskcmpv2di3 */
    8315         7961 :     case 9105:  /* xop_maskcmpv4si3 */
    8316         7961 :     case 9104:  /* xop_maskcmpv8hi3 */
    8317         7961 :     case 9103:  /* xop_maskcmpv16qi3 */
    8318         7961 :     case 2288:  /* *xop_maskcmp_unsv2hi3 */
    8319         7961 :     case 2287:  /* *xop_maskcmp_unsv2qi3 */
    8320         7961 :     case 2286:  /* *xop_maskcmp_unsv4qi3 */
    8321         7961 :     case 2285:  /* *xop_maskcmp_unsv2si3 */
    8322         7961 :     case 2284:  /* *xop_maskcmp_unsv4hi3 */
    8323         7961 :     case 2283:  /* *xop_maskcmp_unsv8qi3 */
    8324         7961 :     case 2282:  /* *xop_maskcmpv2hi3 */
    8325         7961 :     case 2281:  /* *xop_maskcmpv2qi3 */
    8326         7961 :     case 2280:  /* *xop_maskcmpv4qi3 */
    8327         7961 :     case 2279:  /* *xop_maskcmpv2si3 */
    8328         7961 :     case 2278:  /* *xop_maskcmpv4hi3 */
    8329         7961 :     case 2277:  /* *xop_maskcmpv8qi3 */
    8330         7961 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8331         7961 :       ro[1] = *(ro_loc[1] = &XEXP (pat, 1));
    8332         7961 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
    8333         7961 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
    8334         7961 :       break;
    8335              : 
    8336       333734 :     case 7610:  /* *sse4_1_mulv2siv2di3 */
    8337       333734 :     case 7608:  /* *vec_widen_smult_even_v8si */
    8338       333734 :     case 7606:  /* *vec_widen_smult_even_v16si */
    8339       333734 :     case 7604:  /* *vec_widen_umult_even_v4si */
    8340       333734 :     case 7602:  /* *vec_widen_umult_even_v8si */
    8341       333734 :     case 7600:  /* *vec_widen_umult_even_v16si */
    8342       333734 :     case 2215:  /* *sse2_umulv1siv1di3 */
    8343       333734 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8344       333734 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
    8345       333734 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
    8346       333734 :       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 8647:  /* ssse3_pmaddubsw */
    8360        11903 :     case 8646:  /* ssse3_pmaddubsw128 */
    8361        11903 :     case 8637:  /* avx2_pmaddubsw256 */
    8362        11903 :     case 7619:  /* *sse2_pmaddwd */
    8363        11903 :     case 7618:  /* *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 7598:  /* *umulv8hi3_highpart */
    8375        13112 :     case 7596:  /* *smulv8hi3_highpart */
    8376        13112 :     case 7594:  /* *umulv16hi3_highpart */
    8377        13112 :     case 7592:  /* *smulv16hi3_highpart */
    8378        13112 :     case 7590:  /* *umulv32hi3_highpart */
    8379        13112 :     case 7588:  /* *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       251364 :     case 7241:  /* sse2_movsd_v2df */
    8390       251364 :     case 7240:  /* sse2_movsd_v2di */
    8391       251364 :     case 5321:  /* *avx512fp16_movv8bf */
    8392       251364 :     case 5320:  /* *avx512fp16_movv8hf */
    8393       251364 :     case 5319:  /* *avx512fp16_movv8hi */
    8394       251364 :     case 5281:  /* sse_movss_v4sf */
    8395       251364 :     case 5280:  /* sse_movss_v4si */
    8396       251364 :     case 2139:  /* *mmx_movss_v2si */
    8397       251364 :     case 2138:  /* *mmx_movss_v2sf */
    8398       251364 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8399       251364 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    8400       251364 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
    8401       251364 :       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       204396 :     case 8783:  /* avx2_pblenddv4si */
    8411       204396 :     case 8782:  /* avx2_pblenddv8si */
    8412       204396 :     case 8781:  /* *avx2_pblendbf */
    8413       204396 :     case 8780:  /* *avx2_pblendph */
    8414       204396 :     case 8779:  /* *avx2_pblendw */
    8415       204396 :     case 8778:  /* sse4_1_pblendbf */
    8416       204396 :     case 8777:  /* sse4_1_pblendph */
    8417       204396 :     case 8776:  /* sse4_1_pblendw */
    8418       204396 :     case 8714:  /* sse4_1_blendpd */
    8419       204396 :     case 8713:  /* avx_blendpd256 */
    8420       204396 :     case 8712:  /* sse4_1_blendps */
    8421       204396 :     case 8711:  /* avx_blendps256 */
    8422       204396 :     case 2583:  /* avx512vl_blendmv8bf */
    8423       204396 :     case 2582:  /* avx512vl_blendmv16bf */
    8424       204396 :     case 2581:  /* avx512bw_blendmv32bf */
    8425       204396 :     case 2580:  /* avx512fp16_blendmv8hf */
    8426       204396 :     case 2579:  /* avx512vl_blendmv16hf */
    8427       204396 :     case 2578:  /* avx512bw_blendmv32hf */
    8428       204396 :     case 2577:  /* avx512vl_blendmv8hi */
    8429       204396 :     case 2576:  /* avx512vl_blendmv16hi */
    8430       204396 :     case 2575:  /* avx512bw_blendmv32hi */
    8431       204396 :     case 2574:  /* avx512vl_blendmv32qi */
    8432       204396 :     case 2573:  /* avx512vl_blendmv16qi */
    8433       204396 :     case 2572:  /* avx512bw_blendmv64qi */
    8434       204396 :     case 2571:  /* avx512vl_blendmv2df */
    8435       204396 :     case 2570:  /* avx512vl_blendmv4df */
    8436       204396 :     case 2569:  /* avx512f_blendmv8df */
    8437       204396 :     case 2568:  /* avx512vl_blendmv4sf */
    8438       204396 :     case 2567:  /* avx512vl_blendmv8sf */
    8439       204396 :     case 2566:  /* avx512f_blendmv16sf */
    8440       204396 :     case 2565:  /* avx512vl_blendmv2di */
    8441       204396 :     case 2564:  /* avx512vl_blendmv4di */
    8442       204396 :     case 2563:  /* avx512f_blendmv8di */
    8443       204396 :     case 2562:  /* avx512vl_blendmv4si */
    8444       204396 :     case 2561:  /* avx512vl_blendmv8si */
    8445       204396 :     case 2560:  /* avx512f_blendmv16si */
    8446       204396 :     case 2389:  /* *mmx_pblendw32 */
    8447       204396 :     case 2388:  /* *mmx_pblendw32 */
    8448       204396 :     case 2387:  /* *mmx_pblendw32 */
    8449       204396 :     case 2386:  /* *mmx_pblendw64 */
    8450       204396 :     case 2385:  /* *mmx_pblendw64 */
    8451       204396 :     case 2384:  /* *mmx_pblendw64 */
    8452       204396 :     case 2122:  /* *mmx_blendps */
    8453       204396 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8454       204396 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
    8455       204396 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
    8456       204396 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    8457       204396 :       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       372186 :     case 8986:  /* ptesttf2 */
    8526       372186 :     case 8985:  /* *avx_ptestv4df */
    8527       372186 :     case 8984:  /* *avx_ptestv8sf */
    8528       372186 :     case 8983:  /* *avx_ptestv2ti */
    8529       372186 :     case 8982:  /* *avx_ptestv4di */
    8530       372186 :     case 8981:  /* *avx_ptestv8si */
    8531       372186 :     case 8980:  /* *avx_ptestv16hi */
    8532       372186 :     case 8979:  /* *avx_ptestv32qi */
    8533       372186 :     case 8978:  /* *sse4_1_ptestv2df */
    8534       372186 :     case 8977:  /* *sse4_1_ptestv4sf */
    8535       372186 :     case 8976:  /* *sse4_1_ptestv1ti */
    8536       372186 :     case 8975:  /* *sse4_1_ptestv2di */
    8537       372186 :     case 8974:  /* *sse4_1_ptestv4si */
    8538       372186 :     case 8973:  /* *sse4_1_ptestv8hi */
    8539       372186 :     case 8972:  /* *sse4_1_ptestv16qi */
    8540       372186 :     case 8971:  /* avx_vtestpd */
    8541       372186 :     case 8970:  /* avx_vtestpd256 */
    8542       372186 :     case 8969:  /* avx_vtestps */
    8543       372186 :     case 8968:  /* avx_vtestps256 */
    8544       372186 :     case 2679:  /* kortestdi_ccz */
    8545       372186 :     case 2678:  /* kortestsi_ccz */
    8546       372186 :     case 2677:  /* kortesthi_ccz */
    8547       372186 :     case 2676:  /* kortestqi_ccz */
    8548       372186 :     case 2675:  /* kortestdi_ccc */
    8549       372186 :     case 2674:  /* kortestsi_ccc */
    8550       372186 :     case 2673:  /* kortesthi_ccc */
    8551       372186 :     case 2672:  /* kortestqi_ccc */
    8552       372186 :     case 2671:  /* *kortestdi */
    8553       372186 :     case 2670:  /* *kortestsi */
    8554       372186 :     case 2669:  /* *kortesthi */
    8555       372186 :     case 2668:  /* *kortestqi */
    8556       372186 :     case 2667:  /* ktestdi */
    8557       372186 :     case 2666:  /* ktestsi */
    8558       372186 :     case 2665:  /* ktesthi */
    8559       372186 :     case 2664:  /* ktestqi */
    8560       372186 :     case 2049:  /* tpause */
    8561       372186 :     case 2045:  /* umwait */
    8562       372186 :     case 2040:  /* enqcmds_di */
    8563       372186 :     case 2039:  /* enqcmd_di */
    8564       372186 :     case 2038:  /* enqcmds_si */
    8565       372186 :     case 2037:  /* enqcmd_si */
    8566       372186 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (pat, 1), 0, 0));
    8567       372186 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 1));
    8568       372186 :       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 8618:  /* sse3_monitor_di */
    8603         3397 :     case 8617:  /* 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 10065:  /* avx512dq_vmfpclassv2df */
    8633         1208 :     case 10063:  /* avx512dq_vmfpclassv4sf */
    8634         1208 :     case 10061:  /* avx512dq_vmfpclassv8hf */
    8635         1208 :     case 8296:  /* *avx512vl_testnmv2di3_zext */
    8636         1208 :     case 8295:  /* *avx512vl_testnmv2di3_zext */
    8637         1208 :     case 8294:  /* *avx512vl_testnmv2di3_zext */
    8638         1208 :     case 8293:  /* *avx512vl_testnmv4di3_zext */
    8639         1208 :     case 8292:  /* *avx512vl_testnmv4di3_zext */
    8640         1208 :     case 8291:  /* *avx512vl_testnmv4di3_zext */
    8641         1208 :     case 8290:  /* *avx512f_testnmv8di3_zext */
    8642         1208 :     case 8289:  /* *avx512f_testnmv8di3_zext */
    8643         1208 :     case 8288:  /* *avx512f_testnmv8di3_zext */
    8644         1208 :     case 8287:  /* *avx512vl_testnmv4si3_zext */
    8645         1208 :     case 8286:  /* *avx512vl_testnmv4si3_zext */
    8646         1208 :     case 8285:  /* *avx512vl_testnmv4si3_zext */
    8647         1208 :     case 8284:  /* *avx512vl_testnmv8si3_zext */
    8648         1208 :     case 8283:  /* *avx512vl_testnmv8si3_zext */
    8649         1208 :     case 8282:  /* *avx512vl_testnmv8si3_zext */
    8650         1208 :     case 8281:  /* *avx512f_testnmv16si3_zext */
    8651         1208 :     case 8280:  /* *avx512f_testnmv16si3_zext */
    8652         1208 :     case 8279:  /* *avx512f_testnmv16si3_zext */
    8653         1208 :     case 8278:  /* *avx512vl_testnmv8hi3_zext */
    8654         1208 :     case 8277:  /* *avx512vl_testnmv8hi3_zext */
    8655         1208 :     case 8276:  /* *avx512vl_testnmv8hi3_zext */
    8656         1208 :     case 8275:  /* *avx512vl_testnmv16hi3_zext */
    8657         1208 :     case 8274:  /* *avx512vl_testnmv16hi3_zext */
    8658         1208 :     case 8273:  /* *avx512vl_testnmv16hi3_zext */
    8659         1208 :     case 8272:  /* *avx512bw_testnmv32hi3_zext */
    8660         1208 :     case 8271:  /* *avx512bw_testnmv32hi3_zext */
    8661         1208 :     case 8270:  /* *avx512bw_testnmv32hi3_zext */
    8662         1208 :     case 8269:  /* *avx512vl_testnmv16qi3_zext */
    8663         1208 :     case 8268:  /* *avx512vl_testnmv16qi3_zext */
    8664         1208 :     case 8267:  /* *avx512vl_testnmv16qi3_zext */
    8665         1208 :     case 8266:  /* *avx512vl_testnmv32qi3_zext */
    8666         1208 :     case 8265:  /* *avx512vl_testnmv32qi3_zext */
    8667         1208 :     case 8264:  /* *avx512vl_testnmv32qi3_zext */
    8668         1208 :     case 8263:  /* *avx512bw_testnmv64qi3_zext */
    8669         1208 :     case 8262:  /* *avx512bw_testnmv64qi3_zext */
    8670         1208 :     case 8261:  /* *avx512bw_testnmv64qi3_zext */
    8671         1208 :     case 8224:  /* *avx512vl_testmv2di3_zext */
    8672         1208 :     case 8223:  /* *avx512vl_testmv2di3_zext */
    8673         1208 :     case 8222:  /* *avx512vl_testmv2di3_zext */
    8674         1208 :     case 8221:  /* *avx512vl_testmv4di3_zext */
    8675         1208 :     case 8220:  /* *avx512vl_testmv4di3_zext */
    8676         1208 :     case 8219:  /* *avx512vl_testmv4di3_zext */
    8677         1208 :     case 8218:  /* *avx512f_testmv8di3_zext */
    8678         1208 :     case 8217:  /* *avx512f_testmv8di3_zext */
    8679         1208 :     case 8216:  /* *avx512f_testmv8di3_zext */
    8680         1208 :     case 8215:  /* *avx512vl_testmv4si3_zext */
    8681         1208 :     case 8214:  /* *avx512vl_testmv4si3_zext */
    8682         1208 :     case 8213:  /* *avx512vl_testmv4si3_zext */
    8683         1208 :     case 8212:  /* *avx512vl_testmv8si3_zext */
    8684         1208 :     case 8211:  /* *avx512vl_testmv8si3_zext */
    8685         1208 :     case 8210:  /* *avx512vl_testmv8si3_zext */
    8686         1208 :     case 8209:  /* *avx512f_testmv16si3_zext */
    8687         1208 :     case 8208:  /* *avx512f_testmv16si3_zext */
    8688         1208 :     case 8207:  /* *avx512f_testmv16si3_zext */
    8689         1208 :     case 8206:  /* *avx512vl_testmv8hi3_zext */
    8690         1208 :     case 8205:  /* *avx512vl_testmv8hi3_zext */
    8691         1208 :     case 8204:  /* *avx512vl_testmv8hi3_zext */
    8692         1208 :     case 8203:  /* *avx512vl_testmv16hi3_zext */
    8693         1208 :     case 8202:  /* *avx512vl_testmv16hi3_zext */
    8694         1208 :     case 8201:  /* *avx512vl_testmv16hi3_zext */
    8695         1208 :     case 8200:  /* *avx512bw_testmv32hi3_zext */
    8696         1208 :     case 8199:  /* *avx512bw_testmv32hi3_zext */
    8697         1208 :     case 8198:  /* *avx512bw_testmv32hi3_zext */
    8698         1208 :     case 8197:  /* *avx512vl_testmv16qi3_zext */
    8699         1208 :     case 8196:  /* *avx512vl_testmv16qi3_zext */
    8700         1208 :     case 8195:  /* *avx512vl_testmv16qi3_zext */
    8701         1208 :     case 8194:  /* *avx512vl_testmv32qi3_zext */
    8702         1208 :     case 8193:  /* *avx512vl_testmv32qi3_zext */
    8703         1208 :     case 8192:  /* *avx512vl_testmv32qi3_zext */
    8704         1208 :     case 8191:  /* *avx512bw_testmv64qi3_zext */
    8705         1208 :     case 8190:  /* *avx512bw_testmv64qi3_zext */
    8706         1208 :     case 8189:  /* *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       291473 :     case 1932:  /* *prefetch_sse */
    8726       291473 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8727       291473 :       ro[1] = *(ro_loc[1] = &XEXP (pat, 2));
    8728       291473 :       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          977 :     case 1892:  /* *plus_within_umindi3_2 */
    8762          977 :     case 1890:  /* *plus_within_umaxdi3_2 */
    8763          977 :     case 1888:  /* *plus_within_uminsi3_2 */
    8764          977 :     case 1886:  /* *plus_within_umaxsi3_2 */
    8765          977 :     case 1884:  /* *plus_within_uminhi3_2 */
    8766          977 :     case 1882:  /* *plus_within_umaxhi3_2 */
    8767          977 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8768          977 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    8769          977 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
    8770          977 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
    8771          977 :       recog_data.dup_num[0] = 2;
    8772          977 :       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 8771:  /* *sse4_1_pblendvb_gt */
    8794         1998 :     case 8770:  /* *avx2_pblendvb_gt */
    8795         1998 :     case 8769:  /* *sse4_1_pblendvb_lt */
    8796         1998 :     case 8768:  /* *avx2_pblendvb_lt */
    8797         1998 :     case 8728:  /* *sse4_1_blendvpd_gt */
    8798         1998 :     case 8727:  /* *avx_blendvpd256_gt */
    8799         1998 :     case 8726:  /* *sse4_1_blendvps_gt */
    8800         1998 :     case 8725:  /* *avx_blendvps256_gt */
    8801         1998 :     case 8724:  /* *sse4_1_blendvpd_lt */
    8802         1998 :     case 8723:  /* *avx_blendvpd256_lt */
    8803         1998 :     case 8722:  /* *sse4_1_blendvps_lt */
    8804         1998 :     case 8721:  /* *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         5432 :     case 1833:  /* *movsicc_noc_zext_1 */
    8821         5432 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8822         5432 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    8823         5432 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
    8824         5432 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
    8825         5432 :       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      6327662 :     case 10693:  /* avx10_2_fmaddbf16_v8bf */
    8835      6327662 :     case 10691:  /* avx10_2_fmaddbf16_v16bf */
    8836      6327662 :     case 10689:  /* avx10_2_fmaddbf16_v32bf */
    8837      6327662 :     case 3888:  /* *fma_fmadd_v2df */
    8838      6327662 :     case 3886:  /* *fma_fmadd_v4df */
    8839      6327662 :     case 3882:  /* *fma_fmadd_v8df */
    8840      6327662 :     case 3881:  /* *fma_fmadd_df */
    8841      6327662 :     case 3879:  /* *fma_fmadd_v4sf */
    8842      6327662 :     case 3877:  /* *fma_fmadd_v8sf */
    8843      6327662 :     case 3873:  /* *fma_fmadd_v16sf */
    8844      6327662 :     case 3872:  /* *fma_fmadd_sf */
    8845      6327662 :     case 3871:  /* *fma_fmadd_hf */
    8846      6327662 :     case 3869:  /* *fma_fmadd_v8hf */
    8847      6327662 :     case 3867:  /* *fma_fmadd_v16hf */
    8848      6327662 :     case 3863:  /* *fma_fmadd_v32hf */
    8849      6327662 :     case 3862:  /* *fma_fmadd_v4df */
    8850      6327662 :     case 3861:  /* *fma_fmadd_v8sf */
    8851      6327662 :     case 3860:  /* *fma_fmadd_v2df */
    8852      6327662 :     case 3859:  /* *fma_fmadd_v4sf */
    8853      6327662 :     case 3858:  /* *fma_fmadd_df */
    8854      6327662 :     case 3857:  /* *fma_fmadd_sf */
    8855      6327662 :     case 1840:  /* *xop_pcmov_df */
    8856      6327662 :     case 1839:  /* *xop_pcmov_sf */
    8857      6327662 :     case 1838:  /* *movsfcc_1_387 */
    8858      6327662 :     case 1837:  /* *movdfcc_1 */
    8859      6327662 :     case 1836:  /* *movxfcc_1 */
    8860      6327662 :     case 1834:  /* *movqicc_noc */
    8861      6327662 :     case 1831:  /* *movdicc_noc */
    8862      6327662 :     case 1830:  /* *movsicc_noc */
    8863      6327662 :     case 1829:  /* *movhicc_noc */
    8864      6327662 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    8865      6327662 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    8866      6327662 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    8867      6327662 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 2));
    8868      6327662 :       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       173727 :     case 1818:  /* *cmpstrnqi_1 */
    8881       173727 :     case 1817:  /* *cmpstrnqi_1 */
    8882       173727 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 2), 0));
    8883       173727 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 3), 0));
    8884       173727 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 4), 0));
    8885       173727 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8886       173727 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0));
    8887       173727 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 0));
    8888       173727 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    8889       173727 :       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        27843 :     case 1814:  /* *rep_stosqi */
    8903        27843 :     case 1813:  /* *rep_stosqi */
    8904        27843 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8905        27843 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8906        27843 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 3), 0));
    8907        27843 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0));
    8908        27843 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
    8909        27843 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 4), 0);
    8910        27843 :       recog_data.dup_num[0] = 4;
    8911        27843 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 0), 0);
    8912        27843 :       recog_data.dup_num[1] = 3;
    8913        27843 :       break;
    8914              : 
    8915       105950 :     case 1812:  /* *rep_stossi */
    8916       105950 :     case 1811:  /* *rep_stossi */
    8917       105950 :     case 1810:  /* *rep_stosdi_rex64 */
    8918       105950 :     case 1809:  /* *rep_stosdi_rex64 */
    8919       105950 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8920       105950 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8921       105950 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 3), 0));
    8922       105950 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
    8923       105950 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0));
    8924       105950 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 4), 0);
    8925       105950 :       recog_data.dup_num[0] = 4;
    8926       105950 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 0), 0);
    8927       105950 :       recog_data.dup_num[1] = 3;
    8928       105950 :       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       118018 :     case 1800:  /* *rep_movqi */
    8946       118018 :     case 1799:  /* *rep_movqi */
    8947       118018 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8948       118018 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 2), 0));
    8949       118018 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8950       118018 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0));
    8951       118018 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0));
    8952       118018 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
    8953       118018 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 4), 0);
    8954       118018 :       recog_data.dup_num[0] = 5;
    8955       118018 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 3), 0), 0);
    8956       118018 :       recog_data.dup_num[1] = 3;
    8957       118018 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 3), 1), 0);
    8958       118018 :       recog_data.dup_num[2] = 4;
    8959       118018 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 1), 1);
    8960       118018 :       recog_data.dup_num[3] = 5;
    8961       118018 :       break;
    8962              : 
    8963       166170 :     case 1798:  /* *rep_movsi */
    8964       166170 :     case 1797:  /* *rep_movsi */
    8965       166170 :     case 1796:  /* *rep_movdi_rex64 */
    8966       166170 :     case 1795:  /* *rep_movdi_rex64 */
    8967       166170 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    8968       166170 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 2), 0));
    8969       166170 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 0), 0));
    8970       166170 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
    8971       166170 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XVECEXP (pat, 0, 2), 1), 1));
    8972       166170 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0));
    8973       166170 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 4), 0);
    8974       166170 :       recog_data.dup_num[0] = 5;
    8975       166170 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 3), 0), 0);
    8976       166170 :       recog_data.dup_num[1] = 3;
    8977       166170 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 3), 1), 0);
    8978       166170 :       recog_data.dup_num[2] = 4;
    8979       166170 :       recog_data.dup_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 2), 1), 0), 0);
    8980       166170 :       recog_data.dup_num[3] = 5;
    8981       166170 :       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        31274 :     case 11056:  /* atomic_storedi_fpu */
    9011        31274 :     case 11051:  /* atomic_loaddi_fpu */
    9012        31274 :     case 1781:  /* fistsi2_ceil */
    9013        31274 :     case 1780:  /* fistsi2_floor */
    9014        31274 :     case 1779:  /* fisthi2_ceil */
    9015        31274 :     case 1778:  /* fisthi2_floor */
    9016        31274 :     case 1769:  /* frndintxf2_trunc_i387 */
    9017        31274 :     case 1768:  /* frndintxf2_ceil_i387 */
    9018        31274 :     case 1767:  /* frndintxf2_floor_i387 */
    9019        31274 :     case 1766:  /* frndintxf2_roundeven_i387 */
    9020        31274 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9021        31274 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9022        31274 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9023        31274 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 2), 0));
    9024        31274 :       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         6421 :     case 1929:  /* stack_protect_test_1_di */
    9038         6421 :     case 1928:  /* stack_protect_test_1_si */
    9039         6421 :     case 1749:  /* fyl2xp1xf3_i387 */
    9040         6421 :     case 1748:  /* fyl2xxf3_i387 */
    9041         6421 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9042         6421 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9043         6421 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    9044         6421 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9045         6421 :       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        61428 :     case 1728:  /* *fop_df_5_i387 */
    9098        61428 :     case 1727:  /* *fop_xf_5_i387 */
    9099        61428 :     case 1726:  /* *fop_xf_5_i387 */
    9100        61428 :     case 1722:  /* *fop_xf_3_i387 */
    9101        61428 :     case 1721:  /* *fop_df_3_i387 */
    9102        61428 :     case 1720:  /* *fop_sf_3_i387 */
    9103        61428 :     case 1719:  /* *fop_xf_3_i387 */
    9104        61428 :     case 1718:  /* *fop_df_3_i387 */
    9105        61428 :     case 1717:  /* *fop_sf_3_i387 */
    9106        61428 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    9107        61428 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    9108        61428 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    9109        61428 :       ro[3] = *(ro_loc[3] = &XEXP (pat, 1));
    9110        61428 :       break;
    9111              : 
    9112        89259 :     case 1725:  /* *fop_df_4_i387 */
    9113        89259 :     case 1724:  /* *fop_xf_4_i387 */
    9114        89259 :     case 1723:  /* *fop_xf_4_i387 */
    9115        89259 :     case 1716:  /* *fop_xf_2_i387 */
    9116        89259 :     case 1715:  /* *fop_df_2_i387 */
    9117        89259 :     case 1714:  /* *fop_sf_2_i387 */
    9118        89259 :     case 1713:  /* *fop_xf_2_i387 */
    9119        89259 :     case 1712:  /* *fop_df_2_i387 */
    9120        89259 :     case 1711:  /* *fop_sf_2_i387 */
    9121        89259 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    9122        89259 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
    9123        89259 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
    9124        89259 :       ro[3] = *(ro_loc[3] = &XEXP (pat, 1));
    9125        89259 :       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        32435 :     case 1677:  /* *tls_global_dynamic_64_di */
    9210        32435 :     case 1676:  /* *tls_global_dynamic_64_si */
    9211        32435 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9212        32435 :       ro[1] = *(ro_loc[1] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    9213        32435 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    9214        32435 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
    9215        32435 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 2), 0));
    9216        32435 :       break;
    9217              : 
    9218        32409 :     case 1675:  /* *tls_global_dynamic_32_gnu */
    9219        32409 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9220        32409 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9221        32409 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
    9222        32409 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 2));
    9223        32409 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9224        32409 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (pat, 0, 2), 0));
    9225        32409 :       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         1076 :     case 1617:  /* *bmi2_bzhi_di3 */
    9293         1076 :     case 1616:  /* *bmi2_bzhi_si3 */
    9294         1076 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9295         1076 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
    9296         1076 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    9297         1076 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 1));
    9298         1076 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 0);
    9299         1076 :       recog_data.dup_num[0] = 2;
    9300         1076 :       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         7020 :     case 1907:  /* probe_stack_1 */
    9391         7020 :     case 1906:  /* allocate_stack_worker_probe_di */
    9392         7020 :     case 1905:  /* allocate_stack_worker_probe_si */
    9393         7020 :     case 1775:  /* *fistdi2_ceil_1 */
    9394         7020 :     case 1774:  /* *fistdi2_floor_1 */
    9395         7020 :     case 1773:  /* *fistsi2_ceil_1 */
    9396         7020 :     case 1772:  /* *fistsi2_floor_1 */
    9397         7020 :     case 1771:  /* *fisthi2_ceil_1 */
    9398         7020 :     case 1770:  /* *fisthi2_floor_1 */
    9399         7020 :     case 1765:  /* frndintxf2_trunc */
    9400         7020 :     case 1764:  /* frndintxf2_ceil */
    9401         7020 :     case 1763:  /* frndintxf2_floor */
    9402         7020 :     case 1762:  /* frndintxf2_roundeven */
    9403         7020 :     case 1591:  /* lzcnt_hi */
    9404         7020 :     case 1589:  /* tzcnt_hi */
    9405         7020 :     case 1579:  /* lzcnt_di */
    9406         7020 :     case 1578:  /* tzcnt_di */
    9407         7020 :     case 1577:  /* lzcnt_si */
    9408         7020 :     case 1576:  /* tzcnt_si */
    9409         7020 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9410         7020 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
    9411         7020 :       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         9166 :     case 1550:  /* bsr_rex64_1_zext */
    9431         9166 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9432         9166 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0), 0));
    9433         9166 :       break;
    9434              : 
    9435        32543 :     case 1552:  /* bsr_1 */
    9436        32543 :     case 1549:  /* bsr_rex64_1 */
    9437        32543 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9438        32543 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
    9439        32543 :       break;
    9440              : 
    9441        75667 :     case 1551:  /* bsr */
    9442        75667 :     case 1548:  /* bsr_rex64 */
    9443        75667 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9444        75667 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    9445        75667 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1), 0);
    9446        75667 :       recog_data.dup_num[0] = 1;
    9447        75667 :       break;
    9448              : 
    9449          619 :     case 1661:  /* *popcountsi2_zext_2_falsedep */
    9450          619 :     case 1571:  /* *clzsi2_lzcnt_zext_2_falsedep */
    9451          619 :     case 1570:  /* *clzsi2_lzcnt_zext_2_falsedep */
    9452          619 :     case 1547:  /* *ctzsidi2_uext_falsedep */
    9453          619 :     case 1546:  /* *ctzsidi2_sext_falsedep */
    9454          619 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9455          619 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
    9456          619 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    9457          619 :       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         4563 :     case 1657:  /* *popcountdi2_falsedep */
    9476         4563 :     case 1656:  /* *popcountsi2_falsedep */
    9477         4563 :     case 1655:  /* *popcountdi2_falsedep_nf */
    9478         4563 :     case 1654:  /* *popcountsi2_falsedep_nf */
    9479         4563 :     case 1565:  /* *clzdi2_lzcnt_falsedep */
    9480         4563 :     case 1564:  /* *clzsi2_lzcnt_falsedep */
    9481         4563 :     case 1563:  /* *clzdi2_lzcnt_falsedep_nf */
    9482         4563 :     case 1562:  /* *clzsi2_lzcnt_falsedep_nf */
    9483         4563 :     case 1541:  /* *ctzdi2_falsedep */
    9484         4563 :     case 1540:  /* *ctzsi2_falsedep */
    9485         4563 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9486         4563 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
    9487         4563 :       ro[2] = *(ro_loc[2] = &XVECEXP (XVECEXP (pat, 0, 1), 0, 0));
    9488         4563 :       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 10957:  /* avx10_2_vcvttss2usisdi */
    9510         5155 :     case 10955:  /* avx10_2_vcvttss2sisdi */
    9511         5155 :     case 10953:  /* avx10_2_vcvttss2usissi */
    9512         5155 :     case 10951:  /* avx10_2_vcvttss2sissi */
    9513         5155 :     case 10949:  /* avx10_2_vcvttsd2usisdi */
    9514         5155 :     case 10947:  /* avx10_2_vcvttsd2sisdi */
    9515         5155 :     case 10945:  /* avx10_2_vcvttsd2usissi */
    9516         5155 :     case 10943:  /* avx10_2_vcvttsd2sissi */
    9517         5155 :     case 8706:  /* sse4a_vmmovntv2df */
    9518         5155 :     case 8705:  /* 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       654399 :     case 1999:  /* rdseeddi */
    9545       654399 :     case 1998:  /* rdseedsi */
    9546       654399 :     case 1997:  /* rdseedhi */
    9547       654399 :     case 1996:  /* rdranddi */
    9548       654399 :     case 1995:  /* rdrandsi */
    9549       654399 :     case 1994:  /* rdrandhi */
    9550       654399 :     case 1972:  /* fnstenv */
    9551       654399 :     case 1522:  /* *set_got */
    9552       654399 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
    9553       654399 :       break;
    9554              : 
    9555       185669 :     case 8616:  /* sse3_mwait */
    9556       185669 :     case 2057:  /* uwrmsr */
    9557       185669 :     case 2054:  /* patchable_area */
    9558       185669 :     case 2010:  /* wrussdi */
    9559       185669 :     case 2009:  /* wrusssi */
    9560       185669 :     case 2008:  /* wrssdi */
    9561       185669 :     case 2007:  /* wrsssi */
    9562       185669 :     case 1968:  /* xsetbv */
    9563       185669 :     case 1963:  /* xrstors */
    9564       185669 :     case 1962:  /* xrstor */
    9565       185669 :     case 1934:  /* prefetchi */
    9566       185669 :     case 1521:  /* max_skip_align */
    9567       185669 :       ro[0] = *(ro_loc[0] = &XVECEXP (pat, 0, 0));
    9568       185669 :       ro[1] = *(ro_loc[1] = &XVECEXP (pat, 0, 1));
    9569       185669 :       break;
    9570              : 
    9571        58637 :     case 1518:  /* *simple_return_indirect_internaldi */
    9572        58637 :     case 1517:  /* *simple_return_indirect_internalsi */
    9573        58637 :     case 1516:  /* simple_return_pop_internal */
    9574        58637 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
    9575        58637 :       break;
    9576              : 
    9577      1509774 :     case 8615:  /* sse2_clflush */
    9578      1509774 :     case 8613:  /* sse_ldmxcsr */
    9579      1509774 :     case 2058:  /* ldtilecfg */
    9580      1509774 :     case 2055:  /* hreset */
    9581      1509774 :     case 2051:  /* cldemote */
    9582      1509774 :     case 2048:  /* umonitor_di */
    9583      1509774 :     case 2047:  /* umonitor_si */
    9584      1509774 :     case 2044:  /* senduipi */
    9585      1509774 :     case 2024:  /* clzero_di */
    9586      1509774 :     case 2023:  /* clzero_si */
    9587      1509774 :     case 2019:  /* clflushopt */
    9588      1509774 :     case 2018:  /* clwb */
    9589      1509774 :     case 2016:  /* xabort */
    9590      1509774 :     case 2012:  /* clrssbsy */
    9591      1509774 :     case 2006:  /* rstorssp */
    9592      1509774 :     case 2004:  /* incsspdi */
    9593      1509774 :     case 2003:  /* incsspsi */
    9594      1509774 :     case 1993:  /* ptwritedi */
    9595      1509774 :     case 1992:  /* ptwritesi */
    9596      1509774 :     case 1991:  /* wrgsbasedi */
    9597      1509774 :     case 1990:  /* wrfsbasedi */
    9598      1509774 :     case 1989:  /* wrgsbasesi */
    9599      1509774 :     case 1988:  /* wrfsbasesi */
    9600      1509774 :     case 1977:  /* lwp_llwpcbdi */
    9601      1509774 :     case 1976:  /* lwp_llwpcbsi */
    9602      1509774 :     case 1949:  /* fxrstor64 */
    9603      1509774 :     case 1948:  /* fxrstor */
    9604      1509774 :     case 1530:  /* split_stack_return */
    9605      1509774 :     case 1520:  /* nops */
    9606      1509774 :     case 1512:  /* prologue_use */
    9607      1509774 :       ro[0] = *(ro_loc[0] = &XVECEXP (pat, 0, 0));
    9608      1509774 :       break;
    9609              : 
    9610      2044711 :     case 11049:  /* mfence_sse2 */
    9611      2044711 :     case 11048:  /* *sse_sfence */
    9612      2044711 :     case 11047:  /* *sse2_lfence */
    9613      2044711 :     case 2000:  /* *pause */
    9614      2044711 :     case 1511:  /* *memory_blockage */
    9615      2044711 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
    9616      2044711 :       recog_data.dup_loc[0] = &XVECEXP (XEXP (pat, 1), 0, 0);
    9617      2044711 :       recog_data.dup_num[0] = 0;
    9618      2044711 :       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      3646619 :     case 1498:  /* *sibcall_pop_memory */
    9659      3646619 :     case 1497:  /* *sibcall_pop */
    9660      3646619 :     case 1496:  /* *call_pop */
    9661      3646619 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
    9662      3646619 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 1));
    9663      3646619 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1));
    9664      3646619 :       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       160117 :     case 1487:  /* *tablejump_1 */
    9678       160117 :     case 1486:  /* *tablejump_1 */
    9679       160117 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 1));
    9680       160117 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 0), 0));
    9681       160117 :       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     39879761 :     case 1483:  /* jump */
    9689     39879761 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 1), 0));
    9690     39879761 :       break;
    9691              : 
    9692    141242968 :     case 1482:  /* *jcc */
    9693    141242968 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
    9694    141242968 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
    9695    141242968 :       break;
    9696              : 
    9697       489219 :     case 11040:  /* avx512bmm_vbmacxor16x16x16_v16hi */
    9698       489219 :     case 11039:  /* avx512bmm_vbmacxor16x16x16_v32hi */
    9699       489219 :     case 11038:  /* avx512bmm_vbmacor16x16x16_v16hi */
    9700       489219 :     case 11037:  /* avx512bmm_vbmacor16x16x16_v32hi */
    9701       489219 :     case 10997:  /* avx10_2_minmaxpv2df */
    9702       489219 :     case 10993:  /* avx10_2_minmaxpv4df */
    9703       489219 :     case 10989:  /* avx10_2_minmaxpv8df */
    9704       489219 :     case 10985:  /* avx10_2_minmaxpv4sf */
    9705       489219 :     case 10981:  /* avx10_2_minmaxpv8sf */
    9706       489219 :     case 10977:  /* avx10_2_minmaxpv16sf */
    9707       489219 :     case 10973:  /* avx10_2_minmaxpv8hf */
    9708       489219 :     case 10969:  /* avx10_2_minmaxpv16hf */
    9709       489219 :     case 10965:  /* avx10_2_minmaxpv32hf */
    9710       489219 :     case 10963:  /* avx10_2_minmaxbf16_v8bf */
    9711       489219 :     case 10961:  /* avx10_2_minmaxbf16_v16bf */
    9712       489219 :     case 10959:  /* avx10_2_minmaxbf16_v32bf */
    9713       489219 :     case 10789:  /* avx10_2_cmpbf16_v8bf */
    9714       489219 :     case 10787:  /* avx10_2_cmpbf16_v16bf */
    9715       489219 :     case 10785:  /* avx10_2_cmpbf16_v32bf */
    9716       489219 :     case 10640:  /* vdpphps_v4sf */
    9717       489219 :     case 10639:  /* vdpphps_v8sf */
    9718       489219 :     case 10638:  /* vdpphps_v16sf */
    9719       489219 :     case 10601:  /* vpdpwuuds_v16si */
    9720       489219 :     case 10600:  /* vpdpwuud_v16si */
    9721       489219 :     case 10599:  /* vpdpwsuds_v16si */
    9722       489219 :     case 10598:  /* vpdpwsud_v16si */
    9723       489219 :     case 10597:  /* vpdpwusds_v16si */
    9724       489219 :     case 10596:  /* vpdpwusd_v16si */
    9725       489219 :     case 10595:  /* vpdpwuuds_v4si */
    9726       489219 :     case 10594:  /* vpdpwuud_v4si */
    9727       489219 :     case 10593:  /* vpdpwsuds_v4si */
    9728       489219 :     case 10592:  /* vpdpwsud_v4si */
    9729       489219 :     case 10591:  /* vpdpwusds_v4si */
    9730       489219 :     case 10590:  /* vpdpwusd_v4si */
    9731       489219 :     case 10589:  /* vpdpwuuds_v8si */
    9732       489219 :     case 10588:  /* vpdpwuud_v8si */
    9733       489219 :     case 10587:  /* vpdpwsuds_v8si */
    9734       489219 :     case 10586:  /* vpdpwsud_v8si */
    9735       489219 :     case 10585:  /* vpdpwusds_v8si */
    9736       489219 :     case 10584:  /* vpdpwusd_v8si */
    9737       489219 :     case 10449:  /* vpdpbuuds_v16si */
    9738       489219 :     case 10448:  /* vpdpbuud_v16si */
    9739       489219 :     case 10447:  /* vpdpbsuds_v16si */
    9740       489219 :     case 10446:  /* vpdpbsud_v16si */
    9741       489219 :     case 10445:  /* vpdpbssds_v16si */
    9742       489219 :     case 10444:  /* vpdpbssd_v16si */
    9743       489219 :     case 10443:  /* vpdpbuuds_v4si */
    9744       489219 :     case 10442:  /* vpdpbuud_v4si */
    9745       489219 :     case 10441:  /* vpdpbsuds_v4si */
    9746       489219 :     case 10440:  /* vpdpbsud_v4si */
    9747       489219 :     case 10439:  /* vpdpbssds_v4si */
    9748       489219 :     case 10438:  /* vpdpbssd_v4si */
    9749       489219 :     case 10437:  /* vpdpbuuds_v8si */
    9750       489219 :     case 10436:  /* vpdpbuud_v8si */
    9751       489219 :     case 10435:  /* vpdpbsuds_v8si */
    9752       489219 :     case 10434:  /* vpdpbsud_v8si */
    9753       489219 :     case 10433:  /* vpdpbssds_v8si */
    9754       489219 :     case 10432:  /* vpdpbssd_v8si */
    9755       489219 :     case 10416:  /* avx512f_dpbf16ps_v4sf */
    9756       489219 :     case 10414:  /* avx512f_dpbf16ps_v8sf */
    9757       489219 :     case 10412:  /* avx512f_dpbf16ps_v16sf */
    9758       489219 :     case 10384:  /* vpclmulqdq_v2di */
    9759       489219 :     case 10383:  /* vpclmulqdq_v4di */
    9760       489219 :     case 10382:  /* vpclmulqdq_v8di */
    9761       489219 :     case 10363:  /* vpdpwssds_v4si */
    9762       489219 :     case 10362:  /* vpdpwssds_v8si */
    9763       489219 :     case 10361:  /* vpdpwssds_v16si */
    9764       489219 :     case 10354:  /* vpdpwssd_v4si */
    9765       489219 :     case 10353:  /* vpdpwssd_v8si */
    9766       489219 :     case 10352:  /* vpdpwssd_v16si */
    9767       489219 :     case 10345:  /* vpdpbusds_v4si */
    9768       489219 :     case 10344:  /* vpdpbusds_v8si */
    9769       489219 :     case 10343:  /* vpdpbusds_v16si */
    9770       489219 :     case 10336:  /* vpdpbusd_v4si */
    9771       489219 :     case 10335:  /* vpdpbusd_v8si */
    9772       489219 :     case 10334:  /* vpdpbusd_v16si */
    9773       489219 :     case 10315:  /* vpshldv_v2di */
    9774       489219 :     case 10314:  /* vpshldv_v4si */
    9775       489219 :     case 10313:  /* vpshldv_v8hi */
    9776       489219 :     case 10312:  /* vpshldv_v4di */
    9777       489219 :     case 10311:  /* vpshldv_v8si */
    9778       489219 :     case 10310:  /* vpshldv_v16hi */
    9779       489219 :     case 10309:  /* vpshldv_v8di */
    9780       489219 :     case 10308:  /* vpshldv_v16si */
    9781       489219 :     case 10307:  /* vpshldv_v32hi */
    9782       489219 :     case 10288:  /* vpshrdv_v2di */
    9783       489219 :     case 10287:  /* vpshrdv_v4si */
    9784       489219 :     case 10286:  /* vpshrdv_v8hi */
    9785       489219 :     case 10285:  /* vpshrdv_v4di */
    9786       489219 :     case 10284:  /* vpshrdv_v8si */
    9787       489219 :     case 10283:  /* vpshrdv_v16hi */
    9788       489219 :     case 10282:  /* vpshrdv_v8di */
    9789       489219 :     case 10281:  /* vpshrdv_v16si */
    9790       489219 :     case 10280:  /* vpshrdv_v32hi */
    9791       489219 :     case 10278:  /* vpshld_v2di */
    9792       489219 :     case 10276:  /* vpshld_v4si */
    9793       489219 :     case 10274:  /* vpshld_v8hi */
    9794       489219 :     case 10272:  /* vpshld_v4di */
    9795       489219 :     case 10270:  /* vpshld_v8si */
    9796       489219 :     case 10268:  /* vpshld_v16hi */
    9797       489219 :     case 10266:  /* vpshld_v8di */
    9798       489219 :     case 10264:  /* vpshld_v16si */
    9799       489219 :     case 10262:  /* vpshld_v32hi */
    9800       489219 :     case 10260:  /* vpshrd_v2di */
    9801       489219 :     case 10258:  /* vpshrd_v4si */
    9802       489219 :     case 10256:  /* vpshrd_v8hi */
    9803       489219 :     case 10254:  /* vpshrd_v4di */
    9804       489219 :     case 10252:  /* vpshrd_v8si */
    9805       489219 :     case 10250:  /* vpshrd_v16hi */
    9806       489219 :     case 10248:  /* vpshrd_v8di */
    9807       489219 :     case 10246:  /* vpshrd_v16si */
    9808       489219 :     case 10244:  /* vpshrd_v32hi */
    9809       489219 :     case 10236:  /* vgf2p8affineqb_v16qi */
    9810       489219 :     case 10234:  /* vgf2p8affineqb_v32qi */
    9811       489219 :     case 10232:  /* vgf2p8affineqb_v64qi */
    9812       489219 :     case 10230:  /* vgf2p8affineinvqb_v16qi */
    9813       489219 :     case 10228:  /* vgf2p8affineinvqb_v32qi */
    9814       489219 :     case 10226:  /* vgf2p8affineinvqb_v64qi */
    9815       489219 :     case 10175:  /* vpmadd52huqv2di */
    9816       489219 :     case 10174:  /* vpmadd52luqv2di */
    9817       489219 :     case 10173:  /* vpmadd52huqv4di */
    9818       489219 :     case 10172:  /* vpmadd52luqv4di */
    9819       489219 :     case 10171:  /* vpmadd52huqv8di */
    9820       489219 :     case 10170:  /* vpmadd52luqv8di */
    9821       489219 :     case 10157:  /* vsha512rnds2 */
    9822       489219 :     case 10153:  /* vsm3msg2 */
    9823       489219 :     case 10152:  /* vsm3msg1 */
    9824       489219 :     case 10151:  /* sha256rnds2 */
    9825       489219 :     case 10148:  /* sha1rnds4 */
    9826       489219 :     case 10119:  /* *avx512bw_dbpsadbwv32hi */
    9827       489219 :     case 10117:  /* *avx512bw_dbpsadbwv16hi */
    9828       489219 :     case 10115:  /* *avx512bw_dbpsadbwv8hi */
    9829       489219 :     case 10033:  /* avx512dq_rangepv2df */
    9830       489219 :     case 10031:  /* avx512dq_rangepv4df */
    9831       489219 :     case 10027:  /* avx512dq_rangepv8df */
    9832       489219 :     case 10025:  /* avx512dq_rangepv4sf */
    9833       489219 :     case 10023:  /* avx512dq_rangepv8sf */
    9834       489219 :     case 10019:  /* avx512dq_rangepv16sf */
    9835       489219 :     case 10018:  /* *expandv8hi_mask */
    9836       489219 :     case 10017:  /* *expandv16hi_mask */
    9837       489219 :     case 10016:  /* *expandv32hi_mask */
    9838       489219 :     case 10015:  /* *expandv32qi_mask */
    9839       489219 :     case 10014:  /* *expandv16qi_mask */
    9840       489219 :     case 10013:  /* *expandv64qi_mask */
    9841       489219 :     case 10012:  /* *expandv2df_mask */
    9842       489219 :     case 10011:  /* *expandv2di_mask */
    9843       489219 :     case 10010:  /* *expandv4sf_mask */
    9844       489219 :     case 10009:  /* *expandv4si_mask */
    9845       489219 :     case 10008:  /* *expandv4df_mask */
    9846       489219 :     case 10007:  /* *expandv4di_mask */
    9847       489219 :     case 10006:  /* *expandv8sf_mask */
    9848       489219 :     case 10005:  /* *expandv8si_mask */
    9849       489219 :     case 10004:  /* *expandv8df_mask */
    9850       489219 :     case 10003:  /* *expandv8di_mask */
    9851       489219 :     case 10002:  /* *expandv16sf_mask */
    9852       489219 :     case 10001:  /* *expandv16si_mask */
    9853       489219 :     case 10000:  /* expandv8hi_mask */
    9854       489219 :     case 9999:  /* expandv16hi_mask */
    9855       489219 :     case 9998:  /* expandv32hi_mask */
    9856       489219 :     case 9997:  /* expandv32qi_mask */
    9857       489219 :     case 9996:  /* expandv16qi_mask */
    9858       489219 :     case 9995:  /* expandv64qi_mask */
    9859       489219 :     case 9994:  /* expandv2df_mask */
    9860       489219 :     case 9993:  /* expandv2di_mask */
    9861       489219 :     case 9992:  /* expandv4sf_mask */
    9862       489219 :     case 9991:  /* expandv4si_mask */
    9863       489219 :     case 9990:  /* expandv4df_mask */
    9864       489219 :     case 9989:  /* expandv4di_mask */
    9865       489219 :     case 9988:  /* expandv8sf_mask */
    9866       489219 :     case 9987:  /* expandv8si_mask */
    9867       489219 :     case 9986:  /* expandv8df_mask */
    9868       489219 :     case 9985:  /* expandv8di_mask */
    9869       489219 :     case 9984:  /* expandv16sf_mask */
    9870       489219 :     case 9983:  /* expandv16si_mask */
    9871       489219 :     case 9964:  /* compressv8hi_mask */
    9872       489219 :     case 9963:  /* compressv16hi_mask */
    9873       489219 :     case 9962:  /* compressv32hi_mask */
    9874       489219 :     case 9961:  /* compressv32qi_mask */
    9875       489219 :     case 9960:  /* compressv16qi_mask */
    9876       489219 :     case 9959:  /* compressv64qi_mask */
    9877       489219 :     case 9958:  /* avx512vl_compressv2df_mask */
    9878       489219 :     case 9957:  /* avx512vl_compressv2di_mask */
    9879       489219 :     case 9956:  /* avx512vl_compressv4sf_mask */
    9880       489219 :     case 9955:  /* avx512vl_compressv4si_mask */
    9881       489219 :     case 9954:  /* avx512vl_compressv4df_mask */
    9882       489219 :     case 9953:  /* avx512vl_compressv4di_mask */
    9883       489219 :     case 9952:  /* avx512vl_compressv8sf_mask */
    9884       489219 :     case 9951:  /* avx512vl_compressv8si_mask */
    9885       489219 :     case 9950:  /* avx512f_compressv8df_mask */
    9886       489219 :     case 9949:  /* avx512f_compressv8di_mask */
    9887       489219 :     case 9948:  /* avx512f_compressv16sf_mask */
    9888       489219 :     case 9947:  /* avx512f_compressv16si_mask */
    9889       489219 :     case 9511:  /* *avx_vperm2f128v4df_full */
    9890       489219 :     case 9510:  /* *avx_vperm2f128v8sf_full */
    9891       489219 :     case 9509:  /* *avx_vperm2f128v8si_full */
    9892       489219 :     case 9489:  /* avx512vl_vpermt2varv8bf3 */
    9893       489219 :     case 9487:  /* avx512vl_vpermt2varv16bf3 */
    9894       489219 :     case 9485:  /* avx512bw_vpermt2varv32bf3 */
    9895       489219 :     case 9483:  /* avx512fp16_vpermt2varv8hf3 */
    9896       489219 :     case 9481:  /* avx512vl_vpermt2varv16hf3 */
    9897       489219 :     case 9479:  /* avx512bw_vpermt2varv32hf3 */
    9898       489219 :     case 9477:  /* avx512vl_vpermt2varv16qi3 */
    9899       489219 :     case 9475:  /* avx512vl_vpermt2varv32qi3 */
    9900       489219 :     case 9473:  /* avx512bw_vpermt2varv64qi3 */
    9901       489219 :     case 9471:  /* avx512vl_vpermt2varv8hi3 */
    9902       489219 :     case 9469:  /* avx512vl_vpermt2varv16hi3 */
    9903       489219 :     case 9467:  /* avx512bw_vpermt2varv32hi3 */
    9904       489219 :     case 9465:  /* avx512vl_vpermt2varv2df3 */
    9905       489219 :     case 9463:  /* avx512vl_vpermt2varv2di3 */
    9906       489219 :     case 9461:  /* avx512vl_vpermt2varv4sf3 */
    9907       489219 :     case 9459:  /* avx512vl_vpermt2varv4si3 */
    9908       489219 :     case 9457:  /* avx512vl_vpermt2varv4df3 */
    9909       489219 :     case 9455:  /* avx512vl_vpermt2varv4di3 */
    9910       489219 :     case 9453:  /* avx512vl_vpermt2varv8sf3 */
    9911       489219 :     case 9451:  /* avx512vl_vpermt2varv8si3 */
    9912       489219 :     case 9449:  /* avx512f_vpermt2varv8df3 */
    9913       489219 :     case 9447:  /* avx512f_vpermt2varv8di3 */
    9914       489219 :     case 9445:  /* avx512f_vpermt2varv16sf3 */
    9915       489219 :     case 9443:  /* avx512f_vpermt2varv16si3 */
    9916       489219 :     case 9231:  /* avx2_permv2ti */
    9917       489219 :     case 9129:  /* pclmulqdq */
    9918       489219 :     case 9118:  /* xop_pcom_tfv2di3 */
    9919       489219 :     case 9117:  /* xop_pcom_tfv4si3 */
    9920       489219 :     case 9116:  /* xop_pcom_tfv8hi3 */
    9921       489219 :     case 9115:  /* xop_pcom_tfv16qi3 */
    9922       489219 :     case 9070:  /* xop_pperm */
    9923       489219 :     case 8767:  /* sse4_1_pblendvb */
    9924       489219 :     case 8766:  /* avx2_pblendvb */
    9925       489219 :     case 8758:  /* *sse4_1_mpsadbw */
    9926       489219 :     case 8756:  /* *avx2_mpsadbw */
    9927       489219 :     case 8754:  /* avx10_2_mpsadbw */
    9928       489219 :     case 8753:  /* sse4_1_mpsadbw */
    9929       489219 :     case 8752:  /* avx2_mpsadbw */
    9930       489219 :     case 8748:  /* sse4_1_dppd */
    9931       489219 :     case 8747:  /* avx_dppd256 */
    9932       489219 :     case 8746:  /* sse4_1_dpps */
    9933       489219 :     case 8745:  /* avx_dpps256 */
    9934       489219 :     case 8720:  /* sse4_1_blendvsd */
    9935       489219 :     case 8719:  /* sse4_1_blendvss */
    9936       489219 :     case 8718:  /* sse4_1_blendvpd */
    9937       489219 :     case 8717:  /* avx_blendvpd256 */
    9938       489219 :     case 8716:  /* sse4_1_blendvps */
    9939       489219 :     case 8715:  /* avx_blendvps256 */
    9940       489219 :     case 8707:  /* sse4a_extrqi */
    9941       489219 :     case 8678:  /* ssse3_palignrdi */
    9942       489219 :     case 8677:  /* ssse3_palignrv1ti */
    9943       489219 :     case 8676:  /* avx2_palignrv2ti */
    9944       489219 :     case 8675:  /* avx512bw_palignrv4ti */
    9945       489219 :     case 7101:  /* *avx512vl_alignv2di */
    9946       489219 :     case 7099:  /* *avx512vl_alignv4di */
    9947       489219 :     case 7097:  /* *avx512f_alignv8di */
    9948       489219 :     case 7095:  /* *avx512vl_alignv4si */
    9949       489219 :     case 7093:  /* *avx512vl_alignv8si */
    9950       489219 :     case 7091:  /* *avx512f_alignv16si */
    9951       489219 :     case 4382:  /* fma_fcmaddc_v4sf_pair */
    9952       489219 :     case 4381:  /* fma_fmaddc_v4sf_pair */
    9953       489219 :     case 4380:  /* fma_fcmaddc_v8sf_pair */
    9954       489219 :     case 4379:  /* fma_fmaddc_v8sf_pair */
    9955       489219 :     case 4378:  /* fma_fcmaddc_v16sf_pair */
    9956       489219 :     case 4377:  /* fma_fmaddc_v16sf_pair */
    9957       489219 :     case 4363:  /* fma_fcmaddc_v8hf */
    9958       489219 :     case 4361:  /* fma_fmaddc_v8hf */
    9959       489219 :     case 4359:  /* fma_fcmaddc_v16hf */
    9960       489219 :     case 4357:  /* fma_fmaddc_v16hf */
    9961       489219 :     case 4353:  /* fma_fcmaddc_v32hf */
    9962       489219 :     case 4349:  /* fma_fmaddc_v32hf */
    9963       489219 :     case 4143:  /* *fma_fmaddsub_v2df */
    9964       489219 :     case 4141:  /* *fma_fmaddsub_v4df */
    9965       489219 :     case 4137:  /* *fma_fmaddsub_v8df */
    9966       489219 :     case 4135:  /* *fma_fmaddsub_v4sf */
    9967       489219 :     case 4133:  /* *fma_fmaddsub_v8sf */
    9968       489219 :     case 4129:  /* *fma_fmaddsub_v16sf */
    9969       489219 :     case 4127:  /* *fma_fmaddsub_v8hf */
    9970       489219 :     case 4125:  /* *fma_fmaddsub_v16hf */
    9971       489219 :     case 4121:  /* *fma_fmaddsub_v32hf */
    9972       489219 :     case 4120:  /* *fma_fmaddsub_v2df */
    9973       489219 :     case 4119:  /* *fma_fmaddsub_v4df */
    9974       489219 :     case 4118:  /* *fma_fmaddsub_v4sf */
    9975       489219 :     case 4117:  /* *fma_fmaddsub_v8sf */
    9976       489219 :     case 3659:  /* avx512vl_ucmpv2di3 */
    9977       489219 :     case 3657:  /* avx512vl_ucmpv4di3 */
    9978       489219 :     case 3655:  /* avx512f_ucmpv8di3 */
    9979       489219 :     case 3653:  /* avx512vl_ucmpv4si3 */
    9980       489219 :     case 3651:  /* avx512vl_ucmpv8si3 */
    9981       489219 :     case 3649:  /* avx512f_ucmpv16si3 */
    9982       489219 :     case 3647:  /* avx512vl_ucmpv8hi3 */
    9983       489219 :     case 3645:  /* avx512vl_ucmpv16hi3 */
    9984       489219 :     case 3643:  /* avx512bw_ucmpv32hi3 */
    9985       489219 :     case 3641:  /* avx512vl_ucmpv16qi3 */
    9986       489219 :     case 3639:  /* avx512vl_ucmpv32qi3 */
    9987       489219 :     case 3637:  /* avx512bw_ucmpv64qi3 */
    9988       489219 :     case 3552:  /* *avx512vl_cmpv2di3_dup_op */
    9989       489219 :     case 3551:  /* *avx512vl_cmpv2di3_dup_op */
    9990       489219 :     case 3550:  /* *avx512vl_cmpv4di3_dup_op */
    9991       489219 :     case 3549:  /* *avx512vl_cmpv4di3_dup_op */
    9992       489219 :     case 3548:  /* *avx512f_cmpv8di3_dup_op */
    9993       489219 :     case 3547:  /* *avx512f_cmpv8di3_dup_op */
    9994       489219 :     case 3546:  /* *avx512vl_cmpv4si3_dup_op */
    9995       489219 :     case 3545:  /* *avx512vl_cmpv4si3_dup_op */
    9996       489219 :     case 3544:  /* *avx512vl_cmpv8si3_dup_op */
    9997       489219 :     case 3543:  /* *avx512vl_cmpv8si3_dup_op */
    9998       489219 :     case 3542:  /* *avx512f_cmpv16si3_dup_op */
    9999       489219 :     case 3541:  /* *avx512f_cmpv16si3_dup_op */
   10000       489219 :     case 3540:  /* *avx512vl_cmpv8hi3_dup_op */
   10001       489219 :     case 3539:  /* *avx512vl_cmpv8hi3_dup_op */
   10002       489219 :     case 3538:  /* *avx512vl_cmpv16hi3_dup_op */
   10003       489219 :     case 3537:  /* *avx512vl_cmpv16hi3_dup_op */
   10004       489219 :     case 3536:  /* *avx512bw_cmpv32hi3_dup_op */
   10005       489219 :     case 3535:  /* *avx512bw_cmpv32hi3_dup_op */
   10006       489219 :     case 3534:  /* *avx512vl_cmpv16qi3_dup_op */
   10007       489219 :     case 3533:  /* *avx512vl_cmpv16qi3_dup_op */
   10008       489219 :     case 3532:  /* *avx512vl_cmpv32qi3_dup_op */
   10009       489219 :     case 3531:  /* *avx512vl_cmpv32qi3_dup_op */
   10010       489219 :     case 3530:  /* *avx512bw_cmpv64qi3_dup_op */
   10011       489219 :     case 3529:  /* *avx512bw_cmpv64qi3_dup_op */
   10012       489219 :     case 3479:  /* avx512vl_cmpv2di3 */
   10013       489219 :     case 3477:  /* avx512vl_cmpv4di3 */
   10014       489219 :     case 3475:  /* avx512f_cmpv8di3 */
   10015       489219 :     case 3473:  /* avx512vl_cmpv4si3 */
   10016       489219 :     case 3471:  /* avx512vl_cmpv8si3 */
   10017       489219 :     case 3469:  /* avx512f_cmpv16si3 */
   10018       489219 :     case 3467:  /* avx512vl_cmpv8hi3 */
   10019       489219 :     case 3465:  /* avx512vl_cmpv16hi3 */
   10020       489219 :     case 3463:  /* avx512bw_cmpv32hi3 */
   10021       489219 :     case 3461:  /* avx512vl_cmpv16qi3 */
   10022       489219 :     case 3459:  /* avx512vl_cmpv32qi3 */
   10023       489219 :     case 3457:  /* avx512bw_cmpv64qi3 */
   10024       489219 :     case 3335:  /* avx512vl_cmpv2df3 */
   10025       489219 :     case 3333:  /* avx512vl_cmpv4df3 */
   10026       489219 :     case 3329:  /* avx512f_cmpv8df3 */
   10027       489219 :     case 3327:  /* avx512vl_cmpv4sf3 */
   10028       489219 :     case 3325:  /* avx512vl_cmpv8sf3 */
   10029       489219 :     case 3321:  /* avx512f_cmpv16sf3 */
   10030       489219 :     case 3319:  /* avx512fp16_cmpv8hf3 */
   10031       489219 :     case 3317:  /* avx512vl_cmpv16hf3 */
   10032       489219 :     case 3313:  /* avx512bw_cmpv32hf3 */
   10033       489219 :     case 3272:  /* avx_cmpv2df3 */
   10034       489219 :     case 3271:  /* avx_cmpv4df3 */
   10035       489219 :     case 3270:  /* avx_cmpv4sf3 */
   10036       489219 :     case 3269:  /* avx_cmpv8sf3 */
   10037       489219 :     case 2312:  /* mmx_ppermv32 */
   10038       489219 :     case 2311:  /* mmx_ppermv64 */
   10039       489219 :     case 2295:  /* mmx_pblendvb_v2hi */
   10040       489219 :     case 2294:  /* mmx_pblendvb_v2qi */
   10041       489219 :     case 2293:  /* mmx_pblendvb_v4qi */
   10042       489219 :     case 2289:  /* mmx_pblendvb_v8qi */
   10043       489219 :     case 2123:  /* mmx_blendvps */
   10044       489219 :     case 1835:  /* movhf_mask */
   10045       489219 :     case 1481:  /* setcc_hf_mask */
   10046       489219 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10047       489219 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
   10048       489219 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
   10049       489219 :       ro[3] = *(ro_loc[3] = &XVECEXP (XEXP (pat, 1), 0, 2));
   10050       489219 :       break;
   10051              : 
   10052     13287931 :     case 3310:  /* sse2_maskcmpv2df3 */
   10053     13287931 :     case 3309:  /* avx_maskcmpv4df3 */
   10054     13287931 :     case 3308:  /* sse_maskcmpv4sf3 */
   10055     13287931 :     case 3307:  /* avx_maskcmpv8sf3 */
   10056     13287931 :     case 3306:  /* *sse2_maskcmpv2df3_comm */
   10057     13287931 :     case 3305:  /* *avx_maskcmpv4df3_comm */
   10058     13287931 :     case 3304:  /* *sse_maskcmpv4sf3_comm */
   10059     13287931 :     case 3303:  /* *avx_maskcmpv8sf3_comm */
   10060     13287931 :     case 1710:  /* *fop_df_1 */
   10061     13287931 :     case 1709:  /* *fop_sf_1 */
   10062     13287931 :     case 1708:  /* *fop_xf_1_i387 */
   10063     13287931 :     case 1701:  /* *fop_df_comm */
   10064     13287931 :     case 1700:  /* *fop_sf_comm */
   10065     13287931 :     case 1699:  /* *fop_xf_comm_i387 */
   10066     13287931 :     case 1480:  /* setcc_df_sse */
   10067     13287931 :     case 1479:  /* setcc_sf_sse */
   10068     13287931 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10069     13287931 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
   10070     13287931 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
   10071     13287931 :       ro[3] = *(ro_loc[3] = &XEXP (pat, 1));
   10072     13287931 :       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         5157 :     case 1459:  /* *btdi_setcqi */
   10104         5157 :     case 1458:  /* *btsi_setcqi */
   10105         5157 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   10106         5157 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10107         5157 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 2));
   10108         5157 :       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        11255 :     case 1453:  /* *jcc_btdi */
   10129        11255 :     case 1452:  /* *jcc_btsi */
   10130        11255 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10131        11255 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   10132        11255 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 2));
   10133        11255 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   10134        11255 :       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       100275 :     case 1449:  /* *btdi */
   10144       100275 :     case 1448:  /* *btsi */
   10145       100275 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   10146       100275 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 1), 2));
   10147       100275 :       break;
   10148              : 
   10149        24337 :     case 1447:  /* *btcq_imm */
   10150        24337 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   10151        24337 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 2));
   10152        24337 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0);
   10153        24337 :       recog_data.dup_num[0] = 0;
   10154        24337 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 2);
   10155        24337 :       recog_data.dup_num[1] = 1;
   10156        24337 :       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         3358 :     case 1195:  /* *x86_shrd_shld_1_nozext */
   10314         3358 :     case 1183:  /* *x86_64_shrd_shld_1_nozext */
   10315         3358 :     case 1115:  /* *x86_shld_shrd_1_nozext */
   10316         3358 :     case 1103:  /* *x86_64_shld_shrd_1_nozext */
   10317         3358 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10318         3358 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   10319         3358 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10320         3358 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1));
   10321         3358 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10322         3358 :       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        16057 :     case 1191:  /* x86_shrd_1 */
   10358        16057 :     case 1179:  /* x86_64_shrd_1 */
   10359        16057 :     case 1111:  /* x86_shld_1 */
   10360        16057 :     case 1099:  /* x86_64_shld_1 */
   10361        16057 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10362        16057 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0));
   10363        16057 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10364        16057 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1));
   10365        16057 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0);
   10366        16057 :       recog_data.dup_num[0] = 0;
   10367        16057 :       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        87809 :     case 1187:  /* x86_shrd */
   10406        87809 :     case 1175:  /* x86_64_shrd */
   10407        87809 :     case 1107:  /* x86_shld */
   10408        87809 :     case 1095:  /* x86_64_shld */
   10409        87809 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10410        87809 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0), 0));
   10411        87809 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   10412        87809 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0);
   10413        87809 :       recog_data.dup_num[0] = 0;
   10414        87809 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1), 1), 0);
   10415        87809 :       recog_data.dup_num[1] = 2;
   10416        87809 :       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        31482 :     case 1339:  /* *rotrdi3_add */
   10472        31482 :     case 1338:  /* *rotldi3_add */
   10473        31482 :     case 1337:  /* *rotrsi3_add */
   10474        31482 :     case 1336:  /* *rotlsi3_add */
   10475        31482 :     case 1335:  /* *rotrhi3_add */
   10476        31482 :     case 1334:  /* *rotlhi3_add */
   10477        31482 :     case 1333:  /* *rotrqi3_add */
   10478        31482 :     case 1332:  /* *rotlqi3_add */
   10479        31482 :     case 1323:  /* *rotrdi3_mask */
   10480        31482 :     case 1322:  /* *rotldi3_mask */
   10481        31482 :     case 1321:  /* *rotrsi3_mask */
   10482        31482 :     case 1320:  /* *rotlsi3_mask */
   10483        31482 :     case 1319:  /* *rotrhi3_mask */
   10484        31482 :     case 1318:  /* *rotlhi3_mask */
   10485        31482 :     case 1317:  /* *rotrqi3_mask */
   10486        31482 :     case 1316:  /* *rotlqi3_mask */
   10487        31482 :     case 1293:  /* *ashrdi3_add */
   10488        31482 :     case 1292:  /* *lshrdi3_add */
   10489        31482 :     case 1291:  /* *ashldi3_add */
   10490        31482 :     case 1290:  /* *ashrsi3_add */
   10491        31482 :     case 1289:  /* *lshrsi3_add */
   10492        31482 :     case 1288:  /* *ashlsi3_add */
   10493        31482 :     case 1281:  /* *ashrdi3_mask */
   10494        31482 :     case 1280:  /* *lshrdi3_mask */
   10495        31482 :     case 1279:  /* *ashldi3_mask */
   10496        31482 :     case 1278:  /* *ashrsi3_mask */
   10497        31482 :     case 1277:  /* *lshrsi3_mask */
   10498        31482 :     case 1276:  /* *ashlsi3_mask */
   10499        31482 :     case 1157:  /* *ashrti3_doubleword_mask */
   10500        31482 :     case 1156:  /* *lshrti3_doubleword_mask */
   10501        31482 :     case 1155:  /* *ashrdi3_doubleword_mask */
   10502        31482 :     case 1154:  /* *lshrdi3_doubleword_mask */
   10503        31482 :     case 1085:  /* *ashlti3_doubleword_mask */
   10504        31482 :     case 1084:  /* *ashldi3_doubleword_mask */
   10505        31482 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10506        31482 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10507        31482 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0));
   10508        31482 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1));
   10509        31482 :       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        22324 :     case 1019:  /* *negdi_ccc_2 */
   10550        22324 :     case 1018:  /* *negsi_ccc_2 */
   10551        22324 :     case 1017:  /* *neghi_ccc_2 */
   10552        22324 :     case 1016:  /* *negqi_ccc_2 */
   10553        22324 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10554        22324 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
   10555        22324 :       break;
   10556              : 
   10557        27581 :     case 1015:  /* *negdi_ccc_1 */
   10558        27581 :     case 1014:  /* *negsi_ccc_1 */
   10559        27581 :     case 1013:  /* *neghi_ccc_1 */
   10560        27581 :     case 1012:  /* *negqi_ccc_1 */
   10561        27581 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10562        27581 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
   10563        27581 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   10564        27581 :       recog_data.dup_num[0] = 1;
   10565        27581 :       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        94843 :     case 1079:  /* *one_cmpldi2_2 */
   10576        94843 :     case 1078:  /* *one_cmplsi2_2 */
   10577        94843 :     case 1077:  /* *one_cmplhi2_2 */
   10578        94843 :     case 1076:  /* *one_cmplqi2_2 */
   10579        94843 :     case 1010:  /* *negdi_2 */
   10580        94843 :     case 1009:  /* *negsi_2 */
   10581        94843 :     case 1008:  /* *neghi_2 */
   10582        94843 :     case 1007:  /* *negqi_2 */
   10583        94843 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10584        94843 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10585        94843 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   10586        94843 :       recog_data.dup_num[0] = 1;
   10587        94843 :       break;
   10588              : 
   10589        47283 :     case 1211:  /* *highpartdisi2 */
   10590        47283 :     case 1006:  /* *neghi_1_slp */
   10591        47283 :     case 1005:  /* *negqi_1_slp */
   10592        47283 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   10593        47283 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   10594        47283 :       break;
   10595              : 
   10596         6547 :     case 9412:  /* avx512cd_maskw_vec_dupv4si */
   10597         6547 :     case 9411:  /* avx512cd_maskw_vec_dupv8si */
   10598         6547 :     case 9410:  /* avx512cd_maskw_vec_dupv16si */
   10599         6547 :     case 9409:  /* avx512cd_maskb_vec_dupv2di */
   10600         6547 :     case 9408:  /* avx512cd_maskb_vec_dupv4di */
   10601         6547 :     case 9407:  /* avx512cd_maskb_vec_dupv8di */
   10602         6547 :     case 2650:  /* *knotsi_1_zext */
   10603         6547 :     case 1663:  /* *popcounthi2_2 */
   10604         6547 :     case 1662:  /* *popcounthi2_1 */
   10605         6547 :     case 1660:  /* *popcountsi2_zext_2 */
   10606         6547 :     case 1569:  /* *clzsi2_lzcnt_zext_2 */
   10607         6547 :     case 1545:  /* *ctzsidi2_uext */
   10608         6547 :     case 1544:  /* *ctzsidi2_sext */
   10609         6547 :     case 1418:  /* rcrdi2 */
   10610         6547 :     case 1417:  /* rcrsi2 */
   10611         6547 :     case 1038:  /* *nabsdi2_1 */
   10612         6547 :     case 1037:  /* *nabssi2_1 */
   10613         6547 :     case 1036:  /* *nabshi2_1 */
   10614         6547 :     case 1035:  /* *nabsqi2_1 */
   10615         6547 :     case 1030:  /* *nabsti2_doubleword */
   10616         6547 :     case 1029:  /* *nabsdi2_doubleword */
   10617         6547 :     case 1004:  /* *negsi_1_zext */
   10618         6547 :     case 1003:  /* *neghi_1_zextdi */
   10619         6547 :     case 1001:  /* *neghi_1_zextsi */
   10620         6547 :     case 999:  /* *negqi_1_zextdi */
   10621         6547 :     case 997:  /* *negqi_1_zextsi */
   10622         6547 :     case 995:  /* *negqi_1_zexthi */
   10623         6547 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10624         6547 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10625         6547 :       break;
   10626              : 
   10627     42844439 :     case 10405:  /* *vcvtneps2bf16_v4sf */
   10628     42844439 :     case 9546:  /* vec_set_hi_v32qi */
   10629     42844439 :     case 9544:  /* vec_set_hi_v16bf */
   10630     42844439 :     case 9543:  /* vec_set_hi_v16hf */
   10631     42844439 :     case 9542:  /* vec_set_hi_v16hi */
   10632     42844439 :     case 9537:  /* vec_set_hi_v8sf */
   10633     42844439 :     case 9535:  /* vec_set_hi_v8si */
   10634     42844439 :     case 9529:  /* vec_set_hi_v4df */
   10635     42844439 :     case 9527:  /* vec_set_hi_v4di */
   10636     42844439 :     case 8443:  /* vec_set_hi_v8di */
   10637     42844439 :     case 8441:  /* vec_set_hi_v8df */
   10638     42844439 :     case 8435:  /* vec_set_hi_v16si */
   10639     42844439 :     case 8433:  /* vec_set_hi_v16sf */
   10640     42844439 :     case 8104:  /* *iornotv2di3 */
   10641     42844439 :     case 8103:  /* *iornotv4di3 */
   10642     42844439 :     case 8102:  /* *iornotv4si3 */
   10643     42844439 :     case 8101:  /* *iornotv8si3 */
   10644     42844439 :     case 8100:  /* *iornotv8hi3 */
   10645     42844439 :     case 8099:  /* *iornotv16hi3 */
   10646     42844439 :     case 8098:  /* *iornotv32hi3 */
   10647     42844439 :     case 8097:  /* *iornotv16qi3 */
   10648     42844439 :     case 8096:  /* *iornotv32qi3 */
   10649     42844439 :     case 8095:  /* *iornotv64qi3 */
   10650     42844439 :     case 8094:  /* *iornotv8di3 */
   10651     42844439 :     case 8093:  /* *iornotv16si3 */
   10652     42844439 :     case 8029:  /* *andnotv2di3 */
   10653     42844439 :     case 8028:  /* *andnotv4di3 */
   10654     42844439 :     case 8027:  /* *andnotv4si3 */
   10655     42844439 :     case 8026:  /* *andnotv8si3 */
   10656     42844439 :     case 8025:  /* *andnotv8hi3 */
   10657     42844439 :     case 8024:  /* *andnotv16hi3 */
   10658     42844439 :     case 8023:  /* *andnotv32hi3 */
   10659     42844439 :     case 8022:  /* *andnotv16qi3 */
   10660     42844439 :     case 8021:  /* *andnotv32qi3 */
   10661     42844439 :     case 8020:  /* *andnotv64qi3 */
   10662     42844439 :     case 8019:  /* *andnotv8di3 */
   10663     42844439 :     case 8018:  /* *andnotv16si3 */
   10664     42844439 :     case 7451:  /* avx512vl_us_truncatev2div2si2 */
   10665     42844439 :     case 7450:  /* avx512vl_truncatev2div2si2 */
   10666     42844439 :     case 7449:  /* avx512vl_ss_truncatev2div2si2 */
   10667     42844439 :     case 7402:  /* avx512vl_us_truncatev4siv4hi2 */
   10668     42844439 :     case 7401:  /* avx512vl_truncatev4siv4hi2 */
   10669     42844439 :     case 7400:  /* avx512vl_ss_truncatev4siv4hi2 */
   10670     42844439 :     case 7399:  /* avx512vl_us_truncatev2div2hi2 */
   10671     42844439 :     case 7398:  /* avx512vl_truncatev2div2hi2 */
   10672     42844439 :     case 7397:  /* avx512vl_ss_truncatev2div2hi2 */
   10673     42844439 :     case 7396:  /* avx512vl_us_truncatev4div4hi2 */
   10674     42844439 :     case 7395:  /* avx512vl_truncatev4div4hi2 */
   10675     42844439 :     case 7394:  /* avx512vl_ss_truncatev4div4hi2 */
   10676     42844439 :     case 7317:  /* avx512vl_us_truncatev8hiv8qi2 */
   10677     42844439 :     case 7316:  /* avx512vl_truncatev8hiv8qi2 */
   10678     42844439 :     case 7315:  /* avx512vl_ss_truncatev8hiv8qi2 */
   10679     42844439 :     case 7314:  /* avx512vl_us_truncatev4siv4qi2 */
   10680     42844439 :     case 7313:  /* avx512vl_truncatev4siv4qi2 */
   10681     42844439 :     case 7312:  /* avx512vl_ss_truncatev4siv4qi2 */
   10682     42844439 :     case 7311:  /* avx512vl_us_truncatev8siv8qi2 */
   10683     42844439 :     case 7310:  /* avx512vl_truncatev8siv8qi2 */
   10684     42844439 :     case 7309:  /* avx512vl_ss_truncatev8siv8qi2 */
   10685     42844439 :     case 7308:  /* avx512vl_us_truncatev2div2qi2 */
   10686     42844439 :     case 7307:  /* avx512vl_truncatev2div2qi2 */
   10687     42844439 :     case 7306:  /* avx512vl_ss_truncatev2div2qi2 */
   10688     42844439 :     case 7305:  /* avx512vl_us_truncatev4div4qi2 */
   10689     42844439 :     case 7304:  /* avx512vl_truncatev4div4qi2 */
   10690     42844439 :     case 7303:  /* avx512vl_ss_truncatev4div4qi2 */
   10691     42844439 :     case 7238:  /* sse2_loadhpd */
   10692     42844439 :     case 5277:  /* sse_loadhps */
   10693     42844439 :     case 5184:  /* *sse2_cvtpd2ps */
   10694     42844439 :     case 5010:  /* *avx512dq_floatunsv2div2sf2 */
   10695     42844439 :     case 5009:  /* *avx512dq_floatv2div2sf2 */
   10696     42844439 :     case 4785:  /* *avx512fp16_vcvtpd2ph_v2df */
   10697     42844439 :     case 4780:  /* *avx512fp16_vcvtps2ph_v4sf */
   10698     42844439 :     case 4779:  /* *avx512fp16_vcvtpd2ph_v4df */
   10699     42844439 :     case 4566:  /* *avx512fp16_vcvtuqq2ph_v2di */
   10700     42844439 :     case 4565:  /* *avx512fp16_vcvtqq2ph_v2di */
   10701     42844439 :     case 4556:  /* *avx512fp16_vcvtuqq2ph_v4di */
   10702     42844439 :     case 4555:  /* *avx512fp16_vcvtqq2ph_v4di */
   10703     42844439 :     case 4554:  /* *avx512fp16_vcvtudq2ph_v4si */
   10704     42844439 :     case 4553:  /* *avx512fp16_vcvtdq2ph_v4si */
   10705     42844439 :     case 3841:  /* *andnotv1ti3 */
   10706     42844439 :     case 3840:  /* *andnottf3 */
   10707     42844439 :     case 3839:  /* *andnotdf3 */
   10708     42844439 :     case 3838:  /* *andnotsf3 */
   10709     42844439 :     case 3837:  /* *andnothf3 */
   10710     42844439 :     case 3836:  /* *andnotbf3 */
   10711     42844439 :     case 3768:  /* avx512f_andnotv8df3 */
   10712     42844439 :     case 3766:  /* avx512f_andnotv16sf3 */
   10713     42844439 :     case 3765:  /* avx512fp16_andnotv32hf3 */
   10714     42844439 :     case 3764:  /* avx512bf16_andnotv32bf3 */
   10715     42844439 :     case 3762:  /* sse2_andnotv2df3 */
   10716     42844439 :     case 3760:  /* avx_andnotv4df3 */
   10717     42844439 :     case 3758:  /* sse_andnotv4sf3 */
   10718     42844439 :     case 3756:  /* avx_andnotv8sf3 */
   10719     42844439 :     case 3755:  /* avx512fp16_andnotv8hf3 */
   10720     42844439 :     case 3754:  /* avx512fp16_andnotv16hf3 */
   10721     42844439 :     case 3753:  /* avx512bf16_andnotv8bf3 */
   10722     42844439 :     case 3752:  /* avx512bf16_andnotv16bf3 */
   10723     42844439 :     case 2990:  /* sse2_vmsqrtv2df2 */
   10724     42844439 :     case 2986:  /* sse_vmsqrtv4sf2 */
   10725     42844439 :     case 2982:  /* avx512fp16_vmsqrtv8hf2 */
   10726     42844439 :     case 2609:  /* *sse2_movq128_v2df */
   10727     42844439 :     case 2608:  /* *sse2_movq128_v2di */
   10728     42844439 :     case 2318:  /* mmx_andnotv2si3 */
   10729     42844439 :     case 2317:  /* mmx_andnotv4hi3 */
   10730     42844439 :     case 2316:  /* mmx_andnotv8qi3 */
   10731     42844439 :     case 2158:  /* *mmx_andnotv4hf3 */
   10732     42844439 :     case 2157:  /* *mmx_andnotv2hf3 */
   10733     42844439 :     case 2156:  /* *mmx_andnotv4bf3 */
   10734     42844439 :     case 2155:  /* *mmx_andnotv2bf3 */
   10735     42844439 :     case 2124:  /* *mmx_andnotv2sf3 */
   10736     42844439 :     case 1504:  /* *sibcall_value */
   10737     42844439 :     case 1503:  /* *sibcall_value */
   10738     42844439 :     case 1500:  /* *call_value */
   10739     42844439 :     case 1499:  /* *call_value */
   10740     42844439 :     case 983:  /* *concatditi3_7 */
   10741     42844439 :     case 982:  /* *concatditi3_7 */
   10742     42844439 :     case 981:  /* *concatditi3_7 */
   10743     42844439 :     case 980:  /* *concatsidi3_7 */
   10744     42844439 :     case 979:  /* *concatsidi3_7 */
   10745     42844439 :     case 978:  /* *concatsidi3_7 */
   10746     42844439 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10747     42844439 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   10748     42844439 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
   10749     42844439 :       break;
   10750              : 
   10751        71325 :     case 977:  /* *concatditi3_6 */
   10752        71325 :     case 976:  /* *concatditi3_6 */
   10753        71325 :     case 975:  /* *concatditi3_6 */
   10754        71325 :     case 974:  /* *concatditi3_6 */
   10755        71325 :     case 973:  /* *concatditi3_6 */
   10756        71325 :     case 972:  /* *concatditi3_6 */
   10757        71325 :     case 971:  /* *concatsidi3_6 */
   10758        71325 :     case 970:  /* *concatsidi3_6 */
   10759        71325 :     case 969:  /* *concatsidi3_6 */
   10760        71325 :     case 968:  /* *concatsidi3_6 */
   10761        71325 :     case 967:  /* *concatsidi3_6 */
   10762        71325 :     case 966:  /* *concatsidi3_6 */
   10763        71325 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10764        71325 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   10765        71325 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10766        71325 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
   10767        71325 :       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       672129 :     case 947:  /* *concatditi3_3 */
   10788       672129 :     case 946:  /* *concatditi3_3 */
   10789       672129 :     case 945:  /* *concatditi3_3 */
   10790       672129 :     case 944:  /* *concatditi3_3 */
   10791       672129 :     case 943:  /* *concatditi3_3 */
   10792       672129 :     case 942:  /* *concatditi3_3 */
   10793       672129 :     case 941:  /* *concatsidi3_3 */
   10794       672129 :     case 940:  /* *concatsidi3_3 */
   10795       672129 :     case 939:  /* *concatsidi3_3 */
   10796       672129 :     case 938:  /* *concatsidi3_3 */
   10797       672129 :     case 937:  /* *concatsidi3_3 */
   10798       672129 :     case 936:  /* *concatsidi3_3 */
   10799       672129 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10800       672129 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   10801       672129 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10802       672129 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   10803       672129 :       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        55959 :     case 2641:  /* kandndi */
   10859        55959 :     case 2640:  /* kandnsi */
   10860        55959 :     case 2639:  /* kandnhi */
   10861        55959 :     case 2638:  /* kandnqi */
   10862        55959 :     case 2321:  /* *andnotv2hi3 */
   10863        55959 :     case 2320:  /* *andnotv2qi3 */
   10864        55959 :     case 2319:  /* *andnotv4qi3 */
   10865        55959 :     case 1506:  /* *sibcall_value_memory */
   10866        55959 :     case 1505:  /* *sibcall_value_memory */
   10867        55959 :     case 1093:  /* *ashlti3_doubleword_highpart */
   10868        55959 :     case 1092:  /* *ashlti3_doubleword_highpart */
   10869        55959 :     case 1091:  /* *ashldi3_doubleword_highpart */
   10870        55959 :     case 1090:  /* *ashldi3_doubleword_highpart */
   10871        55959 :     case 894:  /* *xorsi_1_zext_imm */
   10872        55959 :     case 893:  /* *iorsi_1_zext_imm */
   10873        55959 :     case 844:  /* *andnhi_1 */
   10874        55959 :     case 843:  /* *andnqi_1 */
   10875        55959 :     case 842:  /* *andndi_1 */
   10876        55959 :     case 841:  /* *andnsi_1 */
   10877        55959 :     case 840:  /* *andnti3_doubleword */
   10878        55959 :     case 839:  /* *andndi3_doubleword */
   10879        55959 :     case 838:  /* *andnti3_doubleword_bmi */
   10880        55959 :     case 837:  /* *andndi3_doubleword_bmi */
   10881        55959 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10882        55959 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10883        55959 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   10884        55959 :       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         3147 :     case 818:  /* *xorqi_extdi_1_cc */
   10902         3147 :     case 817:  /* *iorqi_extdi_1_cc */
   10903         3147 :     case 816:  /* *andqi_extdi_1_cc */
   10904         3147 :     case 815:  /* *xorqi_extsi_1_cc */
   10905         3147 :     case 814:  /* *iorqi_extsi_1_cc */
   10906         3147 :     case 813:  /* *andqi_extsi_1_cc */
   10907         3147 :     case 812:  /* *xorqi_exthi_1_cc */
   10908         3147 :     case 811:  /* *iorqi_exthi_1_cc */
   10909         3147 :     case 810:  /* *andqi_exthi_1_cc */
   10910         3147 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 0), 0));
   10911         3147 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   10912         3147 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10913         3147 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   10914         3147 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10915         3147 :       ro[5] = *(ro_loc[5] = &XEXP (XVECEXP (pat, 0, 0), 1));
   10916         3147 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0), 0), 0);
   10917         3147 :       recog_data.dup_num[0] = 0;
   10918         3147 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   10919         3147 :       recog_data.dup_num[1] = 2;
   10920         3147 :       break;
   10921              : 
   10922        17612 :     case 730:  /* *testti_not_doubleword */
   10923        17612 :     case 729:  /* *testdi_not_doubleword */
   10924        17612 :     case 728:  /* *testdi_not */
   10925        17612 :     case 727:  /* *testsi_not */
   10926        17612 :     case 726:  /* *testhi_not */
   10927        17612 :     case 725:  /* *testqi_not */
   10928        17612 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   10929        17612 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10930        17612 :       break;
   10931              : 
   10932       369989 :     case 724:  /* *testqi_ext_3 */
   10933       369989 :     case 723:  /* *testqi_ext_3 */
   10934       369989 :     case 722:  /* *testqi_ext_3 */
   10935       369989 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   10936       369989 :       ro[1] = *(ro_loc[1] = &XEXP (pat, 1));
   10937       369989 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   10938       369989 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10939       369989 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (pat, 1), 0), 2));
   10940       369989 :       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       103998 :     case 717:  /* *testqi_extdi_1 */
   10952       103998 :     case 716:  /* *testqi_extsi_1 */
   10953       103998 :     case 715:  /* *testqi_exthi_1 */
   10954       103998 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0), 0));
   10955       103998 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   10956       103998 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   10957       103998 :       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          434 :     case 704:  /* *udivmodsi4_noext_zext_2 */
   10982          434 :     case 703:  /* *divmodsi4_noext_zext_2 */
   10983          434 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   10984          434 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 0));
   10985          434 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   10986          434 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   10987          434 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 2), 0));
   10988          434 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   10989          434 :       recog_data.dup_num[0] = 2;
   10990          434 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   10991          434 :       recog_data.dup_num[1] = 3;
   10992          434 :       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       627782 :     case 700:  /* *udivmoddi4_noext */
   11008       627782 :     case 699:  /* *divmoddi4_noext */
   11009       627782 :     case 698:  /* *udivmodsi4_noext */
   11010       627782 :     case 697:  /* *divmodsi4_noext */
   11011       627782 :     case 696:  /* *udivmodhi4_noext */
   11012       627782 :     case 695:  /* *divmodhi4_noext */
   11013       627782 :     case 694:  /* *udivmoddi4_noext_nf */
   11014       627782 :     case 693:  /* *divmoddi4_noext_nf */
   11015       627782 :     case 692:  /* *udivmodsi4_noext_nf */
   11016       627782 :     case 691:  /* *divmodsi4_noext_nf */
   11017       627782 :     case 690:  /* *udivmodhi4_noext_nf */
   11018       627782 :     case 689:  /* *divmodhi4_noext_nf */
   11019       627782 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11020       627782 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11021       627782 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11022       627782 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11023       627782 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 2), 0));
   11024       627782 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11025       627782 :       recog_data.dup_num[0] = 2;
   11026       627782 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11027       627782 :       recog_data.dup_num[1] = 3;
   11028       627782 :       break;
   11029              : 
   11030          646 :     case 688:  /* *udivmodsi4_pow2_zext_2 */
   11031          646 :     case 687:  /* *udivmodsi4_zext_2 */
   11032          646 :     case 686:  /* *divmodsi4_zext_2 */
   11033          646 :     case 674:  /* udivmodsi4_zext_2 */
   11034          646 :     case 673:  /* divmodsi4_zext_2 */
   11035          646 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11036          646 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11037          646 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11038          646 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11039          646 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11040          646 :       recog_data.dup_num[0] = 2;
   11041          646 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11042          646 :       recog_data.dup_num[1] = 3;
   11043          646 :       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       408843 :     case 658:  /* umuldi3_highpart */
   11087       408843 :     case 657:  /* smuldi3_highpart */
   11088       408843 :     case 656:  /* umulsi3_highpart */
   11089       408843 :     case 655:  /* smulsi3_highpart */
   11090       408843 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11091       408843 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11092       408843 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11093       408843 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11094       408843 :       break;
   11095              : 
   11096         2757 :     case 8339:  /* sse2_packssdw */
   11097         2757 :     case 8333:  /* sse2_packsswb */
   11098         2757 :     case 8140:  /* *nandv2di3 */
   11099         2757 :     case 8139:  /* *norv2di3 */
   11100         2757 :     case 8138:  /* *nandv4di3 */
   11101         2757 :     case 8137:  /* *norv4di3 */
   11102         2757 :     case 8136:  /* *nandv4si3 */
   11103         2757 :     case 8135:  /* *norv4si3 */
   11104         2757 :     case 8134:  /* *nandv8si3 */
   11105         2757 :     case 8133:  /* *norv8si3 */
   11106         2757 :     case 8132:  /* *nandv8hi3 */
   11107         2757 :     case 8131:  /* *norv8hi3 */
   11108         2757 :     case 8130:  /* *nandv16hi3 */
   11109         2757 :     case 8129:  /* *norv16hi3 */
   11110         2757 :     case 8128:  /* *nandv32hi3 */
   11111         2757 :     case 8127:  /* *norv32hi3 */
   11112         2757 :     case 8126:  /* *nandv16qi3 */
   11113         2757 :     case 8125:  /* *norv16qi3 */
   11114         2757 :     case 8124:  /* *nandv32qi3 */
   11115         2757 :     case 8123:  /* *norv32qi3 */
   11116         2757 :     case 8122:  /* *nandv64qi3 */
   11117         2757 :     case 8121:  /* *norv64qi3 */
   11118         2757 :     case 8120:  /* *nandv8di3 */
   11119         2757 :     case 8119:  /* *norv8di3 */
   11120         2757 :     case 8118:  /* *nandv16si3 */
   11121         2757 :     case 8117:  /* *norv16si3 */
   11122         2757 :     case 2342:  /* mmx_packssdw */
   11123         2757 :     case 2340:  /* mmx_packsswb */
   11124         2757 :     case 653:  /* *umulqihi3_1_nf */
   11125         2757 :     case 651:  /* *mulqihi3_1_nf */
   11126         2757 :     case 649:  /* *mulditi3_1_nf */
   11127         2757 :     case 647:  /* *mulsidi3_1_nf */
   11128         2757 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   11129         2757 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   11130         2757 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   11131         2757 :       break;
   11132              : 
   11133       795932 :     case 654:  /* *umulqihi3_1 */
   11134       795932 :     case 652:  /* *mulqihi3_1 */
   11135       795932 :     case 650:  /* *mulditi3_1 */
   11136       795932 :     case 648:  /* *mulsidi3_1 */
   11137       795932 :     case 646:  /* *umulditi3_1 */
   11138       795932 :     case 645:  /* *umulsidi3_1 */
   11139       795932 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11140       795932 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11141       795932 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11142       795932 :       break;
   11143              : 
   11144      1208880 :     case 705:  /* *divmodsi4_const */
   11145      1208880 :     case 682:  /* *udivmoddi4_pow2 */
   11146      1208880 :     case 681:  /* *udivmodsi4_pow2 */
   11147      1208880 :     case 680:  /* *udivmoddi4 */
   11148      1208880 :     case 679:  /* *udivmodsi4 */
   11149      1208880 :     case 678:  /* *udivmodhi4 */
   11150      1208880 :     case 677:  /* *divmoddi4 */
   11151      1208880 :     case 676:  /* *divmodsi4 */
   11152      1208880 :     case 675:  /* *divmodhi4 */
   11153      1208880 :     case 670:  /* udivmoddi4_1 */
   11154      1208880 :     case 669:  /* udivmodsi4_1 */
   11155      1208880 :     case 668:  /* divmoddi4_1 */
   11156      1208880 :     case 667:  /* divmodsi4_1 */
   11157      1208880 :     case 644:  /* *bmi2_umulditi3_1 */
   11158      1208880 :     case 643:  /* *bmi2_umulsidi3_1 */
   11159      1208880 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11160      1208880 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11161      1208880 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11162      1208880 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11163      1208880 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11164      1208880 :       recog_data.dup_num[0] = 2;
   11165      1208880 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11166      1208880 :       recog_data.dup_num[1] = 3;
   11167      1208880 :       break;
   11168              : 
   11169       134500 :     case 640:  /* *umulvdi4 */
   11170       134500 :     case 639:  /* *umulvsi4 */
   11171       134500 :     case 638:  /* *umulvhi4 */
   11172       134500 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11173       134500 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   11174       134500 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   11175       134500 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 2), 0));
   11176       134500 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11177       134500 :       recog_data.dup_num[0] = 1;
   11178       134500 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11179       134500 :       recog_data.dup_num[1] = 2;
   11180       134500 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0);
   11181       134500 :       recog_data.dup_num[2] = 1;
   11182       134500 :       recog_data.dup_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1);
   11183       134500 :       recog_data.dup_num[3] = 2;
   11184       134500 :       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         5045 :     case 578:  /* *adddi3_cc_overflow_2 */
   11231         5045 :     case 577:  /* *addsi3_cc_overflow_2 */
   11232         5045 :     case 576:  /* *addhi3_cc_overflow_2 */
   11233         5045 :     case 575:  /* *addqi3_cc_overflow_2 */
   11234         5045 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11235         5045 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11236         5045 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11237         5045 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11238         5045 :       recog_data.dup_num[0] = 1;
   11239         5045 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11240         5045 :       recog_data.dup_num[1] = 2;
   11241         5045 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
   11242         5045 :       recog_data.dup_num[2] = 2;
   11243         5045 :       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       653181 :     case 581:  /* *addti3_doubleword_cc_overflow_1 */
   11269       653181 :     case 580:  /* *adddi3_doubleword_cc_overflow_1 */
   11270       653181 :     case 569:  /* adddi3_cc_overflow_1 */
   11271       653181 :     case 568:  /* addsi3_cc_overflow_1 */
   11272       653181 :     case 567:  /* addhi3_cc_overflow_1 */
   11273       653181 :     case 566:  /* addqi3_cc_overflow_1 */
   11274       653181 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11275       653181 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11276       653181 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11277       653181 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11278       653181 :       recog_data.dup_num[0] = 1;
   11279       653181 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11280       653181 :       recog_data.dup_num[1] = 2;
   11281       653181 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
   11282       653181 :       recog_data.dup_num[2] = 1;
   11283       653181 :       break;
   11284              : 
   11285       178997 :     case 565:  /* *adddi3_cconly_overflow_1 */
   11286       178997 :     case 564:  /* *addsi3_cconly_overflow_1 */
   11287       178997 :     case 563:  /* *addhi3_cconly_overflow_1 */
   11288       178997 :     case 562:  /* *addqi3_cconly_overflow_1 */
   11289       178997 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11290       178997 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11291       178997 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11292       178997 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1);
   11293       178997 :       recog_data.dup_num[0] = 1;
   11294       178997 :       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        93822 :     case 552:  /* subborrowdi */
   11312        93822 :     case 551:  /* subborrowsi */
   11313        93822 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11314        93822 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11315        93822 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 0));
   11316        93822 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0));
   11317        93822 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11318        93822 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1));
   11319        93822 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11320        93822 :       recog_data.dup_num[0] = 1;
   11321        93822 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1), 0);
   11322        93822 :       recog_data.dup_num[1] = 3;
   11323        93822 :       recog_data.dup_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11324        93822 :       recog_data.dup_num[2] = 2;
   11325        93822 :       break;
   11326              : 
   11327       100167 :     case 550:  /* subdi3_carry_ccgz */
   11328       100167 :     case 549:  /* subsi3_carry_ccgz */
   11329       100167 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11330       100167 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
   11331       100167 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
   11332       100167 :       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       341430 :     case 546:  /* subdi3_carry_ccc */
   11342       341430 :     case 545:  /* subsi3_carry_ccc */
   11343       341430 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11344       341430 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11345       341430 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 0));
   11346       341430 :       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        83482 :     case 506:  /* subdi3_carry */
   11400        83482 :     case 505:  /* subsi3_carry */
   11401        83482 :     case 504:  /* subhi3_carry */
   11402        83482 :     case 503:  /* subqi3_carry */
   11403        83482 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11404        83482 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11405        83482 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11406        83482 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   11407        83482 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11408        83482 :       break;
   11409              : 
   11410         4252 :     case 502:  /* *addcarrydi_1 */
   11411         4252 :     case 501:  /* *addcarrysi_1 */
   11412         4252 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11413         4252 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 1));
   11414         4252 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   11415         4252 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0), 0));
   11416         4252 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11417         4252 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   11418         4252 :       ro[6] = *(ro_loc[6] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1));
   11419         4252 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11420         4252 :       recog_data.dup_num[0] = 5;
   11421         4252 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0), 0);
   11422         4252 :       recog_data.dup_num[1] = 3;
   11423         4252 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   11424         4252 :       recog_data.dup_num[2] = 1;
   11425         4252 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11426         4252 :       recog_data.dup_num[3] = 2;
   11427         4252 :       recog_data.dup_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0);
   11428         4252 :       recog_data.dup_num[4] = 3;
   11429         4252 :       break;
   11430              : 
   11431       161416 :     case 500:  /* addcarrydi */
   11432       161416 :     case 499:  /* addcarrysi */
   11433       161416 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11434       161416 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 1));
   11435       161416 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   11436       161416 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0), 0));
   11437       161416 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11438       161416 :       ro[5] = *(ro_loc[5] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   11439       161416 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11440       161416 :       recog_data.dup_num[0] = 5;
   11441       161416 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0), 0);
   11442       161416 :       recog_data.dup_num[1] = 3;
   11443       161416 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   11444       161416 :       recog_data.dup_num[2] = 1;
   11445       161416 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11446       161416 :       recog_data.dup_num[3] = 2;
   11447       161416 :       recog_data.dup_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0);
   11448       161416 :       recog_data.dup_num[4] = 3;
   11449       161416 :       recog_data.dup_loc[5] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 1), 0);
   11450       161416 :       recog_data.dup_num[5] = 2;
   11451       161416 :       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        36471 :     case 476:  /* *adddi3_carry_0r */
   11503        36471 :     case 475:  /* *addsi3_carry_0r */
   11504        36471 :     case 474:  /* *addhi3_carry_0r */
   11505        36471 :     case 473:  /* *addqi3_carry_0r */
   11506        36471 :     case 468:  /* *adddi3_carry_0 */
   11507        36471 :     case 467:  /* *addsi3_carry_0 */
   11508        36471 :     case 466:  /* *addhi3_carry_0 */
   11509        36471 :     case 465:  /* *addqi3_carry_0 */
   11510        36471 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11511        36471 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11512        36471 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11513        36471 :       break;
   11514              : 
   11515        18194 :     case 464:  /* *adddi3_carry_2 */
   11516        18194 :     case 463:  /* *addsi3_carry_2 */
   11517        18194 :     case 462:  /* *addhi3_carry_2 */
   11518        18194 :     case 461:  /* *addqi3_carry_2 */
   11519        18194 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11520        18194 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   11521        18194 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11522        18194 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   11523        18194 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   11524        18194 :       recog_data.dup_loc[0] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0);
   11525        18194 :       recog_data.dup_num[0] = 4;
   11526        18194 :       recog_data.dup_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 0), 0);
   11527        18194 :       recog_data.dup_num[1] = 3;
   11528        18194 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0), 1);
   11529        18194 :       recog_data.dup_num[2] = 1;
   11530        18194 :       recog_data.dup_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11531        18194 :       recog_data.dup_num[3] = 2;
   11532        18194 :       break;
   11533              : 
   11534       357044 :     case 460:  /* adddi3_carry */
   11535       357044 :     case 459:  /* addsi3_carry */
   11536       357044 :     case 458:  /* addhi3_carry */
   11537       357044 :     case 457:  /* addqi3_carry */
   11538       357044 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11539       357044 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   11540       357044 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11541       357044 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   11542       357044 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   11543       357044 :       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       173575 :     case 452:  /* *subdi_3 */
   11567       173575 :     case 451:  /* *subsi_3 */
   11568       173575 :     case 450:  /* *subhi_3 */
   11569       173575 :     case 449:  /* *subqi_3 */
   11570       173575 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   11571       173575 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11572       173575 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   11573       173575 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   11574       173575 :       recog_data.dup_num[0] = 1;
   11575       173575 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   11576       173575 :       recog_data.dup_num[1] = 2;
   11577       173575 :       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        23716 :     case 617:  /* *subdi3_ne_0 */
   11649        23716 :     case 616:  /* *subsi3_ne_0 */
   11650        23716 :     case 615:  /* *subhi3_ne_0 */
   11651        23716 :     case 614:  /* *subqi3_ne_0 */
   11652        23716 :     case 613:  /* *subdi3_eq_0 */
   11653        23716 :     case 612:  /* *subsi3_eq_0 */
   11654        23716 :     case 611:  /* *subhi3_eq_0 */
   11655        23716 :     case 610:  /* *subqi3_eq_0 */
   11656        23716 :     case 387:  /* *subti3_doubleword_zext */
   11657        23716 :     case 386:  /* *subdi3_doubleword_zext */
   11658        23716 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   11659        23716 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   11660        23716 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   11661        23716 :       break;
   11662              : 
   11663          517 :     case 7921:  /* *eqv2di3_2_negate */
   11664          517 :     case 7920:  /* *eqv4di3_2_negate */
   11665          517 :     case 7919:  /* *eqv4si3_2_negate */
   11666          517 :     case 7918:  /* *eqv8si3_2_negate */
   11667          517 :     case 7917:  /* *eqv8hi3_2_negate */
   11668          517 :     case 7916:  /* *eqv16hi3_2_negate */
   11669          517 :     case 7915:  /* *eqv16qi3_2_negate */
   11670          517 :     case 7914:  /* *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        47043 :     case 9030:  /* xop_pmacssdd */
   12331        47043 :     case 9029:  /* xop_pmacsdd */
   12332        47043 :     case 9028:  /* xop_pmacssww */
   12333        47043 :     case 9027:  /* xop_pmacsww */
   12334        47043 :     case 7706:  /* *avx2_lshrv2di3_2 */
   12335        47043 :     case 7705:  /* *avx2_lshrv4di3_2 */
   12336        47043 :     case 7704:  /* *avx2_lshrv2di3_1 */
   12337        47043 :     case 7703:  /* *avx2_lshrv4di3_1 */
   12338        47043 :     case 7036:  /* *avx512vl_vpternlogv2df_3 */
   12339        47043 :     case 7035:  /* *avx512vl_vpternlogv2df_3 */
   12340        47043 :     case 7034:  /* *avx512vl_vpternlogv2df_3 */
   12341        47043 :     case 7033:  /* *avx512vl_vpternlogv2df_3 */
   12342        47043 :     case 7032:  /* *avx512vl_vpternlogv2df_3 */
   12343        47043 :     case 7031:  /* *avx512vl_vpternlogv2df_3 */
   12344        47043 :     case 7030:  /* *avx512vl_vpternlogv2df_3 */
   12345        47043 :     case 7029:  /* *avx512vl_vpternlogv2df_3 */
   12346        47043 :     case 7028:  /* *avx512vl_vpternlogv2df_3 */
   12347        47043 :     case 7027:  /* *avx512vl_vpternlogv4df_3 */
   12348        47043 :     case 7026:  /* *avx512vl_vpternlogv4df_3 */
   12349        47043 :     case 7025:  /* *avx512vl_vpternlogv4df_3 */
   12350        47043 :     case 7024:  /* *avx512vl_vpternlogv4df_3 */
   12351        47043 :     case 7023:  /* *avx512vl_vpternlogv4df_3 */
   12352        47043 :     case 7022:  /* *avx512vl_vpternlogv4df_3 */
   12353        47043 :     case 7021:  /* *avx512vl_vpternlogv4df_3 */
   12354        47043 :     case 7020:  /* *avx512vl_vpternlogv4df_3 */
   12355        47043 :     case 7019:  /* *avx512vl_vpternlogv4df_3 */
   12356        47043 :     case 7018:  /* *avx512f_vpternlogv8df_3 */
   12357        47043 :     case 7017:  /* *avx512f_vpternlogv8df_3 */
   12358        47043 :     case 7016:  /* *avx512f_vpternlogv8df_3 */
   12359        47043 :     case 7015:  /* *avx512f_vpternlogv8df_3 */
   12360        47043 :     case 7014:  /* *avx512f_vpternlogv8df_3 */
   12361        47043 :     case 7013:  /* *avx512f_vpternlogv8df_3 */
   12362        47043 :     case 7012:  /* *avx512f_vpternlogv8df_3 */
   12363        47043 :     case 7011:  /* *avx512f_vpternlogv8df_3 */
   12364        47043 :     case 7010:  /* *avx512f_vpternlogv8df_3 */
   12365        47043 :     case 7009:  /* *avx512vl_vpternlogv4sf_3 */
   12366        47043 :     case 7008:  /* *avx512vl_vpternlogv4sf_3 */
   12367        47043 :     case 7007:  /* *avx512vl_vpternlogv4sf_3 */
   12368        47043 :     case 7006:  /* *avx512vl_vpternlogv4sf_3 */
   12369        47043 :     case 7005:  /* *avx512vl_vpternlogv4sf_3 */
   12370        47043 :     case 7004:  /* *avx512vl_vpternlogv4sf_3 */
   12371        47043 :     case 7003:  /* *avx512vl_vpternlogv4sf_3 */
   12372        47043 :     case 7002:  /* *avx512vl_vpternlogv4sf_3 */
   12373        47043 :     case 7001:  /* *avx512vl_vpternlogv4sf_3 */
   12374        47043 :     case 7000:  /* *avx512vl_vpternlogv8sf_3 */
   12375        47043 :     case 6999:  /* *avx512vl_vpternlogv8sf_3 */
   12376        47043 :     case 6998:  /* *avx512vl_vpternlogv8sf_3 */
   12377        47043 :     case 6997:  /* *avx512vl_vpternlogv8sf_3 */
   12378        47043 :     case 6996:  /* *avx512vl_vpternlogv8sf_3 */
   12379        47043 :     case 6995:  /* *avx512vl_vpternlogv8sf_3 */
   12380        47043 :     case 6994:  /* *avx512vl_vpternlogv8sf_3 */
   12381        47043 :     case 6993:  /* *avx512vl_vpternlogv8sf_3 */
   12382        47043 :     case 6992:  /* *avx512vl_vpternlogv8sf_3 */
   12383        47043 :     case 6991:  /* *avx512f_vpternlogv16sf_3 */
   12384        47043 :     case 6990:  /* *avx512f_vpternlogv16sf_3 */
   12385        47043 :     case 6989:  /* *avx512f_vpternlogv16sf_3 */
   12386        47043 :     case 6988:  /* *avx512f_vpternlogv16sf_3 */
   12387        47043 :     case 6987:  /* *avx512f_vpternlogv16sf_3 */
   12388        47043 :     case 6986:  /* *avx512f_vpternlogv16sf_3 */
   12389        47043 :     case 6985:  /* *avx512f_vpternlogv16sf_3 */
   12390        47043 :     case 6984:  /* *avx512f_vpternlogv16sf_3 */
   12391        47043 :     case 6983:  /* *avx512f_vpternlogv16sf_3 */
   12392        47043 :     case 6982:  /* *avx512vl_vpternlogv8bf_3 */
   12393        47043 :     case 6981:  /* *avx512vl_vpternlogv8bf_3 */
   12394        47043 :     case 6980:  /* *avx512vl_vpternlogv8bf_3 */
   12395        47043 :     case 6979:  /* *avx512vl_vpternlogv8bf_3 */
   12396        47043 :     case 6978:  /* *avx512vl_vpternlogv8bf_3 */
   12397        47043 :     case 6977:  /* *avx512vl_vpternlogv8bf_3 */
   12398        47043 :     case 6976:  /* *avx512vl_vpternlogv8bf_3 */
   12399        47043 :     case 6975:  /* *avx512vl_vpternlogv8bf_3 */
   12400        47043 :     case 6974:  /* *avx512vl_vpternlogv8bf_3 */
   12401        47043 :     case 6973:  /* *avx512vl_vpternlogv16bf_3 */
   12402        47043 :     case 6972:  /* *avx512vl_vpternlogv16bf_3 */
   12403        47043 :     case 6971:  /* *avx512vl_vpternlogv16bf_3 */
   12404        47043 :     case 6970:  /* *avx512vl_vpternlogv16bf_3 */
   12405        47043 :     case 6969:  /* *avx512vl_vpternlogv16bf_3 */
   12406        47043 :     case 6968:  /* *avx512vl_vpternlogv16bf_3 */
   12407        47043 :     case 6967:  /* *avx512vl_vpternlogv16bf_3 */
   12408        47043 :     case 6966:  /* *avx512vl_vpternlogv16bf_3 */
   12409        47043 :     case 6965:  /* *avx512vl_vpternlogv16bf_3 */
   12410        47043 :     case 6964:  /* *avx512bw_vpternlogv32bf_3 */
   12411        47043 :     case 6963:  /* *avx512bw_vpternlogv32bf_3 */
   12412        47043 :     case 6962:  /* *avx512bw_vpternlogv32bf_3 */
   12413        47043 :     case 6961:  /* *avx512bw_vpternlogv32bf_3 */
   12414        47043 :     case 6960:  /* *avx512bw_vpternlogv32bf_3 */
   12415        47043 :     case 6959:  /* *avx512bw_vpternlogv32bf_3 */
   12416        47043 :     case 6958:  /* *avx512bw_vpternlogv32bf_3 */
   12417        47043 :     case 6957:  /* *avx512bw_vpternlogv32bf_3 */
   12418        47043 :     case 6956:  /* *avx512bw_vpternlogv32bf_3 */
   12419        47043 :     case 6955:  /* *avx512fp16_vpternlogv8hf_3 */
   12420        47043 :     case 6954:  /* *avx512fp16_vpternlogv8hf_3 */
   12421        47043 :     case 6953:  /* *avx512fp16_vpternlogv8hf_3 */
   12422        47043 :     case 6952:  /* *avx512fp16_vpternlogv8hf_3 */
   12423        47043 :     case 6951:  /* *avx512fp16_vpternlogv8hf_3 */
   12424        47043 :     case 6950:  /* *avx512fp16_vpternlogv8hf_3 */
   12425        47043 :     case 6949:  /* *avx512fp16_vpternlogv8hf_3 */
   12426        47043 :     case 6948:  /* *avx512fp16_vpternlogv8hf_3 */
   12427        47043 :     case 6947:  /* *avx512fp16_vpternlogv8hf_3 */
   12428        47043 :     case 6946:  /* *avx512vl_vpternlogv16hf_3 */
   12429        47043 :     case 6945:  /* *avx512vl_vpternlogv16hf_3 */
   12430        47043 :     case 6944:  /* *avx512vl_vpternlogv16hf_3 */
   12431        47043 :     case 6943:  /* *avx512vl_vpternlogv16hf_3 */
   12432        47043 :     case 6942:  /* *avx512vl_vpternlogv16hf_3 */
   12433        47043 :     case 6941:  /* *avx512vl_vpternlogv16hf_3 */
   12434        47043 :     case 6940:  /* *avx512vl_vpternlogv16hf_3 */
   12435        47043 :     case 6939:  /* *avx512vl_vpternlogv16hf_3 */
   12436        47043 :     case 6938:  /* *avx512vl_vpternlogv16hf_3 */
   12437        47043 :     case 6937:  /* *avx512bw_vpternlogv32hf_3 */
   12438        47043 :     case 6936:  /* *avx512bw_vpternlogv32hf_3 */
   12439        47043 :     case 6935:  /* *avx512bw_vpternlogv32hf_3 */
   12440        47043 :     case 6934:  /* *avx512bw_vpternlogv32hf_3 */
   12441        47043 :     case 6933:  /* *avx512bw_vpternlogv32hf_3 */
   12442        47043 :     case 6932:  /* *avx512bw_vpternlogv32hf_3 */
   12443        47043 :     case 6931:  /* *avx512bw_vpternlogv32hf_3 */
   12444        47043 :     case 6930:  /* *avx512bw_vpternlogv32hf_3 */
   12445        47043 :     case 6929:  /* *avx512bw_vpternlogv32hf_3 */
   12446        47043 :     case 6928:  /* *avx512vl_vpternlogv2di_3 */
   12447        47043 :     case 6927:  /* *avx512vl_vpternlogv2di_3 */
   12448        47043 :     case 6926:  /* *avx512vl_vpternlogv2di_3 */
   12449        47043 :     case 6925:  /* *avx512vl_vpternlogv2di_3 */
   12450        47043 :     case 6924:  /* *avx512vl_vpternlogv2di_3 */
   12451        47043 :     case 6923:  /* *avx512vl_vpternlogv2di_3 */
   12452        47043 :     case 6922:  /* *avx512vl_vpternlogv2di_3 */
   12453        47043 :     case 6921:  /* *avx512vl_vpternlogv2di_3 */
   12454        47043 :     case 6920:  /* *avx512vl_vpternlogv2di_3 */
   12455        47043 :     case 6919:  /* *avx512vl_vpternlogv4di_3 */
   12456        47043 :     case 6918:  /* *avx512vl_vpternlogv4di_3 */
   12457        47043 :     case 6917:  /* *avx512vl_vpternlogv4di_3 */
   12458        47043 :     case 6916:  /* *avx512vl_vpternlogv4di_3 */
   12459        47043 :     case 6915:  /* *avx512vl_vpternlogv4di_3 */
   12460        47043 :     case 6914:  /* *avx512vl_vpternlogv4di_3 */
   12461        47043 :     case 6913:  /* *avx512vl_vpternlogv4di_3 */
   12462        47043 :     case 6912:  /* *avx512vl_vpternlogv4di_3 */
   12463        47043 :     case 6911:  /* *avx512vl_vpternlogv4di_3 */
   12464        47043 :     case 6910:  /* *avx512f_vpternlogv8di_3 */
   12465        47043 :     case 6909:  /* *avx512f_vpternlogv8di_3 */
   12466        47043 :     case 6908:  /* *avx512f_vpternlogv8di_3 */
   12467        47043 :     case 6907:  /* *avx512f_vpternlogv8di_3 */
   12468        47043 :     case 6906:  /* *avx512f_vpternlogv8di_3 */
   12469        47043 :     case 6905:  /* *avx512f_vpternlogv8di_3 */
   12470        47043 :     case 6904:  /* *avx512f_vpternlogv8di_3 */
   12471        47043 :     case 6903:  /* *avx512f_vpternlogv8di_3 */
   12472        47043 :     case 6902:  /* *avx512f_vpternlogv8di_3 */
   12473        47043 :     case 6901:  /* *avx512vl_vpternlogv4si_3 */
   12474        47043 :     case 6900:  /* *avx512vl_vpternlogv4si_3 */
   12475        47043 :     case 6899:  /* *avx512vl_vpternlogv4si_3 */
   12476        47043 :     case 6898:  /* *avx512vl_vpternlogv4si_3 */
   12477        47043 :     case 6897:  /* *avx512vl_vpternlogv4si_3 */
   12478        47043 :     case 6896:  /* *avx512vl_vpternlogv4si_3 */
   12479        47043 :     case 6895:  /* *avx512vl_vpternlogv4si_3 */
   12480        47043 :     case 6894:  /* *avx512vl_vpternlogv4si_3 */
   12481        47043 :     case 6893:  /* *avx512vl_vpternlogv4si_3 */
   12482        47043 :     case 6892:  /* *avx512vl_vpternlogv8si_3 */
   12483        47043 :     case 6891:  /* *avx512vl_vpternlogv8si_3 */
   12484        47043 :     case 6890:  /* *avx512vl_vpternlogv8si_3 */
   12485        47043 :     case 6889:  /* *avx512vl_vpternlogv8si_3 */
   12486        47043 :     case 6888:  /* *avx512vl_vpternlogv8si_3 */
   12487        47043 :     case 6887:  /* *avx512vl_vpternlogv8si_3 */
   12488        47043 :     case 6886:  /* *avx512vl_vpternlogv8si_3 */
   12489        47043 :     case 6885:  /* *avx512vl_vpternlogv8si_3 */
   12490        47043 :     case 6884:  /* *avx512vl_vpternlogv8si_3 */
   12491        47043 :     case 6883:  /* *avx512f_vpternlogv16si_3 */
   12492        47043 :     case 6882:  /* *avx512f_vpternlogv16si_3 */
   12493        47043 :     case 6881:  /* *avx512f_vpternlogv16si_3 */
   12494        47043 :     case 6880:  /* *avx512f_vpternlogv16si_3 */
   12495        47043 :     case 6879:  /* *avx512f_vpternlogv16si_3 */
   12496        47043 :     case 6878:  /* *avx512f_vpternlogv16si_3 */
   12497        47043 :     case 6877:  /* *avx512f_vpternlogv16si_3 */
   12498        47043 :     case 6876:  /* *avx512f_vpternlogv16si_3 */
   12499        47043 :     case 6875:  /* *avx512f_vpternlogv16si_3 */
   12500        47043 :     case 6874:  /* *avx512vl_vpternlogv8hi_3 */
   12501        47043 :     case 6873:  /* *avx512vl_vpternlogv8hi_3 */
   12502        47043 :     case 6872:  /* *avx512vl_vpternlogv8hi_3 */
   12503        47043 :     case 6871:  /* *avx512vl_vpternlogv8hi_3 */
   12504        47043 :     case 6870:  /* *avx512vl_vpternlogv8hi_3 */
   12505        47043 :     case 6869:  /* *avx512vl_vpternlogv8hi_3 */
   12506        47043 :     case 6868:  /* *avx512vl_vpternlogv8hi_3 */
   12507        47043 :     case 6867:  /* *avx512vl_vpternlogv8hi_3 */
   12508        47043 :     case 6866:  /* *avx512vl_vpternlogv8hi_3 */
   12509        47043 :     case 6865:  /* *avx512vl_vpternlogv16hi_3 */
   12510        47043 :     case 6864:  /* *avx512vl_vpternlogv16hi_3 */
   12511        47043 :     case 6863:  /* *avx512vl_vpternlogv16hi_3 */
   12512        47043 :     case 6862:  /* *avx512vl_vpternlogv16hi_3 */
   12513        47043 :     case 6861:  /* *avx512vl_vpternlogv16hi_3 */
   12514        47043 :     case 6860:  /* *avx512vl_vpternlogv16hi_3 */
   12515        47043 :     case 6859:  /* *avx512vl_vpternlogv16hi_3 */
   12516        47043 :     case 6858:  /* *avx512vl_vpternlogv16hi_3 */
   12517        47043 :     case 6857:  /* *avx512vl_vpternlogv16hi_3 */
   12518        47043 :     case 6856:  /* *avx512bw_vpternlogv32hi_3 */
   12519        47043 :     case 6855:  /* *avx512bw_vpternlogv32hi_3 */
   12520        47043 :     case 6854:  /* *avx512bw_vpternlogv32hi_3 */
   12521        47043 :     case 6853:  /* *avx512bw_vpternlogv32hi_3 */
   12522        47043 :     case 6852:  /* *avx512bw_vpternlogv32hi_3 */
   12523        47043 :     case 6851:  /* *avx512bw_vpternlogv32hi_3 */
   12524        47043 :     case 6850:  /* *avx512bw_vpternlogv32hi_3 */
   12525        47043 :     case 6849:  /* *avx512bw_vpternlogv32hi_3 */
   12526        47043 :     case 6848:  /* *avx512bw_vpternlogv32hi_3 */
   12527        47043 :     case 6847:  /* *avx512vl_vpternlogv16qi_3 */
   12528        47043 :     case 6846:  /* *avx512vl_vpternlogv16qi_3 */
   12529        47043 :     case 6845:  /* *avx512vl_vpternlogv16qi_3 */
   12530        47043 :     case 6844:  /* *avx512vl_vpternlogv16qi_3 */
   12531        47043 :     case 6843:  /* *avx512vl_vpternlogv16qi_3 */
   12532        47043 :     case 6842:  /* *avx512vl_vpternlogv16qi_3 */
   12533        47043 :     case 6841:  /* *avx512vl_vpternlogv16qi_3 */
   12534        47043 :     case 6840:  /* *avx512vl_vpternlogv16qi_3 */
   12535        47043 :     case 6839:  /* *avx512vl_vpternlogv16qi_3 */
   12536        47043 :     case 6838:  /* *avx512vl_vpternlogv32qi_3 */
   12537        47043 :     case 6837:  /* *avx512vl_vpternlogv32qi_3 */
   12538        47043 :     case 6836:  /* *avx512vl_vpternlogv32qi_3 */
   12539        47043 :     case 6835:  /* *avx512vl_vpternlogv32qi_3 */
   12540        47043 :     case 6834:  /* *avx512vl_vpternlogv32qi_3 */
   12541        47043 :     case 6833:  /* *avx512vl_vpternlogv32qi_3 */
   12542        47043 :     case 6832:  /* *avx512vl_vpternlogv32qi_3 */
   12543        47043 :     case 6831:  /* *avx512vl_vpternlogv32qi_3 */
   12544        47043 :     case 6830:  /* *avx512vl_vpternlogv32qi_3 */
   12545        47043 :     case 6829:  /* *avx512bw_vpternlogv64qi_3 */
   12546        47043 :     case 6828:  /* *avx512bw_vpternlogv64qi_3 */
   12547        47043 :     case 6827:  /* *avx512bw_vpternlogv64qi_3 */
   12548        47043 :     case 6826:  /* *avx512bw_vpternlogv64qi_3 */
   12549        47043 :     case 6825:  /* *avx512bw_vpternlogv64qi_3 */
   12550        47043 :     case 6824:  /* *avx512bw_vpternlogv64qi_3 */
   12551        47043 :     case 6823:  /* *avx512bw_vpternlogv64qi_3 */
   12552        47043 :     case 6822:  /* *avx512bw_vpternlogv64qi_3 */
   12553        47043 :     case 6821:  /* *avx512bw_vpternlogv64qi_3 */
   12554        47043 :     case 1315:  /* *extendv2di2_highpart_stv_noavx512vl */
   12555        47043 :     case 1314:  /* *extendv2di2_highpart_stv */
   12556        47043 :     case 965:  /* *concatditi3_5 */
   12557        47043 :     case 964:  /* *concatditi3_5 */
   12558        47043 :     case 963:  /* *concatditi3_5 */
   12559        47043 :     case 962:  /* *concatsidi3_5 */
   12560        47043 :     case 961:  /* *concatsidi3_5 */
   12561        47043 :     case 960:  /* *concatsidi3_5 */
   12562        47043 :     case 383:  /* *leadi_general_4 */
   12563        47043 :     case 382:  /* *leadi_general_4 */
   12564        47043 :     case 381:  /* *leasi_general_4 */
   12565        47043 :     case 380:  /* *leasi_general_4 */
   12566        47043 :     case 379:  /* *leahi_general_4 */
   12567        47043 :     case 378:  /* *leahi_general_4 */
   12568        47043 :     case 377:  /* *leaqi_general_4 */
   12569        47043 :     case 376:  /* *leaqi_general_4 */
   12570        47043 :     case 371:  /* *leahi_general_2b */
   12571        47043 :     case 370:  /* *leaqi_general_2b */
   12572        47043 :     case 369:  /* *leahi_general_2 */
   12573        47043 :     case 368:  /* *leaqi_general_2 */
   12574        47043 :     case 367:  /* *leahi_general_1 */
   12575        47043 :     case 366:  /* *leaqi_general_1 */
   12576        47043 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   12577        47043 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   12578        47043 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   12579        47043 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (pat, 1), 1));
   12580        47043 :       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       109688 :     case 637:  /* *mulvdi4_1 */
   12634       109688 :     case 636:  /* *mulvsi4_1 */
   12635       109688 :     case 635:  /* *mulvhi4_1 */
   12636       109688 :     case 440:  /* *subvti4_doubleword_1 */
   12637       109688 :     case 439:  /* *subvdi4_doubleword_1 */
   12638       109688 :     case 436:  /* subvdi4_1 */
   12639       109688 :     case 435:  /* subvsi4_1 */
   12640       109688 :     case 434:  /* subvhi4_1 */
   12641       109688 :     case 433:  /* subvqi4_1 */
   12642       109688 :     case 357:  /* *addvti4_doubleword_1 */
   12643       109688 :     case 356:  /* *addvdi4_doubleword_1 */
   12644       109688 :     case 353:  /* addvdi4_1 */
   12645       109688 :     case 352:  /* addvsi4_1 */
   12646       109688 :     case 351:  /* addvhi4_1 */
   12647       109688 :     case 350:  /* addvqi4_1 */
   12648       109688 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12649       109688 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12650       109688 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1));
   12651       109688 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   12652       109688 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   12653       109688 :       recog_data.dup_num[0] = 1;
   12654       109688 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   12655       109688 :       recog_data.dup_num[1] = 2;
   12656       109688 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0);
   12657       109688 :       recog_data.dup_num[2] = 1;
   12658       109688 :       break;
   12659              : 
   12660       255862 :     case 642:  /* *umulvqi4 */
   12661       255862 :     case 641:  /* *mulvqi4 */
   12662       255862 :     case 634:  /* *mulvhi4 */
   12663       255862 :     case 633:  /* *mulvdi4 */
   12664       255862 :     case 632:  /* *mulvsi4 */
   12665       255862 :     case 438:  /* *subvti4_doubleword */
   12666       255862 :     case 437:  /* *subvdi4_doubleword */
   12667       255862 :     case 432:  /* *subvdi4 */
   12668       255862 :     case 431:  /* *subvsi4 */
   12669       255862 :     case 430:  /* *subvhi4 */
   12670       255862 :     case 429:  /* *subvqi4 */
   12671       255862 :     case 355:  /* *addvti4_doubleword */
   12672       255862 :     case 354:  /* *addvdi4_doubleword */
   12673       255862 :     case 349:  /* *addvdi4 */
   12674       255862 :     case 348:  /* *addvsi4 */
   12675       255862 :     case 347:  /* *addvhi4 */
   12676       255862 :     case 346:  /* *addvqi4 */
   12677       255862 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12678       255862 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12679       255862 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   12680       255862 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   12681       255862 :       recog_data.dup_num[0] = 1;
   12682       255862 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   12683       255862 :       recog_data.dup_num[1] = 2;
   12684       255862 :       recog_data.dup_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 0);
   12685       255862 :       recog_data.dup_num[2] = 1;
   12686       255862 :       recog_data.dup_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0), 1);
   12687       255862 :       recog_data.dup_num[3] = 2;
   12688       255862 :       break;
   12689              : 
   12690         2444 :     case 827:  /* *xorqi_extdi_2 */
   12691         2444 :     case 826:  /* *iorqi_extdi_2 */
   12692         2444 :     case 825:  /* *andqi_extdi_2 */
   12693         2444 :     case 824:  /* *xorqi_extsi_2 */
   12694         2444 :     case 823:  /* *iorqi_extsi_2 */
   12695         2444 :     case 822:  /* *andqi_extsi_2 */
   12696         2444 :     case 821:  /* *xorqi_exthi_2 */
   12697         2444 :     case 820:  /* *iorqi_exthi_2 */
   12698         2444 :     case 819:  /* *andqi_exthi_2 */
   12699         2444 :     case 345:  /* *subqi_extdi_2 */
   12700         2444 :     case 344:  /* *addqi_extdi_2 */
   12701         2444 :     case 343:  /* *subqi_extsi_2 */
   12702         2444 :     case 342:  /* *addqi_extsi_2 */
   12703         2444 :     case 341:  /* *subqi_exthi_2 */
   12704         2444 :     case 340:  /* *addqi_exthi_2 */
   12705         2444 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   12706         2444 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   12707         2444 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0), 0));
   12708         2444 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12709         2444 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   12710         2444 :       break;
   12711              : 
   12712        43330 :     case 1275:  /* *ashrqi_extdi_1 */
   12713        43330 :     case 1274:  /* *lshrqi_extdi_1 */
   12714        43330 :     case 1273:  /* *ashrqi_extsi_1 */
   12715        43330 :     case 1272:  /* *lshrqi_extsi_1 */
   12716        43330 :     case 1271:  /* *ashrqi_exthi_1 */
   12717        43330 :     case 1270:  /* *lshrqi_exthi_1 */
   12718        43330 :     case 1153:  /* *ashlqi_extdi_1 */
   12719        43330 :     case 1152:  /* *ashlqi_extsi_1 */
   12720        43330 :     case 1151:  /* *ashlqi_exthi_1 */
   12721        43330 :     case 809:  /* *xorqi_extdi_1 */
   12722        43330 :     case 808:  /* *iorqi_extdi_1 */
   12723        43330 :     case 807:  /* *andqi_extdi_1 */
   12724        43330 :     case 806:  /* *xorqi_extsi_1 */
   12725        43330 :     case 805:  /* *iorqi_extsi_1 */
   12726        43330 :     case 804:  /* *andqi_extsi_1 */
   12727        43330 :     case 803:  /* *xorqi_exthi_1 */
   12728        43330 :     case 802:  /* *iorqi_exthi_1 */
   12729        43330 :     case 801:  /* *andqi_exthi_1 */
   12730        43330 :     case 428:  /* *subqi_extdi_1 */
   12731        43330 :     case 427:  /* *subqi_extsi_1 */
   12732        43330 :     case 426:  /* *subqi_exthi_1 */
   12733        43330 :     case 339:  /* *addqi_extdi_1 */
   12734        43330 :     case 338:  /* *addqi_extsi_1 */
   12735        43330 :     case 337:  /* *addqi_exthi_1 */
   12736        43330 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   12737        43330 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   12738        43330 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   12739        43330 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12740        43330 :       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         2569 :     case 791:  /* *xorqi_extdi_0 */
   12765         2569 :     case 790:  /* *iorqi_extdi_0 */
   12766         2569 :     case 789:  /* *andqi_extdi_0 */
   12767         2569 :     case 788:  /* *xorqi_extsi_0 */
   12768         2569 :     case 787:  /* *iorqi_extsi_0 */
   12769         2569 :     case 786:  /* *andqi_extsi_0 */
   12770         2569 :     case 785:  /* *xorqi_exthi_0 */
   12771         2569 :     case 784:  /* *iorqi_exthi_0 */
   12772         2569 :     case 783:  /* *andqi_exthi_0 */
   12773         2569 :     case 333:  /* *addqi_extdi_0 */
   12774         2569 :     case 332:  /* *addqi_extsi_0 */
   12775         2569 :     case 331:  /* *addqi_exthi_0 */
   12776         2569 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   12777         2569 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   12778         2569 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0));
   12779         2569 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12780         2569 :       break;
   12781              : 
   12782       533558 :     case 1269:  /* *ashrdi3_cconly */
   12783       533558 :     case 1268:  /* *lshrdi3_cconly */
   12784       533558 :     case 1267:  /* *ashrsi3_cconly */
   12785       533558 :     case 1266:  /* *lshrsi3_cconly */
   12786       533558 :     case 1265:  /* *ashrhi3_cconly */
   12787       533558 :     case 1264:  /* *lshrhi3_cconly */
   12788       533558 :     case 1263:  /* *ashrqi3_cconly */
   12789       533558 :     case 1262:  /* *lshrqi3_cconly */
   12790       533558 :     case 1150:  /* *ashldi3_cconly */
   12791       533558 :     case 1149:  /* *ashlsi3_cconly */
   12792       533558 :     case 1148:  /* *ashlhi3_cconly */
   12793       533558 :     case 1147:  /* *ashlqi3_cconly */
   12794       533558 :     case 923:  /* *xordi_3 */
   12795       533558 :     case 922:  /* *iordi_3 */
   12796       533558 :     case 921:  /* *xorsi_3 */
   12797       533558 :     case 920:  /* *iorsi_3 */
   12798       533558 :     case 919:  /* *xorhi_3 */
   12799       533558 :     case 918:  /* *iorhi_3 */
   12800       533558 :     case 917:  /* *xorqi_3 */
   12801       533558 :     case 916:  /* *iorqi_3 */
   12802       533558 :     case 915:  /* *iordi_ccz_1 */
   12803       533558 :     case 914:  /* *iorsi_ccz_1 */
   12804       533558 :     case 913:  /* *iorhi_ccz_1 */
   12805       533558 :     case 912:  /* *iorqi_ccz_1 */
   12806       533558 :     case 330:  /* *adddi_5 */
   12807       533558 :     case 329:  /* *addsi_5 */
   12808       533558 :     case 328:  /* *addhi_5 */
   12809       533558 :     case 327:  /* *addqi_5 */
   12810       533558 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12811       533558 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12812       533558 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   12813       533558 :       break;
   12814              : 
   12815        77927 :     case 326:  /* *addsi_4 */
   12816        77927 :     case 325:  /* *addhi_4 */
   12817        77927 :     case 324:  /* *addqi_4 */
   12818        77927 :     case 323:  /* *adddi_4 */
   12819        77927 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12820        77927 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   12821        77927 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   12822        77927 :       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        39465 :     case 321:  /* *adddi_3 */
   12835        39465 :     case 320:  /* *addsi_3 */
   12836        39465 :     case 319:  /* *addhi_3 */
   12837        39465 :     case 318:  /* *addqi_3 */
   12838        39465 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12839        39465 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   12840        39465 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12841        39465 :       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      3184548 :     case 1259:  /* *ashrdi3_cmp */
   12861      3184548 :     case 1258:  /* *lshrdi3_cmp */
   12862      3184548 :     case 1257:  /* *ashrsi3_cmp */
   12863      3184548 :     case 1256:  /* *lshrsi3_cmp */
   12864      3184548 :     case 1255:  /* *ashrhi3_cmp */
   12865      3184548 :     case 1254:  /* *lshrhi3_cmp */
   12866      3184548 :     case 1253:  /* *ashrqi3_cmp */
   12867      3184548 :     case 1252:  /* *lshrqi3_cmp */
   12868      3184548 :     case 1145:  /* *ashldi3_cmp */
   12869      3184548 :     case 1144:  /* *ashlsi3_cmp */
   12870      3184548 :     case 1143:  /* *ashlhi3_cmp */
   12871      3184548 :     case 1142:  /* *ashlqi3_cmp */
   12872      3184548 :     case 907:  /* *xordi_2 */
   12873      3184548 :     case 906:  /* *iordi_2 */
   12874      3184548 :     case 905:  /* *xorsi_2 */
   12875      3184548 :     case 904:  /* *iorsi_2 */
   12876      3184548 :     case 903:  /* *xorhi_2 */
   12877      3184548 :     case 902:  /* *iorhi_2 */
   12878      3184548 :     case 901:  /* *xorqi_2 */
   12879      3184548 :     case 900:  /* *iorqi_2 */
   12880      3184548 :     case 782:  /* *andsi_2 */
   12881      3184548 :     case 781:  /* *andhi_2 */
   12882      3184548 :     case 780:  /* *andqi_2 */
   12883      3184548 :     case 779:  /* *andqi_2_maybe_si */
   12884      3184548 :     case 777:  /* *anddi_2 */
   12885      3184548 :     case 418:  /* *subdi_2 */
   12886      3184548 :     case 417:  /* *subsi_2 */
   12887      3184548 :     case 416:  /* *subhi_2 */
   12888      3184548 :     case 415:  /* *subqi_2 */
   12889      3184548 :     case 316:  /* *adddi_2 */
   12890      3184548 :     case 315:  /* *addsi_2 */
   12891      3184548 :     case 314:  /* *addhi_2 */
   12892      3184548 :     case 313:  /* *addqi_2 */
   12893      3184548 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0));
   12894      3184548 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   12895      3184548 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   12896      3184548 :       recog_data.dup_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 0);
   12897      3184548 :       recog_data.dup_num[0] = 1;
   12898      3184548 :       recog_data.dup_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 1), 1), 1);
   12899      3184548 :       recog_data.dup_num[1] = 2;
   12900      3184548 :       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        19297 :     case 1416:  /* *rotrhi3_1_slp */
   12943        19297 :     case 1415:  /* *rotlhi3_1_slp */
   12944        19297 :     case 1414:  /* *rotrqi3_1_slp */
   12945        19297 :     case 1413:  /* *rotlqi3_1_slp */
   12946        19297 :     case 1251:  /* *ashrhi3_1_slp */
   12947        19297 :     case 1250:  /* *lshrhi3_1_slp */
   12948        19297 :     case 1249:  /* *ashrqi3_1_slp */
   12949        19297 :     case 1248:  /* *lshrqi3_1_slp */
   12950        19297 :     case 1141:  /* *ashlhi3_1_slp */
   12951        19297 :     case 1140:  /* *ashlqi3_1_slp */
   12952        19297 :     case 758:  /* *xorhi_1_slp */
   12953        19297 :     case 757:  /* *iorhi_1_slp */
   12954        19297 :     case 756:  /* *andhi_1_slp */
   12955        19297 :     case 755:  /* *xorqi_1_slp */
   12956        19297 :     case 754:  /* *iorqi_1_slp */
   12957        19297 :     case 753:  /* *andqi_1_slp */
   12958        19297 :     case 408:  /* *subhi_1_slp */
   12959        19297 :     case 407:  /* *subqi_1_slp */
   12960        19297 :     case 306:  /* *addhi_1_slp */
   12961        19297 :     case 305:  /* *addqi_1_slp */
   12962        19297 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   12963        19297 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   12964        19297 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   12965        19297 :       break;
   12966              : 
   12967       485087 :     case 2663:  /* *klshrsi3_1_zext */
   12968       485087 :     case 2645:  /* kxnordi */
   12969       485087 :     case 2644:  /* kxnorsi */
   12970       485087 :     case 2643:  /* kxnorhi */
   12971       485087 :     case 2642:  /* kxnorqi */
   12972       485087 :     case 1404:  /* *rotrsi3_1_zext */
   12973       485087 :     case 1403:  /* *rotlsi3_1_zext */
   12974       485087 :     case 1402:  /* *rotrhi3_1_zextdi */
   12975       485087 :     case 1400:  /* *rotlhi3_1_zextdi */
   12976       485087 :     case 1398:  /* *rotrhi3_1_zextsi */
   12977       485087 :     case 1396:  /* *rotlhi3_1_zextsi */
   12978       485087 :     case 1394:  /* *rotrqi3_1_zextdi */
   12979       485087 :     case 1392:  /* *rotlqi3_1_zextdi */
   12980       485087 :     case 1390:  /* *rotrqi3_1_zextsi */
   12981       485087 :     case 1388:  /* *rotlqi3_1_zextsi */
   12982       485087 :     case 1386:  /* *rotrqi3_1_zexthi */
   12983       485087 :     case 1384:  /* *rotlqi3_1_zexthi */
   12984       485087 :     case 1239:  /* *ashrsi3_1_zext */
   12985       485087 :     case 1238:  /* *lshrsi3_1_zext */
   12986       485087 :     case 1237:  /* *ashrhi3_1_zextdi */
   12987       485087 :     case 1235:  /* *lshrhi3_1_zextdi */
   12988       485087 :     case 1233:  /* *ashrhi3_1_zextsi */
   12989       485087 :     case 1231:  /* *lshrhi3_1_zextsi */
   12990       485087 :     case 1229:  /* *ashrqi3_1_zextdi */
   12991       485087 :     case 1227:  /* *lshrqi3_1_zextdi */
   12992       485087 :     case 1225:  /* *ashrqi3_1_zextsi */
   12993       485087 :     case 1223:  /* *lshrqi3_1_zextsi */
   12994       485087 :     case 1221:  /* *ashrqi3_1_zexthi */
   12995       485087 :     case 1219:  /* *lshrqi3_1_zexthi */
   12996       485087 :     case 1202:  /* *ashrsi3_cvt_zext */
   12997       485087 :     case 1173:  /* ashrti3_doubleword_lowpart */
   12998       485087 :     case 1172:  /* lshrti3_doubleword_lowpart */
   12999       485087 :     case 1171:  /* ashrdi3_doubleword_lowpart */
   13000       485087 :     case 1170:  /* lshrdi3_doubleword_lowpart */
   13001       485087 :     case 1135:  /* *ashlsi3_1_zext */
   13002       485087 :     case 1134:  /* *ashlhi3_1_zextdi */
   13003       485087 :     case 1132:  /* *ashlhi3_1_zextsi */
   13004       485087 :     case 1130:  /* *ashlqi3_1_zextdi */
   13005       485087 :     case 1128:  /* *ashlqi3_1_zextsi */
   13006       485087 :     case 1126:  /* *ashlqi3_1_zexthi */
   13007       485087 :     case 899:  /* *notxorqi_1 */
   13008       485087 :     case 892:  /* *xorsi_1_zext */
   13009       485087 :     case 891:  /* *iorsi_1_zext */
   13010       485087 :     case 890:  /* *xorhi_1_zextdi */
   13011       485087 :     case 888:  /* *iorhi_1_zextdi */
   13012       485087 :     case 886:  /* *xorhi_1_zextsi */
   13013       485087 :     case 884:  /* *iorhi_1_zextsi */
   13014       485087 :     case 882:  /* *xorqi_1_zextdi */
   13015       485087 :     case 880:  /* *iorqi_1_zextdi */
   13016       485087 :     case 878:  /* *xorqi_1_zextsi */
   13017       485087 :     case 876:  /* *iorqi_1_zextsi */
   13018       485087 :     case 874:  /* *xorqi_1_zexthi */
   13019       485087 :     case 872:  /* *iorqi_1_zexthi */
   13020       485087 :     case 865:  /* *notxordi_1 */
   13021       485087 :     case 864:  /* *notxorsi_1 */
   13022       485087 :     case 863:  /* *notxorhi_1 */
   13023       485087 :     case 746:  /* *andsi_1_zext */
   13024       485087 :     case 745:  /* *andhi_1_zextdi */
   13025       485087 :     case 743:  /* *andhi_1_zextsi */
   13026       485087 :     case 741:  /* *andqi_1_zextdi */
   13027       485087 :     case 739:  /* *andqi_1_zextsi */
   13028       485087 :     case 737:  /* *andqi_1_zexthi */
   13029       485087 :     case 629:  /* *mulsi3_1_zext */
   13030       485087 :     case 627:  /* *imulhidizu */
   13031       485087 :     case 625:  /* *imulhisizu */
   13032       485087 :     case 544:  /* *subsi3_carry_zext_0r */
   13033       485087 :     case 543:  /* *subhi3_carry_zextdi_0r */
   13034       485087 :     case 542:  /* *subhi3_carry_zextsi_0r */
   13035       485087 :     case 541:  /* *subqi3_carry_zextdi_0r */
   13036       485087 :     case 540:  /* *subqi3_carry_zextsi_0r */
   13037       485087 :     case 539:  /* *subqi3_carry_zexthi_0r */
   13038       485087 :     case 538:  /* *subsi3_carry_zext_0 */
   13039       485087 :     case 537:  /* *subhi3_carry_zextdi_0 */
   13040       485087 :     case 536:  /* *subhi3_carry_zextsi_0 */
   13041       485087 :     case 535:  /* *subqi3_carry_zextdi_0 */
   13042       485087 :     case 534:  /* *subqi3_carry_zextsi_0 */
   13043       485087 :     case 533:  /* *subqi3_carry_zexthi_0 */
   13044       485087 :     case 406:  /* *subsi_1_zext */
   13045       485087 :     case 405:  /* *subhi_1_zextdi */
   13046       485087 :     case 403:  /* *subhi_1_zextsi */
   13047       485087 :     case 401:  /* *subqi_1_zextdi */
   13048       485087 :     case 399:  /* *subqi_1_zextsi */
   13049       485087 :     case 397:  /* *subqi_1_zexthi */
   13050       485087 :     case 300:  /* addsi_1_zext */
   13051       485087 :     case 299:  /* *addhi_1_zextdi */
   13052       485087 :     case 297:  /* *addhi_1_zextsi */
   13053       485087 :     case 295:  /* *addqi_1_zextdi */
   13054       485087 :     case 293:  /* *addqi_1_zextsi */
   13055       485087 :     case 291:  /* *addqi_1_zexthi */
   13056       485087 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   13057       485087 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   13058       485087 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1));
   13059       485087 :       break;
   13060              : 
   13061      2516160 :     case 8409:  /* vec_interleave_lowv4si */
   13062      2516160 :     case 8407:  /* *avx512f_interleave_lowv16si */
   13063      2516160 :     case 8405:  /* avx2_interleave_lowv8si */
   13064      2516160 :     case 8403:  /* vec_interleave_highv4si */
   13065      2516160 :     case 8401:  /* *avx512f_interleave_highv16si */
   13066      2516160 :     case 8399:  /* avx2_interleave_highv8si */
   13067      2516160 :     case 8397:  /* vec_interleave_lowv8bf */
   13068      2516160 :     case 8395:  /* vec_interleave_lowv8hf */
   13069      2516160 :     case 8393:  /* vec_interleave_lowv8hi */
   13070      2516160 :     case 8391:  /* avx2_interleave_lowv16bf */
   13071      2516160 :     case 8389:  /* avx2_interleave_lowv16hf */
   13072      2516160 :     case 8387:  /* avx2_interleave_lowv16hi */
   13073      2516160 :     case 8385:  /* *avx512bw_interleave_lowv32bf */
   13074      2516160 :     case 8383:  /* *avx512bw_interleave_lowv32hf */
   13075      2516160 :     case 8381:  /* *avx512bw_interleave_lowv32hi */
   13076      2516160 :     case 8379:  /* vec_interleave_highv8bf */
   13077      2516160 :     case 8377:  /* vec_interleave_highv8hf */
   13078      2516160 :     case 8375:  /* vec_interleave_highv8hi */
   13079      2516160 :     case 8373:  /* avx2_interleave_highv16bf */
   13080      2516160 :     case 8371:  /* avx2_interleave_highv16hf */
   13081      2516160 :     case 8369:  /* avx2_interleave_highv16hi */
   13082      2516160 :     case 8367:  /* avx512bw_interleave_highv32bf */
   13083      2516160 :     case 8365:  /* avx512bw_interleave_highv32hf */
   13084      2516160 :     case 8363:  /* avx512bw_interleave_highv32hi */
   13085      2516160 :     case 8361:  /* vec_interleave_lowv16qi */
   13086      2516160 :     case 8359:  /* avx2_interleave_lowv32qi */
   13087      2516160 :     case 8357:  /* avx512bw_interleave_lowv64qi */
   13088      2516160 :     case 8355:  /* vec_interleave_highv16qi */
   13089      2516160 :     case 8353:  /* avx2_interleave_highv32qi */
   13090      2516160 :     case 8351:  /* avx512bw_interleave_highv64qi */
   13091      2516160 :     case 8116:  /* *xnorv2di3 */
   13092      2516160 :     case 8115:  /* *xnorv4di3 */
   13093      2516160 :     case 8114:  /* *xnorv4si3 */
   13094      2516160 :     case 8113:  /* *xnorv8si3 */
   13095      2516160 :     case 8112:  /* *xnorv8hi3 */
   13096      2516160 :     case 8111:  /* *xnorv16hi3 */
   13097      2516160 :     case 8110:  /* *xnorv32hi3 */
   13098      2516160 :     case 8109:  /* *xnorv16qi3 */
   13099      2516160 :     case 8108:  /* *xnorv32qi3 */
   13100      2516160 :     case 8107:  /* *xnorv64qi3 */
   13101      2516160 :     case 8106:  /* *xnorv8di3 */
   13102      2516160 :     case 8105:  /* *xnorv16si3 */
   13103      2516160 :     case 7230:  /* vec_interleave_lowv2di */
   13104      2516160 :     case 7228:  /* *avx512f_interleave_lowv8di */
   13105      2516160 :     case 7226:  /* avx2_interleave_lowv4di */
   13106      2516160 :     case 7224:  /* vec_interleave_highv2di */
   13107      2516160 :     case 7222:  /* *avx512f_interleave_highv8di */
   13108      2516160 :     case 7220:  /* avx2_interleave_highv4di */
   13109      2516160 :     case 5416:  /* *vec_interleave_lowv2df */
   13110      2516160 :     case 5413:  /* avx_unpcklpd256 */
   13111      2516160 :     case 5409:  /* avx512f_unpcklpd512 */
   13112      2516160 :     case 5406:  /* *vec_interleave_highv2df */
   13113      2516160 :     case 5403:  /* avx_unpckhpd256 */
   13114      2516160 :     case 5401:  /* *avx512f_unpckhpd512 */
   13115      2516160 :     case 5258:  /* vec_interleave_lowv4sf */
   13116      2516160 :     case 5255:  /* avx_unpcklps256 */
   13117      2516160 :     case 5253:  /* *avx512f_unpcklps512 */
   13118      2516160 :     case 5251:  /* vec_interleave_highv4sf */
   13119      2516160 :     case 5249:  /* avx_unpckhps256 */
   13120      2516160 :     case 5247:  /* *avx512f_unpckhps512 */
   13121      2516160 :     case 5246:  /* sse_movlhps_v8bf */
   13122      2516160 :     case 5245:  /* sse_movlhps_v8hf */
   13123      2516160 :     case 5244:  /* sse_movlhps_v8hi */
   13124      2516160 :     case 5243:  /* sse_movlhps */
   13125      2516160 :     case 5242:  /* sse_movhlps */
   13126      2516160 :     case 2351:  /* mmx_punpckldq */
   13127      2516160 :     case 2350:  /* mmx_punpckhdq */
   13128      2516160 :     case 2349:  /* mmx_punpcklwd */
   13129      2516160 :     case 2348:  /* mmx_punpckhwd */
   13130      2516160 :     case 2347:  /* mmx_punpcklbw_low */
   13131      2516160 :     case 2346:  /* mmx_punpcklbw */
   13132      2516160 :     case 2345:  /* mmx_punpckhbw_low */
   13133      2516160 :     case 2344:  /* mmx_punpckhbw */
   13134      2516160 :     case 2136:  /* *vec_interleave_highv2sf */
   13135      2516160 :     case 2135:  /* *vec_interleave_lowv2sf */
   13136      2516160 :     case 1401:  /* *rotrhi3_1_zextdi_nf */
   13137      2516160 :     case 1399:  /* *rotlhi3_1_zextdi_nf */
   13138      2516160 :     case 1397:  /* *rotrhi3_1_zextsi_nf */
   13139      2516160 :     case 1395:  /* *rotlhi3_1_zextsi_nf */
   13140      2516160 :     case 1393:  /* *rotrqi3_1_zextdi_nf */
   13141      2516160 :     case 1391:  /* *rotlqi3_1_zextdi_nf */
   13142      2516160 :     case 1389:  /* *rotrqi3_1_zextsi_nf */
   13143      2516160 :     case 1387:  /* *rotlqi3_1_zextsi_nf */
   13144      2516160 :     case 1385:  /* *rotrqi3_1_zexthi_nf */
   13145      2516160 :     case 1383:  /* *rotlqi3_1_zexthi_nf */
   13146      2516160 :     case 1382:  /* *bmi2_rorxsi3_1_zext */
   13147      2516160 :     case 1236:  /* *ashrhi3_1_zextdi_nf */
   13148      2516160 :     case 1234:  /* *lshrhi3_1_zextdi_nf */
   13149      2516160 :     case 1232:  /* *ashrhi3_1_zextsi_nf */
   13150      2516160 :     case 1230:  /* *lshrhi3_1_zextsi_nf */
   13151      2516160 :     case 1228:  /* *ashrqi3_1_zextdi_nf */
   13152      2516160 :     case 1226:  /* *lshrqi3_1_zextdi_nf */
   13153      2516160 :     case 1224:  /* *ashrqi3_1_zextsi_nf */
   13154      2516160 :     case 1222:  /* *lshrqi3_1_zextsi_nf */
   13155      2516160 :     case 1220:  /* *ashrqi3_1_zexthi_nf */
   13156      2516160 :     case 1218:  /* *lshrqi3_1_zexthi_nf */
   13157      2516160 :     case 1217:  /* *bmi2_ashrsi3_1_zext */
   13158      2516160 :     case 1216:  /* *bmi2_lshrsi3_1_zext */
   13159      2516160 :     case 1169:  /* ashrti3_doubleword_lowpart_nf */
   13160      2516160 :     case 1168:  /* lshrti3_doubleword_lowpart_nf */
   13161      2516160 :     case 1167:  /* ashrdi3_doubleword_lowpart_nf */
   13162      2516160 :     case 1166:  /* lshrdi3_doubleword_lowpart_nf */
   13163      2516160 :     case 1133:  /* *ashlhi3_1_zextdi_nf */
   13164      2516160 :     case 1131:  /* *ashlhi3_1_zextsi_nf */
   13165      2516160 :     case 1129:  /* *ashlqi3_1_zextdi_nf */
   13166      2516160 :     case 1127:  /* *ashlqi3_1_zextsi_nf */
   13167      2516160 :     case 1125:  /* *ashlqi3_1_zexthi_nf */
   13168      2516160 :     case 1124:  /* *bmi2_ashlsi3_1_zext */
   13169      2516160 :     case 889:  /* *xorhi_1_zextdi_nf */
   13170      2516160 :     case 887:  /* *iorhi_1_zextdi_nf */
   13171      2516160 :     case 885:  /* *xorhi_1_zextsi_nf */
   13172      2516160 :     case 883:  /* *iorhi_1_zextsi_nf */
   13173      2516160 :     case 881:  /* *xorqi_1_zextdi_nf */
   13174      2516160 :     case 879:  /* *iorqi_1_zextdi_nf */
   13175      2516160 :     case 877:  /* *xorqi_1_zextsi_nf */
   13176      2516160 :     case 875:  /* *iorqi_1_zextsi_nf */
   13177      2516160 :     case 873:  /* *xorqi_1_zexthi_nf */
   13178      2516160 :     case 871:  /* *iorqi_1_zexthi_nf */
   13179      2516160 :     case 744:  /* *andhi_1_zextdi_nf */
   13180      2516160 :     case 742:  /* *andhi_1_zextsi_nf */
   13181      2516160 :     case 740:  /* *andqi_1_zextdi_nf */
   13182      2516160 :     case 738:  /* *andqi_1_zextsi_nf */
   13183      2516160 :     case 736:  /* *andqi_1_zexthi_nf */
   13184      2516160 :     case 628:  /* *mulsi3_1_zext_nf */
   13185      2516160 :     case 626:  /* *imulhidizu_nf */
   13186      2516160 :     case 624:  /* *imulhisizu_nf */
   13187      2516160 :     case 404:  /* *subhi_1_zextdi_nf */
   13188      2516160 :     case 402:  /* *subhi_1_zextsi_nf */
   13189      2516160 :     case 400:  /* *subqi_1_zextdi_nf */
   13190      2516160 :     case 398:  /* *subqi_1_zextsi_nf */
   13191      2516160 :     case 396:  /* *subqi_1_zexthi_nf */
   13192      2516160 :     case 298:  /* *addhi_1_zextdi_nf */
   13193      2516160 :     case 296:  /* *addhi_1_zextsi_nf */
   13194      2516160 :     case 294:  /* *addqi_1_zextdi_nf */
   13195      2516160 :     case 292:  /* *addqi_1_zextsi_nf */
   13196      2516160 :     case 290:  /* *addqi_1_zexthi_nf */
   13197      2516160 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   13198      2516160 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   13199      2516160 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   13200      2516160 :       break;
   13201              : 
   13202     21585151 :     case 10687:  /* avx10_2_divbf16_v8bf */
   13203     21585151 :     case 10685:  /* avx10_2_mulbf16_v8bf */
   13204     21585151 :     case 10683:  /* avx10_2_subbf16_v8bf */
   13205     21585151 :     case 10681:  /* avx10_2_addbf16_v8bf */
   13206     21585151 :     case 10679:  /* avx10_2_divbf16_v16bf */
   13207     21585151 :     case 10677:  /* avx10_2_mulbf16_v16bf */
   13208     21585151 :     case 10675:  /* avx10_2_subbf16_v16bf */
   13209     21585151 :     case 10673:  /* avx10_2_addbf16_v16bf */
   13210     21585151 :     case 10671:  /* avx10_2_divbf16_v32bf */
   13211     21585151 :     case 10669:  /* avx10_2_mulbf16_v32bf */
   13212     21585151 :     case 10667:  /* avx10_2_subbf16_v32bf */
   13213     21585151 :     case 10665:  /* avx10_2_addbf16_v32bf */
   13214     21585151 :     case 10663:  /* avx10_2_sminbf16_v8bf */
   13215     21585151 :     case 10661:  /* avx10_2_smaxbf16_v8bf */
   13216     21585151 :     case 10659:  /* avx10_2_sminbf16_v16bf */
   13217     21585151 :     case 10657:  /* avx10_2_smaxbf16_v16bf */
   13218     21585151 :     case 10655:  /* avx10_2_sminbf16_v32bf */
   13219     21585151 :     case 10653:  /* avx10_2_smaxbf16_v32bf */
   13220     21585151 :     case 9683:  /* avx_vec_concatv8df */
   13221     21585151 :     case 9682:  /* avx_vec_concatv16sf */
   13222     21585151 :     case 9681:  /* avx_vec_concatv8di */
   13223     21585151 :     case 9680:  /* avx_vec_concatv16si */
   13224     21585151 :     case 9679:  /* avx_vec_concatv32bf */
   13225     21585151 :     case 9678:  /* avx_vec_concatv32hf */
   13226     21585151 :     case 9677:  /* avx_vec_concatv32hi */
   13227     21585151 :     case 9676:  /* avx_vec_concatv64qi */
   13228     21585151 :     case 9675:  /* avx_vec_concatv4df */
   13229     21585151 :     case 9674:  /* avx_vec_concatv8sf */
   13230     21585151 :     case 9673:  /* avx_vec_concatv4di */
   13231     21585151 :     case 9672:  /* avx_vec_concatv8si */
   13232     21585151 :     case 9671:  /* avx_vec_concatv16bf */
   13233     21585151 :     case 9670:  /* avx_vec_concatv16hf */
   13234     21585151 :     case 9669:  /* avx_vec_concatv16hi */
   13235     21585151 :     case 9668:  /* avx_vec_concatv32qi */
   13236     21585151 :     case 9666:  /* avx512bw_lshrvv32hi */
   13237     21585151 :     case 9664:  /* avx512bw_ashlvv32hi */
   13238     21585151 :     case 9662:  /* avx512vl_lshrvv16hi */
   13239     21585151 :     case 9660:  /* avx512vl_ashlvv16hi */
   13240     21585151 :     case 9658:  /* avx512vl_lshrvv8hi */
   13241     21585151 :     case 9656:  /* avx512vl_ashlvv8hi */
   13242     21585151 :     case 9654:  /* avx2_lshrvv2di */
   13243     21585151 :     case 9652:  /* avx2_ashlvv2di */
   13244     21585151 :     case 9650:  /* avx2_lshrvv4di */
   13245     21585151 :     case 9648:  /* avx2_ashlvv4di */
   13246     21585151 :     case 9646:  /* avx512f_lshrvv8di */
   13247     21585151 :     case 9644:  /* avx512f_ashlvv8di */
   13248     21585151 :     case 9642:  /* avx2_lshrvv4si */
   13249     21585151 :     case 9640:  /* avx2_ashlvv4si */
   13250     21585151 :     case 9638:  /* avx2_lshrvv8si */
   13251     21585151 :     case 9636:  /* avx2_ashlvv8si */
   13252     21585151 :     case 9634:  /* avx512f_lshrvv16si */
   13253     21585151 :     case 9632:  /* avx512f_ashlvv16si */
   13254     21585151 :     case 9630:  /* avx512bw_ashrvv32hi */
   13255     21585151 :     case 9628:  /* avx512vl_ashrvv16hi */
   13256     21585151 :     case 9626:  /* avx512vl_ashrvv8hi */
   13257     21585151 :     case 9624:  /* avx512f_ashrvv8di */
   13258     21585151 :     case 9622:  /* avx2_ashrvv4di */
   13259     21585151 :     case 9620:  /* avx2_ashrvv2di */
   13260     21585151 :     case 9618:  /* avx512f_ashrvv16si */
   13261     21585151 :     case 9616:  /* avx2_ashrvv8si */
   13262     21585151 :     case 9614:  /* avx2_ashrvv4si */
   13263     21585151 :     case 9094:  /* *ashrv2di3 */
   13264     21585151 :     case 9081:  /* xop_rotrv2di3 */
   13265     21585151 :     case 9080:  /* xop_rotrv4si3 */
   13266     21585151 :     case 9079:  /* xop_rotrv8hi3 */
   13267     21585151 :     case 9078:  /* xop_rotrv16qi3 */
   13268     21585151 :     case 9077:  /* xop_rotlv2di3 */
   13269     21585151 :     case 9076:  /* xop_rotlv4si3 */
   13270     21585151 :     case 9075:  /* xop_rotlv8hi3 */
   13271     21585151 :     case 9074:  /* xop_rotlv16qi3 */
   13272     21585151 :     case 8522:  /* *vec_concatv2di_0 */
   13273     21585151 :     case 8521:  /* vec_concatv2di */
   13274     21585151 :     case 8520:  /* *vec_concatv4si_0 */
   13275     21585151 :     case 8519:  /* *vec_concatv8hi_0 */
   13276     21585151 :     case 8518:  /* *vec_concatv16qi_0 */
   13277     21585151 :     case 8515:  /* *vec_concatv4si */
   13278     21585151 :     case 8514:  /* *vec_concatv8hi */
   13279     21585151 :     case 8513:  /* *vec_concatv16qi */
   13280     21585151 :     case 8512:  /* *vec_concatv2si */
   13281     21585151 :     case 8511:  /* *vec_concatv2si_sse4_1 */
   13282     21585151 :     case 8092:  /* xorv1ti3 */
   13283     21585151 :     case 8091:  /* iorv1ti3 */
   13284     21585151 :     case 8090:  /* andv1ti3 */
   13285     21585151 :     case 8089:  /* *xorv8hi3 */
   13286     21585151 :     case 8088:  /* *iorv8hi3 */
   13287     21585151 :     case 8087:  /* *andv8hi3 */
   13288     21585151 :     case 8086:  /* *xorv16hi3 */
   13289     21585151 :     case 8085:  /* *iorv16hi3 */
   13290     21585151 :     case 8084:  /* *andv16hi3 */
   13291     21585151 :     case 8083:  /* *xorv32hi3 */
   13292     21585151 :     case 8082:  /* *iorv32hi3 */
   13293     21585151 :     case 8081:  /* *andv32hi3 */
   13294     21585151 :     case 8080:  /* *xorv16qi3 */
   13295     21585151 :     case 8079:  /* *iorv16qi3 */
   13296     21585151 :     case 8078:  /* *andv16qi3 */
   13297     21585151 :     case 8077:  /* *xorv32qi3 */
   13298     21585151 :     case 8076:  /* *iorv32qi3 */
   13299     21585151 :     case 8075:  /* *andv32qi3 */
   13300     21585151 :     case 8074:  /* *xorv64qi3 */
   13301     21585151 :     case 8073:  /* *iorv64qi3 */
   13302     21585151 :     case 8072:  /* *andv64qi3 */
   13303     21585151 :     case 8070:  /* *xorv2di3 */
   13304     21585151 :     case 8068:  /* *iorv2di3 */
   13305     21585151 :     case 8066:  /* *andv2di3 */
   13306     21585151 :     case 8064:  /* *xorv4di3 */
   13307     21585151 :     case 8062:  /* *iorv4di3 */
   13308     21585151 :     case 8060:  /* *andv4di3 */
   13309     21585151 :     case 8058:  /* *xorv8di3 */
   13310     21585151 :     case 8056:  /* *iorv8di3 */
   13311     21585151 :     case 8054:  /* *andv8di3 */
   13312     21585151 :     case 8052:  /* *xorv4si3 */
   13313     21585151 :     case 8050:  /* *iorv4si3 */
   13314     21585151 :     case 8048:  /* *andv4si3 */
   13315     21585151 :     case 8046:  /* *xorv8si3 */
   13316     21585151 :     case 8044:  /* *iorv8si3 */
   13317     21585151 :     case 8042:  /* *andv8si3 */
   13318     21585151 :     case 8040:  /* *xorv16si3 */
   13319     21585151 :     case 8038:  /* *iorv16si3 */
   13320     21585151 :     case 8036:  /* *andv16si3 */
   13321     21585151 :     case 8004:  /* *one_cmplv2di2 */
   13322     21585151 :     case 8002:  /* *one_cmplv4di2 */
   13323     21585151 :     case 8000:  /* *one_cmplv4si2 */
   13324     21585151 :     case 7998:  /* *one_cmplv8si2 */
   13325     21585151 :     case 7997:  /* *one_cmplv8hi2 */
   13326     21585151 :     case 7996:  /* *one_cmplv16hi2 */
   13327     21585151 :     case 7995:  /* *one_cmplv32hi2 */
   13328     21585151 :     case 7994:  /* *one_cmplv16qi2 */
   13329     21585151 :     case 7993:  /* *one_cmplv32qi2 */
   13330     21585151 :     case 7992:  /* *one_cmplv64qi2 */
   13331     21585151 :     case 7990:  /* *one_cmplv8di2 */
   13332     21585151 :     case 7988:  /* *one_cmplv16si2 */
   13333     21585151 :     case 7987:  /* *sse2_gtv4si3 */
   13334     21585151 :     case 7986:  /* *sse2_gtv8hi3 */
   13335     21585151 :     case 7985:  /* *sse2_gtv16qi3 */
   13336     21585151 :     case 7984:  /* avx2_gtv4di3 */
   13337     21585151 :     case 7983:  /* avx2_gtv8si3 */
   13338     21585151 :     case 7982:  /* avx2_gtv16hi3 */
   13339     21585151 :     case 7981:  /* avx2_gtv32qi3 */
   13340     21585151 :     case 7980:  /* sse4_2_gtv2di3 */
   13341     21585151 :     case 7979:  /* *sse2_eqv4si3 */
   13342     21585151 :     case 7978:  /* *sse2_eqv8hi3 */
   13343     21585151 :     case 7977:  /* *sse2_eqv16qi3 */
   13344     21585151 :     case 7976:  /* *sse4_1_eqv2di3 */
   13345     21585151 :     case 7913:  /* *avx2_eqv4di3 */
   13346     21585151 :     case 7912:  /* *avx2_eqv8si3 */
   13347     21585151 :     case 7911:  /* *avx2_eqv16hi3 */
   13348     21585151 :     case 7910:  /* *avx2_eqv32qi3 */
   13349     21585151 :     case 7909:  /* *uminv16qi3 */
   13350     21585151 :     case 7908:  /* *umaxv16qi3 */
   13351     21585151 :     case 7906:  /* *sse4_1_uminv4si3 */
   13352     21585151 :     case 7904:  /* *sse4_1_umaxv4si3 */
   13353     21585151 :     case 7902:  /* *sse4_1_uminv8hi3 */
   13354     21585151 :     case 7900:  /* *sse4_1_umaxv8hi3 */
   13355     21585151 :     case 7899:  /* *sminv8hi3 */
   13356     21585151 :     case 7898:  /* *smaxv8hi3 */
   13357     21585151 :     case 7896:  /* *sse4_1_sminv4si3 */
   13358     21585151 :     case 7894:  /* *sse4_1_smaxv4si3 */
   13359     21585151 :     case 7892:  /* *sse4_1_sminv16qi3 */
   13360     21585151 :     case 7890:  /* *sse4_1_smaxv16qi3 */
   13361     21585151 :     case 7888:  /* *avx512bw_uminv8hi3 */
   13362     21585151 :     case 7886:  /* *avx512bw_umaxv8hi3 */
   13363     21585151 :     case 7884:  /* *avx512bw_sminv8hi3 */
   13364     21585151 :     case 7882:  /* *avx512bw_smaxv8hi3 */
   13365     21585151 :     case 7880:  /* *avx512bw_uminv16hi3 */
   13366     21585151 :     case 7878:  /* *avx512bw_umaxv16hi3 */
   13367     21585151 :     case 7876:  /* *avx512bw_sminv16hi3 */
   13368     21585151 :     case 7874:  /* *avx512bw_smaxv16hi3 */
   13369     21585151 :     case 7872:  /* *avx512bw_uminv32hi3 */
   13370     21585151 :     case 7870:  /* *avx512bw_umaxv32hi3 */
   13371     21585151 :     case 7868:  /* *avx512bw_sminv32hi3 */
   13372     21585151 :     case 7866:  /* *avx512bw_smaxv32hi3 */
   13373     21585151 :     case 7864:  /* *avx512bw_uminv32qi3 */
   13374     21585151 :     case 7862:  /* *avx512bw_umaxv32qi3 */
   13375     21585151 :     case 7860:  /* *avx512bw_sminv32qi3 */
   13376     21585151 :     case 7858:  /* *avx512bw_smaxv32qi3 */
   13377     21585151 :     case 7856:  /* *avx512bw_uminv16qi3 */
   13378     21585151 :     case 7854:  /* *avx512bw_umaxv16qi3 */
   13379     21585151 :     case 7852:  /* *avx512bw_sminv16qi3 */
   13380     21585151 :     case 7850:  /* *avx512bw_smaxv16qi3 */
   13381     21585151 :     case 7848:  /* *avx512bw_uminv64qi3 */
   13382     21585151 :     case 7846:  /* *avx512bw_umaxv64qi3 */
   13383     21585151 :     case 7844:  /* *avx512bw_sminv64qi3 */
   13384     21585151 :     case 7842:  /* *avx512bw_smaxv64qi3 */
   13385     21585151 :     case 7840:  /* *avx512f_uminv2di3 */
   13386     21585151 :     case 7838:  /* *avx512f_umaxv2di3 */
   13387     21585151 :     case 7836:  /* *avx512f_sminv2di3 */
   13388     21585151 :     case 7834:  /* *avx512f_smaxv2di3 */
   13389     21585151 :     case 7832:  /* *avx512f_uminv4di3 */
   13390     21585151 :     case 7830:  /* *avx512f_umaxv4di3 */
   13391     21585151 :     case 7828:  /* *avx512f_sminv4di3 */
   13392     21585151 :     case 7826:  /* *avx512f_smaxv4di3 */
   13393     21585151 :     case 7824:  /* *avx512f_uminv8di3 */
   13394     21585151 :     case 7822:  /* *avx512f_umaxv8di3 */
   13395     21585151 :     case 7820:  /* *avx512f_sminv8di3 */
   13396     21585151 :     case 7818:  /* *avx512f_smaxv8di3 */
   13397     21585151 :     case 7816:  /* *avx512f_uminv4si3 */
   13398     21585151 :     case 7814:  /* *avx512f_umaxv4si3 */
   13399     21585151 :     case 7812:  /* *avx512f_sminv4si3 */
   13400     21585151 :     case 7810:  /* *avx512f_smaxv4si3 */
   13401     21585151 :     case 7808:  /* *avx512f_uminv8si3 */
   13402     21585151 :     case 7806:  /* *avx512f_umaxv8si3 */
   13403     21585151 :     case 7804:  /* *avx512f_sminv8si3 */
   13404     21585151 :     case 7802:  /* *avx512f_smaxv8si3 */
   13405     21585151 :     case 7800:  /* *avx512f_uminv16si3 */
   13406     21585151 :     case 7798:  /* *avx512f_umaxv16si3 */
   13407     21585151 :     case 7796:  /* *avx512f_sminv16si3 */
   13408     21585151 :     case 7794:  /* *avx512f_smaxv16si3 */
   13409     21585151 :     case 7793:  /* *avx2_uminv8si3 */
   13410     21585151 :     case 7792:  /* *avx2_umaxv8si3 */
   13411     21585151 :     case 7791:  /* *avx2_sminv8si3 */
   13412     21585151 :     case 7790:  /* *avx2_smaxv8si3 */
   13413     21585151 :     case 7789:  /* *avx2_uminv16hi3 */
   13414     21585151 :     case 7788:  /* *avx2_umaxv16hi3 */
   13415     21585151 :     case 7787:  /* *avx2_sminv16hi3 */
   13416     21585151 :     case 7786:  /* *avx2_smaxv16hi3 */
   13417     21585151 :     case 7785:  /* *avx2_uminv32qi3 */
   13418     21585151 :     case 7784:  /* *avx2_umaxv32qi3 */
   13419     21585151 :     case 7783:  /* *avx2_sminv32qi3 */
   13420     21585151 :     case 7782:  /* *avx2_smaxv32qi3 */
   13421     21585151 :     case 7780:  /* avx512vl_rorv2di */
   13422     21585151 :     case 7778:  /* avx512vl_rolv2di */
   13423     21585151 :     case 7776:  /* avx512vl_rorv4di */
   13424     21585151 :     case 7774:  /* avx512vl_rolv4di */
   13425     21585151 :     case 7772:  /* avx512f_rorv8di */
   13426     21585151 :     case 7770:  /* avx512f_rolv8di */
   13427     21585151 :     case 7768:  /* avx512vl_rorv4si */
   13428     21585151 :     case 7766:  /* avx512vl_rolv4si */
   13429     21585151 :     case 7764:  /* avx512vl_rorv8si */
   13430     21585151 :     case 7762:  /* avx512vl_rolv8si */
   13431     21585151 :     case 7760:  /* avx512f_rorv16si */
   13432     21585151 :     case 7758:  /* avx512f_rolv16si */
   13433     21585151 :     case 7756:  /* avx512vl_rorvv2di */
   13434     21585151 :     case 7754:  /* avx512vl_rolvv2di */
   13435     21585151 :     case 7752:  /* avx512vl_rorvv4di */
   13436     21585151 :     case 7750:  /* avx512vl_rolvv4di */
   13437     21585151 :     case 7748:  /* avx512f_rorvv8di */
   13438     21585151 :     case 7746:  /* avx512f_rolvv8di */
   13439     21585151 :     case 7744:  /* avx512vl_rorvv4si */
   13440     21585151 :     case 7742:  /* avx512vl_rolvv4si */
   13441     21585151 :     case 7740:  /* avx512vl_rorvv8si */
   13442     21585151 :     case 7738:  /* avx512vl_rolvv8si */
   13443     21585151 :     case 7736:  /* avx512f_rorvv16si */
   13444     21585151 :     case 7734:  /* avx512f_rolvv16si */
   13445     21585151 :     case 7733:  /* sse2_lshrv1ti3 */
   13446     21585151 :     case 7732:  /* sse2_ashlv1ti3 */
   13447     21585151 :     case 7731:  /* avx2_lshrv2ti3 */
   13448     21585151 :     case 7730:  /* avx2_ashlv2ti3 */
   13449     21585151 :     case 7729:  /* avx512bw_lshrv1ti3 */
   13450     21585151 :     case 7728:  /* avx512bw_ashlv1ti3 */
   13451     21585151 :     case 7727:  /* avx512bw_lshrv2ti3 */
   13452     21585151 :     case 7726:  /* avx512bw_ashlv2ti3 */
   13453     21585151 :     case 7725:  /* avx512bw_lshrv4ti3 */
   13454     21585151 :     case 7724:  /* avx512bw_ashlv4ti3 */
   13455     21585151 :     case 7723:  /* *rotrv1ti3_internal */
   13456     21585151 :     case 7722:  /* *rotlv1ti3_internal */
   13457     21585151 :     case 7721:  /* *ashrv1ti3_internal */
   13458     21585151 :     case 7720:  /* *lshrv1ti3_internal */
   13459     21585151 :     case 7719:  /* *ashlv1ti3_internal */
   13460     21585151 :     case 7717:  /* lshrv8di3 */
   13461     21585151 :     case 7715:  /* ashlv8di3 */
   13462     21585151 :     case 7713:  /* lshrv16si3 */
   13463     21585151 :     case 7711:  /* ashlv16si3 */
   13464     21585151 :     case 7709:  /* lshrv32hi3 */
   13465     21585151 :     case 7707:  /* ashlv32hi3 */
   13466     21585151 :     case 7702:  /* lshrv2di3 */
   13467     21585151 :     case 7701:  /* ashlv2di3 */
   13468     21585151 :     case 7700:  /* lshrv4di3 */
   13469     21585151 :     case 7699:  /* ashlv4di3 */
   13470     21585151 :     case 7698:  /* lshrv4si3 */
   13471     21585151 :     case 7697:  /* ashlv4si3 */
   13472     21585151 :     case 7696:  /* lshrv8si3 */
   13473     21585151 :     case 7695:  /* ashlv8si3 */
   13474     21585151 :     case 7694:  /* lshrv8hi3 */
   13475     21585151 :     case 7693:  /* ashlv8hi3 */
   13476     21585151 :     case 7692:  /* lshrv16hi3 */
   13477     21585151 :     case 7691:  /* ashlv16hi3 */
   13478     21585151 :     case 7689:  /* *lshrv2di3 */
   13479     21585151 :     case 7687:  /* *ashlv2di3 */
   13480     21585151 :     case 7685:  /* *lshrv4di3 */
   13481     21585151 :     case 7683:  /* *ashlv4di3 */
   13482     21585151 :     case 7681:  /* *lshrv4si3 */
   13483     21585151 :     case 7679:  /* *ashlv4si3 */
   13484     21585151 :     case 7677:  /* *lshrv8si3 */
   13485     21585151 :     case 7675:  /* *ashlv8si3 */
   13486     21585151 :     case 7673:  /* *lshrv8hi3 */
   13487     21585151 :     case 7671:  /* *ashlv8hi3 */
   13488     21585151 :     case 7669:  /* *lshrv16hi3 */
   13489     21585151 :     case 7667:  /* *ashlv16hi3 */
   13490     21585151 :     case 7656:  /* *ashrv8di3 */
   13491     21585151 :     case 7654:  /* *ashrv16si3 */
   13492     21585151 :     case 7652:  /* *ashrv4di3 */
   13493     21585151 :     case 7650:  /* *ashrv32hi3 */
   13494     21585151 :     case 7649:  /* *ashrv4si3_1 */
   13495     21585151 :     case 7648:  /* *ashrv8si3_1 */
   13496     21585151 :     case 7647:  /* *ashrv8hi3_1 */
   13497     21585151 :     case 7646:  /* *ashrv16hi3_1 */
   13498     21585151 :     case 7645:  /* ashrv4si3 */
   13499     21585151 :     case 7644:  /* ashrv8si3 */
   13500     21585151 :     case 7643:  /* ashrv8hi3 */
   13501     21585151 :     case 7642:  /* ashrv16hi3 */
   13502     21585151 :     case 7640:  /* *ashrv2di3 */
   13503     21585151 :     case 7638:  /* *ashrv4si3 */
   13504     21585151 :     case 7636:  /* *ashrv8si3 */
   13505     21585151 :     case 7634:  /* *ashrv8hi3 */
   13506     21585151 :     case 7632:  /* *ashrv16hi3 */
   13507     21585151 :     case 7630:  /* *sse4_1_mulv4si3 */
   13508     21585151 :     case 7628:  /* *avx2_mulv8si3 */
   13509     21585151 :     case 7626:  /* *avx512f_mulv16si3 */
   13510     21585151 :     case 7624:  /* *avx512dq_mulv2di3 */
   13511     21585151 :     case 7622:  /* *avx512dq_mulv4di3 */
   13512     21585151 :     case 7620:  /* *avx512dq_mulv8di3 */
   13513     21585151 :     case 7586:  /* *mulv8hi3 */
   13514     21585151 :     case 7584:  /* *mulv16hi3 */
   13515     21585151 :     case 7582:  /* *mulv32hi3 */
   13516     21585151 :     case 7580:  /* *sse2_ussubv8hi3 */
   13517     21585151 :     case 7578:  /* *sse2_sssubv8hi3 */
   13518     21585151 :     case 7576:  /* *sse2_usaddv8hi3 */
   13519     21585151 :     case 7574:  /* *sse2_ssaddv8hi3 */
   13520     21585151 :     case 7572:  /* *avx2_ussubv16hi3 */
   13521     21585151 :     case 7570:  /* *avx2_sssubv16hi3 */
   13522     21585151 :     case 7568:  /* *avx2_usaddv16hi3 */
   13523     21585151 :     case 7566:  /* *avx2_ssaddv16hi3 */
   13524     21585151 :     case 7564:  /* *avx512bw_ussubv32hi3 */
   13525     21585151 :     case 7562:  /* *avx512bw_sssubv32hi3 */
   13526     21585151 :     case 7560:  /* *avx512bw_usaddv32hi3 */
   13527     21585151 :     case 7558:  /* *avx512bw_ssaddv32hi3 */
   13528     21585151 :     case 7556:  /* *sse2_ussubv16qi3 */
   13529     21585151 :     case 7554:  /* *sse2_sssubv16qi3 */
   13530     21585151 :     case 7552:  /* *sse2_usaddv16qi3 */
   13531     21585151 :     case 7550:  /* *sse2_ssaddv16qi3 */
   13532     21585151 :     case 7548:  /* *avx2_ussubv32qi3 */
   13533     21585151 :     case 7546:  /* *avx2_sssubv32qi3 */
   13534     21585151 :     case 7544:  /* *avx2_usaddv32qi3 */
   13535     21585151 :     case 7542:  /* *avx2_ssaddv32qi3 */
   13536     21585151 :     case 7540:  /* *avx512bw_ussubv64qi3 */
   13537     21585151 :     case 7538:  /* *avx512bw_sssubv64qi3 */
   13538     21585151 :     case 7536:  /* *avx512bw_usaddv64qi3 */
   13539     21585151 :     case 7534:  /* *avx512bw_ssaddv64qi3 */
   13540     21585151 :     case 7509:  /* *subv2di3 */
   13541     21585151 :     case 7508:  /* *addv2di3 */
   13542     21585151 :     case 7507:  /* *subv4di3 */
   13543     21585151 :     case 7506:  /* *addv4di3 */
   13544     21585151 :     case 7505:  /* *subv8di3 */
   13545     21585151 :     case 7504:  /* *addv8di3 */
   13546     21585151 :     case 7503:  /* *subv4si3 */
   13547     21585151 :     case 7502:  /* *addv4si3 */
   13548     21585151 :     case 7501:  /* *subv8si3 */
   13549     21585151 :     case 7500:  /* *addv8si3 */
   13550     21585151 :     case 7499:  /* *subv16si3 */
   13551     21585151 :     case 7498:  /* *addv16si3 */
   13552     21585151 :     case 7497:  /* *subv8hi3 */
   13553     21585151 :     case 7496:  /* *addv8hi3 */
   13554     21585151 :     case 7495:  /* *subv16hi3 */
   13555     21585151 :     case 7494:  /* *addv16hi3 */
   13556     21585151 :     case 7493:  /* *subv32hi3 */
   13557     21585151 :     case 7492:  /* *addv32hi3 */
   13558     21585151 :     case 7491:  /* *subv16qi3 */
   13559     21585151 :     case 7490:  /* *addv16qi3 */
   13560     21585151 :     case 7489:  /* *subv32qi3 */
   13561     21585151 :     case 7488:  /* *addv32qi3 */
   13562     21585151 :     case 7487:  /* *subv64qi3 */
   13563     21585151 :     case 7486:  /* *addv64qi3 */
   13564     21585151 :     case 7244:  /* vec_concatv2df */
   13565     21585151 :     case 5294:  /* *vec_concatv8bf_0 */
   13566     21585151 :     case 5293:  /* *vec_concatv8hf_0 */
   13567     21585151 :     case 5292:  /* *vec_concatv4sf_0 */
   13568     21585151 :     case 5291:  /* *vec_concatv8bf */
   13569     21585151 :     case 5290:  /* *vec_concatv8hf */
   13570     21585151 :     case 5289:  /* *vec_concatv4sf */
   13571     21585151 :     case 5288:  /* *vec_concatv2sf_sse */
   13572     21585151 :     case 5287:  /* *vec_concatv2sf_sse4_1 */
   13573     21585151 :     case 3856:  /* *xortf3 */
   13574     21585151 :     case 3855:  /* *iortf3 */
   13575     21585151 :     case 3854:  /* *andtf3 */
   13576     21585151 :     case 3853:  /* xordf3 */
   13577     21585151 :     case 3852:  /* iordf3 */
   13578     21585151 :     case 3851:  /* anddf3 */
   13579     21585151 :     case 3850:  /* xorsf3 */
   13580     21585151 :     case 3849:  /* iorsf3 */
   13581     21585151 :     case 3848:  /* andsf3 */
   13582     21585151 :     case 3847:  /* xorhf3 */
   13583     21585151 :     case 3846:  /* iorhf3 */
   13584     21585151 :     case 3845:  /* andhf3 */
   13585     21585151 :     case 3844:  /* xorbf3 */
   13586     21585151 :     case 3843:  /* iorbf3 */
   13587     21585151 :     case 3842:  /* andbf3 */
   13588     21585151 :     case 3835:  /* *bit_and_float_vector_all_ones */
   13589     21585151 :     case 3834:  /* *bit_and_float_vector_all_ones */
   13590     21585151 :     case 3833:  /* *bit_and_float_vector_all_ones */
   13591     21585151 :     case 3832:  /* *bit_and_float_vector_all_ones */
   13592     21585151 :     case 3831:  /* *bit_and_float_vector_all_ones */
   13593     21585151 :     case 3830:  /* *bit_and_float_vector_all_ones */
   13594     21585151 :     case 3829:  /* *bit_and_float_vector_all_ones */
   13595     21585151 :     case 3828:  /* *bit_and_float_vector_all_ones */
   13596     21585151 :     case 3827:  /* *bit_and_float_vector_all_ones */
   13597     21585151 :     case 3826:  /* *bit_and_float_vector_all_ones */
   13598     21585151 :     case 3825:  /* *bit_and_float_vector_all_ones */
   13599     21585151 :     case 3824:  /* *bit_and_float_vector_all_ones */
   13600     21585151 :     case 3822:  /* *xorv8df3 */
   13601     21585151 :     case 3820:  /* *iorv8df3 */
   13602     21585151 :     case 3818:  /* *andv8df3 */
   13603     21585151 :     case 3816:  /* *xorv16sf3 */
   13604     21585151 :     case 3814:  /* *iorv16sf3 */
   13605     21585151 :     case 3812:  /* *andv16sf3 */
   13606     21585151 :     case 3811:  /* *xorv32hf3 */
   13607     21585151 :     case 3810:  /* *iorv32hf3 */
   13608     21585151 :     case 3809:  /* *andv32hf3 */
   13609     21585151 :     case 3808:  /* *xorv32bf3 */
   13610     21585151 :     case 3807:  /* *iorv32bf3 */
   13611     21585151 :     case 3806:  /* *andv32bf3 */
   13612     21585151 :     case 3804:  /* *xorv2df3 */
   13613     21585151 :     case 3802:  /* *iorv2df3 */
   13614     21585151 :     case 3800:  /* *andv2df3 */
   13615     21585151 :     case 3798:  /* *xorv4df3 */
   13616     21585151 :     case 3796:  /* *iorv4df3 */
   13617     21585151 :     case 3794:  /* *andv4df3 */
   13618     21585151 :     case 3792:  /* *xorv4sf3 */
   13619     21585151 :     case 3790:  /* *iorv4sf3 */
   13620     21585151 :     case 3788:  /* *andv4sf3 */
   13621     21585151 :     case 3786:  /* *xorv8sf3 */
   13622     21585151 :     case 3784:  /* *iorv8sf3 */
   13623     21585151 :     case 3782:  /* *andv8sf3 */
   13624     21585151 :     case 3781:  /* *xorv8hf3 */
   13625     21585151 :     case 3780:  /* *iorv8hf3 */
   13626     21585151 :     case 3779:  /* *andv8hf3 */
   13627     21585151 :     case 3778:  /* *xorv16hf3 */
   13628     21585151 :     case 3777:  /* *iorv16hf3 */
   13629     21585151 :     case 3776:  /* *andv16hf3 */
   13630     21585151 :     case 3775:  /* *xorv8bf3 */
   13631     21585151 :     case 3774:  /* *iorv8bf3 */
   13632     21585151 :     case 3773:  /* *andv8bf3 */
   13633     21585151 :     case 3772:  /* *xorv16bf3 */
   13634     21585151 :     case 3771:  /* *iorv16bf3 */
   13635     21585151 :     case 3770:  /* *andv16bf3 */
   13636     21585151 :     case 3082:  /* *sminv2df3 */
   13637     21585151 :     case 3080:  /* *smaxv2df3 */
   13638     21585151 :     case 3078:  /* *sminv4df3 */
   13639     21585151 :     case 3076:  /* *smaxv4df3 */
   13640     21585151 :     case 3072:  /* *sminv8df3 */
   13641     21585151 :     case 3068:  /* *smaxv8df3 */
   13642     21585151 :     case 3066:  /* *sminv4sf3 */
   13643     21585151 :     case 3064:  /* *smaxv4sf3 */
   13644     21585151 :     case 3062:  /* *sminv8sf3 */
   13645     21585151 :     case 3060:  /* *smaxv8sf3 */
   13646     21585151 :     case 3056:  /* *sminv16sf3 */
   13647     21585151 :     case 3052:  /* *smaxv16sf3 */
   13648     21585151 :     case 3050:  /* *sminv8hf3 */
   13649     21585151 :     case 3048:  /* *smaxv8hf3 */
   13650     21585151 :     case 3046:  /* *sminv16hf3 */
   13651     21585151 :     case 3044:  /* *smaxv16hf3 */
   13652     21585151 :     case 3040:  /* *sminv32hf3 */
   13653     21585151 :     case 3036:  /* *smaxv32hf3 */
   13654     21585151 :     case 2927:  /* sse2_divv2df3 */
   13655     21585151 :     case 2925:  /* avx_divv4df3 */
   13656     21585151 :     case 2921:  /* avx512f_divv8df3 */
   13657     21585151 :     case 2919:  /* sse_divv4sf3 */
   13658     21585151 :     case 2917:  /* avx_divv8sf3 */
   13659     21585151 :     case 2913:  /* avx512f_divv16sf3 */
   13660     21585151 :     case 2911:  /* avx512fp16_divv8hf3 */
   13661     21585151 :     case 2909:  /* avx512fp16_divv16hf3 */
   13662     21585151 :     case 2905:  /* avx512fp16_divv32hf3 */
   13663     21585151 :     case 2871:  /* *mulv2df3 */
   13664     21585151 :     case 2867:  /* *mulv4df3 */
   13665     21585151 :     case 2863:  /* *mulv8df3 */
   13666     21585151 :     case 2859:  /* *mulv4sf3 */
   13667     21585151 :     case 2855:  /* *mulv8sf3 */
   13668     21585151 :     case 2851:  /* *mulv16sf3 */
   13669     21585151 :     case 2847:  /* *mulv8hf3 */
   13670     21585151 :     case 2843:  /* *mulv16hf3 */
   13671     21585151 :     case 2839:  /* *mulv32hf3 */
   13672     21585151 :     case 2805:  /* *subv2df3 */
   13673     21585151 :     case 2801:  /* *addv2df3 */
   13674     21585151 :     case 2797:  /* *subv4df3 */
   13675     21585151 :     case 2793:  /* *addv4df3 */
   13676     21585151 :     case 2789:  /* *subv8df3 */
   13677     21585151 :     case 2785:  /* *addv8df3 */
   13678     21585151 :     case 2781:  /* *subv4sf3 */
   13679     21585151 :     case 2777:  /* *addv4sf3 */
   13680     21585151 :     case 2773:  /* *subv8sf3 */
   13681     21585151 :     case 2769:  /* *addv8sf3 */
   13682     21585151 :     case 2765:  /* *subv16sf3 */
   13683     21585151 :     case 2761:  /* *addv16sf3 */
   13684     21585151 :     case 2757:  /* *subv8hf3 */
   13685     21585151 :     case 2753:  /* *addv8hf3 */
   13686     21585151 :     case 2749:  /* *subv16hf3 */
   13687     21585151 :     case 2745:  /* *addv16hf3 */
   13688     21585151 :     case 2741:  /* *subv32hf3 */
   13689     21585151 :     case 2737:  /* *addv32hf3 */
   13690     21585151 :     case 2611:  /* *sse2_movq128_v2df_1 */
   13691     21585151 :     case 2610:  /* *sse2_movq128_v2di_1 */
   13692     21585151 :     case 2396:  /* *mmx_concatv2si */
   13693     21585151 :     case 2330:  /* *mmx_xorv2si3 */
   13694     21585151 :     case 2329:  /* *mmx_iorv2si3 */
   13695     21585151 :     case 2328:  /* *mmx_andv2si3 */
   13696     21585151 :     case 2327:  /* *mmx_xorv4hi3 */
   13697     21585151 :     case 2326:  /* *mmx_iorv4hi3 */
   13698     21585151 :     case 2325:  /* *mmx_andv4hi3 */
   13699     21585151 :     case 2324:  /* *mmx_xorv8qi3 */
   13700     21585151 :     case 2323:  /* *mmx_iorv8qi3 */
   13701     21585151 :     case 2322:  /* *mmx_andv8qi3 */
   13702     21585151 :     case 2276:  /* *gtv2hi3 */
   13703     21585151 :     case 2275:  /* *gtv2qi3 */
   13704     21585151 :     case 2274:  /* *gtv4qi3 */
   13705     21585151 :     case 2273:  /* mmx_gtv2si3 */
   13706     21585151 :     case 2272:  /* mmx_gtv4hi3 */
   13707     21585151 :     case 2271:  /* mmx_gtv8qi3 */
   13708     21585151 :     case 2270:  /* *eqv2hi3 */
   13709     21585151 :     case 2269:  /* *eqv2qi3 */
   13710     21585151 :     case 2268:  /* *eqv4qi3 */
   13711     21585151 :     case 2267:  /* *mmx_eqv2si3 */
   13712     21585151 :     case 2266:  /* *mmx_eqv4hi3 */
   13713     21585151 :     case 2265:  /* *mmx_eqv8qi3 */
   13714     21585151 :     case 2261:  /* *mmx_ashrv2hi3_1 */
   13715     21585151 :     case 2260:  /* ashrv2hi3 */
   13716     21585151 :     case 2259:  /* lshrv2hi3 */
   13717     21585151 :     case 2258:  /* ashlv2hi3 */
   13718     21585151 :     case 2257:  /* mmx_lshrv1si3 */
   13719     21585151 :     case 2256:  /* mmx_ashlv1si3 */
   13720     21585151 :     case 2255:  /* mmx_lshrv1di3 */
   13721     21585151 :     case 2254:  /* mmx_ashlv1di3 */
   13722     21585151 :     case 2253:  /* mmx_lshrv2si3 */
   13723     21585151 :     case 2252:  /* mmx_ashlv2si3 */
   13724     21585151 :     case 2251:  /* mmx_lshrv4hi3 */
   13725     21585151 :     case 2250:  /* mmx_ashlv4hi3 */
   13726     21585151 :     case 2249:  /* *mmx_ashrv2si3_1 */
   13727     21585151 :     case 2248:  /* *mmx_ashrv4hi3_1 */
   13728     21585151 :     case 2247:  /* mmx_ashrv2si3 */
   13729     21585151 :     case 2246:  /* mmx_ashrv4hi3 */
   13730     21585151 :     case 2239:  /* uminv2hi3 */
   13731     21585151 :     case 2238:  /* umaxv2hi3 */
   13732     21585151 :     case 2237:  /* uminv2qi3 */
   13733     21585151 :     case 2236:  /* umaxv2qi3 */
   13734     21585151 :     case 2235:  /* uminv4qi3 */
   13735     21585151 :     case 2234:  /* umaxv4qi3 */
   13736     21585151 :     case 2233:  /* *mmx_uminv8qi3 */
   13737     21585151 :     case 2232:  /* *mmx_umaxv8qi3 */
   13738     21585151 :     case 2231:  /* uminv2si3 */
   13739     21585151 :     case 2230:  /* umaxv2si3 */
   13740     21585151 :     case 2229:  /* uminv4hi3 */
   13741     21585151 :     case 2228:  /* umaxv4hi3 */
   13742     21585151 :     case 2227:  /* sminv2hi3 */
   13743     21585151 :     case 2226:  /* smaxv2hi3 */
   13744     21585151 :     case 2225:  /* sminv2qi3 */
   13745     21585151 :     case 2224:  /* smaxv2qi3 */
   13746     21585151 :     case 2223:  /* sminv4qi3 */
   13747     21585151 :     case 2222:  /* smaxv4qi3 */
   13748     21585151 :     case 2221:  /* *mmx_sminv4hi3 */
   13749     21585151 :     case 2220:  /* *mmx_smaxv4hi3 */
   13750     21585151 :     case 2219:  /* sminv2si3 */
   13751     21585151 :     case 2218:  /* smaxv2si3 */
   13752     21585151 :     case 2217:  /* sminv8qi3 */
   13753     21585151 :     case 2216:  /* smaxv8qi3 */
   13754     21585151 :     case 2208:  /* mulv2hi3 */
   13755     21585151 :     case 2207:  /* *mmx_mulv4hi3 */
   13756     21585151 :     case 2206:  /* mulv2si3 */
   13757     21585151 :     case 2205:  /* ussubv2hi3 */
   13758     21585151 :     case 2204:  /* sssubv2hi3 */
   13759     21585151 :     case 2203:  /* usaddv2hi3 */
   13760     21585151 :     case 2202:  /* ssaddv2hi3 */
   13761     21585151 :     case 2201:  /* ussubv2qi3 */
   13762     21585151 :     case 2200:  /* sssubv2qi3 */
   13763     21585151 :     case 2199:  /* usaddv2qi3 */
   13764     21585151 :     case 2198:  /* ssaddv2qi3 */
   13765     21585151 :     case 2197:  /* ussubv4qi3 */
   13766     21585151 :     case 2196:  /* sssubv4qi3 */
   13767     21585151 :     case 2195:  /* usaddv4qi3 */
   13768     21585151 :     case 2194:  /* ssaddv4qi3 */
   13769     21585151 :     case 2193:  /* *mmx_ussubv4hi3 */
   13770     21585151 :     case 2192:  /* *mmx_sssubv4hi3 */
   13771     21585151 :     case 2191:  /* *mmx_usaddv4hi3 */
   13772     21585151 :     case 2190:  /* *mmx_ssaddv4hi3 */
   13773     21585151 :     case 2189:  /* *mmx_ussubv8qi3 */
   13774     21585151 :     case 2188:  /* *mmx_sssubv8qi3 */
   13775     21585151 :     case 2187:  /* *mmx_usaddv8qi3 */
   13776     21585151 :     case 2186:  /* *mmx_ssaddv8qi3 */
   13777     21585151 :     case 2183:  /* subv2hi3 */
   13778     21585151 :     case 2182:  /* addv2hi3 */
   13779     21585151 :     case 2181:  /* subv4qi3 */
   13780     21585151 :     case 2180:  /* addv4qi3 */
   13781     21585151 :     case 2179:  /* *mmx_subv1di3 */
   13782     21585151 :     case 2178:  /* *mmx_addv1di3 */
   13783     21585151 :     case 2177:  /* *mmx_subv2si3 */
   13784     21585151 :     case 2176:  /* *mmx_addv2si3 */
   13785     21585151 :     case 2175:  /* *mmx_subv4hi3 */
   13786     21585151 :     case 2174:  /* *mmx_addv4hi3 */
   13787     21585151 :     case 2173:  /* *mmx_subv8qi3 */
   13788     21585151 :     case 2172:  /* *mmx_addv8qi3 */
   13789     21585151 :     case 2170:  /* xorv4hf3 */
   13790     21585151 :     case 2169:  /* iorv4hf3 */
   13791     21585151 :     case 2168:  /* andv4hf3 */
   13792     21585151 :     case 2167:  /* xorv2hf3 */
   13793     21585151 :     case 2166:  /* iorv2hf3 */
   13794     21585151 :     case 2165:  /* andv2hf3 */
   13795     21585151 :     case 2164:  /* xorv4bf3 */
   13796     21585151 :     case 2163:  /* iorv4bf3 */
   13797     21585151 :     case 2162:  /* andv4bf3 */
   13798     21585151 :     case 2161:  /* xorv2bf3 */
   13799     21585151 :     case 2160:  /* iorv2bf3 */
   13800     21585151 :     case 2159:  /* andv2bf3 */
   13801     21585151 :     case 2140:  /* *mmx_concatv2sf */
   13802     21585151 :     case 2127:  /* xorv2sf3 */
   13803     21585151 :     case 2126:  /* iorv2sf3 */
   13804     21585151 :     case 2125:  /* andv2sf3 */
   13805     21585151 :     case 1846:  /* sminhf3 */
   13806     21585151 :     case 1845:  /* smaxhf3 */
   13807     21585151 :     case 1844:  /* smindf3 */
   13808     21585151 :     case 1843:  /* smaxdf3 */
   13809     21585151 :     case 1842:  /* sminsf3 */
   13810     21585151 :     case 1841:  /* smaxsf3 */
   13811     21585151 :     case 1705:  /* *divhf */
   13812     21585151 :     case 1704:  /* *mulhf */
   13813     21585151 :     case 1703:  /* *subhf */
   13814     21585151 :     case 1702:  /* *addhf */
   13815     21585151 :     case 1411:  /* *rotrhi3_1_nf */
   13816     21585151 :     case 1409:  /* *rotlhi3_1_nf */
   13817     21585151 :     case 1407:  /* *rotrqi3_1_nf */
   13818     21585151 :     case 1405:  /* *rotlqi3_1_nf */
   13819     21585151 :     case 1380:  /* *rotrdi3_1_nf */
   13820     21585151 :     case 1378:  /* *rotldi3_1_nf */
   13821     21585151 :     case 1376:  /* *rotrsi3_1_nf */
   13822     21585151 :     case 1374:  /* *rotlsi3_1_nf */
   13823     21585151 :     case 1373:  /* *bmi2_rorxdi3_1 */
   13824     21585151 :     case 1372:  /* *bmi2_rorxsi3_1 */
   13825     21585151 :     case 1246:  /* *lshrhi3_1_nf */
   13826     21585151 :     case 1244:  /* *lshrqi3_1_nf */
   13827     21585151 :     case 1242:  /* *ashrhi3_1_nf */
   13828     21585151 :     case 1240:  /* *ashrqi3_1_nf */
   13829     21585151 :     case 1214:  /* *lshrdi3_1_nf */
   13830     21585151 :     case 1212:  /* *lshrsi3_1_nf */
   13831     21585151 :     case 1209:  /* *ashrdi3_1_nf */
   13832     21585151 :     case 1207:  /* *ashrsi3_1_nf */
   13833     21585151 :     case 1206:  /* *bmi2_ashrdi3_1 */
   13834     21585151 :     case 1205:  /* *bmi2_lshrdi3_1 */
   13835     21585151 :     case 1204:  /* *bmi2_ashrsi3_1 */
   13836     21585151 :     case 1203:  /* *bmi2_lshrsi3_1 */
   13837     21585151 :     case 1200:  /* ashrdi3_cvt_nf */
   13838     21585151 :     case 1198:  /* ashrsi3_cvt_nf */
   13839     21585151 :     case 1138:  /* *ashlqi3_1_nf */
   13840     21585151 :     case 1136:  /* *ashlhi3_1_nf */
   13841     21585151 :     case 1122:  /* *ashldi3_1_nf */
   13842     21585151 :     case 1120:  /* *ashlsi3_1_nf */
   13843     21585151 :     case 1119:  /* *bmi2_ashldi3_1 */
   13844     21585151 :     case 1118:  /* *bmi2_ashlsi3_1 */
   13845     21585151 :     case 897:  /* *xorqi_1_nf */
   13846     21585151 :     case 895:  /* *iorqi_1_nf */
   13847     21585151 :     case 861:  /* *xordi_1_nf */
   13848     21585151 :     case 859:  /* *iordi_1_nf */
   13849     21585151 :     case 857:  /* *xorsi_1_nf */
   13850     21585151 :     case 855:  /* *iorsi_1_nf */
   13851     21585151 :     case 853:  /* *xorhi_1_nf */
   13852     21585151 :     case 851:  /* *iorhi_1_nf */
   13853     21585151 :     case 751:  /* *andqi_1_nf */
   13854     21585151 :     case 749:  /* *andsi_1_nf */
   13855     21585151 :     case 747:  /* *andhi_1_nf */
   13856     21585151 :     case 733:  /* *anddi_1_nf */
   13857     21585151 :     case 630:  /* *mulqi3_1_nf */
   13858     21585151 :     case 622:  /* *muldi3_1_nf */
   13859     21585151 :     case 620:  /* *mulsi3_1_nf */
   13860     21585151 :     case 618:  /* *mulhi3_1_nf */
   13861     21585151 :     case 394:  /* *subdi_1_nf */
   13862     21585151 :     case 392:  /* *subsi_1_nf */
   13863     21585151 :     case 390:  /* *subhi_1_nf */
   13864     21585151 :     case 388:  /* *subqi_1_nf */
   13865     21585151 :     case 303:  /* *addqi_1_nf */
   13866     21585151 :     case 301:  /* *addhi_1_nf */
   13867     21585151 :     case 288:  /* *adddi_1_nf */
   13868     21585151 :     case 286:  /* *addsi_1_nf */
   13869     21585151 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   13870     21585151 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
   13871     21585151 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 1));
   13872     21585151 :       break;
   13873              : 
   13874          114 :     case 285:  /* *addti3_doubleword_concat_zext */
   13875          114 :     case 284:  /* *addti3_doubleword_concat_zext */
   13876          114 :     case 283:  /* *addti3_doubleword_concat_zext */
   13877          114 :     case 282:  /* *adddi3_doubleword_concat_zext */
   13878          114 :     case 281:  /* *adddi3_doubleword_concat_zext */
   13879          114 :     case 280:  /* *adddi3_doubleword_concat_zext */
   13880          114 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   13881          114 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1), 0));
   13882          114 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   13883          114 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   13884          114 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   13885          114 :       break;
   13886              : 
   13887        15943 :     case 279:  /* *addti3_doubleword_concat */
   13888        15943 :     case 278:  /* *addti3_doubleword_concat */
   13889        15943 :     case 277:  /* *addti3_doubleword_concat */
   13890        15943 :     case 276:  /* *adddi3_doubleword_concat */
   13891        15943 :     case 275:  /* *adddi3_doubleword_concat */
   13892        15943 :     case 274:  /* *adddi3_doubleword_concat */
   13893        15943 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   13894        15943 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   13895        15943 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 0), 0));
   13896        15943 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0), 1));
   13897        15943 :       ro[4] = *(ro_loc[4] = &XEXP (XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 1), 0));
   13898        15943 :       break;
   13899              : 
   13900        37759 :     case 597:  /* *adddi3_ne_0 */
   13901        37759 :     case 596:  /* *addsi3_ne_0 */
   13902        37759 :     case 595:  /* *addhi3_ne_0 */
   13903        37759 :     case 594:  /* *addqi3_ne_0 */
   13904        37759 :     case 593:  /* *adddi3_eq_0 */
   13905        37759 :     case 592:  /* *addsi3_eq_0 */
   13906        37759 :     case 591:  /* *addhi3_eq_0 */
   13907        37759 :     case 590:  /* *addqi3_eq_0 */
   13908        37759 :     case 273:  /* *addti3_doubleword_zext */
   13909        37759 :     case 272:  /* *adddi3_doubleword_zext */
   13910        37759 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   13911        37759 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   13912        37759 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0), 0));
   13913        37759 :       break;
   13914              : 
   13915    217880194 :     case 2662:  /* klshiftrtdi */
   13916    217880194 :     case 2661:  /* kashiftdi */
   13917    217880194 :     case 2660:  /* klshiftrtsi */
   13918    217880194 :     case 2659:  /* kashiftsi */
   13919    217880194 :     case 2658:  /* klshiftrthi */
   13920    217880194 :     case 2657:  /* kashifthi */
   13921    217880194 :     case 2656:  /* klshiftrtqi */
   13922    217880194 :     case 2655:  /* kashiftqi */
   13923    217880194 :     case 2654:  /* kadddi */
   13924    217880194 :     case 2653:  /* kaddsi */
   13925    217880194 :     case 2652:  /* kaddhi */
   13926    217880194 :     case 2651:  /* kaddqi */
   13927    217880194 :     case 2637:  /* kxordi */
   13928    217880194 :     case 2636:  /* kiordi */
   13929    217880194 :     case 2635:  /* kanddi */
   13930    217880194 :     case 2634:  /* kxorsi */
   13931    217880194 :     case 2633:  /* kiorsi */
   13932    217880194 :     case 2632:  /* kandsi */
   13933    217880194 :     case 2631:  /* kxorhi */
   13934    217880194 :     case 2630:  /* kiorhi */
   13935    217880194 :     case 2629:  /* kandhi */
   13936    217880194 :     case 2628:  /* kxorqi */
   13937    217880194 :     case 2627:  /* kiorqi */
   13938    217880194 :     case 2626:  /* kandqi */
   13939    217880194 :     case 2339:  /* *xorv2hi3 */
   13940    217880194 :     case 2338:  /* *iorv2hi3 */
   13941    217880194 :     case 2337:  /* *andv2hi3 */
   13942    217880194 :     case 2336:  /* *xorv2qi3 */
   13943    217880194 :     case 2335:  /* *iorv2qi3 */
   13944    217880194 :     case 2334:  /* *andv2qi3 */
   13945    217880194 :     case 2333:  /* *xorv4qi3 */
   13946    217880194 :     case 2332:  /* *iorv4qi3 */
   13947    217880194 :     case 2331:  /* *andv4qi3 */
   13948    217880194 :     case 2264:  /* ashrv2qi3 */
   13949    217880194 :     case 2263:  /* lshrv2qi3 */
   13950    217880194 :     case 2262:  /* ashlv2qi3 */
   13951    217880194 :     case 2185:  /* subv2qi3 */
   13952    217880194 :     case 2184:  /* addv2qi3 */
   13953    217880194 :     case 2119:  /* mmx_gev2sf3 */
   13954    217880194 :     case 2118:  /* mmx_gtv2sf3 */
   13955    217880194 :     case 2117:  /* *mmx_eqv2sf3 */
   13956    217880194 :     case 2104:  /* *mmx_sminv2sf3 */
   13957    217880194 :     case 2103:  /* *mmx_smaxv2sf3 */
   13958    217880194 :     case 2102:  /* *mmx_mulv2sf3 */
   13959    217880194 :     case 2101:  /* *mmx_subv2sf3 */
   13960    217880194 :     case 2100:  /* *mmx_addv2sf3 */
   13961    217880194 :     case 1904:  /* pro_epilogue_adjust_stack_sub_di */
   13962    217880194 :     case 1903:  /* pro_epilogue_adjust_stack_sub_si */
   13963    217880194 :     case 1902:  /* pro_epilogue_adjust_stack_add_noccdi */
   13964    217880194 :     case 1901:  /* pro_epilogue_adjust_stack_add_noccsi */
   13965    217880194 :     case 1900:  /* pro_epilogue_adjust_stack_add_di */
   13966    217880194 :     case 1899:  /* pro_epilogue_adjust_stack_add_si */
   13967    217880194 :     case 1880:  /* *umindi3_1 */
   13968    217880194 :     case 1879:  /* *umaxdi3_1 */
   13969    217880194 :     case 1878:  /* *smindi3_1 */
   13970    217880194 :     case 1877:  /* *smaxdi3_1 */
   13971    217880194 :     case 1876:  /* *uminsi3_1 */
   13972    217880194 :     case 1875:  /* *umaxsi3_1 */
   13973    217880194 :     case 1874:  /* *sminsi3_1 */
   13974    217880194 :     case 1873:  /* *smaxsi3_1 */
   13975    217880194 :     case 1872:  /* *uminhi3_1 */
   13976    217880194 :     case 1871:  /* *umaxhi3_1 */
   13977    217880194 :     case 1870:  /* *sminhi3_1 */
   13978    217880194 :     case 1869:  /* *smaxhi3_1 */
   13979    217880194 :     case 1868:  /* *uminqi3_1 */
   13980    217880194 :     case 1867:  /* *umaxqi3_1 */
   13981    217880194 :     case 1866:  /* *sminqi3_1 */
   13982    217880194 :     case 1865:  /* *smaxqi3_1 */
   13983    217880194 :     case 1864:  /* *uminti3_doubleword */
   13984    217880194 :     case 1863:  /* *umaxti3_doubleword */
   13985    217880194 :     case 1862:  /* *sminti3_doubleword */
   13986    217880194 :     case 1861:  /* *smaxti3_doubleword */
   13987    217880194 :     case 1860:  /* *umindi3_doubleword */
   13988    217880194 :     case 1859:  /* *umaxdi3_doubleword */
   13989    217880194 :     case 1858:  /* *smindi3_doubleword */
   13990    217880194 :     case 1857:  /* *smaxdi3_doubleword */
   13991    217880194 :     case 1412:  /* *rotrhi3_1 */
   13992    217880194 :     case 1410:  /* *rotlhi3_1 */
   13993    217880194 :     case 1408:  /* *rotrqi3_1 */
   13994    217880194 :     case 1406:  /* *rotlqi3_1 */
   13995    217880194 :     case 1381:  /* *rotrdi3_1 */
   13996    217880194 :     case 1379:  /* *rotldi3_1 */
   13997    217880194 :     case 1377:  /* *rotrsi3_1 */
   13998    217880194 :     case 1375:  /* *rotlsi3_1 */
   13999    217880194 :     case 1247:  /* *lshrhi3_1 */
   14000    217880194 :     case 1245:  /* *lshrqi3_1 */
   14001    217880194 :     case 1243:  /* *ashrhi3_1 */
   14002    217880194 :     case 1241:  /* *ashrqi3_1 */
   14003    217880194 :     case 1215:  /* *lshrdi3_1 */
   14004    217880194 :     case 1213:  /* *lshrsi3_1 */
   14005    217880194 :     case 1210:  /* *ashrdi3_1 */
   14006    217880194 :     case 1208:  /* *ashrsi3_1 */
   14007    217880194 :     case 1201:  /* ashrdi3_cvt */
   14008    217880194 :     case 1199:  /* ashrsi3_cvt */
   14009    217880194 :     case 1165:  /* ashrti3_doubleword */
   14010    217880194 :     case 1164:  /* lshrti3_doubleword */
   14011    217880194 :     case 1163:  /* ashrdi3_doubleword */
   14012    217880194 :     case 1162:  /* lshrdi3_doubleword */
   14013    217880194 :     case 1139:  /* *ashlqi3_1 */
   14014    217880194 :     case 1137:  /* *ashlhi3_1 */
   14015    217880194 :     case 1123:  /* *ashldi3_1 */
   14016    217880194 :     case 1121:  /* *ashlsi3_1 */
   14017    217880194 :     case 1089:  /* ashlti3_doubleword */
   14018    217880194 :     case 1088:  /* ashldi3_doubleword */
   14019    217880194 :     case 898:  /* *xorqi_1 */
   14020    217880194 :     case 896:  /* *iorqi_1 */
   14021    217880194 :     case 867:  /* *xordi_1_btc */
   14022    217880194 :     case 866:  /* *iordi_1_bts */
   14023    217880194 :     case 862:  /* *xordi_1 */
   14024    217880194 :     case 860:  /* *iordi_1 */
   14025    217880194 :     case 858:  /* *xorsi_1 */
   14026    217880194 :     case 856:  /* *iorsi_1 */
   14027    217880194 :     case 854:  /* *xorhi_1 */
   14028    217880194 :     case 852:  /* *iorhi_1 */
   14029    217880194 :     case 850:  /* *xorti3_doubleword */
   14030    217880194 :     case 849:  /* *iorti3_doubleword */
   14031    217880194 :     case 848:  /* *xordi3_doubleword */
   14032    217880194 :     case 847:  /* *iordi3_doubleword */
   14033    217880194 :     case 752:  /* *andqi_1 */
   14034    217880194 :     case 750:  /* *andsi_1 */
   14035    217880194 :     case 748:  /* *andhi_1 */
   14036    217880194 :     case 735:  /* *anddi_1_btr */
   14037    217880194 :     case 734:  /* *anddi_1 */
   14038    217880194 :     case 732:  /* *andti3_doubleword */
   14039    217880194 :     case 731:  /* *anddi3_doubleword */
   14040    217880194 :     case 631:  /* *mulqi3_1 */
   14041    217880194 :     case 623:  /* *muldi3_1 */
   14042    217880194 :     case 621:  /* *mulsi3_1 */
   14043    217880194 :     case 619:  /* *mulhi3_1 */
   14044    217880194 :     case 522:  /* *subdi3_carry_0r */
   14045    217880194 :     case 521:  /* *subsi3_carry_0r */
   14046    217880194 :     case 520:  /* *subhi3_carry_0r */
   14047    217880194 :     case 519:  /* *subqi3_carry_0r */
   14048    217880194 :     case 514:  /* *subdi3_carry_0 */
   14049    217880194 :     case 513:  /* *subsi3_carry_0 */
   14050    217880194 :     case 512:  /* *subhi3_carry_0 */
   14051    217880194 :     case 511:  /* *subqi3_carry_0 */
   14052    217880194 :     case 395:  /* *subdi_1 */
   14053    217880194 :     case 393:  /* *subsi_1 */
   14054    217880194 :     case 391:  /* *subhi_1 */
   14055    217880194 :     case 389:  /* *subqi_1 */
   14056    217880194 :     case 385:  /* *subti3_doubleword */
   14057    217880194 :     case 384:  /* *subdi3_doubleword */
   14058    217880194 :     case 304:  /* *addqi_1 */
   14059    217880194 :     case 302:  /* *addhi_1 */
   14060    217880194 :     case 289:  /* *adddi_1 */
   14061    217880194 :     case 287:  /* *addsi_1 */
   14062    217880194 :     case 271:  /* *addti3_doubleword */
   14063    217880194 :     case 270:  /* *adddi3_doubleword */
   14064    217880194 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14065    217880194 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14066    217880194 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 1));
   14067    217880194 :       break;
   14068              : 
   14069       550083 :     case 8614:  /* sse_stmxcsr */
   14070       550083 :     case 2059:  /* sttilecfg */
   14071       550083 :     case 2028:  /* rdpid_rex64 */
   14072       550083 :     case 2027:  /* rdpid */
   14073       550083 :     case 1987:  /* rdgsbasedi */
   14074       550083 :     case 1986:  /* rdfsbasedi */
   14075       550083 :     case 1985:  /* rdgsbasesi */
   14076       550083 :     case 1984:  /* rdfsbasesi */
   14077       550083 :     case 1979:  /* lwp_slwpcbdi */
   14078       550083 :     case 1978:  /* lwp_slwpcbsi */
   14079       550083 :     case 1974:  /* fnstsw */
   14080       550083 :     case 1947:  /* fxsave64 */
   14081       550083 :     case 1946:  /* fxsave */
   14082       550083 :     case 1942:  /* rdtsc */
   14083       550083 :     case 1935:  /* *prefetch_rst2 */
   14084       550083 :     case 1740:  /* x86_fnstsw_1 */
   14085       550083 :     case 1686:  /* *load_tp_x32_zext */
   14086       550083 :     case 1685:  /* *load_tp_di */
   14087       550083 :     case 1684:  /* *load_tp_si */
   14088       550083 :     case 1524:  /* set_got_rex64 */
   14089       550083 :     case 242:  /* x86_fnstcw_1 */
   14090       550083 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14091       550083 :       break;
   14092              : 
   14093        88044 :     case 267:  /* floatunssixf2_i387_with_xmm */
   14094        88044 :     case 266:  /* floatunssidf2_i387_with_xmm */
   14095        88044 :     case 265:  /* floatunssisf2_i387_with_xmm */
   14096        88044 :     case 241:  /* fix_truncsi_i387 */
   14097        88044 :     case 240:  /* fix_trunchi_i387 */
   14098        88044 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14099        88044 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14100        88044 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
   14101        88044 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 2), 0));
   14102        88044 :       break;
   14103              : 
   14104        97337 :     case 260:  /* floatdixf2_i387_with_xmm */
   14105        97337 :     case 259:  /* floatdidf2_i387_with_xmm */
   14106        97337 :     case 258:  /* floatdisf2_i387_with_xmm */
   14107        97337 :     case 239:  /* fix_truncdi_i387 */
   14108        97337 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14109        97337 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14110        97337 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
   14111        97337 :       ro[3] = *(ro_loc[3] = &XEXP (XVECEXP (pat, 0, 2), 0));
   14112        97337 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 3), 0));
   14113        97337 :       break;
   14114              : 
   14115       468741 :     case 2730:  /* *negv2df2 */
   14116       468741 :     case 2729:  /* *absv2df2 */
   14117       468741 :     case 2728:  /* *negv4df2 */
   14118       468741 :     case 2727:  /* *absv4df2 */
   14119       468741 :     case 2726:  /* *negv8df2 */
   14120       468741 :     case 2725:  /* *absv8df2 */
   14121       468741 :     case 2724:  /* *negv4sf2 */
   14122       468741 :     case 2723:  /* *absv4sf2 */
   14123       468741 :     case 2722:  /* *negv8sf2 */
   14124       468741 :     case 2721:  /* *absv8sf2 */
   14125       468741 :     case 2720:  /* *negv16sf2 */
   14126       468741 :     case 2719:  /* *absv16sf2 */
   14127       468741 :     case 2718:  /* *negv8hf2 */
   14128       468741 :     case 2717:  /* *absv8hf2 */
   14129       468741 :     case 2716:  /* *negv16hf2 */
   14130       468741 :     case 2715:  /* *absv16hf2 */
   14131       468741 :     case 2714:  /* *negv32hf2 */
   14132       468741 :     case 2713:  /* *absv32hf2 */
   14133       468741 :     case 2712:  /* *negv8bf2 */
   14134       468741 :     case 2711:  /* *absv8bf2 */
   14135       468741 :     case 2710:  /* *negv16bf2 */
   14136       468741 :     case 2709:  /* *absv16bf2 */
   14137       468741 :     case 2708:  /* *negv32bf2 */
   14138       468741 :     case 2707:  /* *absv32bf2 */
   14139       468741 :     case 2150:  /* *mmx_negv4hf */
   14140       468741 :     case 2149:  /* *mmx_absv4hf */
   14141       468741 :     case 2148:  /* *mmx_negv2hf */
   14142       468741 :     case 2147:  /* *mmx_absv2hf */
   14143       468741 :     case 2146:  /* *mmx_negv4bf */
   14144       468741 :     case 2145:  /* *mmx_absv4bf */
   14145       468741 :     case 2144:  /* *mmx_negv2bf */
   14146       468741 :     case 2143:  /* *mmx_absv2bf */
   14147       468741 :     case 2098:  /* *mmx_negv2sf2 */
   14148       468741 :     case 2097:  /* *mmx_absv2sf2 */
   14149       468741 :     case 1531:  /* ffssi2_no_cmove */
   14150       468741 :     case 1053:  /* *negdf2_1 */
   14151       468741 :     case 1052:  /* *absdf2_1 */
   14152       468741 :     case 1051:  /* *negsf2_1 */
   14153       468741 :     case 1050:  /* *abssf2_1 */
   14154       468741 :     case 1049:  /* *neghf2_1 */
   14155       468741 :     case 1048:  /* *abshf2_1 */
   14156       468741 :     case 1040:  /* *negtf2_1 */
   14157       468741 :     case 1039:  /* *abstf2_1 */
   14158       468741 :     case 235:  /* fix_truncdi_i387_fisttp */
   14159       468741 :     case 234:  /* fix_truncsi_i387_fisttp */
   14160       468741 :     case 233:  /* fix_trunchi_i387_fisttp */
   14161       468741 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14162       468741 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14163       468741 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
   14164       468741 :       break;
   14165              : 
   14166            0 :     case 228:  /* *fixuns_truncdf_1 */
   14167            0 :     case 227:  /* *fixuns_truncsf_1 */
   14168            0 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14169            0 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 2), 0));
   14170            0 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 3), 0));
   14171            0 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14172            0 :       ro[4] = *(ro_loc[4] = &XEXP (XVECEXP (pat, 0, 1), 0));
   14173            0 :       break;
   14174              : 
   14175         6207 :     case 203:  /* *extendqisi_ext_1 */
   14176         6207 :     case 202:  /* *extendqisi_ext_1 */
   14177         6207 :     case 201:  /* *extendqisi_ext_1 */
   14178         6207 :     case 200:  /* *extendqihi_ext_1 */
   14179         6207 :     case 199:  /* *extendqihi_ext_1 */
   14180         6207 :     case 198:  /* *extendqihi_ext_1 */
   14181         6207 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14182         6207 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   14183         6207 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   14184         6207 :       break;
   14185              : 
   14186       257241 :     case 10497:  /* vcvtneobf162ps_v16bf */
   14187       257241 :     case 10496:  /* vcvtneoph2ps_v16hf */
   14188       257241 :     case 10495:  /* vcvtneobf162ps_v8bf */
   14189       257241 :     case 10494:  /* vcvtneoph2ps_v8hf */
   14190       257241 :     case 10493:  /* vcvtneebf162ps_v16bf */
   14191       257241 :     case 10492:  /* vcvtneeph2ps_v16hf */
   14192       257241 :     case 10491:  /* vcvtneebf162ps_v8bf */
   14193       257241 :     case 10490:  /* vcvtneeph2ps_v8hf */
   14194       257241 :     case 10489:  /* vbcstnesh2ps_v4sf */
   14195       257241 :     case 10488:  /* vbcstnesh2ps_v8sf */
   14196       257241 :     case 10487:  /* vbcstnebf162ps_v4sf */
   14197       257241 :     case 10486:  /* vbcstnebf162ps_v8sf */
   14198       257241 :     case 10166:  /* avx512f_pd512_pd */
   14199       257241 :     case 10165:  /* avx512f_ps512_ps */
   14200       257241 :     case 10164:  /* avx512f_si512_si */
   14201       257241 :     case 9389:  /* *avx512dq_broadcastv8sf */
   14202       257241 :     case 9387:  /* *avx512dq_broadcastv16sf */
   14203       257241 :     case 9385:  /* *avx512dq_broadcastv4si */
   14204       257241 :     case 9383:  /* *avx512dq_broadcastv8si */
   14205       257241 :     case 9381:  /* *avx512dq_broadcastv16si */
   14206       257241 :     case 9285:  /* avx512vl_vec_dupv8bf */
   14207       257241 :     case 9283:  /* avx512vl_vec_dupv16bf */
   14208       257241 :     case 9281:  /* avx512bw_vec_dupv32bf */
   14209       257241 :     case 9279:  /* avx512fp16_vec_dupv8hf */
   14210       257241 :     case 9277:  /* avx512vl_vec_dupv16hf */
   14211       257241 :     case 9275:  /* avx512bw_vec_dupv32hf */
   14212       257241 :     case 9273:  /* avx512vl_vec_dupv8hi */
   14213       257241 :     case 9271:  /* avx512vl_vec_dupv16hi */
   14214       257241 :     case 9269:  /* avx512bw_vec_dupv32hi */
   14215       257241 :     case 9267:  /* avx512vl_vec_dupv32qi */
   14216       257241 :     case 9265:  /* avx512vl_vec_dupv16qi */
   14217       257241 :     case 9263:  /* avx512bw_vec_dupv64qi */
   14218       257241 :     case 9261:  /* avx512vl_vec_dupv2df */
   14219       257241 :     case 9259:  /* avx512vl_vec_dupv4df */
   14220       257241 :     case 9257:  /* avx512f_vec_dupv8df */
   14221       257241 :     case 9255:  /* avx512vl_vec_dupv4sf */
   14222       257241 :     case 9253:  /* avx512vl_vec_dupv8sf */
   14223       257241 :     case 9251:  /* avx512f_vec_dupv16sf */
   14224       257241 :     case 9249:  /* avx512vl_vec_dupv2di */
   14225       257241 :     case 9247:  /* avx512vl_vec_dupv4di */
   14226       257241 :     case 9245:  /* avx512f_vec_dupv8di */
   14227       257241 :     case 9243:  /* avx512vl_vec_dupv4si */
   14228       257241 :     case 9241:  /* avx512vl_vec_dupv8si */
   14229       257241 :     case 9239:  /* avx512f_vec_dupv16si */
   14230       257241 :     case 9238:  /* avx512bw_vec_dupv32bf_1 */
   14231       257241 :     case 9237:  /* avx512bw_vec_dupv32hf_1 */
   14232       257241 :     case 9236:  /* avx512bw_vec_dupv64qi_1 */
   14233       257241 :     case 9235:  /* avx512bw_vec_dupv32hi_1 */
   14234       257241 :     case 9234:  /* avx512f_vec_dupv8di_1 */
   14235       257241 :     case 9233:  /* avx512f_vec_dupv16si_1 */
   14236       257241 :     case 9232:  /* avx2_vec_dupv4df */
   14237       257241 :     case 9155:  /* avx2_pbroadcastv16bf_1 */
   14238       257241 :     case 9154:  /* avx2_pbroadcastv16hf_1 */
   14239       257241 :     case 9153:  /* avx2_pbroadcastv4di_1 */
   14240       257241 :     case 9152:  /* avx2_pbroadcastv8si_1 */
   14241       257241 :     case 9151:  /* avx2_pbroadcastv16hi_1 */
   14242       257241 :     case 9150:  /* avx2_pbroadcastv32qi_1 */
   14243       257241 :     case 9149:  /* avx2_pbroadcastv8bf */
   14244       257241 :     case 9148:  /* avx2_pbroadcastv16bf */
   14245       257241 :     case 9147:  /* avx2_pbroadcastv32bf */
   14246       257241 :     case 9146:  /* avx2_pbroadcastv8hf */
   14247       257241 :     case 9145:  /* avx2_pbroadcastv16hf */
   14248       257241 :     case 9144:  /* avx2_pbroadcastv32hf */
   14249       257241 :     case 9143:  /* avx2_pbroadcastv2di */
   14250       257241 :     case 9142:  /* avx2_pbroadcastv4di */
   14251       257241 :     case 9141:  /* avx2_pbroadcastv4si */
   14252       257241 :     case 9140:  /* avx2_pbroadcastv8si */
   14253       257241 :     case 9139:  /* avx2_pbroadcastv8hi */
   14254       257241 :     case 9138:  /* avx2_pbroadcastv16hi */
   14255       257241 :     case 9137:  /* avx2_pbroadcastv32hi */
   14256       257241 :     case 9136:  /* avx2_pbroadcastv16qi */
   14257       257241 :     case 9135:  /* avx2_pbroadcastv32qi */
   14258       257241 :     case 9134:  /* avx2_pbroadcastv64qi */
   14259       257241 :     case 9133:  /* avx2_pbroadcastv8di */
   14260       257241 :     case 9132:  /* avx2_pbroadcastv16si */
   14261       257241 :     case 8956:  /* sse4_1_zero_extendv2siv2di2 */
   14262       257241 :     case 8954:  /* sse4_1_sign_extendv2siv2di2 */
   14263       257241 :     case 8932:  /* sse4_1_zero_extendv2hiv2di2 */
   14264       257241 :     case 8930:  /* sse4_1_sign_extendv2hiv2di2 */
   14265       257241 :     case 8920:  /* avx2_zero_extendv4hiv4di2 */
   14266       257241 :     case 8918:  /* avx2_sign_extendv4hiv4di2 */
   14267       257241 :     case 8905:  /* sse4_1_zero_extendv2qiv2di2 */
   14268       257241 :     case 8903:  /* sse4_1_sign_extendv2qiv2di2 */
   14269       257241 :     case 8893:  /* avx2_zero_extendv4qiv4di2 */
   14270       257241 :     case 8891:  /* avx2_sign_extendv4qiv4di2 */
   14271       257241 :     case 8881:  /* avx512f_zero_extendv8qiv8di2 */
   14272       257241 :     case 8879:  /* avx512f_sign_extendv8qiv8di2 */
   14273       257241 :     case 8865:  /* sse4_1_zero_extendv4hiv4si2 */
   14274       257241 :     case 8863:  /* sse4_1_sign_extendv4hiv4si2 */
   14275       257241 :     case 8835:  /* sse4_1_zero_extendv4qiv4si2 */
   14276       257241 :     case 8833:  /* sse4_1_sign_extendv4qiv4si2 */
   14277       257241 :     case 8823:  /* avx2_zero_extendv8qiv8si2 */
   14278       257241 :     case 8821:  /* avx2_sign_extendv8qiv8si2 */
   14279       257241 :     case 8803:  /* sse4_1_zero_extendv8qiv8hi2 */
   14280       257241 :     case 8801:  /* sse4_1_sign_extendv8qiv8hi2 */
   14281       257241 :     case 8503:  /* *vec_extractv4si_0_zext */
   14282       257241 :     case 8502:  /* *vec_extractv4si_0_zext_sse4 */
   14283       257241 :     case 7476:  /* *avx512f_us_truncatev8div16qi2_store_2 */
   14284       257241 :     case 7475:  /* *avx512f_truncatev8div16qi2_store_2 */
   14285       257241 :     case 7474:  /* *avx512f_ss_truncatev8div16qi2_store_2 */
   14286       257241 :     case 7470:  /* avx512f_us_truncatev8div16qi2 */
   14287       257241 :     case 7469:  /* avx512f_truncatev8div16qi2 */
   14288       257241 :     case 7468:  /* avx512f_ss_truncatev8div16qi2 */
   14289       257241 :     case 7458:  /* *avx512vl_us_truncatev2div2si2_store_2 */
   14290       257241 :     case 7457:  /* *avx512vl_truncatev2div2si2_store_2 */
   14291       257241 :     case 7456:  /* *avx512vl_ss_truncatev2div2si2_store_2 */
   14292       257241 :     case 7439:  /* *avx512vl_us_truncatev2div2hi2_store_2 */
   14293       257241 :     case 7438:  /* *avx512vl_truncatev2div2hi2_store_2 */
   14294       257241 :     case 7437:  /* *avx512vl_ss_truncatev2div2hi2_store_2 */
   14295       257241 :     case 7415:  /* *avx512vl_us_truncatev4div4hi2_store_2 */
   14296       257241 :     case 7414:  /* *avx512vl_truncatev4div4hi2_store_2 */
   14297       257241 :     case 7413:  /* *avx512vl_ss_truncatev4div4hi2_store_2 */
   14298       257241 :     case 7412:  /* *avx512vl_us_truncatev4siv4hi2_store_2 */
   14299       257241 :     case 7411:  /* *avx512vl_truncatev4siv4hi2_store_2 */
   14300       257241 :     case 7410:  /* *avx512vl_ss_truncatev4siv4hi2_store_2 */
   14301       257241 :     case 7375:  /* *avx512vl_us_truncatev8siv8qi2_store_2 */
   14302       257241 :     case 7374:  /* *avx512vl_truncatev8siv8qi2_store_2 */
   14303       257241 :     case 7373:  /* *avx512vl_ss_truncatev8siv8qi2_store_2 */
   14304       257241 :     case 7372:  /* *avx512vl_us_truncatev8hiv8qi2_store_2 */
   14305       257241 :     case 7371:  /* *avx512vl_truncatev8hiv8qi2_store_2 */
   14306       257241 :     case 7370:  /* *avx512vl_ss_truncatev8hiv8qi2_store_2 */
   14307       257241 :     case 7345:  /* *avx512vl_us_truncatev4div4qi2_store_2 */
   14308       257241 :     case 7344:  /* *avx512vl_truncatev4div4qi2_store_2 */
   14309       257241 :     case 7343:  /* *avx512vl_ss_truncatev4div4qi2_store_2 */
   14310       257241 :     case 7342:  /* *avx512vl_us_truncatev4siv4qi2_store_2 */
   14311       257241 :     case 7341:  /* *avx512vl_truncatev4siv4qi2_store_2 */
   14312       257241 :     case 7340:  /* *avx512vl_ss_truncatev4siv4qi2_store_2 */
   14313       257241 :     case 7324:  /* *avx512vl_us_truncatev2div2qi2_store_2 */
   14314       257241 :     case 7323:  /* *avx512vl_truncatev2div2qi2_store_2 */
   14315       257241 :     case 7322:  /* *avx512vl_ss_truncatev2div2qi2_store_2 */
   14316       257241 :     case 5330:  /* *vec_setv2di_0_zero_extendsi_1 */
   14317       257241 :     case 5318:  /* *vec_setv2di_0_zero_extendhi_1 */
   14318       257241 :     case 5286:  /* avx512f_vec_dupv8df_1 */
   14319       257241 :     case 5285:  /* avx512f_vec_dupv16sf_1 */
   14320       257241 :     case 5284:  /* avx2_vec_dupv8sf_1 */
   14321       257241 :     case 5283:  /* avx2_vec_dupv4sf */
   14322       257241 :     case 5282:  /* avx2_vec_dupv8sf */
   14323       257241 :     case 5238:  /* sse2_cvtps2pd */
   14324       257241 :     case 5195:  /* vec_unpacks_lo_v16sf */
   14325       257241 :     case 5194:  /* *avx_cvtps2pd256_2 */
   14326       257241 :     case 5165:  /* sse2_cvttpd2dq */
   14327       257241 :     case 5153:  /* avx512dq_fixuns_truncv2sfv2di2 */
   14328       257241 :     case 5151:  /* avx512dq_fix_truncv2sfv2di2 */
   14329       257241 :     case 5063:  /* *fixuns_truncv2dfv2si2 */
   14330       257241 :     case 5023:  /* sse2_cvtdq2pd */
   14331       257241 :     case 5022:  /* avx_cvtdq2pd256_2 */
   14332       257241 :     case 5021:  /* avx512f_cvtdq2pd512_2 */
   14333       257241 :     case 5019:  /* *floatunsv2siv2df2 */
   14334       257241 :     case 4967:  /* sse2_cvttsd2siq */
   14335       257241 :     case 4965:  /* sse2_cvttsd2si */
   14336       257241 :     case 4953:  /* avx512f_vcvttsd2usiq */
   14337       257241 :     case 4951:  /* avx512f_vcvttsd2usi */
   14338       257241 :     case 4941:  /* avx512f_vcvttss2usiq */
   14339       257241 :     case 4939:  /* avx512f_vcvttss2usi */
   14340       257241 :     case 4832:  /* sse_cvttss2siq */
   14341       257241 :     case 4830:  /* sse_cvttss2si */
   14342       257241 :     case 4815:  /* sse_cvttps2pi */
   14343       257241 :     case 4763:  /* avx512fp16_float_extend_phv2df2 */
   14344       257241 :     case 4757:  /* avx512fp16_float_extend_phv4sf2 */
   14345       257241 :     case 4755:  /* avx512fp16_float_extend_phv4df2 */
   14346       257241 :     case 4737:  /* avx512fp16_fixuns_truncdi2 */
   14347       257241 :     case 4735:  /* avx512fp16_fix_truncdi2 */
   14348       257241 :     case 4733:  /* avx512fp16_fixuns_truncsi2 */
   14349       257241 :     case 4731:  /* avx512fp16_fix_truncsi2 */
   14350       257241 :     case 4717:  /* avx512fp16_fixuns_truncv2di2 */
   14351       257241 :     case 4715:  /* avx512fp16_fix_truncv2di2 */
   14352       257241 :     case 4701:  /* avx512fp16_fixuns_truncv4di2 */
   14353       257241 :     case 4699:  /* avx512fp16_fix_truncv4di2 */
   14354       257241 :     case 4697:  /* avx512fp16_fixuns_truncv4si2 */
   14355       257241 :     case 4695:  /* avx512fp16_fix_truncv4si2 */
   14356       257241 :     case 2422:  /* *vec_dupv2hi */
   14357       257241 :     case 2401:  /* *vec_extractv2si_1_zext */
   14358       257241 :     case 2399:  /* *vec_extractv2si_0_zext */
   14359       257241 :     case 2398:  /* *vec_extractv2si_0_zext_sse4 */
   14360       257241 :     case 2391:  /* *vec_dupv4hi */
   14361       257241 :     case 2359:  /* sse4_1_zero_extendv2qiv2hi2 */
   14362       257241 :     case 2358:  /* sse4_1_sign_extendv2qiv2hi2 */
   14363       257241 :     case 2357:  /* sse4_1_zero_extendv2qiv2si2 */
   14364       257241 :     case 2356:  /* sse4_1_sign_extendv2qiv2si2 */
   14365       257241 :     case 2355:  /* sse4_1_zero_extendv2hiv2si2 */
   14366       257241 :     case 2354:  /* sse4_1_sign_extendv2hiv2si2 */
   14367       257241 :     case 2353:  /* sse4_1_zero_extendv4qiv4hi2 */
   14368       257241 :     case 2352:  /* sse4_1_sign_extendv4qiv4hi2 */
   14369       257241 :     case 1072:  /* *one_cmplsi2_1_zext */
   14370       257241 :     case 1071:  /* *one_cmplhi2_1_zextdi */
   14371       257241 :     case 1070:  /* *one_cmplhi2_1_zextsi */
   14372       257241 :     case 1069:  /* *one_cmplqi2_1_zextdi */
   14373       257241 :     case 1068:  /* *one_cmplqi2_1_zextsi */
   14374       257241 :     case 1067:  /* *one_cmplqi2_1_zexthi */
   14375       257241 :     case 1002:  /* *neghi_1_zextdi_nf */
   14376       257241 :     case 1000:  /* *neghi_1_zextsi_nf */
   14377       257241 :     case 998:  /* *negqi_1_zextdi_nf */
   14378       257241 :     case 996:  /* *negqi_1_zextsi_nf */
   14379       257241 :     case 994:  /* *negqi_1_zexthi_nf */
   14380       257241 :     case 226:  /* *fixuns_truncdfsi2_avx512f_zext */
   14381       257241 :     case 225:  /* *fixuns_truncsfsi2_avx512f_zext */
   14382       257241 :     case 224:  /* *fixuns_trunchfsi2zext */
   14383       257241 :     case 196:  /* *extendqisi2_zext */
   14384       257241 :     case 194:  /* *extendhisi2_zext */
   14385       257241 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14386       257241 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   14387       257241 :       break;
   14388              : 
   14389       137147 :     case 190:  /* extendditi2 */
   14390       137147 :     case 189:  /* extendsidi2_1 */
   14391       137147 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14392       137147 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14393       137147 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 2), 0));
   14394       137147 :       break;
   14395              : 
   14396         3235 :     case 2106:  /* mmx_ieee_minv2sf3 */
   14397         3235 :     case 2105:  /* mmx_ieee_maxv2sf3 */
   14398         3235 :     case 1911:  /* probe_stack_range_di */
   14399         3235 :     case 1910:  /* probe_stack_range_si */
   14400         3235 :     case 1696:  /* *tls_dynamic_gnu2_call_64_di */
   14401         3235 :     case 1695:  /* *tls_dynamic_gnu2_call_64_si */
   14402         3235 :     case 1593:  /* bmi_bextr_di */
   14403         3235 :     case 1592:  /* bmi_bextr_si */
   14404         3235 :     case 167:  /* push2p_di */
   14405         3235 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14406         3235 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
   14407         3235 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 1));
   14408         3235 :       break;
   14409              : 
   14410         6376 :     case 2612:  /* movdi_to_sse */
   14411         6376 :     case 1915:  /* stack_protect_set_1_di_di */
   14412         6376 :     case 1914:  /* stack_protect_set_1_si_di */
   14413         6376 :     case 1913:  /* stack_protect_set_1_di_si */
   14414         6376 :     case 1912:  /* stack_protect_set_1_si_si */
   14415         6376 :     case 1759:  /* lrintxfdi2 */
   14416         6376 :     case 168:  /* pop2p_di */
   14417         6376 :     case 164:  /* pop2_di */
   14418         6376 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14419         6376 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0, 0));
   14420         6376 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (pat, 0, 1), 0));
   14421         6376 :       break;
   14422              : 
   14423       779729 :     case 11055:  /* atomic_storedi_1 */
   14424       779729 :     case 11054:  /* atomic_storesi_1 */
   14425       779729 :     case 11053:  /* atomic_storehi_1 */
   14426       779729 :     case 11052:  /* atomic_storeqi_1 */
   14427       779729 :     case 10783:  /* avx10_2_fpclassbf16_v8bf */
   14428       779729 :     case 10781:  /* avx10_2_fpclassbf16_v16bf */
   14429       779729 :     case 10779:  /* avx10_2_fpclassbf16_v32bf */
   14430       779729 :     case 10777:  /* avx10_2_getmantbf16_v8bf */
   14431       779729 :     case 10775:  /* avx10_2_reducebf16_v8bf */
   14432       779729 :     case 10773:  /* avx10_2_rndscalebf16_v8bf */
   14433       779729 :     case 10771:  /* avx10_2_getmantbf16_v16bf */
   14434       779729 :     case 10769:  /* avx10_2_reducebf16_v16bf */
   14435       779729 :     case 10767:  /* avx10_2_rndscalebf16_v16bf */
   14436       779729 :     case 10765:  /* avx10_2_getmantbf16_v32bf */
   14437       779729 :     case 10763:  /* avx10_2_reducebf16_v32bf */
   14438       779729 :     case 10761:  /* avx10_2_rndscalebf16_v32bf */
   14439       779729 :     case 10651:  /* avx10_2_scalefbf16_v8bf */
   14440       779729 :     case 10649:  /* avx10_2_scalefbf16_v16bf */
   14441       779729 :     case 10647:  /* avx10_2_scalefbf16_v32bf */
   14442       779729 :     case 10552:  /* vcvtbiasph2hf8sv16hf */
   14443       779729 :     case 10550:  /* vcvtbiasph2hf8v16hf */
   14444       779729 :     case 10548:  /* vcvtbiasph2bf8sv16hf */
   14445       779729 :     case 10546:  /* vcvtbiasph2bf8v16hf */
   14446       779729 :     case 10544:  /* vcvtbiasph2hf8sv32hf */
   14447       779729 :     case 10542:  /* vcvtbiasph2hf8v32hf */
   14448       779729 :     case 10540:  /* vcvtbiasph2bf8sv32hf */
   14449       779729 :     case 10538:  /* vcvtbiasph2bf8v32hf */
   14450       779729 :     case 10528:  /* vcvt2ph2hf8sv8hf */
   14451       779729 :     case 10526:  /* vcvt2ph2hf8v8hf */
   14452       779729 :     case 10524:  /* vcvt2ph2bf8sv8hf */
   14453       779729 :     case 10522:  /* vcvt2ph2bf8v8hf */
   14454       779729 :     case 10520:  /* vcvt2ph2hf8sv16hf */
   14455       779729 :     case 10518:  /* vcvt2ph2hf8v16hf */
   14456       779729 :     case 10516:  /* vcvt2ph2bf8sv16hf */
   14457       779729 :     case 10514:  /* vcvt2ph2bf8v16hf */
   14458       779729 :     case 10512:  /* vcvt2ph2hf8sv32hf */
   14459       779729 :     case 10510:  /* vcvt2ph2hf8v32hf */
   14460       779729 :     case 10508:  /* vcvt2ph2bf8sv32hf */
   14461       779729 :     case 10506:  /* vcvt2ph2bf8v32hf */
   14462       779729 :     case 10398:  /* avx512vp2intersect_2intersectv16si */
   14463       779729 :     case 10397:  /* avx512vp2intersect_2intersectv4si */
   14464       779729 :     case 10396:  /* avx512vp2intersect_2intersectv8si */
   14465       779729 :     case 10395:  /* avx512vp2intersect_2intersectv2di */
   14466       779729 :     case 10394:  /* avx512vp2intersect_2intersectv4di */
   14467       779729 :     case 10393:  /* avx512vp2intersect_2intersectv8di */
   14468       779729 :     case 10389:  /* avx512vl_vpshufbitqmbv32qi */
   14469       779729 :     case 10387:  /* avx512vl_vpshufbitqmbv16qi */
   14470       779729 :     case 10385:  /* avx512vl_vpshufbitqmbv64qi */
   14471       779729 :     case 10381:  /* vaesenclast_v64qi */
   14472       779729 :     case 10380:  /* vaesenclast_v16qi */
   14473       779729 :     case 10379:  /* vaesenclast_v32qi */
   14474       779729 :     case 10378:  /* vaesenc_v64qi */
   14475       779729 :     case 10377:  /* vaesenc_v16qi */
   14476       779729 :     case 10376:  /* vaesenc_v32qi */
   14477       779729 :     case 10375:  /* vaesdeclast_v64qi */
   14478       779729 :     case 10374:  /* vaesdeclast_v16qi */
   14479       779729 :     case 10373:  /* vaesdeclast_v32qi */
   14480       779729 :     case 10372:  /* vaesdec_v64qi */
   14481       779729 :     case 10371:  /* vaesdec_v16qi */
   14482       779729 :     case 10370:  /* vaesdec_v32qi */
   14483       779729 :     case 10242:  /* vgf2p8mulb_v16qi */
   14484       779729 :     case 10240:  /* vgf2p8mulb_v32qi */
   14485       779729 :     case 10238:  /* vgf2p8mulb_v64qi */
   14486       779729 :     case 10192:  /* vpmultishiftqbv32qi */
   14487       779729 :     case 10190:  /* vpmultishiftqbv16qi */
   14488       779729 :     case 10188:  /* vpmultishiftqbv64qi */
   14489       779729 :     case 10163:  /* vsm4rnds4_v4si */
   14490       779729 :     case 10162:  /* vsm4rnds4_v8si */
   14491       779729 :     case 10161:  /* vsm4rnds4_v16si */
   14492       779729 :     case 10160:  /* vsm4key4_v4si */
   14493       779729 :     case 10159:  /* vsm4key4_v8si */
   14494       779729 :     case 10158:  /* vsm4key4_v16si */
   14495       779729 :     case 10156:  /* vsha512msg2 */
   14496       779729 :     case 10155:  /* vsha512msg1 */
   14497       779729 :     case 10150:  /* sha256msg2 */
   14498       779729 :     case 10149:  /* sha256msg1 */
   14499       779729 :     case 10147:  /* sha1nexte */
   14500       779729 :     case 10146:  /* sha1msg2 */
   14501       779729 :     case 10145:  /* sha1msg1 */
   14502       779729 :     case 10099:  /* avx512vl_getmantv2df */
   14503       779729 :     case 10095:  /* avx512vl_getmantv4df */
   14504       779729 :     case 10091:  /* avx512f_getmantv8df */
   14505       779729 :     case 10087:  /* avx512vl_getmantv4sf */
   14506       779729 :     case 10083:  /* avx512vl_getmantv8sf */
   14507       779729 :     case 10079:  /* avx512f_getmantv16sf */
   14508       779729 :     case 10075:  /* avx512fp16_getmantv8hf */
   14509       779729 :     case 10071:  /* avx512vl_getmantv16hf */
   14510       779729 :     case 10067:  /* avx512bw_getmantv32hf */
   14511       779729 :     case 10059:  /* avx512dq_fpclassv2df */
   14512       779729 :     case 10057:  /* avx512dq_fpclassv4df */
   14513       779729 :     case 10055:  /* avx512dq_fpclassv8df */
   14514       779729 :     case 10053:  /* avx512dq_fpclassv4sf */
   14515       779729 :     case 10051:  /* avx512dq_fpclassv8sf */
   14516       779729 :     case 10049:  /* avx512dq_fpclassv16sf */
   14517       779729 :     case 10047:  /* avx512dq_fpclassv8hf */
   14518       779729 :     case 10045:  /* avx512dq_fpclassv16hf */
   14519       779729 :     case 10043:  /* avx512dq_fpclassv32hf */
   14520       779729 :     case 9729:  /* *avx512f_vcvtps2ph512 */
   14521       779729 :     case 9725:  /* *avx512f_vcvtps2ph512 */
   14522       779729 :     case 9723:  /* *vcvtps2ph256 */
   14523       779729 :     case 9721:  /* vcvtps2ph256 */
   14524       779729 :     case 9720:  /* *vcvtps2ph_store */
   14525       779729 :     case 9423:  /* avx_vpermilvarv2df3 */
   14526       779729 :     case 9421:  /* avx_vpermilvarv4df3 */
   14527       779729 :     case 9419:  /* avx512f_vpermilvarv8df3 */
   14528       779729 :     case 9417:  /* avx_vpermilvarv4sf3 */
   14529       779729 :     case 9415:  /* avx_vpermilvarv8sf3 */
   14530       779729 :     case 9413:  /* avx512f_vpermilvarv16sf3 */
   14531       779729 :     case 9194:  /* avx512bw_permvarv32bf */
   14532       779729 :     case 9192:  /* avx512vl_permvarv16bf */
   14533       779729 :     case 9190:  /* avx512vl_permvarv8bf */
   14534       779729 :     case 9188:  /* avx512bw_permvarv32hf */
   14535       779729 :     case 9186:  /* avx512vl_permvarv16hf */
   14536       779729 :     case 9184:  /* avx512fp16_permvarv8hf */
   14537       779729 :     case 9182:  /* avx512bw_permvarv32hi */
   14538       779729 :     case 9180:  /* avx512vl_permvarv16hi */
   14539       779729 :     case 9178:  /* avx512vl_permvarv8hi */
   14540       779729 :     case 9176:  /* avx512vl_permvarv32qi */
   14541       779729 :     case 9174:  /* avx512vl_permvarv16qi */
   14542       779729 :     case 9172:  /* avx512bw_permvarv64qi */
   14543       779729 :     case 9170:  /* avx2_permvarv4df */
   14544       779729 :     case 9168:  /* avx2_permvarv4di */
   14545       779729 :     case 9166:  /* avx512f_permvarv8df */
   14546       779729 :     case 9164:  /* avx512f_permvarv8di */
   14547       779729 :     case 9162:  /* avx512f_permvarv16sf */
   14548       779729 :     case 9160:  /* avx512f_permvarv16si */
   14549       779729 :     case 9158:  /* avx2_permvarv8sf */
   14550       779729 :     case 9156:  /* avx2_permvarv8si */
   14551       779729 :     case 9128:  /* aeskeygenassist */
   14552       779729 :     case 9126:  /* aesdeclast */
   14553       779729 :     case 9125:  /* aesdec */
   14554       779729 :     case 9124:  /* aesenclast */
   14555       779729 :     case 9123:  /* aesenc */
   14556       779729 :     case 9012:  /* sse4_1_roundpd */
   14557       779729 :     case 9011:  /* avx_roundpd256 */
   14558       779729 :     case 9010:  /* sse4_1_roundps */
   14559       779729 :     case 9009:  /* avx_roundps256 */
   14560       779729 :     case 8764:  /* sse4_1_packusdw */
   14561       779729 :     case 8762:  /* avx2_packusdw */
   14562       779729 :     case 8760:  /* avx512bw_packusdw */
   14563       779729 :     case 8710:  /* sse4a_insertq */
   14564       779729 :     case 8708:  /* sse4a_extrq */
   14565       779729 :     case 8671:  /* ssse3_psignv2si3 */
   14566       779729 :     case 8670:  /* ssse3_psignv4hi3 */
   14567       779729 :     case 8669:  /* ssse3_psignv8qi3 */
   14568       779729 :     case 8668:  /* ssse3_psignv4si3 */
   14569       779729 :     case 8667:  /* avx2_psignv8si3 */
   14570       779729 :     case 8666:  /* ssse3_psignv8hi3 */
   14571       779729 :     case 8665:  /* avx2_psignv16hi3 */
   14572       779729 :     case 8664:  /* ssse3_psignv16qi3 */
   14573       779729 :     case 8663:  /* avx2_psignv32qi3 */
   14574       779729 :     case 8660:  /* ssse3_pshufbv16qi3 */
   14575       779729 :     case 8658:  /* avx2_pshufbv32qi3 */
   14576       779729 :     case 8656:  /* avx512bw_pshufbv64qi3 */
   14577       779729 :     case 8642:  /* avx512bw_pmaddubsw512v32hi */
   14578       779729 :     case 8640:  /* avx512bw_pmaddubsw512v16hi */
   14579       779729 :     case 8638:  /* avx512bw_pmaddubsw512v8hi */
   14580       779729 :     case 8539:  /* *sse2_psadbw */
   14581       779729 :     case 8538:  /* *avx2_psadbw */
   14582       779729 :     case 8537:  /* *avx512f_psadbw */
   14583       779729 :     case 8481:  /* *avx512bw_pshufhwv32hi */
   14584       779729 :     case 8475:  /* *avx512bw_pshuflwv32hi */
   14585       779729 :     case 8349:  /* sse2_packuswb */
   14586       779729 :     case 8347:  /* avx2_packuswb */
   14587       779729 :     case 8345:  /* avx512bw_packuswb */
   14588       779729 :     case 8187:  /* avx512vl_testnmv2di3 */
   14589       779729 :     case 8185:  /* avx512vl_testnmv4di3 */
   14590       779729 :     case 8183:  /* avx512f_testnmv8di3 */
   14591       779729 :     case 8181:  /* avx512vl_testnmv4si3 */
   14592       779729 :     case 8179:  /* avx512vl_testnmv8si3 */
   14593       779729 :     case 8177:  /* avx512f_testnmv16si3 */
   14594       779729 :     case 8175:  /* avx512vl_testnmv8hi3 */
   14595       779729 :     case 8173:  /* avx512vl_testnmv16hi3 */
   14596       779729 :     case 8171:  /* avx512bw_testnmv32hi3 */
   14597       779729 :     case 8169:  /* avx512vl_testnmv16qi3 */
   14598       779729 :     case 8167:  /* avx512vl_testnmv32qi3 */
   14599       779729 :     case 8165:  /* avx512bw_testnmv64qi3 */
   14600       779729 :     case 8163:  /* avx512vl_testmv2di3 */
   14601       779729 :     case 8161:  /* avx512vl_testmv4di3 */
   14602       779729 :     case 8159:  /* avx512f_testmv8di3 */
   14603       779729 :     case 8157:  /* avx512vl_testmv4si3 */
   14604       779729 :     case 8155:  /* avx512vl_testmv8si3 */
   14605       779729 :     case 8153:  /* avx512f_testmv16si3 */
   14606       779729 :     case 8151:  /* avx512vl_testmv8hi3 */
   14607       779729 :     case 8149:  /* avx512vl_testmv16hi3 */
   14608       779729 :     case 8147:  /* avx512bw_testmv32hi3 */
   14609       779729 :     case 8145:  /* avx512vl_testmv16qi3 */
   14610       779729 :     case 8143:  /* avx512vl_testmv32qi3 */
   14611       779729 :     case 8141:  /* avx512bw_testmv64qi3 */
   14612       779729 :     case 7616:  /* avx512bw_pmaddwd512v8hi */
   14613       779729 :     case 7614:  /* avx512bw_pmaddwd512v16hi */
   14614       779729 :     case 7612:  /* avx512bw_pmaddwd512v32hi */
   14615       779729 :     case 7191:  /* avx512vl_rndscalev2df */
   14616       779729 :     case 7187:  /* avx512vl_rndscalev4df */
   14617       779729 :     case 7183:  /* avx512f_rndscalev8df */
   14618       779729 :     case 7179:  /* avx512vl_rndscalev4sf */
   14619       779729 :     case 7175:  /* avx512vl_rndscalev8sf */
   14620       779729 :     case 7171:  /* avx512f_rndscalev16sf */
   14621       779729 :     case 7167:  /* avx512fp16_rndscalev8hf */
   14622       779729 :     case 7163:  /* avx512vl_rndscalev16hf */
   14623       779729 :     case 7159:  /* avx512bw_rndscalev32hf */
   14624       779729 :     case 5461:  /* avx512vl_scalefv2df */
   14625       779729 :     case 5457:  /* avx512vl_scalefv4df */
   14626       779729 :     case 5453:  /* avx512f_scalefv8df */
   14627       779729 :     case 5449:  /* avx512vl_scalefv4sf */
   14628       779729 :     case 5445:  /* avx512vl_scalefv8sf */
   14629       779729 :     case 5441:  /* avx512f_scalefv16sf */
   14630       779729 :     case 5437:  /* avx512fp16_scalefv8hf */
   14631       779729 :     case 5433:  /* avx512vl_scalefv16hf */
   14632       779729 :     case 5429:  /* avx512bw_scalefv32hf */
   14633       779729 :     case 4411:  /* avx512fp16_fcmulc_v8hf */
   14634       779729 :     case 4409:  /* avx512fp16_fmulc_v8hf */
   14635       779729 :     case 4407:  /* avx512vl_fcmulc_v16hf */
   14636       779729 :     case 4405:  /* avx512vl_fmulc_v16hf */
   14637       779729 :     case 4401:  /* avx512bw_fcmulc_v32hf */
   14638       779729 :     case 4397:  /* avx512bw_fmulc_v32hf */
   14639       779729 :     case 3635:  /* *avx512vl_eqv2di3_1 */
   14640       779729 :     case 3633:  /* *avx512vl_eqv2di3_1 */
   14641       779729 :     case 3631:  /* *avx512vl_eqv4di3_1 */
   14642       779729 :     case 3629:  /* *avx512vl_eqv4di3_1 */
   14643       779729 :     case 3627:  /* *avx512f_eqv8di3_1 */
   14644       779729 :     case 3625:  /* *avx512f_eqv8di3_1 */
   14645       779729 :     case 3623:  /* *avx512vl_eqv4si3_1 */
   14646       779729 :     case 3621:  /* *avx512vl_eqv4si3_1 */
   14647       779729 :     case 3619:  /* *avx512vl_eqv8si3_1 */
   14648       779729 :     case 3617:  /* *avx512vl_eqv8si3_1 */
   14649       779729 :     case 3615:  /* *avx512f_eqv16si3_1 */
   14650       779729 :     case 3613:  /* *avx512f_eqv16si3_1 */
   14651       779729 :     case 3575:  /* *avx512vl_eqv8hi3_1 */
   14652       779729 :     case 3573:  /* *avx512vl_eqv8hi3_1 */
   14653       779729 :     case 3571:  /* *avx512vl_eqv16hi3_1 */
   14654       779729 :     case 3569:  /* *avx512vl_eqv16hi3_1 */
   14655       779729 :     case 3567:  /* *avx512bw_eqv32hi3_1 */
   14656       779729 :     case 3565:  /* *avx512bw_eqv32hi3_1 */
   14657       779729 :     case 3563:  /* *avx512vl_eqv32qi3_1 */
   14658       779729 :     case 3561:  /* *avx512vl_eqv32qi3_1 */
   14659       779729 :     case 3559:  /* *avx512vl_eqv16qi3_1 */
   14660       779729 :     case 3557:  /* *avx512vl_eqv16qi3_1 */
   14661       779729 :     case 3555:  /* *avx512bw_eqv64qi3_1 */
   14662       779729 :     case 3553:  /* *avx512bw_eqv64qi3_1 */
   14663       779729 :     case 3253:  /* *reducepv2df */
   14664       779729 :     case 3249:  /* *reducepv4df */
   14665       779729 :     case 3245:  /* *reducepv8df */
   14666       779729 :     case 3241:  /* *reducepv4sf */
   14667       779729 :     case 3237:  /* *reducepv8sf */
   14668       779729 :     case 3233:  /* *reducepv16sf */
   14669       779729 :     case 3229:  /* *reducepv8hf */
   14670       779729 :     case 3225:  /* *reducepv16hf */
   14671       779729 :     case 3221:  /* *reducepv32hf */
   14672       779729 :     case 3151:  /* ieee_minv2df3 */
   14673       779729 :     case 3149:  /* ieee_maxv2df3 */
   14674       779729 :     case 3147:  /* ieee_minv4df3 */
   14675       779729 :     case 3145:  /* ieee_maxv4df3 */
   14676       779729 :     case 3141:  /* ieee_minv8df3 */
   14677       779729 :     case 3137:  /* ieee_maxv8df3 */
   14678       779729 :     case 3135:  /* ieee_minv4sf3 */
   14679       779729 :     case 3133:  /* ieee_maxv4sf3 */
   14680       779729 :     case 3131:  /* ieee_minv8sf3 */
   14681       779729 :     case 3129:  /* ieee_maxv8sf3 */
   14682       779729 :     case 3125:  /* ieee_minv16sf3 */
   14683       779729 :     case 3121:  /* ieee_maxv16sf3 */
   14684       779729 :     case 3119:  /* ieee_minv8hf3 */
   14685       779729 :     case 3117:  /* ieee_maxv8hf3 */
   14686       779729 :     case 3115:  /* ieee_minv16hf3 */
   14687       779729 :     case 3113:  /* ieee_maxv16hf3 */
   14688       779729 :     case 3109:  /* ieee_minv32hf3 */
   14689       779729 :     case 3105:  /* ieee_maxv32hf3 */
   14690       779729 :     case 2431:  /* *mmx_psadbw */
   14691       779729 :     case 2379:  /* mmx_pshufbv4qi3 */
   14692       779729 :     case 2378:  /* mmx_pshufbv8qi3 */
   14693       779729 :     case 2343:  /* mmx_packusdw */
   14694       779729 :     case 2341:  /* mmx_packuswb */
   14695       779729 :     case 2111:  /* mmx_rsqit1v2sf3 */
   14696       779729 :     case 2109:  /* mmx_rcpit2v2sf3 */
   14697       779729 :     case 2108:  /* mmx_rcpit1v2sf3 */
   14698       779729 :     case 1961:  /* xsaves64 */
   14699       779729 :     case 1960:  /* xsavec64 */
   14700       779729 :     case 1959:  /* xsaveopt64 */
   14701       779729 :     case 1958:  /* xsave64 */
   14702       779729 :     case 1957:  /* xsaves_rex64 */
   14703       779729 :     case 1956:  /* xsavec_rex64 */
   14704       779729 :     case 1955:  /* xsaveopt_rex64 */
   14705       779729 :     case 1954:  /* xsave_rex64 */
   14706       779729 :     case 1938:  /* sse4_2_crc32si */
   14707       779729 :     case 1937:  /* sse4_2_crc32hi */
   14708       779729 :     case 1936:  /* sse4_2_crc32qi */
   14709       779729 :     case 1852:  /* *ieee_smindf3 */
   14710       779729 :     case 1851:  /* *ieee_smaxdf3 */
   14711       779729 :     case 1850:  /* *ieee_sminsf3 */
   14712       779729 :     case 1849:  /* *ieee_smaxsf3 */
   14713       779729 :     case 1848:  /* *ieee_sminhf3 */
   14714       779729 :     case 1847:  /* *ieee_smaxhf3 */
   14715       779729 :     case 1757:  /* sse4_1_rounddf2 */
   14716       779729 :     case 1756:  /* sse4_1_roundsf2 */
   14717       779729 :     case 1755:  /* sse4_1_roundhf2 */
   14718       779729 :     case 1754:  /* avx512f_scalefdf2 */
   14719       779729 :     case 1753:  /* avx512f_scalefsf2 */
   14720       779729 :     case 1629:  /* bmi2_pext_di3 */
   14721       779729 :     case 1628:  /* bmi2_pext_si3 */
   14722       779729 :     case 1627:  /* bmi2_pdep_di3 */
   14723       779729 :     case 1626:  /* bmi2_pdep_si3 */
   14724       779729 :     case 1478:  /* *setcc_si_slp */
   14725       779729 :     case 163:  /* push2_di */
   14726       779729 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14727       779729 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
   14728       779729 :       ro[2] = *(ro_loc[2] = &XVECEXP (XEXP (pat, 1), 0, 1));
   14729       779729 :       break;
   14730              : 
   14731       373927 :     case 155:  /* *insvdi_lowpart_1 */
   14732       373927 :     case 154:  /* *insvdi_lowpart_1 */
   14733       373927 :     case 153:  /* *insvdi_lowpart_1 */
   14734       373927 :     case 152:  /* *insvti_lowpart_1 */
   14735       373927 :     case 151:  /* *insvti_lowpart_1 */
   14736       373927 :     case 150:  /* *insvti_lowpart_1 */
   14737       373927 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14738       373927 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   14739       373927 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   14740       373927 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   14741       373927 :       break;
   14742              : 
   14743      1256211 :     case 149:  /* *insvti_highpart_1 */
   14744      1256211 :     case 148:  /* *insvti_highpart_1 */
   14745      1256211 :     case 147:  /* *insvti_highpart_1 */
   14746      1256211 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14747      1256211 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   14748      1256211 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
   14749      1256211 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   14750      1256211 :       break;
   14751              : 
   14752          471 :     case 140:  /* *insvqi_2 */
   14753          471 :     case 139:  /* *insvqi_2 */
   14754          471 :     case 138:  /* *insvqi_2 */
   14755          471 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 0), 0));
   14756          471 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
   14757          471 :       ro[2] = *(ro_loc[2] = &XEXP (pat, 1));
   14758          471 :       break;
   14759              : 
   14760         5696 :     case 1075:  /* *one_cmplhi_1_slp */
   14761         5696 :     case 1074:  /* *one_cmplqi_1_slp */
   14762         5696 :     case 146:  /* *insvqi_3 */
   14763         5696 :     case 145:  /* *insvqi_3 */
   14764         5696 :     case 144:  /* *insvqi_3 */
   14765         5696 :     case 143:  /* *insvqi_3 */
   14766         5696 :     case 142:  /* *insvqi_3 */
   14767         5696 :     case 141:  /* *insvqi_3 */
   14768         5696 :     case 137:  /* *insvqi_1 */
   14769         5696 :     case 136:  /* *insvqi_1 */
   14770         5696 :     case 135:  /* *insvqi_1 */
   14771         5696 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 0), 0));
   14772         5696 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
   14773         5696 :       break;
   14774              : 
   14775        35955 :     case 131:  /* *extzvqi */
   14776        35955 :     case 130:  /* *extzvqi */
   14777        35955 :     case 129:  /* *extzvqi */
   14778        35955 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   14779        35955 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   14780        35955 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
   14781        35955 :       break;
   14782              : 
   14783      1310706 :     case 2649:  /* knotdi */
   14784      1310706 :     case 2648:  /* knotsi */
   14785      1310706 :     case 2647:  /* knothi */
   14786      1310706 :     case 2646:  /* knotqi */
   14787      1310706 :     case 2171:  /* negv2qi2 */
   14788      1310706 :     case 2129:  /* mmx_floatv2siv2sf2 */
   14789      1310706 :     case 2128:  /* mmx_fix_truncv2sfv2si2 */
   14790      1310706 :     case 1828:  /* *x86_movdicc_0_m1_neg */
   14791      1310706 :     case 1827:  /* *x86_movsicc_0_m1_neg */
   14792      1310706 :     case 1826:  /* *x86_movhicc_0_m1_neg */
   14793      1310706 :     case 1825:  /* *x86_movqicc_0_m1_neg */
   14794      1310706 :     case 1824:  /* *x86_movdicc_0_m1_se */
   14795      1310706 :     case 1823:  /* *x86_movsicc_0_m1_se */
   14796      1310706 :     case 1822:  /* *x86_movdicc_0_m1 */
   14797      1310706 :     case 1821:  /* *x86_movsicc_0_m1 */
   14798      1310706 :     case 1665:  /* popcounthi2 */
   14799      1310706 :     case 1653:  /* popcountdi2 */
   14800      1310706 :     case 1652:  /* popcountsi2 */
   14801      1310706 :     case 1561:  /* clzdi2_lzcnt */
   14802      1310706 :     case 1560:  /* clzsi2_lzcnt */
   14803      1310706 :     case 1539:  /* ctzdi2 */
   14804      1310706 :     case 1538:  /* ctzsi2 */
   14805      1310706 :     case 1047:  /* *negxf2_i387_1 */
   14806      1310706 :     case 1046:  /* *absxf2_i387_1 */
   14807      1310706 :     case 1045:  /* *negdf2_i387_1 */
   14808      1310706 :     case 1044:  /* *absdf2_i387_1 */
   14809      1310706 :     case 1043:  /* *negsf2_i387_1 */
   14810      1310706 :     case 1042:  /* *abssf2_i387_1 */
   14811      1310706 :     case 1034:  /* *absdi2_1 */
   14812      1310706 :     case 1033:  /* *abssi2_1 */
   14813      1310706 :     case 1032:  /* *abshi2_1 */
   14814      1310706 :     case 1031:  /* *absqi2_1 */
   14815      1310706 :     case 1028:  /* *absti2_doubleword */
   14816      1310706 :     case 1027:  /* *absdi2_doubleword */
   14817      1310706 :     case 993:  /* *negdi_1 */
   14818      1310706 :     case 991:  /* *negsi_1 */
   14819      1310706 :     case 989:  /* *neghi_1 */
   14820      1310706 :     case 987:  /* *negqi_1 */
   14821      1310706 :     case 985:  /* *negti2_doubleword */
   14822      1310706 :     case 984:  /* *negdi2_doubleword */
   14823      1310706 :     case 238:  /* *fix_truncdi_i387_1 */
   14824      1310706 :     case 237:  /* *fix_truncsi_i387_1 */
   14825      1310706 :     case 236:  /* *fix_trunchi_i387_1 */
   14826      1310706 :     case 186:  /* zero_extendqihi2_and */
   14827      1310706 :     case 183:  /* zero_extendhisi2_and */
   14828      1310706 :     case 182:  /* zero_extendqisi2_and */
   14829      1310706 :     case 125:  /* *extvdi_1_0 */
   14830      1310706 :     case 124:  /* *extvsi_1_0 */
   14831      1310706 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14832      1310706 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 1), 0));
   14833      1310706 :       break;
   14834              : 
   14835          247 :     case 1083:  /* *one_cmplqi_extdi_1 */
   14836          247 :     case 1082:  /* *one_cmplqi_extsi_1 */
   14837          247 :     case 1081:  /* *one_cmplqi_exthi_1 */
   14838          247 :     case 121:  /* *movstrictqi_extdi_1 */
   14839          247 :     case 120:  /* *movstrictqi_extsi_1 */
   14840          247 :     case 119:  /* *movstrictqi_exthi_1 */
   14841          247 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 0), 0));
   14842          247 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   14843          247 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (pat, 1), 0));
   14844          247 :       break;
   14845              : 
   14846        15477 :     case 1495:  /* *sibcall_memory */
   14847        15477 :     case 1494:  /* *sibcall_memory */
   14848        15477 :     case 118:  /* *movstricthi_xor */
   14849        15477 :     case 117:  /* *movstrictqi_xor */
   14850        15477 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XVECEXP (pat, 0, 0), 0), 0));
   14851        15477 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 1));
   14852        15477 :       break;
   14853              : 
   14854       119981 :     case 177:  /* *swapxf */
   14855       119981 :     case 114:  /* *swaphi */
   14856       119981 :     case 113:  /* *swapqi */
   14857       119981 :     case 112:  /* swapdi */
   14858       119981 :     case 111:  /* swapsi */
   14859       119981 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   14860       119981 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 1));
   14861       119981 :       recog_data.dup_loc[0] = &XEXP (XVECEXP (pat, 0, 1), 0);
   14862       119981 :       recog_data.dup_num[0] = 1;
   14863       119981 :       recog_data.dup_loc[1] = &XEXP (XVECEXP (pat, 0, 1), 1);
   14864       119981 :       recog_data.dup_num[1] = 0;
   14865       119981 :       break;
   14866              : 
   14867     35542692 :     case 10747:  /* avx10_2_sqrtbf16_v8bf */
   14868     35542692 :     case 10745:  /* avx10_2_sqrtbf16_v16bf */
   14869     35542692 :     case 10743:  /* avx10_2_sqrtbf16_v32bf */
   14870     35542692 :     case 10410:  /* avx512f_cvtneps2bf16_v8sf */
   14871     35542692 :     case 10408:  /* avx512f_cvtneps2bf16_v16sf */
   14872     35542692 :     case 10407:  /* vcvtneps2bf16_v8sf */
   14873     35542692 :     case 10224:  /* vpopcountv8hi */
   14874     35542692 :     case 10222:  /* vpopcountv16hi */
   14875     35542692 :     case 10220:  /* vpopcountv32hi */
   14876     35542692 :     case 10218:  /* vpopcountv32qi */
   14877     35542692 :     case 10216:  /* vpopcountv16qi */
   14878     35542692 :     case 10214:  /* vpopcountv64qi */
   14879     35542692 :     case 10204:  /* vpopcountv2di */
   14880     35542692 :     case 10202:  /* vpopcountv4di */
   14881     35542692 :     case 10200:  /* vpopcountv8di */
   14882     35542692 :     case 10198:  /* vpopcountv4si */
   14883     35542692 :     case 10196:  /* vpopcountv8si */
   14884     35542692 :     case 10194:  /* vpopcountv16si */
   14885     35542692 :     case 10169:  /* avx512f_pd512_256pd */
   14886     35542692 :     case 10168:  /* avx512f_ps512_256ps */
   14887     35542692 :     case 10167:  /* avx512f_si512_256si */
   14888     35542692 :     case 10131:  /* clzv2di2 */
   14889     35542692 :     case 10129:  /* clzv4di2 */
   14890     35542692 :     case 10127:  /* clzv8di2 */
   14891     35542692 :     case 10125:  /* clzv4si2 */
   14892     35542692 :     case 10123:  /* clzv8si2 */
   14893     35542692 :     case 10121:  /* clzv16si2 */
   14894     35542692 :     case 9613:  /* avx_pd256_pd */
   14895     35542692 :     case 9612:  /* avx_ps256_ps */
   14896     35542692 :     case 9611:  /* avx_si256_si */
   14897     35542692 :     case 9405:  /* *avx512dq_broadcastv4df_1 */
   14898     35542692 :     case 9403:  /* *avx512dq_broadcastv4di_1 */
   14899     35542692 :     case 9401:  /* *avx512dq_broadcastv8df_1 */
   14900     35542692 :     case 9399:  /* *avx512dq_broadcastv8di_1 */
   14901     35542692 :     case 9397:  /* *avx512dq_broadcastv16si_1 */
   14902     35542692 :     case 9395:  /* *avx512dq_broadcastv16sf_1 */
   14903     35542692 :     case 9393:  /* *avx512vl_broadcastv8sf_1 */
   14904     35542692 :     case 9391:  /* *avx512vl_broadcastv8si_1 */
   14905     35542692 :     case 9364:  /* vec_dupv4df */
   14906     35542692 :     case 9363:  /* vec_dupv4di */
   14907     35542692 :     case 9362:  /* vec_dupv8sf */
   14908     35542692 :     case 9361:  /* vec_dupv8si */
   14909     35542692 :     case 9360:  /* *vec_dupv8bf */
   14910     35542692 :     case 9359:  /* *vec_dupv16bf */
   14911     35542692 :     case 9358:  /* *vec_dupv8hf */
   14912     35542692 :     case 9357:  /* *vec_dupv16hf */
   14913     35542692 :     case 9356:  /* *vec_dupv4si */
   14914     35542692 :     case 9355:  /* *vec_dupv8si */
   14915     35542692 :     case 9354:  /* *vec_dupv8hi */
   14916     35542692 :     case 9353:  /* *vec_dupv16hi */
   14917     35542692 :     case 9352:  /* *vec_dupv16qi */
   14918     35542692 :     case 9351:  /* *vec_dupv32qi */
   14919     35542692 :     case 9345:  /* *vec_dupv2di */
   14920     35542692 :     case 9344:  /* *vec_dupv4si */
   14921     35542692 :     case 9343:  /* vec_dupv4sf */
   14922     35542692 :     case 9341:  /* *avx512vl_vec_dup_gprv2df */
   14923     35542692 :     case 9339:  /* *avx512vl_vec_dup_gprv4df */
   14924     35542692 :     case 9337:  /* *avx512f_vec_dup_gprv8df */
   14925     35542692 :     case 9335:  /* *avx512vl_vec_dup_gprv4sf */
   14926     35542692 :     case 9333:  /* *avx512vl_vec_dup_gprv8sf */
   14927     35542692 :     case 9331:  /* *avx512f_vec_dup_gprv16sf */
   14928     35542692 :     case 9329:  /* *avx512vl_vec_dup_gprv2di */
   14929     35542692 :     case 9327:  /* *avx512vl_vec_dup_gprv4di */
   14930     35542692 :     case 9325:  /* *avx512f_vec_dup_gprv8di */
   14931     35542692 :     case 9323:  /* *avx512vl_vec_dup_gprv4si */
   14932     35542692 :     case 9321:  /* *avx512vl_vec_dup_gprv8si */
   14933     35542692 :     case 9319:  /* *avx512f_vec_dup_gprv16si */
   14934     35542692 :     case 9317:  /* *avx512vl_vec_dup_gprv8bf */
   14935     35542692 :     case 9315:  /* *avx512vl_vec_dup_gprv16bf */
   14936     35542692 :     case 9313:  /* *avx512bw_vec_dup_gprv32bf */
   14937     35542692 :     case 9311:  /* *avx512fp16_vec_dup_gprv8hf */
   14938     35542692 :     case 9309:  /* *avx512vl_vec_dup_gprv16hf */
   14939     35542692 :     case 9307:  /* *avx512bw_vec_dup_gprv32hf */
   14940     35542692 :     case 9305:  /* *avx512vl_vec_dup_gprv8hi */
   14941     35542692 :     case 9303:  /* *avx512vl_vec_dup_gprv16hi */
   14942     35542692 :     case 9301:  /* *avx512bw_vec_dup_gprv32hi */
   14943     35542692 :     case 9299:  /* *avx512vl_vec_dup_gprv32qi */
   14944     35542692 :     case 9297:  /* *avx512vl_vec_dup_gprv16qi */
   14945     35542692 :     case 9295:  /* *avx512bw_vec_dup_gprv64qi */
   14946     35542692 :     case 9293:  /* *avx512f_broadcastv8di */
   14947     35542692 :     case 9291:  /* *avx512f_broadcastv8df */
   14948     35542692 :     case 9289:  /* *avx512f_broadcastv16si */
   14949     35542692 :     case 9287:  /* *avx512f_broadcastv16sf */
   14950     35542692 :     case 8960:  /* *sse4_1_zero_extendv2siv2di2_1 */
   14951     35542692 :     case 8958:  /* *sse4_1_sign_extendv2siv2di2_1 */
   14952     35542692 :     case 8950:  /* avx2_zero_extendv4siv4di2 */
   14953     35542692 :     case 8948:  /* avx2_sign_extendv4siv4di2 */
   14954     35542692 :     case 8944:  /* avx512f_zero_extendv8siv8di2 */
   14955     35542692 :     case 8942:  /* avx512f_sign_extendv8siv8di2 */
   14956     35542692 :     case 8936:  /* *sse4_1_zero_extendv2hiv2di2_1 */
   14957     35542692 :     case 8934:  /* *sse4_1_sign_extendv2hiv2di2_1 */
   14958     35542692 :     case 8924:  /* *avx2_zero_extendv4hiv4di2_1 */
   14959     35542692 :     case 8922:  /* *avx2_sign_extendv4hiv4di2_1 */
   14960     35542692 :     case 8916:  /* avx512f_zero_extendv8hiv8di2 */
   14961     35542692 :     case 8914:  /* avx512f_sign_extendv8hiv8di2 */
   14962     35542692 :     case 8909:  /* *sse4_1_zero_extendv2qiv2di2_1 */
   14963     35542692 :     case 8907:  /* *sse4_1_sign_extendv2qiv2di2_1 */
   14964     35542692 :     case 8897:  /* *avx2_zero_extendv4qiv4di2_1 */
   14965     35542692 :     case 8895:  /* *avx2_sign_extendv4qiv4di2_1 */
   14966     35542692 :     case 8885:  /* *avx512f_zero_extendv8qiv8di2_1 */
   14967     35542692 :     case 8883:  /* *avx512f_sign_extendv8qiv8di2_1 */
   14968     35542692 :     case 8869:  /* *sse4_1_zero_extendv4hiv4si2_1 */
   14969     35542692 :     case 8867:  /* *sse4_1_sign_extendv4hiv4si2_1 */
   14970     35542692 :     case 8857:  /* avx2_zero_extendv8hiv8si2 */
   14971     35542692 :     case 8855:  /* avx2_sign_extendv8hiv8si2 */
   14972     35542692 :     case 8849:  /* avx512f_zero_extendv16hiv16si2 */
   14973     35542692 :     case 8847:  /* avx512f_sign_extendv16hiv16si2 */
   14974     35542692 :     case 8839:  /* *sse4_1_zero_extendv4qiv4si2_1 */
   14975     35542692 :     case 8837:  /* *sse4_1_sign_extendv4qiv4si2_1 */
   14976     35542692 :     case 8827:  /* *avx2_zero_extendv8qiv8si2_1 */
   14977     35542692 :     case 8825:  /* *avx2_sign_extendv8qiv8si2_1 */
   14978     35542692 :     case 8819:  /* *avx512f_zero_extendv16qiv16si2 */
   14979     35542692 :     case 8817:  /* *avx512f_sign_extendv16qiv16si2 */
   14980     35542692 :     case 8807:  /* *sse4_1_zero_extendv8qiv8hi2_1 */
   14981     35542692 :     case 8805:  /* *sse4_1_sign_extendv8qiv8hi2_1 */
   14982     35542692 :     case 8795:  /* avx512bw_zero_extendv32qiv32hi2 */
   14983     35542692 :     case 8793:  /* avx512bw_sign_extendv32qiv32hi2 */
   14984     35542692 :     case 8787:  /* avx2_zero_extendv16qiv16hi2 */
   14985     35542692 :     case 8785:  /* avx2_sign_extendv16qiv16hi2 */
   14986     35542692 :     case 8690:  /* *absv2di2 */
   14987     35542692 :     case 8689:  /* *absv4di2 */
   14988     35542692 :     case 8688:  /* *absv8di2 */
   14989     35542692 :     case 8687:  /* *absv4si2 */
   14990     35542692 :     case 8686:  /* *absv8si2 */
   14991     35542692 :     case 8685:  /* *absv16si2 */
   14992     35542692 :     case 8684:  /* *absv8hi2 */
   14993     35542692 :     case 8683:  /* *absv16hi2 */
   14994     35542692 :     case 8682:  /* *absv32hi2 */
   14995     35542692 :     case 8681:  /* *absv16qi2 */
   14996     35542692 :     case 8680:  /* *absv32qi2 */
   14997     35542692 :     case 8679:  /* *absv64qi2 */
   14998     35542692 :     case 8508:  /* *vec_extractv2di_1 */
   14999     35542692 :     case 8501:  /* *vec_extractv2di_0_sse */
   15000     35542692 :     case 8500:  /* *vec_extractv2di_0 */
   15001     35542692 :     case 8499:  /* *vec_extractv4si_0 */
   15002     35542692 :     case 8489:  /* *vec_extractv8hi_0_mem */
   15003     35542692 :     case 8488:  /* *vec_extractv16qi_0_mem */
   15004     35542692 :     case 7473:  /* *avx512f_us_truncatev8div16qi2_store_1 */
   15005     35542692 :     case 7472:  /* *avx512f_truncatev8div16qi2_store_1 */
   15006     35542692 :     case 7471:  /* *avx512f_ss_truncatev8div16qi2_store_1 */
   15007     35542692 :     case 7455:  /* *avx512vl_us_truncatev2div2si2_store_1 */
   15008     35542692 :     case 7454:  /* *avx512vl_truncatev2div2si2_store_1 */
   15009     35542692 :     case 7453:  /* *avx512vl_ss_truncatev2div2si2_store_1 */
   15010     35542692 :     case 7436:  /* *avx512vl_us_truncatev2div2hi2_store_1 */
   15011     35542692 :     case 7435:  /* *avx512vl_truncatev2div2hi2_store_1 */
   15012     35542692 :     case 7434:  /* *avx512vl_ss_truncatev2div2hi2_store_1 */
   15013     35542692 :     case 7409:  /* *avx512vl_us_truncatev4div4hi2_store_1 */
   15014     35542692 :     case 7408:  /* *avx512vl_truncatev4div4hi2_store_1 */
   15015     35542692 :     case 7407:  /* *avx512vl_ss_truncatev4div4hi2_store_1 */
   15016     35542692 :     case 7406:  /* *avx512vl_us_truncatev4siv4hi2_store_1 */
   15017     35542692 :     case 7405:  /* *avx512vl_truncatev4siv4hi2_store_1 */
   15018     35542692 :     case 7404:  /* *avx512vl_ss_truncatev4siv4hi2_store_1 */
   15019     35542692 :     case 7369:  /* *avx512vl_us_truncatev8siv8qi2_store_1 */
   15020     35542692 :     case 7368:  /* *avx512vl_truncatev8siv8qi2_store_1 */
   15021     35542692 :     case 7367:  /* *avx512vl_ss_truncatev8siv8qi2_store_1 */
   15022     35542692 :     case 7366:  /* *avx512vl_us_truncatev8hiv8qi2_store_1 */
   15023     35542692 :     case 7365:  /* *avx512vl_truncatev8hiv8qi2_store_1 */
   15024     35542692 :     case 7364:  /* *avx512vl_ss_truncatev8hiv8qi2_store_1 */
   15025     35542692 :     case 7339:  /* *avx512vl_us_truncatev4div4qi2_store_1 */
   15026     35542692 :     case 7338:  /* *avx512vl_truncatev4div4qi2_store_1 */
   15027     35542692 :     case 7337:  /* *avx512vl_ss_truncatev4div4qi2_store_1 */
   15028     35542692 :     case 7336:  /* *avx512vl_us_truncatev4siv4qi2_store_1 */
   15029     35542692 :     case 7335:  /* *avx512vl_truncatev4siv4qi2_store_1 */
   15030     35542692 :     case 7334:  /* *avx512vl_ss_truncatev4siv4qi2_store_1 */
   15031     35542692 :     case 7321:  /* *avx512vl_us_truncatev2div2qi2_store_1 */
   15032     35542692 :     case 7320:  /* *avx512vl_truncatev2div2qi2_store_1 */
   15033     35542692 :     case 7319:  /* *avx512vl_ss_truncatev2div2qi2_store_1 */
   15034     35542692 :     case 7291:  /* *avx512vl_us_truncatev16hiv16qi2 */
   15035     35542692 :     case 7290:  /* *avx512vl_truncatev16hiv16qi2 */
   15036     35542692 :     case 7289:  /* *avx512vl_ss_truncatev16hiv16qi2 */
   15037     35542692 :     case 7288:  /* *avx512vl_us_truncatev8siv8hi2 */
   15038     35542692 :     case 7287:  /* *avx512vl_truncatev8siv8hi2 */
   15039     35542692 :     case 7286:  /* *avx512vl_ss_truncatev8siv8hi2 */
   15040     35542692 :     case 7285:  /* *avx512vl_us_truncatev4div4si2 */
   15041     35542692 :     case 7284:  /* *avx512vl_truncatev4div4si2 */
   15042     35542692 :     case 7283:  /* *avx512vl_ss_truncatev4div4si2 */
   15043     35542692 :     case 7278:  /* avx512bw_us_truncatev32hiv32qi2 */
   15044     35542692 :     case 7277:  /* avx512bw_truncatev32hiv32qi2 */
   15045     35542692 :     case 7276:  /* avx512bw_ss_truncatev32hiv32qi2 */
   15046     35542692 :     case 7258:  /* *avx512f_us_truncatev8div8hi2 */
   15047     35542692 :     case 7257:  /* *avx512f_truncatev8div8hi2 */
   15048     35542692 :     case 7256:  /* *avx512f_ss_truncatev8div8hi2 */
   15049     35542692 :     case 7255:  /* *avx512f_us_truncatev8div8si2 */
   15050     35542692 :     case 7254:  /* *avx512f_truncatev8div8si2 */
   15051     35542692 :     case 7253:  /* *avx512f_ss_truncatev8div8si2 */
   15052     35542692 :     case 7252:  /* *avx512f_us_truncatev16siv16hi2 */
   15053     35542692 :     case 7251:  /* *avx512f_truncatev16siv16hi2 */
   15054     35542692 :     case 7250:  /* *avx512f_ss_truncatev16siv16hi2 */
   15055     35542692 :     case 7249:  /* *avx512f_us_truncatev16siv16qi2 */
   15056     35542692 :     case 7248:  /* *avx512f_truncatev16siv16qi2 */
   15057     35542692 :     case 7247:  /* *avx512f_ss_truncatev16siv16qi2 */
   15058     35542692 :     case 7242:  /* vec_dupv2df */
   15059     35542692 :     case 7237:  /* *vec_extractv2df_0_sse */
   15060     35542692 :     case 7236:  /* sse2_storelpd */
   15061     35542692 :     case 7235:  /* *vec_extractv2df_1_sse */
   15062     35542692 :     case 7234:  /* sse2_storehpd */
   15063     35542692 :     case 5398:  /* *vec_extractv8bf_0 */
   15064     35542692 :     case 5397:  /* *vec_extractv16bf_0 */
   15065     35542692 :     case 5396:  /* *vec_extractv32bf_0 */
   15066     35542692 :     case 5395:  /* *vec_extractv8hf_0 */
   15067     35542692 :     case 5394:  /* *vec_extractv16hf_0 */
   15068     35542692 :     case 5393:  /* *vec_extractv32hf_0 */
   15069     35542692 :     case 5392:  /* vec_extract_hi_v32qi */
   15070     35542692 :     case 5391:  /* vec_extract_lo_v32qi */
   15071     35542692 :     case 5390:  /* vec_extract_hi_v64qi */
   15072     35542692 :     case 5389:  /* vec_extract_lo_v64qi */
   15073     35542692 :     case 5388:  /* vec_extract_hi_v16bf */
   15074     35542692 :     case 5387:  /* vec_extract_hi_v16hf */
   15075     35542692 :     case 5386:  /* vec_extract_hi_v16hi */
   15076     35542692 :     case 5385:  /* vec_extract_lo_v16bf */
   15077     35542692 :     case 5384:  /* vec_extract_lo_v16hf */
   15078     35542692 :     case 5383:  /* vec_extract_lo_v16hi */
   15079     35542692 :     case 5382:  /* vec_extract_hi_v32bf */
   15080     35542692 :     case 5381:  /* vec_extract_hi_v32hf */
   15081     35542692 :     case 5380:  /* vec_extract_hi_v32hi */
   15082     35542692 :     case 5379:  /* vec_extract_lo_v32bf */
   15083     35542692 :     case 5378:  /* vec_extract_lo_v32hf */
   15084     35542692 :     case 5377:  /* vec_extract_lo_v32hi */
   15085     35542692 :     case 5376:  /* vec_extract_hi_v8sf */
   15086     35542692 :     case 5375:  /* vec_extract_hi_v8si */
   15087     35542692 :     case 5372:  /* vec_extract_lo_v8sf */
   15088     35542692 :     case 5371:  /* vec_extract_lo_v8si */
   15089     35542692 :     case 5368:  /* vec_extract_hi_v4df */
   15090     35542692 :     case 5367:  /* vec_extract_hi_v4di */
   15091     35542692 :     case 5364:  /* vec_extract_lo_v4df */
   15092     35542692 :     case 5363:  /* vec_extract_lo_v4di */
   15093     35542692 :     case 5360:  /* vec_extract_lo_v16si */
   15094     35542692 :     case 5359:  /* vec_extract_lo_v16sf */
   15095     35542692 :     case 5356:  /* vec_extract_hi_v16si */
   15096     35542692 :     case 5355:  /* vec_extract_hi_v16sf */
   15097     35542692 :     case 5352:  /* vec_extract_hi_v8di */
   15098     35542692 :     case 5351:  /* vec_extract_hi_v8df */
   15099     35542692 :     case 5348:  /* vec_extract_lo_v8di */
   15100     35542692 :     case 5347:  /* vec_extract_lo_v8df */
   15101     35542692 :     case 5334:  /* *vec_extractv4sf_0 */
   15102     35542692 :     case 5278:  /* sse_storelps */
   15103     35542692 :     case 5276:  /* sse_storehps */
   15104     35542692 :     case 5240:  /* sse2_cvtps2pd_1 */
   15105     35542692 :     case 5192:  /* avx_cvtps2pd256 */
   15106     35542692 :     case 5188:  /* avx512f_cvtps2pd512 */
   15107     35542692 :     case 5185:  /* truncv2dfv2sf2 */
   15108     35542692 :     case 5182:  /* avx_cvtpd2ps256 */
   15109     35542692 :     case 5178:  /* *avx512f_cvtpd2ps512 */
   15110     35542692 :     case 5161:  /* *fixuns_truncv4sfv4si2 */
   15111     35542692 :     case 5159:  /* *fixuns_truncv8sfv8si2 */
   15112     35542692 :     case 5145:  /* fixuns_truncv4sfv4di2 */
   15113     35542692 :     case 5143:  /* fix_truncv4sfv4di2 */
   15114     35542692 :     case 5139:  /* fixuns_truncv8sfv8di2 */
   15115     35542692 :     case 5135:  /* fix_truncv8sfv8di2 */
   15116     35542692 :     case 5105:  /* fixuns_truncv2dfv2di2 */
   15117     35542692 :     case 5103:  /* fix_truncv2dfv2di2 */
   15118     35542692 :     case 5101:  /* fixuns_truncv4dfv4di2 */
   15119     35542692 :     case 5099:  /* fix_truncv4dfv4di2 */
   15120     35542692 :     case 5095:  /* fixuns_truncv8dfv8di2 */
   15121     35542692 :     case 5091:  /* fix_truncv8dfv8di2 */
   15122     35542692 :     case 5073:  /* fixuns_truncv4dfv4si2 */
   15123     35542692 :     case 5069:  /* fix_truncv4dfv4si2 */
   15124     35542692 :     case 5058:  /* fixuns_truncv8dfv8si2 */
   15125     35542692 :     case 5054:  /* fix_truncv8dfv8si2 */
   15126     35542692 :     case 5017:  /* floatunsv4siv4df2 */
   15127     35542692 :     case 5015:  /* floatunsv8siv8df2 */
   15128     35542692 :     case 5007:  /* floatunsv4div4sf2 */
   15129     35542692 :     case 5005:  /* floatv4div4sf2 */
   15130     35542692 :     case 5001:  /* floatunsv8div8sf2 */
   15131     35542692 :     case 4997:  /* floatv8div8sf2 */
   15132     35542692 :     case 4993:  /* floatunsv2div2df2 */
   15133     35542692 :     case 4989:  /* floatv2div2df2 */
   15134     35542692 :     case 4985:  /* floatunsv4div4df2 */
   15135     35542692 :     case 4981:  /* floatv4div4df2 */
   15136     35542692 :     case 4977:  /* floatunsv8div8df2 */
   15137     35542692 :     case 4973:  /* floatv8div8df2 */
   15138     35542692 :     case 4971:  /* floatv4siv4df2 */
   15139     35542692 :     case 4969:  /* floatv8siv8df2 */
   15140     35542692 :     case 4927:  /* fixuns_truncv2dfv2si2 */
   15141     35542692 :     case 4925:  /* sse2_cvttpd2pi */
   15142     35542692 :     case 4922:  /* floatunsv2siv2df2 */
   15143     35542692 :     case 4921:  /* sse2_cvtpi2pd */
   15144     35542692 :     case 4919:  /* fix_truncv4sfv4si2 */
   15145     35542692 :     case 4915:  /* fix_truncv8sfv8si2 */
   15146     35542692 :     case 4909:  /* fixuns_truncv16sfv16si2 */
   15147     35542692 :     case 4905:  /* fix_truncv16sfv16si2 */
   15148     35542692 :     case 4857:  /* *floatunsv4siv4sf2 */
   15149     35542692 :     case 4853:  /* *floatunsv8siv8sf2 */
   15150     35542692 :     case 4849:  /* *floatunsv16siv16sf2 */
   15151     35542692 :     case 4847:  /* floatv4siv4sf2 */
   15152     35542692 :     case 4845:  /* floatv8siv8sf2 */
   15153     35542692 :     case 4841:  /* floatv16siv16sf2 */
   15154     35542692 :     case 4775:  /* avx512fp16_vcvtps2ph_v8sf */
   15155     35542692 :     case 4771:  /* avx512fp16_vcvtps2ph_v16sf */
   15156     35542692 :     case 4767:  /* avx512fp16_vcvtpd2ph_v8df */
   15157     35542692 :     case 4765:  /* *avx512fp16_float_extend_phv2df2_load */
   15158     35542692 :     case 4761:  /* *avx512fp16_float_extend_phv4sf2_load */
   15159     35542692 :     case 4759:  /* *avx512fp16_float_extend_phv4df2_load */
   15160     35542692 :     case 4751:  /* avx512fp16_float_extend_phv8sf2 */
   15161     35542692 :     case 4747:  /* avx512fp16_float_extend_phv16sf2 */
   15162     35542692 :     case 4743:  /* avx512fp16_float_extend_phv8df2 */
   15163     35542692 :     case 4742:  /* avx512fp16_fixuns_truncdi2_mem */
   15164     35542692 :     case 4741:  /* avx512fp16_fix_truncdi2_mem */
   15165     35542692 :     case 4740:  /* avx512fp16_fixuns_truncsi2_mem */
   15166     35542692 :     case 4739:  /* avx512fp16_fix_truncsi2_mem */
   15167     35542692 :     case 4721:  /* *avx512fp16_fixuns_truncv2di2_load */
   15168     35542692 :     case 4719:  /* *avx512fp16_fix_truncv2di2_load */
   15169     35542692 :     case 4709:  /* *avx512fp16_fixuns_truncv4di2_load */
   15170     35542692 :     case 4707:  /* *avx512fp16_fix_truncv4di2_load */
   15171     35542692 :     case 4705:  /* *avx512fp16_fixuns_truncv4si2_load */
   15172     35542692 :     case 4703:  /* *avx512fp16_fix_truncv4si2_load */
   15173     35542692 :     case 4683:  /* avx512fp16_fixuns_truncv8di2 */
   15174     35542692 :     case 4679:  /* avx512fp16_fix_truncv8di2 */
   15175     35542692 :     case 4675:  /* avx512fp16_fixuns_truncv16si2 */
   15176     35542692 :     case 4671:  /* avx512fp16_fix_truncv16si2 */
   15177     35542692 :     case 4667:  /* avx512fp16_fixuns_truncv8si2 */
   15178     35542692 :     case 4663:  /* avx512fp16_fix_truncv8si2 */
   15179     35542692 :     case 4659:  /* avx512fp16_fixuns_truncv32hi2 */
   15180     35542692 :     case 4655:  /* avx512fp16_fix_truncv32hi2 */
   15181     35542692 :     case 4651:  /* avx512fp16_fixuns_truncv16hi2 */
   15182     35542692 :     case 4647:  /* avx512fp16_fix_truncv16hi2 */
   15183     35542692 :     case 4643:  /* avx512fp16_fixuns_truncv8hi2 */
   15184     35542692 :     case 4639:  /* avx512fp16_fix_truncv8hi2 */
   15185     35542692 :     case 4549:  /* avx512fp16_vcvtuqq2ph_v8di */
   15186     35542692 :     case 4545:  /* avx512fp16_vcvtqq2ph_v8di */
   15187     35542692 :     case 4541:  /* avx512fp16_vcvtudq2ph_v16si */
   15188     35542692 :     case 4537:  /* avx512fp16_vcvtdq2ph_v16si */
   15189     35542692 :     case 4533:  /* avx512fp16_vcvtudq2ph_v8si */
   15190     35542692 :     case 4529:  /* avx512fp16_vcvtdq2ph_v8si */
   15191     35542692 :     case 4525:  /* avx512fp16_vcvtuw2ph_v32hi */
   15192     35542692 :     case 4521:  /* avx512fp16_vcvtw2ph_v32hi */
   15193     35542692 :     case 4517:  /* avx512fp16_vcvtuw2ph_v16hi */
   15194     35542692 :     case 4513:  /* avx512fp16_vcvtw2ph_v16hi */
   15195     35542692 :     case 4509:  /* avx512fp16_vcvtuw2ph_v8hi */
   15196     35542692 :     case 4505:  /* avx512fp16_vcvtw2ph_v8hi */
   15197     35542692 :     case 2980:  /* sse2_sqrtv2df2 */
   15198     35542692 :     case 2978:  /* avx_sqrtv4df2 */
   15199     35542692 :     case 2974:  /* avx512f_sqrtv8df2 */
   15200     35542692 :     case 2972:  /* sse_sqrtv4sf2 */
   15201     35542692 :     case 2970:  /* avx_sqrtv8sf2 */
   15202     35542692 :     case 2966:  /* avx512f_sqrtv16sf2 */
   15203     35542692 :     case 2964:  /* avx512fp16_sqrtv8hf2 */
   15204     35542692 :     case 2962:  /* avx512fp16_sqrtv16hf2 */
   15205     35542692 :     case 2958:  /* avx512fp16_sqrtv32hf2 */
   15206     35542692 :     case 2442:  /* popcountv2si2 */
   15207     35542692 :     case 2441:  /* popcountv2hi2 */
   15208     35542692 :     case 2440:  /* popcountv4hi2 */
   15209     35542692 :     case 2439:  /* popcountv2qi2 */
   15210     35542692 :     case 2438:  /* popcountv4qi2 */
   15211     35542692 :     case 2437:  /* popcountv8qi2 */
   15212     35542692 :     case 2425:  /* *vec_dupv2hi */
   15213     35542692 :     case 2424:  /* *vec_dupv2bf */
   15214     35542692 :     case 2423:  /* *vec_dupv2hf */
   15215     35542692 :     case 2400:  /* *vec_extractv2si_1 */
   15216     35542692 :     case 2397:  /* *vec_extractv2si_0 */
   15217     35542692 :     case 2395:  /* *vec_dupv2si */
   15218     35542692 :     case 2394:  /* *vec_dupv4hi */
   15219     35542692 :     case 2393:  /* *vec_dupv4bf */
   15220     35542692 :     case 2392:  /* *vec_dupv4hf */
   15221     35542692 :     case 2390:  /* mmx_pswapdv2si2 */
   15222     35542692 :     case 2363:  /* avx512vl_truncv2siv2hi2 */
   15223     35542692 :     case 2362:  /* avx512vl_truncv2siv2qi2 */
   15224     35542692 :     case 2361:  /* avx512vl_truncv2hiv2qi2 */
   15225     35542692 :     case 2360:  /* avx512vl_truncv4hiv4qi2 */
   15226     35542692 :     case 2315:  /* one_cmplv2hi2 */
   15227     35542692 :     case 2314:  /* one_cmplv2qi2 */
   15228     35542692 :     case 2313:  /* one_cmplv4qi2 */
   15229     35542692 :     case 2245:  /* absv2hi2 */
   15230     35542692 :     case 2244:  /* absv2qi2 */
   15231     35542692 :     case 2243:  /* absv4qi2 */
   15232     35542692 :     case 2242:  /* ssse3_absv2si2 */
   15233     35542692 :     case 2241:  /* ssse3_absv4hi2 */
   15234     35542692 :     case 2240:  /* ssse3_absv8qi2 */
   15235     35542692 :     case 2142:  /* *vec_extractv2sf_1 */
   15236     35542692 :     case 2141:  /* *vec_extractv2sf_0 */
   15237     35542692 :     case 2137:  /* *vec_dupv2sf */
   15238     35542692 :     case 2134:  /* *mmx_movsldup */
   15239     35542692 :     case 2133:  /* *mmx_movshdup */
   15240     35542692 :     case 2132:  /* mmx_pswapdv2sf2 */
   15241     35542692 :     case 1739:  /* *sqrtdf2_sse */
   15242     35542692 :     case 1738:  /* *sqrtsf2_sse */
   15243     35542692 :     case 1737:  /* sqrthf2 */
   15244     35542692 :     case 1734:  /* sqrtxf2 */
   15245     35542692 :     case 1671:  /* *bswaphi2 */
   15246     35542692 :     case 1670:  /* *bswaphi2_movbe */
   15247     35542692 :     case 1669:  /* *bswapdi2 */
   15248     35542692 :     case 1668:  /* *bswapsi2 */
   15249     35542692 :     case 1667:  /* *bswapdi2_movbe */
   15250     35542692 :     case 1666:  /* *bswapsi2_movbe */
   15251     35542692 :     case 1664:  /* popcounthi2_nf */
   15252     35542692 :     case 1651:  /* popcountdi2_nf */
   15253     35542692 :     case 1650:  /* popcountsi2_nf */
   15254     35542692 :     case 1559:  /* clzdi2_lzcnt_nf */
   15255     35542692 :     case 1558:  /* clzsi2_lzcnt_nf */
   15256     35542692 :     case 1371:  /* rotr64ti2_doubleword */
   15257     35542692 :     case 1370:  /* rotl64ti2_doubleword */
   15258     35542692 :     case 1369:  /* rotr32di2_doubleword */
   15259     35542692 :     case 1368:  /* rotl32di2_doubleword */
   15260     35542692 :     case 1073:  /* *one_cmplqi2_1 */
   15261     35542692 :     case 1066:  /* *one_cmpldi2_1 */
   15262     35542692 :     case 1065:  /* *one_cmplsi2_1 */
   15263     35542692 :     case 1064:  /* *one_cmplhi2_1 */
   15264     35542692 :     case 1063:  /* *one_cmplti2_doubleword */
   15265     35542692 :     case 1062:  /* *one_cmpldi2_doubleword */
   15266     35542692 :     case 1061:  /* *negxf2_i387 */
   15267     35542692 :     case 1060:  /* *absxf2_i387 */
   15268     35542692 :     case 1059:  /* *negdf2_i387 */
   15269     35542692 :     case 1058:  /* *absdf2_i387 */
   15270     35542692 :     case 1057:  /* *negsf2_i387 */
   15271     35542692 :     case 1056:  /* *abssf2_i387 */
   15272     35542692 :     case 992:  /* *negdi_1_nf */
   15273     35542692 :     case 990:  /* *negsi_1_nf */
   15274     35542692 :     case 988:  /* *neghi_1_nf */
   15275     35542692 :     case 986:  /* *negqi_1_nf */
   15276     35542692 :     case 264:  /* *floatunsdidf2_avx512 */
   15277     35542692 :     case 263:  /* *floatunssidf2_avx512 */
   15278     35542692 :     case 262:  /* *floatunsdisf2_avx512 */
   15279     35542692 :     case 261:  /* *floatunssisf2_avx512 */
   15280     35542692 :     case 257:  /* *floatdidf2_i387 */
   15281     35542692 :     case 256:  /* *floatdisf2_i387 */
   15282     35542692 :     case 255:  /* floatunsdihf2 */
   15283     35542692 :     case 254:  /* floatdihf2 */
   15284     35542692 :     case 253:  /* floatunssihf2 */
   15285     35542692 :     case 252:  /* floatsihf2 */
   15286     35542692 :     case 251:  /* *floatdidf2 */
   15287     35542692 :     case 250:  /* *floatsidf2 */
   15288     35542692 :     case 249:  /* *floatdisf2 */
   15289     35542692 :     case 248:  /* *floatsisf2 */
   15290     35542692 :     case 247:  /* floatdixf2 */
   15291     35542692 :     case 246:  /* floatsixf2 */
   15292     35542692 :     case 245:  /* floathixf2 */
   15293     35542692 :     case 244:  /* floathidf2 */
   15294     35542692 :     case 243:  /* floathisf2 */
   15295     35542692 :     case 232:  /* fix_truncdfdi_sse */
   15296     35542692 :     case 231:  /* fix_truncdfsi_sse */
   15297     35542692 :     case 230:  /* fix_truncsfdi_sse */
   15298     35542692 :     case 229:  /* fix_truncsfsi_sse */
   15299     35542692 :     case 223:  /* fixuns_truncdfsi2_avx512f */
   15300     35542692 :     case 222:  /* fixuns_truncsfsi2_avx512f */
   15301     35542692 :     case 221:  /* fixuns_truncdfdi2 */
   15302     35542692 :     case 220:  /* fixuns_truncsfdi2 */
   15303     35542692 :     case 219:  /* fixuns_trunchfdi2 */
   15304     35542692 :     case 218:  /* fix_trunchfdi2 */
   15305     35542692 :     case 217:  /* fixuns_trunchfsi2 */
   15306     35542692 :     case 216:  /* fix_trunchfsi2 */
   15307     35542692 :     case 215:  /* truncsfbf2 */
   15308     35542692 :     case 214:  /* *truncdfhf2 */
   15309     35542692 :     case 213:  /* *truncsfhf2 */
   15310     35542692 :     case 212:  /* truncxfdf2 */
   15311     35542692 :     case 211:  /* truncxfsf2 */
   15312     35542692 :     case 210:  /* truncdfsf2 */
   15313     35542692 :     case 209:  /* *extenddfxf2_i387 */
   15314     35542692 :     case 208:  /* *extendsfxf2_i387 */
   15315     35542692 :     case 206:  /* *extendhfdf2 */
   15316     35542692 :     case 205:  /* *extendhfsf2 */
   15317     35542692 :     case 204:  /* *extendsfdf2 */
   15318     35542692 :     case 197:  /* extendqihi2 */
   15319     35542692 :     case 195:  /* extendqisi2 */
   15320     35542692 :     case 193:  /* extendhisi2 */
   15321     35542692 :     case 192:  /* extendhidi2 */
   15322     35542692 :     case 191:  /* extendqidi2 */
   15323     35542692 :     case 188:  /* *extendsidi2_rex64 */
   15324     35542692 :     case 187:  /* *zero_extendqihi2 */
   15325     35542692 :     case 185:  /* *zero_extendhisi2 */
   15326     35542692 :     case 184:  /* *zero_extendqisi2 */
   15327     35542692 :     case 181:  /* zero_extendhidi2 */
   15328     35542692 :     case 180:  /* zero_extendqidi2 */
   15329     35542692 :     case 179:  /* *zero_extendsidi2 */
   15330     35542692 :     case 178:  /* zero_extendditi2 */
   15331     35542692 :     case 128:  /* *extzvdi */
   15332     35542692 :     case 127:  /* *extzvsi */
   15333     35542692 :     case 126:  /* *extzvhi */
   15334     35542692 :     case 123:  /* *extvsi */
   15335     35542692 :     case 122:  /* *extvhi */
   15336     35542692 :     case 110:  /* *movabsdi_2 */
   15337     35542692 :     case 109:  /* *movabssi_2 */
   15338     35542692 :     case 108:  /* *movabshi_2 */
   15339     35542692 :     case 107:  /* *movabsqi_2 */
   15340     35542692 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   15341     35542692 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
   15342     35542692 :       break;
   15343              : 
   15344     55214410 :     case 1493:  /* *sibcall */
   15345     55214410 :     case 1492:  /* *sibcall */
   15346     55214410 :     case 1489:  /* *call */
   15347     55214410 :     case 1488:  /* *call */
   15348     55214410 :     case 1477:  /* *setcc_qi_slp */
   15349     55214410 :     case 134:  /* insvdi_1 */
   15350     55214410 :     case 133:  /* insvsi_1 */
   15351     55214410 :     case 132:  /* insvhi_1 */
   15352     55214410 :     case 116:  /* *movstricthi_1 */
   15353     55214410 :     case 115:  /* *movstrictqi_1 */
   15354     55214410 :     case 106:  /* *movabsdi_1 */
   15355     55214410 :     case 105:  /* *movabssi_1 */
   15356     55214410 :     case 104:  /* *movabshi_1 */
   15357     55214410 :     case 103:  /* *movabsqi_1 */
   15358     55214410 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 0), 0));
   15359     55214410 :       ro[1] = *(ro_loc[1] = &XEXP (pat, 1));
   15360     55214410 :       break;
   15361              : 
   15362       340705 :     case 11060:  /* storedi_via_sse */
   15363       340705 :     case 11059:  /* loaddi_via_sse */
   15364       340705 :     case 11058:  /* storedi_via_fpu */
   15365       340705 :     case 11057:  /* loaddi_via_fpu */
   15366       340705 :     case 11046:  /* avx512bmm_vbitrevb_v32qi */
   15367       340705 :     case 11045:  /* avx512bmm_vbitrevb_v16qi */
   15368       340705 :     case 11044:  /* avx512bmm_vbitrevb_v64qi */
   15369       340705 :     case 11035:  /* avx10_2_vmovrsqv2di */
   15370       340705 :     case 11033:  /* avx10_2_vmovrsqv4di */
   15371       340705 :     case 11031:  /* avx10_2_vmovrsqv8di */
   15372       340705 :     case 11029:  /* avx10_2_vmovrsdv4si */
   15373       340705 :     case 11027:  /* avx10_2_vmovrsdv8si */
   15374       340705 :     case 11025:  /* avx10_2_vmovrsdv16si */
   15375       340705 :     case 11023:  /* avx10_2_vmovrswv8hi */
   15376       340705 :     case 11021:  /* avx10_2_vmovrswv16hi */
   15377       340705 :     case 11019:  /* avx10_2_vmovrswv32hi */
   15378       340705 :     case 11017:  /* avx10_2_vmovrsbv16qi */
   15379       340705 :     case 11015:  /* avx10_2_vmovrsbv32qi */
   15380       340705 :     case 11013:  /* avx10_2_vmovrsbv64qi */
   15381       340705 :     case 10941:  /* avx10_2_vcvttps2uqqsv2di */
   15382       340705 :     case 10939:  /* avx10_2_vcvttps2qqsv2di */
   15383       340705 :     case 10937:  /* avx10_2_vcvttps2uqqsv4di */
   15384       340705 :     case 10935:  /* avx10_2_vcvttps2qqsv4di */
   15385       340705 :     case 10931:  /* avx10_2_vcvttps2uqqsv8di */
   15386       340705 :     case 10927:  /* avx10_2_vcvttps2qqsv8di */
   15387       340705 :     case 10925:  /* avx10_2_vcvttpd2uqqsv2df */
   15388       340705 :     case 10923:  /* avx10_2_vcvttpd2qqsv2df */
   15389       340705 :     case 10921:  /* avx10_2_vcvttpd2uqqsv4df */
   15390       340705 :     case 10919:  /* avx10_2_vcvttpd2qqsv4df */
   15391       340705 :     case 10915:  /* avx10_2_vcvttpd2uqqsv8df */
   15392       340705 :     case 10911:  /* avx10_2_vcvttpd2qqsv8df */
   15393       340705 :     case 10909:  /* avx10_2_vcvttpd2udqsv2df */
   15394       340705 :     case 10907:  /* avx10_2_vcvttpd2dqsv2df */
   15395       340705 :     case 10905:  /* avx10_2_vcvttpd2udqsv4df */
   15396       340705 :     case 10903:  /* avx10_2_vcvttpd2dqsv4df */
   15397       340705 :     case 10899:  /* avx10_2_vcvttpd2udqsv8df */
   15398       340705 :     case 10895:  /* avx10_2_vcvttpd2dqsv8df */
   15399       340705 :     case 10893:  /* avx10_2_vcvttps2udqsv4sf */
   15400       340705 :     case 10891:  /* avx10_2_vcvttps2dqsv4sf */
   15401       340705 :     case 10889:  /* avx10_2_vcvttps2udqsv8sf */
   15402       340705 :     case 10887:  /* avx10_2_vcvttps2dqsv8sf */
   15403       340705 :     case 10883:  /* avx10_2_vcvttps2udqsv16sf */
   15404       340705 :     case 10879:  /* avx10_2_vcvttps2dqsv16sf */
   15405       340705 :     case 10877:  /* avx10_2_cvttps2iubsv4sf */
   15406       340705 :     case 10875:  /* avx10_2_cvttps2ibsv4sf */
   15407       340705 :     case 10873:  /* avx10_2_cvttps2iubsv8sf */
   15408       340705 :     case 10871:  /* avx10_2_cvttps2ibsv8sf */
   15409       340705 :     case 10867:  /* avx10_2_cvttps2iubsv16sf */
   15410       340705 :     case 10863:  /* avx10_2_cvttps2ibsv16sf */
   15411       340705 :     case 10861:  /* avx10_2_cvtps2iubsv4sf */
   15412       340705 :     case 10859:  /* avx10_2_cvtps2ibsv4sf */
   15413       340705 :     case 10857:  /* avx10_2_cvtps2iubsv8sf */
   15414       340705 :     case 10855:  /* avx10_2_cvtps2ibsv8sf */
   15415       340705 :     case 10851:  /* avx10_2_cvtps2iubsv16sf */
   15416       340705 :     case 10847:  /* avx10_2_cvtps2ibsv16sf */
   15417       340705 :     case 10845:  /* avx10_2_cvttph2iubsv8hf */
   15418       340705 :     case 10843:  /* avx10_2_cvttph2ibsv8hf */
   15419       340705 :     case 10841:  /* avx10_2_cvttph2iubsv16hf */
   15420       340705 :     case 10839:  /* avx10_2_cvttph2ibsv16hf */
   15421       340705 :     case 10835:  /* avx10_2_cvttph2iubsv32hf */
   15422       340705 :     case 10831:  /* avx10_2_cvttph2ibsv32hf */
   15423       340705 :     case 10829:  /* avx10_2_cvtph2iubsv8hf */
   15424       340705 :     case 10827:  /* avx10_2_cvtph2ibsv8hf */
   15425       340705 :     case 10825:  /* avx10_2_cvtph2iubsv16hf */
   15426       340705 :     case 10823:  /* avx10_2_cvtph2ibsv16hf */
   15427       340705 :     case 10819:  /* avx10_2_cvtph2iubsv32hf */
   15428       340705 :     case 10815:  /* avx10_2_cvtph2ibsv32hf */
   15429       340705 :     case 10813:  /* avx10_2_cvttbf162iubsv8bf */
   15430       340705 :     case 10811:  /* avx10_2_cvttbf162ibsv8bf */
   15431       340705 :     case 10809:  /* avx10_2_cvtbf162iubsv8bf */
   15432       340705 :     case 10807:  /* avx10_2_cvtbf162ibsv8bf */
   15433       340705 :     case 10805:  /* avx10_2_cvttbf162iubsv16bf */
   15434       340705 :     case 10803:  /* avx10_2_cvttbf162ibsv16bf */
   15435       340705 :     case 10801:  /* avx10_2_cvtbf162iubsv16bf */
   15436       340705 :     case 10799:  /* avx10_2_cvtbf162ibsv16bf */
   15437       340705 :     case 10797:  /* avx10_2_cvttbf162iubsv32bf */
   15438       340705 :     case 10795:  /* avx10_2_cvttbf162ibsv32bf */
   15439       340705 :     case 10793:  /* avx10_2_cvtbf162iubsv32bf */
   15440       340705 :     case 10791:  /* avx10_2_cvtbf162ibsv32bf */
   15441       340705 :     case 10759:  /* avx10_2_getexpbf16_v8bf */
   15442       340705 :     case 10757:  /* avx10_2_getexpbf16_v16bf */
   15443       340705 :     case 10755:  /* avx10_2_getexpbf16_v32bf */
   15444       340705 :     case 10753:  /* avx10_2_rcpbf16_v8bf */
   15445       340705 :     case 10751:  /* avx10_2_rcpbf16_v16bf */
   15446       340705 :     case 10749:  /* avx10_2_rcpbf16_v32bf */
   15447       340705 :     case 10741:  /* avx10_2_rsqrtbf16_v8bf */
   15448       340705 :     case 10739:  /* avx10_2_rsqrtbf16_v16bf */
   15449       340705 :     case 10737:  /* avx10_2_rsqrtbf16_v32bf */
   15450       340705 :     case 10582:  /* vcvthf82phv8hf */
   15451       340705 :     case 10580:  /* vcvthf82phv16hf */
   15452       340705 :     case 10578:  /* vcvthf82phv32hf */
   15453       340705 :     case 10576:  /* vcvtph2hf8sv32hf */
   15454       340705 :     case 10574:  /* vcvtph2hf8v32hf */
   15455       340705 :     case 10572:  /* vcvtph2bf8sv32hf */
   15456       340705 :     case 10570:  /* vcvtph2bf8v32hf */
   15457       340705 :     case 10568:  /* vcvtph2hf8sv16hf */
   15458       340705 :     case 10566:  /* vcvtph2hf8v16hf */
   15459       340705 :     case 10564:  /* vcvtph2bf8sv16hf */
   15460       340705 :     case 10562:  /* vcvtph2bf8v16hf */
   15461       340705 :     case 10143:  /* *conflictv2di */
   15462       340705 :     case 10141:  /* *conflictv4di */
   15463       340705 :     case 10139:  /* *conflictv8di */
   15464       340705 :     case 10137:  /* *conflictv4si */
   15465       340705 :     case 10135:  /* *conflictv8si */
   15466       340705 :     case 10133:  /* *conflictv16si */
   15467       340705 :     case 9714:  /* *avx512f_vcvtph2ps512 */
   15468       340705 :     case 9712:  /* vcvtph2ps256 */
   15469       340705 :     case 9710:  /* *vcvtph2ps_load */
   15470       340705 :     case 9127:  /* aesimc */
   15471       340705 :     case 9100:  /* xop_frczv4df2 */
   15472       340705 :     case 9099:  /* xop_frczv8sf2 */
   15473       340705 :     case 9098:  /* xop_frczv2df2 */
   15474       340705 :     case 9097:  /* xop_frczv4sf2 */
   15475       340705 :     case 9096:  /* xop_frczdf2 */
   15476       340705 :     case 9095:  /* xop_frczsf2 */
   15477       340705 :     case 8784:  /* sse4_1_phminposuw */
   15478       340705 :     case 8751:  /* sse4_1_movntdqa */
   15479       340705 :     case 8750:  /* avx2_movntdqa */
   15480       340705 :     case 8749:  /* avx512f_movntdqa */
   15481       340705 :     case 8704:  /* sse4a_movntdf */
   15482       340705 :     case 8703:  /* sse4a_movntsf */
   15483       340705 :     case 8589:  /* sse2_pmovmskb */
   15484       340705 :     case 8588:  /* avx2_pmovmskb */
   15485       340705 :     case 8543:  /* sse2_movmskpd */
   15486       340705 :     case 8542:  /* avx_movmskpd256 */
   15487       340705 :     case 8541:  /* sse_movmskps */
   15488       340705 :     case 8540:  /* avx_movmskps256 */
   15489       340705 :     case 7075:  /* avx512vl_getexpv2df */
   15490       340705 :     case 7071:  /* avx512vl_getexpv4df */
   15491       340705 :     case 7067:  /* avx512f_getexpv8df */
   15492       340705 :     case 7063:  /* avx512vl_getexpv4sf */
   15493       340705 :     case 7059:  /* avx512vl_getexpv8sf */
   15494       340705 :     case 7055:  /* avx512f_getexpv16sf */
   15495       340705 :     case 7051:  /* avx512fp16_getexpv8hf */
   15496       340705 :     case 7047:  /* avx512vl_getexpv16hf */
   15497       340705 :     case 7043:  /* avx512bw_getexpv32hf */
   15498       340705 :     case 5207:  /* avx512vl_cvtq2maskv2di */
   15499       340705 :     case 5206:  /* avx512vl_cvtq2maskv4di */
   15500       340705 :     case 5205:  /* avx512f_cvtq2maskv8di */
   15501       340705 :     case 5204:  /* avx512vl_cvtd2maskv4si */
   15502       340705 :     case 5203:  /* avx512vl_cvtd2maskv8si */
   15503       340705 :     case 5202:  /* avx512f_cvtd2maskv16si */
   15504       340705 :     case 5201:  /* avx512vl_cvtw2maskv8hi */
   15505       340705 :     case 5200:  /* avx512vl_cvtw2maskv16hi */
   15506       340705 :     case 5199:  /* avx512bw_cvtw2maskv32hi */
   15507       340705 :     case 5198:  /* avx512vl_cvtb2maskv32qi */
   15508       340705 :     case 5197:  /* avx512vl_cvtb2maskv16qi */
   15509       340705 :     case 5196:  /* avx512bw_cvtb2maskv64qi */
   15510       340705 :     case 5163:  /* unspec_sse2_cvttpd2dq */
   15511       340705 :     case 5157:  /* *unspec_fixuns_truncv4sfv4si2 */
   15512       340705 :     case 5155:  /* *unspec_fixuns_truncv8sfv8si2 */
   15513       340705 :     case 5149:  /* unspec_avx512dq_fixuns_truncv2sfv2di2 */
   15514       340705 :     case 5147:  /* unspec_avx512dq_fix_truncv2sfv2di2 */
   15515       340705 :     case 5133:  /* unspec_fixuns_truncv4sfv4di2 */
   15516       340705 :     case 5131:  /* unspec_fix_truncv4sfv4di2 */
   15517       340705 :     case 5127:  /* unspec_fixuns_truncv8sfv8di2 */
   15518       340705 :     case 5123:  /* unspec_fix_truncv8sfv8di2 */
   15519       340705 :     case 5121:  /* fixuns_notruncv2dfv2di2 */
   15520       340705 :     case 5119:  /* fixuns_notruncv4dfv4di2 */
   15521       340705 :     case 5115:  /* fixuns_notruncv8dfv8di2 */
   15522       340705 :     case 5113:  /* fix_notruncv2dfv2di2 */
   15523       340705 :     case 5111:  /* fix_notruncv4dfv4di2 */
   15524       340705 :     case 5107:  /* fix_notruncv8dfv8di2 */
   15525       340705 :     case 5089:  /* unspec_fixuns_truncv2dfv2di2 */
   15526       340705 :     case 5087:  /* unspec_fix_truncv2dfv2di2 */
   15527       340705 :     case 5085:  /* unspec_fixuns_truncv4dfv4di2 */
   15528       340705 :     case 5083:  /* unspec_fix_truncv4dfv4di2 */
   15529       340705 :     case 5079:  /* unspec_fixuns_truncv8dfv8di2 */
   15530       340705 :     case 5075:  /* unspec_fix_truncv8dfv8di2 */
   15531       340705 :     case 5071:  /* unspec_fixuns_truncv4dfv4si2 */
   15532       340705 :     case 5067:  /* unspec_fix_truncv4dfv4si2 */
   15533       340705 :     case 5050:  /* unspec_fixuns_truncv8dfv8si2 */
   15534       340705 :     case 5046:  /* unspec_fix_truncv8dfv8si2 */
   15535       340705 :     case 5039:  /* fixuns_notruncv4dfv4si2 */
   15536       340705 :     case 5035:  /* fixuns_notruncv8dfv8si2 */
   15537       340705 :     case 5029:  /* avx_cvtpd2dq256 */
   15538       340705 :     case 5025:  /* avx512f_cvtpd2dq512 */
   15539       340705 :     case 4963:  /* unspec_sse2_cvttsd2siq */
   15540       340705 :     case 4961:  /* unspec_sse2_cvttsd2si */
   15541       340705 :     case 4960:  /* sse2_cvtsd2siq_2 */
   15542       340705 :     case 4959:  /* sse2_cvtsd2si_2 */
   15543       340705 :     case 4949:  /* unspec_avx512f_vcvttsd2usiq */
   15544       340705 :     case 4947:  /* unspec_avx512f_vcvttsd2usi */
   15545       340705 :     case 4937:  /* unspec_avx512f_vcvttss2usiq */
   15546       340705 :     case 4935:  /* unspec_avx512f_vcvttss2usi */
   15547       340705 :     case 4926:  /* unspec_fixuns_truncv2dfv2si2 */
   15548       340705 :     case 4924:  /* unspec_sse2_cvttpd2pi */
   15549       340705 :     case 4923:  /* sse2_cvtpd2pi */
   15550       340705 :     case 4917:  /* unspec_fix_truncv4sfv4si2 */
   15551       340705 :     case 4913:  /* unspec_fix_truncv8sfv8si2 */
   15552       340705 :     case 4901:  /* unspec_fixuns_truncv16sfv16si2 */
   15553       340705 :     case 4897:  /* unspec_fix_truncv16sfv16si2 */
   15554       340705 :     case 4893:  /* *avx512dq_cvtps2uqqv4di */
   15555       340705 :     case 4889:  /* *avx512dq_cvtps2uqqv8di */
   15556       340705 :     case 4885:  /* *avx512dq_cvtps2qqv4di */
   15557       340705 :     case 4881:  /* *avx512dq_cvtps2qqv8di */
   15558       340705 :     case 4877:  /* *avx512vl_fixuns_notruncv4sfv4si */
   15559       340705 :     case 4873:  /* *avx512vl_fixuns_notruncv8sfv8si */
   15560       340705 :     case 4869:  /* *avx512f_fixuns_notruncv16sfv16si */
   15561       340705 :     case 4865:  /* avx512f_fix_notruncv16sfv16si */
   15562       340705 :     case 4863:  /* sse2_fix_notruncv4sfv4si */
   15563       340705 :     case 4861:  /* avx_fix_notruncv8sfv8si */
   15564       340705 :     case 4828:  /* unspec_sse_cvttss2siq */
   15565       340705 :     case 4826:  /* unspec_sse_cvttss2si */
   15566       340705 :     case 4825:  /* sse_cvtss2siq_2 */
   15567       340705 :     case 4824:  /* sse_cvtss2si_2 */
   15568       340705 :     case 4814:  /* unspec_sse_cvttps2pi */
   15569       340705 :     case 4729:  /* unspec_avx512fp16_fixuns_truncdi2 */
   15570       340705 :     case 4727:  /* unspec_avx512fp16_fix_truncdi2 */
   15571       340705 :     case 4725:  /* unspec_avx512fp16_fixuns_truncsi2 */
   15572       340705 :     case 4723:  /* unspec_avx512fp16_fix_truncsi2 */
   15573       340705 :     case 4713:  /* unspec_avx512fp16_fixuns_truncv2di2 */
   15574       340705 :     case 4711:  /* unspec_avx512fp16_fix_truncv2di2 */
   15575       340705 :     case 4693:  /* unspec_avx512fp16_fixuns_truncv4di2 */
   15576       340705 :     case 4691:  /* unspec_avx512fp16_fix_truncv4di2 */
   15577       340705 :     case 4689:  /* unspec_avx512fp16_fixuns_truncv4si2 */
   15578       340705 :     case 4687:  /* unspec_avx512fp16_fix_truncv4si2 */
   15579       340705 :     case 4635:  /* unspec_avx512fp16_fixuns_truncv8di2 */
   15580       340705 :     case 4631:  /* unspec_avx512fp16_fix_truncv8di2 */
   15581       340705 :     case 4627:  /* unspec_avx512fp16_fixuns_truncv16si2 */
   15582       340705 :     case 4623:  /* unspec_avx512fp16_fix_truncv16si2 */
   15583       340705 :     case 4619:  /* unspec_avx512fp16_fixuns_truncv8si2 */
   15584       340705 :     case 4615:  /* unspec_avx512fp16_fix_truncv8si2 */
   15585       340705 :     case 4611:  /* unspec_avx512fp16_fixuns_truncv32hi2 */
   15586       340705 :     case 4607:  /* unspec_avx512fp16_fix_truncv32hi2 */
   15587       340705 :     case 4603:  /* unspec_avx512fp16_fixuns_truncv16hi2 */
   15588       340705 :     case 4599:  /* unspec_avx512fp16_fix_truncv16hi2 */
   15589       340705 :     case 4595:  /* unspec_avx512fp16_fixuns_truncv8hi2 */
   15590       340705 :     case 4591:  /* unspec_avx512fp16_fix_truncv8hi2 */
   15591       340705 :     case 4582:  /* avx512fp16_vcvtsh2siq_2 */
   15592       340705 :     case 4581:  /* avx512fp16_vcvtsh2usiq_2 */
   15593       340705 :     case 4580:  /* avx512fp16_vcvtsh2si_2 */
   15594       340705 :     case 4579:  /* avx512fp16_vcvtsh2usi_2 */
   15595       340705 :     case 4501:  /* avx512fp16_vcvtph2qq_v2di */
   15596       340705 :     case 4497:  /* avx512fp16_vcvtph2uqq_v2di */
   15597       340705 :     case 4493:  /* avx512fp16_vcvtph2dq_v4si */
   15598       340705 :     case 4489:  /* avx512fp16_vcvtph2udq_v4si */
   15599       340705 :     case 4485:  /* avx512fp16_vcvtph2w_v8hi */
   15600       340705 :     case 4481:  /* avx512fp16_vcvtph2uw_v8hi */
   15601       340705 :     case 4477:  /* avx512fp16_vcvtph2qq_v4di */
   15602       340705 :     case 4473:  /* avx512fp16_vcvtph2uqq_v4di */
   15603       340705 :     case 4469:  /* avx512fp16_vcvtph2dq_v8si */
   15604       340705 :     case 4465:  /* avx512fp16_vcvtph2udq_v8si */
   15605       340705 :     case 4461:  /* avx512fp16_vcvtph2w_v16hi */
   15606       340705 :     case 4457:  /* avx512fp16_vcvtph2uw_v16hi */
   15607       340705 :     case 4453:  /* avx512fp16_vcvtph2qq_v8di */
   15608       340705 :     case 4449:  /* avx512fp16_vcvtph2uqq_v8di */
   15609       340705 :     case 4445:  /* avx512fp16_vcvtph2dq_v16si */
   15610       340705 :     case 4441:  /* avx512fp16_vcvtph2udq_v16si */
   15611       340705 :     case 4437:  /* avx512fp16_vcvtph2w_v32hi */
   15612       340705 :     case 4433:  /* avx512fp16_vcvtph2uw_v32hi */
   15613       340705 :     case 3024:  /* *rsqrt14v2df */
   15614       340705 :     case 3022:  /* *rsqrt14v4df */
   15615       340705 :     case 3020:  /* *rsqrt14v8df */
   15616       340705 :     case 3018:  /* *rsqrt14v4sf */
   15617       340705 :     case 3016:  /* *rsqrt14v8sf */
   15618       340705 :     case 3014:  /* *rsqrt14v16sf */
   15619       340705 :     case 3012:  /* avx512fp16_rsqrtv8hf2 */
   15620       340705 :     case 3010:  /* avx512fp16_rsqrtv16hf2 */
   15621       340705 :     case 3008:  /* avx512fp16_rsqrtv32hf2 */
   15622       340705 :     case 3007:  /* sse_rsqrtv4sf2 */
   15623       340705 :     case 3006:  /* avx_rsqrtv8sf2 */
   15624       340705 :     case 2952:  /* *rcp14v2df */
   15625       340705 :     case 2950:  /* *rcp14v4df */
   15626       340705 :     case 2948:  /* *rcp14v8df */
   15627       340705 :     case 2946:  /* *rcp14v4sf */
   15628       340705 :     case 2944:  /* *rcp14v8sf */
   15629       340705 :     case 2942:  /* *rcp14v16sf */
   15630       340705 :     case 2937:  /* avx512fp16_rcpv8hf2 */
   15631       340705 :     case 2935:  /* avx512fp16_rcpv16hf2 */
   15632       340705 :     case 2933:  /* avx512fp16_rcpv32hf2 */
   15633       340705 :     case 2930:  /* sse_rcpv4sf2 */
   15634       340705 :     case 2929:  /* avx_rcpv8sf2 */
   15635       340705 :     case 2625:  /* sse2_movntv2di */
   15636       340705 :     case 2624:  /* avx_movntv4di */
   15637       340705 :     case 2623:  /* avx512f_movntv8di */
   15638       340705 :     case 2622:  /* sse2_movntv2df */
   15639       340705 :     case 2621:  /* avx_movntv4df */
   15640       340705 :     case 2620:  /* avx512f_movntv8df */
   15641       340705 :     case 2619:  /* sse_movntv4sf */
   15642       340705 :     case 2618:  /* avx_movntv8sf */
   15643       340705 :     case 2617:  /* avx512f_movntv16sf */
   15644       340705 :     case 2616:  /* sse2_movntidi */
   15645       340705 :     case 2615:  /* sse2_movntisi */
   15646       340705 :     case 2614:  /* sse3_lddqu */
   15647       340705 :     case 2613:  /* avx_lddqu256 */
   15648       340705 :     case 2550:  /* *avx512vl_loadv8bf */
   15649       340705 :     case 2549:  /* *avx512vl_loadv16bf */
   15650       340705 :     case 2548:  /* *avx512bw_loadv32bf */
   15651       340705 :     case 2547:  /* *avx512fp16_loadv8hf */
   15652       340705 :     case 2546:  /* *avx512vl_loadv16hf */
   15653       340705 :     case 2545:  /* *avx512bw_loadv32hf */
   15654       340705 :     case 2544:  /* *avx512vl_loadv8hi */
   15655       340705 :     case 2543:  /* *avx512vl_loadv16hi */
   15656       340705 :     case 2542:  /* *avx512bw_loadv32hi */
   15657       340705 :     case 2541:  /* *avx512vl_loadv32qi */
   15658       340705 :     case 2540:  /* *avx512vl_loadv16qi */
   15659       340705 :     case 2539:  /* *avx512bw_loadv64qi */
   15660       340705 :     case 2520:  /* *avx512vl_loadv2df */
   15661       340705 :     case 2519:  /* *avx512vl_loadv4df */
   15662       340705 :     case 2518:  /* *avx512f_loadv8df */
   15663       340705 :     case 2517:  /* *avx512vl_loadv4sf */
   15664       340705 :     case 2516:  /* *avx512vl_loadv8sf */
   15665       340705 :     case 2515:  /* *avx512f_loadv16sf */
   15666       340705 :     case 2514:  /* *avx512vl_loadv2di */
   15667       340705 :     case 2513:  /* *avx512vl_loadv4di */
   15668       340705 :     case 2512:  /* *avx512f_loadv8di */
   15669       340705 :     case 2511:  /* *avx512vl_loadv4si */
   15670       340705 :     case 2510:  /* *avx512vl_loadv8si */
   15671       340705 :     case 2509:  /* *avx512f_loadv16si */
   15672       340705 :     case 2432:  /* mmx_pmovmskb */
   15673       340705 :     case 2110:  /* mmx_rsqrtv2sf2 */
   15674       340705 :     case 2107:  /* mmx_rcpv2sf2 */
   15675       340705 :     case 2096:  /* sse_movntq */
   15676       340705 :     case 2063:  /* movrsdi */
   15677       340705 :     case 2062:  /* movrssi */
   15678       340705 :     case 2061:  /* movrshi */
   15679       340705 :     case 2060:  /* movrsqi */
   15680       340705 :     case 2056:  /* urdmsr */
   15681       340705 :     case 2032:  /* movdiridi */
   15682       340705 :     case 2031:  /* movdirisi */
   15683       340705 :     case 2002:  /* rdsspdi */
   15684       340705 :     case 2001:  /* rdsspsi */
   15685       340705 :     case 1970:  /* xgetbv */
   15686       340705 :     case 1953:  /* xsaves */
   15687       340705 :     case 1952:  /* xsavec */
   15688       340705 :     case 1951:  /* xsaveopt */
   15689       340705 :     case 1950:  /* xsave */
   15690       340705 :     case 1940:  /* rdpmc */
   15691       340705 :     case 1785:  /* movmsk_df */
   15692       340705 :     case 1784:  /* fxamxf2_i387 */
   15693       340705 :     case 1783:  /* fxamdf2_i387 */
   15694       340705 :     case 1782:  /* fxamsf2_i387 */
   15695       340705 :     case 1761:  /* lrintxfsi2 */
   15696       340705 :     case 1760:  /* lrintxfhi2 */
   15697       340705 :     case 1758:  /* rintxf2 */
   15698       340705 :     case 1751:  /* *f2xm1xf2_i387 */
   15699       340705 :     case 1744:  /* cosxf2 */
   15700       340705 :     case 1743:  /* sinxf2 */
   15701       340705 :     case 1736:  /* rsqrthf2 */
   15702       340705 :     case 1735:  /* *rsqrtsf2_sse */
   15703       340705 :     case 1733:  /* truncxfdf2_i387_noop_unspec */
   15704       340705 :     case 1732:  /* truncxfsf2_i387_noop_unspec */
   15705       340705 :     case 1707:  /* rcphf2 */
   15706       340705 :     case 1706:  /* *rcpsf2_sse */
   15707       340705 :     case 1694:  /* *tls_dynamic_gnu2_lea_64_di */
   15708       340705 :     case 1693:  /* *tls_dynamic_gnu2_lea_64_si */
   15709       340705 :     case 1590:  /* lzcnt_hi_nf */
   15710       340705 :     case 1588:  /* tzcnt_hi_nf */
   15711       340705 :     case 1575:  /* lzcnt_di_nf */
   15712       340705 :     case 1574:  /* tzcnt_di_nf */
   15713       340705 :     case 1573:  /* lzcnt_si_nf */
   15714       340705 :     case 1572:  /* tzcnt_si_nf */
   15715       340705 :     case 207:  /* extendbfsf2_1 */
   15716       340705 :     case 87:  /* popfldi1 */
   15717       340705 :     case 86:  /* popflsi1 */
   15718       340705 :     case 85:  /* pushfldi2 */
   15719       340705 :     case 84:  /* pushflsi2 */
   15720       340705 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   15721       340705 :       ro[1] = *(ro_loc[1] = &XVECEXP (XEXP (pat, 1), 0, 0));
   15722       340705 :       break;
   15723              : 
   15724     16594466 :     case 1473:  /* *setcc_si_1_and */
   15725     16594466 :     case 1472:  /* *setcc_hi_1_and */
   15726     16594466 :     case 166:  /* popp_di */
   15727     16594466 :     case 165:  /* pushp_di */
   15728     16594466 :     case 95:  /* *movdi_or */
   15729     16594466 :     case 94:  /* *movsi_or */
   15730     16594466 :     case 93:  /* *movhi_or */
   15731     16594466 :     case 92:  /* *movdi_and */
   15732     16594466 :     case 91:  /* *movsi_and */
   15733     16594466 :     case 90:  /* *movhi_and */
   15734     16594466 :     case 89:  /* *movdi_xor */
   15735     16594466 :     case 88:  /* *movsi_xor */
   15736     16594466 :     case 83:  /* *popdi1_epilogue */
   15737     16594466 :     case 82:  /* *popsi1_epilogue */
   15738     16594466 :     case 79:  /* *pushdi2_prologue */
   15739     16594466 :     case 78:  /* *pushsi2_prologue */
   15740     16594466 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (pat, 0, 0), 0));
   15741     16594466 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (pat, 0, 0), 1));
   15742     16594466 :       break;
   15743              : 
   15744   1457541406 :     case 10392:  /* *movp2hi_internal */
   15745   1457541406 :     case 10391:  /* *movp2qi_internal */
   15746   1457541406 :     case 5524:  /* *avx512vl_vpternlogv2df_0 */
   15747   1457541406 :     case 5523:  /* *avx512vl_vpternlogv4df_0 */
   15748   1457541406 :     case 5522:  /* *avx512f_vpternlogv8df_0 */
   15749   1457541406 :     case 5521:  /* *avx512vl_vpternlogv4sf_0 */
   15750   1457541406 :     case 5520:  /* *avx512vl_vpternlogv8sf_0 */
   15751   1457541406 :     case 5519:  /* *avx512f_vpternlogv16sf_0 */
   15752   1457541406 :     case 5518:  /* *avx512vl_vpternlogv8bf_0 */
   15753   1457541406 :     case 5517:  /* *avx512vl_vpternlogv16bf_0 */
   15754   1457541406 :     case 5516:  /* *avx512bw_vpternlogv32bf_0 */
   15755   1457541406 :     case 5515:  /* *avx512fp16_vpternlogv8hf_0 */
   15756   1457541406 :     case 5514:  /* *avx512vl_vpternlogv16hf_0 */
   15757   1457541406 :     case 5513:  /* *avx512bw_vpternlogv32hf_0 */
   15758   1457541406 :     case 5512:  /* *avx512vl_vpternlogv2di_0 */
   15759   1457541406 :     case 5511:  /* *avx512vl_vpternlogv4di_0 */
   15760   1457541406 :     case 5510:  /* *avx512f_vpternlogv8di_0 */
   15761   1457541406 :     case 5509:  /* *avx512vl_vpternlogv4si_0 */
   15762   1457541406 :     case 5508:  /* *avx512vl_vpternlogv8si_0 */
   15763   1457541406 :     case 5507:  /* *avx512f_vpternlogv16si_0 */
   15764   1457541406 :     case 5506:  /* *avx512vl_vpternlogv8hi_0 */
   15765   1457541406 :     case 5505:  /* *avx512vl_vpternlogv16hi_0 */
   15766   1457541406 :     case 5504:  /* *avx512bw_vpternlogv32hi_0 */
   15767   1457541406 :     case 5503:  /* *avx512vl_vpternlogv16qi_0 */
   15768   1457541406 :     case 5502:  /* *avx512vl_vpternlogv32qi_0 */
   15769   1457541406 :     case 5501:  /* *avx512bw_vpternlogv64qi_0 */
   15770   1457541406 :     case 2469:  /* movv2df_internal */
   15771   1457541406 :     case 2468:  /* movv4df_internal */
   15772   1457541406 :     case 2467:  /* movv8df_internal */
   15773   1457541406 :     case 2466:  /* movv4sf_internal */
   15774   1457541406 :     case 2465:  /* movv8sf_internal */
   15775   1457541406 :     case 2464:  /* movv16sf_internal */
   15776   1457541406 :     case 2463:  /* movv8bf_internal */
   15777   1457541406 :     case 2462:  /* movv16bf_internal */
   15778   1457541406 :     case 2461:  /* movv32bf_internal */
   15779   1457541406 :     case 2460:  /* movv8hf_internal */
   15780   1457541406 :     case 2459:  /* movv16hf_internal */
   15781   1457541406 :     case 2458:  /* movv32hf_internal */
   15782   1457541406 :     case 2457:  /* movv1ti_internal */
   15783   1457541406 :     case 2456:  /* movv2ti_internal */
   15784   1457541406 :     case 2455:  /* movv4ti_internal */
   15785   1457541406 :     case 2454:  /* movv2di_internal */
   15786   1457541406 :     case 2453:  /* movv4di_internal */
   15787   1457541406 :     case 2452:  /* movv8di_internal */
   15788   1457541406 :     case 2451:  /* movv4si_internal */
   15789   1457541406 :     case 2450:  /* movv8si_internal */
   15790   1457541406 :     case 2449:  /* movv16si_internal */
   15791   1457541406 :     case 2448:  /* movv8hi_internal */
   15792   1457541406 :     case 2447:  /* movv16hi_internal */
   15793   1457541406 :     case 2446:  /* movv32hi_internal */
   15794   1457541406 :     case 2445:  /* movv16qi_internal */
   15795   1457541406 :     case 2444:  /* movv32qi_internal */
   15796   1457541406 :     case 2443:  /* movv64qi_internal */
   15797   1457541406 :     case 2095:  /* *pushv2qi2 */
   15798   1457541406 :     case 2094:  /* *movv1di_imm */
   15799   1457541406 :     case 2093:  /* *movv2sf_imm */
   15800   1457541406 :     case 2092:  /* *movv2si_imm */
   15801   1457541406 :     case 2091:  /* *movv4bf_imm */
   15802   1457541406 :     case 2090:  /* *movv4hf_imm */
   15803   1457541406 :     case 2089:  /* *movv4hi_imm */
   15804   1457541406 :     case 2088:  /* *movv8qi_imm */
   15805   1457541406 :     case 2087:  /* *movv2bf_imm */
   15806   1457541406 :     case 2086:  /* *movv2hf_imm */
   15807   1457541406 :     case 2085:  /* *movv1si_imm */
   15808   1457541406 :     case 2084:  /* *movv2hi_imm */
   15809   1457541406 :     case 2083:  /* *movv4qi_imm */
   15810   1457541406 :     case 2082:  /* *movv2qi_imm */
   15811   1457541406 :     case 2081:  /* *movv2qi_internal */
   15812   1457541406 :     case 2080:  /* *pushv2bf2_rex64 */
   15813   1457541406 :     case 2079:  /* *pushv2hf2_rex64 */
   15814   1457541406 :     case 2078:  /* *pushv1si2_rex64 */
   15815   1457541406 :     case 2077:  /* *pushv2hi2_rex64 */
   15816   1457541406 :     case 2076:  /* *pushv4qi2_rex64 */
   15817   1457541406 :     case 2075:  /* *movv2bf_internal */
   15818   1457541406 :     case 2074:  /* *movv2hf_internal */
   15819   1457541406 :     case 2073:  /* *movv1si_internal */
   15820   1457541406 :     case 2072:  /* *movv2hi_internal */
   15821   1457541406 :     case 2071:  /* *movv4qi_internal */
   15822   1457541406 :     case 2070:  /* *movv4bf_internal */
   15823   1457541406 :     case 2069:  /* *movv4hf_internal */
   15824   1457541406 :     case 2068:  /* *movv2sf_internal */
   15825   1457541406 :     case 2067:  /* *movv1di_internal */
   15826   1457541406 :     case 2066:  /* *movv2si_internal */
   15827   1457541406 :     case 2065:  /* *movv4hi_internal */
   15828   1457541406 :     case 2064:  /* *movv8qi_internal */
   15829   1457541406 :     case 1933:  /* *prefetch_3dnow */
   15830   1457541406 :     case 1476:  /* *setcc_qi */
   15831   1457541406 :     case 1475:  /* *setcc_si_1_movzbl */
   15832   1457541406 :     case 1474:  /* *setcc_hi_1_movzbl */
   15833   1457541406 :     case 1471:  /* *setcc_di_1 */
   15834   1457541406 :     case 1470:  /* *setcc_di_zu */
   15835   1457541406 :     case 1469:  /* *setcc_si_zu */
   15836   1457541406 :     case 1468:  /* *setcc_hi_zu */
   15837   1457541406 :     case 269:  /* *leadi */
   15838   1457541406 :     case 268:  /* *leasi */
   15839   1457541406 :     case 176:  /* *movbf_internal */
   15840   1457541406 :     case 175:  /* *movhf_internal */
   15841   1457541406 :     case 174:  /* *movsf_internal */
   15842   1457541406 :     case 173:  /* *movdf_internal */
   15843   1457541406 :     case 172:  /* *movxf_internal */
   15844   1457541406 :     case 171:  /* *movtf_internal */
   15845   1457541406 :     case 170:  /* *pushsf */
   15846   1457541406 :     case 169:  /* *pushsf_rex64 */
   15847   1457541406 :     case 162:  /* *pushbf */
   15848   1457541406 :     case 161:  /* *pushhf */
   15849   1457541406 :     case 160:  /* *pushbf_rex64 */
   15850   1457541406 :     case 159:  /* *pushhf_rex64 */
   15851   1457541406 :     case 158:  /* *pushdf */
   15852   1457541406 :     case 157:  /* *pushxf */
   15853   1457541406 :     case 156:  /* *pushtf */
   15854   1457541406 :     case 102:  /* *movqi_internal */
   15855   1457541406 :     case 101:  /* *movhi_internal */
   15856   1457541406 :     case 100:  /* *movsi_internal */
   15857   1457541406 :     case 99:  /* *movdi_internal */
   15858   1457541406 :     case 98:  /* *movti_internal */
   15859   1457541406 :     case 97:  /* *movoi_internal_avx */
   15860   1457541406 :     case 96:  /* *movxi_internal_avx512f */
   15861   1457541406 :     case 81:  /* *popdi1 */
   15862   1457541406 :     case 80:  /* *popsi1 */
   15863   1457541406 :     case 77:  /* *pushhi2 */
   15864   1457541406 :     case 76:  /* *pushqi2 */
   15865   1457541406 :     case 75:  /* *pushsi2 */
   15866   1457541406 :     case 74:  /* *pushsi2_rex64 */
   15867   1457541406 :     case 73:  /* *pushdi2_rex64 */
   15868   1457541406 :     case 72:  /* *pushti2 */
   15869   1457541406 :     case 71:  /* *pushdi2 */
   15870   1457541406 :     case 70:  /* *pushv1ti2 */
   15871   1457541406 :     case 69:  /* *pushv1ti2 */
   15872   1457541406 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   15873   1457541406 :       ro[1] = *(ro_loc[1] = &XEXP (pat, 1));
   15874   1457541406 :       break;
   15875              : 
   15876              :     case 9131:  /* avx_vzeroupper_callee_abi */
   15877              :     case 2436:  /* *mmx_femms */
   15878              :     case 2435:  /* *mmx_emms */
   15879              :     case 2053:  /* serialize */
   15880              :     case 2052:  /* speculation_barrier */
   15881              :     case 2043:  /* testui */
   15882              :     case 2042:  /* stui */
   15883              :     case 2041:  /* clui */
   15884              :     case 2036:  /* xresldtrk */
   15885              :     case 2035:  /* xsusldtrk */
   15886              :     case 2030:  /* wbnoinvd */
   15887              :     case 2029:  /* wbinvd */
   15888              :     case 2017:  /* xtest_1 */
   15889              :     case 2015:  /* xend */
   15890              :     case 2013:  /* nop_endbr */
   15891              :     case 2011:  /* setssbsy */
   15892              :     case 2005:  /* saveprevssp */
   15893              :     case 1975:  /* fnclex */
   15894              :     case 1931:  /* ud2 */
   15895              :     case 1930:  /* trap */
   15896              :     case 1786:  /* cld */
   15897              :     case 1529:  /* *leave_rex64 */
   15898              :     case 1528:  /* *leave */
   15899              :     case 1527:  /* eh_return_internal */
   15900              :     case 1519:  /* nop */
   15901              :     case 1515:  /* simple_return_internal_long */
   15902              :     case 1514:  /* interrupt_return */
   15903              :     case 1513:  /* simple_return_internal */
   15904              :     case 1510:  /* blockage */
   15905              :     case 561:  /* *setcc_qi_negqi_ccc_2_ccc */
   15906              :     case 560:  /* *setcc_qi_negqi_ccc_2_cc */
   15907              :     case 559:  /* *setcc_qi_negqi_ccc_1_ccc */
   15908              :     case 558:  /* *setcc_qi_negqi_ccc_1_cc */
   15909              :     case 557:  /* *setccc */
   15910              :     case 556:  /* *setcc_qi_addqi3_cconly_overflow_1_ccc */
   15911              :     case 555:  /* *setcc_qi_addqi3_cconly_overflow_1_cc */
   15912              :     case 68:  /* *x86_cmc */
   15913              :     case 67:  /* x86_stc */
   15914              :       break;
   15915              : 
   15916        17819 :     case 59:  /* *cmpxuhf */
   15917        17819 :     case 57:  /* *cmpxudf */
   15918        17819 :     case 55:  /* *cmpxusf */
   15919        17819 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 0));
   15920        17819 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 1));
   15921        17819 :       break;
   15922              : 
   15923      6398932 :     case 65:  /* *cmpiuhf */
   15924      6398932 :     case 63:  /* *cmpiudf */
   15925      6398932 :     case 61:  /* *cmpiusf */
   15926      6398932 :     case 58:  /* *cmpxhf */
   15927      6398932 :     case 56:  /* *cmpxdf */
   15928      6398932 :     case 54:  /* *cmpxsf */
   15929      6398932 :     case 53:  /* *cmpiuxf_i387 */
   15930      6398932 :       ro[0] = *(ro_loc[0] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
   15931      6398932 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
   15932      6398932 :       break;
   15933              : 
   15934          934 :     case 1674:  /* parityqi2_cmp */
   15935          934 :     case 51:  /* x86_sahf_1 */
   15936          934 :       ro[0] = *(ro_loc[0] = &XVECEXP (XEXP (pat, 1), 0, 0));
   15937          934 :       break;
   15938              : 
   15939            0 :     case 50:  /* *cmpuxf_i387 */
   15940            0 :     case 49:  /* *cmpudf_i387 */
   15941            0 :     case 48:  /* *cmpusf_i387 */
   15942            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   15943            0 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 0));
   15944            0 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0, 0), 1));
   15945            0 :       break;
   15946              : 
   15947            0 :     case 47:  /* *cmpxf_si_i387 */
   15948            0 :     case 46:  /* *cmpdf_si_i387 */
   15949            0 :     case 45:  /* *cmpsf_si_i387 */
   15950            0 :     case 44:  /* *cmpxf_hi_i387 */
   15951            0 :     case 43:  /* *cmpdf_hi_i387 */
   15952            0 :     case 42:  /* *cmpsf_hi_i387 */
   15953            0 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   15954            0 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
   15955            0 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1), 0));
   15956            0 :       break;
   15957              : 
   15958           76 :     case 8595:  /* *sse2_pmovmskb_lt */
   15959           76 :     case 8594:  /* *avx2_pmovmskb_lt */
   15960           76 :     case 8555:  /* *sse2_movmskpd_lt */
   15961           76 :     case 8554:  /* *avx_movmskpd256_lt */
   15962           76 :     case 8553:  /* *sse_movmskps_lt */
   15963           76 :     case 8552:  /* *avx_movmskps256_lt */
   15964           76 :     case 41:  /* *cmpdf_i387 */
   15965           76 :     case 40:  /* *cmpsf_i387 */
   15966           76 :     case 39:  /* *cmpxf_i387 */
   15967           76 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   15968           76 :       ro[1] = *(ro_loc[1] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 0));
   15969           76 :       ro[2] = *(ro_loc[2] = &XEXP (XVECEXP (XEXP (pat, 1), 0, 0), 1));
   15970           76 :       break;
   15971              : 
   15972          808 :     case 36:  /* *cmpqi_extdi_4 */
   15973          808 :     case 35:  /* *cmpqi_extsi_4 */
   15974          808 :     case 34:  /* *cmpqi_exthi_4 */
   15975          808 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   15976          808 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
   15977          808 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   15978          808 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   15979          808 :       break;
   15980              : 
   15981         6408 :     case 33:  /* *cmpqi_extdi_3 */
   15982         6408 :     case 32:  /* *cmpqi_extsi_3 */
   15983         6408 :     case 31:  /* *cmpqi_exthi_3 */
   15984         6408 :     case 30:  /* *cmpqi_extdi_2 */
   15985         6408 :     case 29:  /* *cmpqi_extsi_2 */
   15986         6408 :     case 28:  /* *cmpqi_exthi_2 */
   15987         6408 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 0), 0), 0));
   15988         6408 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
   15989         6408 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   15990         6408 :       break;
   15991              : 
   15992           52 :     case 27:  /* *cmpqi_extdi_1 */
   15993           52 :     case 26:  /* *cmpqi_extsi_1 */
   15994           52 :     case 25:  /* *cmpqi_exthi_1 */
   15995           52 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 1), 0));
   15996           52 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
   15997           52 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (pat, 1), 1), 0));
   15998           52 :       break;
   15999              : 
   16000      2880850 :     case 721:  /* *testti_doubleword */
   16001      2880850 :     case 714:  /* *testsi_1 */
   16002      2880850 :     case 713:  /* *testhi_1 */
   16003      2880850 :     case 712:  /* *testqi_1 */
   16004      2880850 :     case 711:  /* *testqi_1_maybe_si */
   16005      2880850 :     case 710:  /* *testdi_1 */
   16006      2880850 :     case 24:  /* *cmpdi_plus_1 */
   16007      2880850 :     case 23:  /* *cmpsi_plus_1 */
   16008      2880850 :     case 22:  /* *cmphi_plus_1 */
   16009      2880850 :     case 21:  /* *cmpqi_plus_1 */
   16010      2880850 :     case 20:  /* *cmpdi_minus_1 */
   16011      2880850 :     case 19:  /* *cmpsi_minus_1 */
   16012      2880850 :     case 18:  /* *cmphi_minus_1 */
   16013      2880850 :     case 17:  /* *cmpqi_minus_1 */
   16014      2880850 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (XEXP (pat, 1), 0), 0));
   16015      2880850 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (XEXP (pat, 1), 0), 1));
   16016      2880850 :       break;
   16017              : 
   16018    134302662 :     case 66:  /* *cmpibf */
   16019    134302662 :     case 64:  /* *cmpihf */
   16020    134302662 :     case 62:  /* *cmpidf */
   16021    134302662 :     case 60:  /* *cmpisf */
   16022    134302662 :     case 52:  /* *cmpixf_i387 */
   16023    134302662 :     case 38:  /* *cmpti_doubleword */
   16024    134302662 :     case 37:  /* *cmpdi_doubleword */
   16025    134302662 :     case 16:  /* *cmpdi_1 */
   16026    134302662 :     case 15:  /* *cmpsi_1 */
   16027    134302662 :     case 14:  /* *cmphi_1 */
   16028    134302662 :     case 13:  /* *cmpqi_1 */
   16029    134302662 :     case 12:  /* *cmpdi_ccno_1 */
   16030    134302662 :     case 11:  /* *cmpsi_ccno_1 */
   16031    134302662 :     case 10:  /* *cmphi_ccno_1 */
   16032    134302662 :     case 9:  /* *cmpqi_ccno_1 */
   16033    134302662 :     case 8:  /* *cmpdi_ccz_1 */
   16034    134302662 :     case 7:  /* *cmpsi_ccz_1 */
   16035    134302662 :     case 6:  /* *cmphi_ccz_1 */
   16036    134302662 :     case 5:  /* *cmpqi_ccz_1 */
   16037    134302662 :       ro[0] = *(ro_loc[0] = &XEXP (XEXP (pat, 1), 0));
   16038    134302662 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 1));
   16039    134302662 :       break;
   16040              : 
   16041          443 :     case 4:  /* ccmpdi */
   16042          443 :     case 3:  /* ccmpsi */
   16043          443 :     case 2:  /* ccmphi */
   16044          443 :     case 1:  /* ccmpqi */
   16045          443 :       ro[0] = *(ro_loc[0] = &XEXP (pat, 0));
   16046          443 :       ro[1] = *(ro_loc[1] = &XEXP (XEXP (pat, 1), 0));
   16047          443 :       ro[2] = *(ro_loc[2] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 0));
   16048          443 :       ro[3] = *(ro_loc[3] = &XEXP (XEXP (XEXP (XEXP (pat, 1), 1), 0), 1));
   16049          443 :       ro[4] = *(ro_loc[4] = &XVECEXP (XEXP (XEXP (pat, 1), 2), 0, 0));
   16050          443 :       break;
   16051              : 
   16052              :     }
   16053   2240472525 : }
        

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.