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

            Bug ID: 118154
           Summary: [15 Regression] RISC-V: Miscompile with -march=rv64gcv
                    -O3 since 15-5117-g0b27a7dd050
           Product: gcc
           Version: 15.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: tree-optimization
          Assignee: unassigned at gcc dot gnu.org
          Reporter: patrick at rivosinc dot com
  Target Milestone: ---

Testcase:
long a;
signed char b;
long long d;
signed char c[22][22][484];
void m(long long *l, int n) { *l ^= n + (*l >> 2); }
int main() {
  signed char l = 35;
  for (signed char f = 4; f; f++) {
    for (signed g = 0; g < 022; g += 4)
      for (signed char h = 0; h < 022; h++) {
        c[9][g][h * 22 + h] = l;
        a = ({ a > 4095 ? a : 4095; });
      }
    for (int i = 0; i < 22; i += 3)
      for (signed char j = 1; j; j++)
        for (signed char k = 0; k < 022; k++)
          b = ({ b > 19 ? b : 19; });
  }
  for (long f = 0; f < 22; ++f)
    for (long g = 0; g < 22; ++g)
      for (long h = 0; h < 22; ++h)
        for (long i = 0; i < 22; ++i)
          m(&d, c[f][g][h * 2 + i]);
  if (d != 38)
    return 1;
}

Commands:
/scratch/tc-testing/tc-compiler-fuzz-bisect/build-rv64gcv/bin/riscv64-unknown-linux-gnu-gcc
-march=rv64gcv -O3 test.c -o user-config.out -fno-strict-aliasing -fwrapv
QEMU_CPU=rv64,vlen=128,rvv_ta_all_1s=true,rvv_ma_all_1s=true,v=true,vext_spec=v1.0,zve32f=true,zve32x=true,zve64d=true,zve64f=true,zve64x=true
timeout --verbose -k 0.1 4
/scratch/tc-testing/tc-compiler-fuzz-trunk/build-gcv/bin/qemu-riscv64
user-config.out

Found via fuzzer

First bad commit: r15-5117-g0b27a7dd050

Reply via email to