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

--- Comment #7 from Andrew Pinski <pinskia at gcc dot gnu.org> ---
GCC 9.3.0 says:
/app/example.cpp:19:18: missed:   can't use a fully-masked loop because the
target doesn't have the appropriate masked load or store.
/app/example.cpp:19:18: note:   vect_model_load_cost: aligned.
/app/example.cpp:19:18: note:   vect_model_load_cost: inside_cost = 2,
prologue_cost = 0 .
/app/example.cpp:19:18: note:   ==> examining statement: _2 = (unsigned int)
_24;
/app/example.cpp:19:18: note:   vect_is_simple_use: operand # VUSE <.MEM_12>
MEM[(long unsigned intD.17 *)SR.139_80 + 8B], type of def: internal
...

But GCC 9.4.0 says:
/app/example.cpp:19:18: missed:   not falling back to elementwise accesses
/app/example.cpp:20:49: missed:   not vectorized: relevant stmt not supported:
_24 = MEM[(long unsigned int *)SR.139_80 + 8B];
/app/example.cpp:19:18: missed:  bad operation or unsupported loop bound.
/app/example.cpp:19:18: missed: couldn't vectorize loop
/app/example.cpp:20:49: missed: not vectorized: relevant stmt not supported:
_24 = MEM[(long unsigned int *)SR.139_80 + 8B];
/app/example.cpp:9:1: note: vectorized 0 loops in function.

Reply via email to