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

            Bug ID: 120651
           Summary: [15/16 Regression] RISC-V: Miscompile at -O3 with
                    -flto since r15-3228-g771256bcb9d
           Product: gcc
           Version: 16.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: target
          Assignee: unassigned at gcc dot gnu.org
          Reporter: ewlu at rivosinc dot com
  Target Milestone: ---

Testcase:
long long s;
short a = 3;
_Bool b[20];
unsigned long long c[20][20];
int main() {
  for (signed p = 0; p < 18; p += 4)
    for (unsigned q = 0; q < 20; q++) {
      a *= (unsigned char)2057594037927935;
      b[q] = 0;
      c[p][q] = 0;
    }
  s ^= a;
  for (int p = 0; p < 20;)
    for (int u = 0; u < 20;)
      for (; p < 20; ++p)
        for (; u < 20; ++u) {
          s ^= b[p];
          s ^= c[p][u];
        }
  __builtin_printf("%llu\n", s);
}

Commands:
# -O3
> /scratch/ewlu/daily-upstream-build/build-gcv/bin/riscv64-unknown-linux-gnu-gcc
>  -march=rv64gcv -flto -O3 -mrvv-vector-bits=zvl red.c -o user-config.out 
> -fsigned-char -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,zve64f=true
>  timeout --verbose -k 0.1 4 
> /scratch/ewlu/daily-upstream-build/build-gcv/bin/qemu-riscv64 user-config.out 
> 1
15875
# -O2
> /scratch/ewlu/daily-upstream-build/build-gcv/bin/riscv64-unknown-linux-gnu-gcc
>  -march=rv64gcv -flto -O2 -mrvv-vector-bits=zvl red.c -o user-config.out 
> -fsigned-char -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,zve64f=true
>  timeout --verbose -k 0.1 4 
> /scratch/ewlu/daily-upstream-build/build-gcv/bin/qemu-riscv64 user-config.out 
> 1
18446744073709540355

Also appears when swapping -flto for -fwhole-program

Found via fuzzer

Reply via email to