https://gcc.gnu.org/bugzilla/show_bug.cgi?id=111492
Bug ID: 111492 Summary: RISC-V: Dynamic LMUL picking incorrect LMUL Product: gcc Version: 14.0 Status: UNCONFIRMED Severity: normal Priority: P3 Component: c Assignee: unassigned at gcc dot gnu.org Reporter: juzhe.zhong at rivai dot ai Target Milestone: --- #include <stdbool.h> #include <assert.h> struct A { unsigned int a; unsigned char c1, c2; bool b1 : 1; bool b2 : 1; bool b3 : 1; }; void foo (const struct A *x, int y) { int s = 0, i; for (i = 0; i < y; ++i) { const struct A a = x[i]; s += a.b1 ? 1 : 0; } assert (s == 0); //__builtin_abort (); } int main () { struct A x[100]; int i; __builtin_memset (x, -1, sizeof (x)); for (i = 0; i < 100; i++) { x[i].b1 = false; x[i].b2 = false; x[i].b3 = false; } foo (x, 100); return 0; } --param=riscv-autovec-lmul=dynamic. Pick LMUL = 8 incorrectly which cause horrible register spillings.