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

            Bug ID: 116280
           Summary: [15 Regression] RISC-V: expected mode RVVMF8QI for
                    operand 2 of insn pred_vwsllrvvmf4hi but got mode
                    RVVMF2SI
           Product: gcc
           Version: 15.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: target
          Assignee: unassigned at gcc dot gnu.org
          Reporter: patrick at rivosinc dot com
  Target Milestone: ---

Created attachment 58865
  --> https://gcc.gnu.org/bugzilla/attachment.cgi?id=58865&action=edit
Unreduced testcase

Testcase:
short a;
char b;
void c(int e[][1][1], char f[][1][1][1][1]) {
  for (int g; b;)
    for (;;)
      for (int h; h < 4073709551572ULL; h += 18446744073709551612U)
        a = f[2][2][1][4073709551612][1] << e[1][1][g];
}


Command/backtrace:
> /scratch/tc-testing/tc-compiler-fuzz-trunk/build-gcv/bin/riscv64-unknown-linux-gnu-gcc
>  -O3 -march=rv64imdzvbb func.c -c -o /dev/null
during RTL pass: split1
func.c: In function 'c':
func.c:8:1: internal compiler error: expected mode RVVMF4QI for operand 2 of
insn pred_vwsllrvvmf2hi but got mode RVVM1SI.

    8 | }
      | ^
0x2de6365 internal_error(char const*, ...)
        ../../../gcc/gcc/diagnostic-global-context.cc:491
0x1878b7e riscv_vector::insn_expander<11>::emit_insn(insn_code, rtx_def**)
        ../../../gcc/gcc/config/riscv/riscv-v.cc:299
0x186fd1c riscv_vector::emit_vlmax_insn(unsigned int, unsigned int, rtx_def**)
        ../../../gcc/gcc/config/riscv/riscv-v.cc:398
0x20b9a9f gen_split_10234(rtx_insn*, rtx_def**)
        ../../../gcc/gcc/config/riscv/autovec-opt.md:1550
0xf04134 try_split(rtx_def*, rtx_insn*, int)
        ../../../gcc/gcc/emit-rtl.cc:3941
0x12df0c5 split_insn
        ../../../gcc/gcc/recog.cc:3462
0x12e4127 split_all_insns()
        ../../../gcc/gcc/recog.cc:3566
0x12e41ec execute
        ../../../gcc/gcc/recog.cc:4490
Please submit a full bug report, with preprocessed source (by using
-freport-bug).
Please include the complete backtrace with any bug report.
See <https://gcc.gnu.org/bugs/> for instructions.

Godbolt: https://godbolt.org/z/WcKErGs9M

Found via fuzzer

Reply via email to