https://gcc.gnu.org/bugzilla/show_bug.cgi?id=106959

            Bug ID: 106959
           Summary: [13 Regression] ICE in curr_insn_transform, at
                    lra-constraints.cc:4168 (error: unable to generate
                    reloads), or ICE in simplify_subreg, at
                    simplify-rtx.cc:7405
           Product: gcc
           Version: 13.0
            Status: UNCONFIRMED
          Keywords: ice-on-valid-code
          Severity: normal
          Priority: P3
         Component: target
          Assignee: unassigned at gcc dot gnu.org
          Reporter: asolokha at gmx dot com
                CC: sayle at gcc dot gnu.org
  Target Milestone: ---
            Target: x86_64-unknown-linux-gnu

1. gcc 13.0.0 20220911 snapshot (g:0ea5e3f4542832b8da016b152695e64a2a386309)
ICEs when compiling the following testcase w/ -msse4 -O2 -fno-tree-loop-im
--param max-combine-insns=2:

unsigned __int128 n;

int
foo (int x)
{
  __int128 a = 0;
  int b = !!(n * 2);

  while (x < 2)
    {
      if (a)
        {
          if (n)
            n ^= 1;
          else
            x <<= 32;
        }

      a = 1;
    }

  return b;
}

% x86_64-unknown-linux-gnu-gcc-13.0.0 -msse4 -O2 -fno-tree-loop-im --param
max-combine-insns=2 -w -c nyxubvpd.c
nyxubvpd.c: In function 'foo':
nyxubvpd.c:23:1: error: unable to generate reloads for:
   23 | }
      | ^
(insn 8 7 62 2 (parallel [
            (set (reg:TI 90)
                (ashift:TI (reg:V1TI 96 [ n.1_4 ])
                    (const_int 1 [0x1])))
            (clobber (reg:CC 17 flags))
        ]) "nyxubvpd.c":7:16 747 {ashlti3_doubleword}
     (expr_list:REG_DEAD (reg:V1TI 96 [ n.1_4 ])
        (expr_list:REG_UNUSED (reg:CC 17 flags)
            (nil))))
during RTL pass: reload
nyxubvpd.c:23:1: internal compiler error: in curr_insn_transform, at
lra-constraints.cc:4168
0x730822 _fatal_insn(char const*, rtx_def const*, char const*, int, char
const*)
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/rtl-error.cc:108
0x70a880 curr_insn_transform
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/lra-constraints.cc:4168
0xd41a2e lra_constraints(bool)
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/lra-constraints.cc:5203
0xd2db02 lra(_IO_FILE*)
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/lra.cc:2375
0xce35d9 do_reload
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/ira.cc:5940
0xce35d9 execute
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/ira.cc:6126

2. W/o --param max-combine-insns=2, it yields the following instead:

% x86_64-unknown-linux-gnu-gcc-13.0.0 -msse4 -O2 -fno-tree-loop-im -w -c
nyxubvpd.c
during RTL pass: combine
nyxubvpd.c: In function 'foo':
nyxubvpd.c:23:1: internal compiler error: in simplify_subreg, at
simplify-rtx.cc:7405
   23 | }
      | ^
0x734cf5 simplify_context::simplify_subreg(machine_mode, rtx_def*,
machine_mode, poly_int<1u, unsigned long>)
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/simplify-rtx.cc:7405
0x1cdb6ff simplify_subreg(machine_mode, rtx_def*, machine_mode, poly_int<1u,
unsigned long>)
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/rtl.h:3498
0x1cdb6ff combine_simplify_rtx
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/combine.cc:5874
0x1cdd76e subst
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/combine.cc:5605
0x1cdd538 subst
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/combine.cc:5532
0x1cdd538 subst
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/combine.cc:5532
0x1cdd538 subst
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/combine.cc:5532
0x1ce0b22 try_combine
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/combine.cc:3336
0x1ce692c combine_instructions
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/combine.cc:1287
0x1ce692c rest_of_handle_combine
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/combine.cc:14978
0x1ce692c execute
       
/var/tmp/portage/sys-devel/gcc-13.0.0_p20220911/work/gcc-13-20220911/gcc/combine.cc:15023

It is probably a duplicate of PR106933.

Reply via email to