https://gcc.gnu.org/bugzilla/show_bug.cgi?id=114200
Bug ID: 114200 Summary: [14] RISC-V fixed-length vector miscompile at -O3 Product: gcc Version: 14.0 Status: UNCONFIRMED Severity: normal Priority: P3 Component: target Assignee: unassigned at gcc dot gnu.org Reporter: patrick at rivosinc dot com Target Milestone: --- Testcase: int printf(const char *, ...); short a, e = 1; _Bool b, d; short c[300]; int main() { for (int f = 0; f < 19; f++) { for (int g = 0; g < 14; g++) for (int h = 0; h < 10; h++) a += c[g] + e; b += d; } printf("%d\n", a); } Commands: > /scratch/tc-testing/tc-feb-20/build-rv64gcv/bin/riscv64-unknown-linux-gnu-gcc > -march=rv64gcv -O3 --param=riscv-autovec-preference=fixed-vlmax red.c -o > red.out > /scratch/tc-testing/tc-feb-20-llvm/build/bin/qemu-riscv64 red.out 2318 > /scratch/tc-testing/tc-feb-20/build-rv64gcv/bin/riscv64-unknown-linux-gnu-gcc > -march=rv64gcv -O2 --param=riscv-autovec-preference=fixed-vlmax red.c -o > red.out > /scratch/tc-testing/tc-feb-20-llvm/build/bin/qemu-riscv64 red.out 2660 Tested/found using r14-9084-g61ab046a327 (not bisected) Found using fuzzer