On Mon, 23 Sep 2024, Tamar Christina wrote:
> I had made the condition to strict before, here's an updated patch:
>
> Hi All,
>
> The previous check if a value was external was checking
> !vect_get_internal_def (vinfo, var) but this of course isn't completely right
> as they could reductions etc.
>
> This changes the check to just explicitly look at externals and constants.
> Note that reductions remain unhandled here, but we don't support codegen of
> boolean reductions today anyway.
Can you explain how you get to see constant/external defs with a
stmt_vec_info? That's somehow a violation of some inherent
invariant in the vectorizer.
Richard.
> So at the time we do then this would have the be handled as well in lowering.
>
> Bootstrapped Regtested on aarch64-none-linux-gnu, arm-none-linux-gnueabihf,
> x86_64-pc-linux-gnu -m32, -m64 and no issues.
>
> Ok for master?
>
> Thanks,
> Tamar
>
> gcc/ChangeLog:
>
> PR tree-optimization/116817
> * tree-vect-patterns.cc (vect_recog_bool_pattern): Check for const or
> externals.
>
> gcc/testsuite/ChangeLog:
>
> PR tree-optimization/116817
> * g++.dg/vect/pr116817.cc: New test.
>
> -- inline copy of patch --
>
> diff --git a/gcc/testsuite/g++.dg/vect/pr116817.cc
> b/gcc/testsuite/g++.dg/vect/pr116817.cc
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..7e28982fb138c2cccc4f956aedb03fa454d9d858
> --- /dev/null
> +++ b/gcc/testsuite/g++.dg/vect/pr116817.cc
> @@ -0,0 +1,16 @@
> +/* { dg-do compile } */
> +/* { dg-additional-options "-O3" } */
> +
> +int main_ulData0;
> +unsigned *main_pSrcBuffer;
> +int main(void) {
> + int iSrc = 0;
> + bool bData0;
> + for (; iSrc < 4; iSrc++) {
> + if (bData0)
> + main_pSrcBuffer[iSrc] = main_ulData0;
> + else
> + main_pSrcBuffer[iSrc] = 0;
> + bData0 = !bData0;
> + }
> +}
> diff --git a/gcc/tree-vect-patterns.cc b/gcc/tree-vect-patterns.cc
> index
> e7e877dd2adb55262822f1660f8d92b42d44e6d0..f0298b2ab97a1e7dd0d943340e1389c3c0fa796e
> 100644
> --- a/gcc/tree-vect-patterns.cc
> +++ b/gcc/tree-vect-patterns.cc
> @@ -6062,12 +6062,15 @@ vect_recog_bool_pattern (vec_info *vinfo,
> if (get_vectype_for_scalar_type (vinfo, type) == NULL_TREE)
> return NULL;
>
> + stmt_vec_info var_def_info = vinfo->lookup_def (var);
> if (check_bool_pattern (var, vinfo, bool_stmts))
> var = adjust_bool_stmts (vinfo, bool_stmts, type, stmt_vinfo);
> else if (integer_type_for_mask (var, vinfo))
> return NULL;
> else if (TREE_CODE (TREE_TYPE (var)) == BOOLEAN_TYPE
> - && !vect_get_internal_def (vinfo, var))
> + && (!var_def_info
> + || STMT_VINFO_DEF_TYPE (var_def_info) == vect_external_def
> + || STMT_VINFO_DEF_TYPE (var_def_info) == vect_constant_def))
> {
> /* If the condition is already a boolean then manually convert it to a
> mask of the given integer type but don't set a vectype. */
>
--
Richard Biener <[email protected]>
SUSE Software Solutions Germany GmbH,
Frankenstrasse 146, 90461 Nuernberg, Germany;
GF: Ivo Totev, Andrew McDonald, Werner Knoblich; (HRB 36809, AG Nuernberg)