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

            Bug ID: 118931
           Summary: [15] RISC-V: rv64gcv miscompile at -O[23] since
                    r15-3228-g771256bcb9d
           Product: gcc
           Version: 15.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 m;
char f = 151;
char h = 103;
unsigned char a = 109;
int main() {
  for (char l = 0; l < 255 - 241; l += h - 102)
    a *= f;
  m = a;
  __builtin_printf("%llu\n", m);
}

Commands:
> /scratch/ewlu/daily-upstream-build/build-gcv/bin/riscv64-unknown-linux-gnu-gcc
>  -march=rv64gcv -flto -O3 -mrvv-vector-bits=zvl red.c -o red.out
> 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
>  /scratch/ewlu/daily-upstream-build/build-gcv/bin/qemu-riscv64 red.out 1
247

> /scratch/ewlu/daily-upstream-build/build-gcv/bin/riscv64-unknown-linux-gnu-gcc
>  -march=rv64gcv -flto -O2 -mrvv-vector-bits=zvl red.c -o red.out
> 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
>  /scratch/ewlu/daily-upstream-build/build-gcv/bin/qemu-riscv64 red.out 1
247

> /scratch/ewlu/daily-upstream-build/build-gcv/bin/riscv64-unknown-linux-gnu-gcc
>  -march=rv64gcv -flto -O1 -mrvv-vector-bits=zvl red.c -o red.out
> 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
>  /scratch/ewlu/daily-upstream-build/build-gcv/bin/qemu-riscv64 red.out 1
29

Looks like another latent bug exposed by costing more patterns.
x86 also outputs 29

Found via fuzzer

Reply via email to