From: Richard Biener Date: Tue, 12 Oct 2021 11:49:39 +0000 (+0200) Subject: tree-optimization/102696 - fix SLP discovery for failed BIT_FIELD_REF X-Git-Tag: basepoints/gcc-13~3962 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=d1dcaa31453fa080a27938b064e53f02272d4aa1;p=thirdparty%2Fgcc.git tree-optimization/102696 - fix SLP discovery for failed BIT_FIELD_REF This fixes a forgotten adjustment of matches[] when we fail SLP discovery. 2021-10-12 Richard Biener PR tree-optimization/102696 * tree-vect-slp.c (vect_build_slp_tree_2): Properly mark the tree fatally failed when we reject a BIT_FIELD_REF. * g++.dg/vect/pr102696.cc: New testcase. --- diff --git a/gcc/testsuite/g++.dg/vect/pr102696.cc b/gcc/testsuite/g++.dg/vect/pr102696.cc new file mode 100644 index 000000000000..5560354304a7 --- /dev/null +++ b/gcc/testsuite/g++.dg/vect/pr102696.cc @@ -0,0 +1,16 @@ +// { dg-do compile } +// { dg-additional-options "-O3" } +// { dg-additional-options "-march=skylake-avx512" { target x86_64-*-* i?86-*-* } } + +int a; +extern bool b[][14]; +char h; +void f(short g[][14]) +{ + for (short d = h; d < 21; d += 1) + for (unsigned char e = 0; e < 14; e += 1) + { + a = 0; + b[d][e] = g[d][e]; + } +} diff --git a/gcc/tree-vect-slp.c b/gcc/tree-vect-slp.c index c70d06e5f20c..709bcb636864 100644 --- a/gcc/tree-vect-slp.c +++ b/gcc/tree-vect-slp.c @@ -1761,6 +1761,7 @@ vect_build_slp_tree_2 (vec_info *vinfo, slp_tree node, bit_field_size (bfref), &lane)) { lperm.release (); + matches[0] = false; return NULL; } lperm.safe_push (std::make_pair (0, (unsigned)lane));