On Tue, Sep 02, 2025 at 03:28:46PM +0200, Richard Biener wrote:
> On Tue, 2 Sep 2025, Jakub Jelinek wrote:
> 
> > On Tue, Sep 02, 2025 at 11:34:59AM +0200, Richard Biener wrote:
> > > 
> > > Oops, now also to the list.
> > 
> > If so, it needs to punt on anything that uses something more than once.
> > So, alg_add_factor and alg_sub_factor are always bad (so return NULL),
> > because they do use accumulator both in the PLUS/MINUS and LSHIFT.
> > alg_add_t2_m/alg_sub_t2_m/alg_shift if synth_shift_p
> > and alg.log[i], all in addition to what it has been doing before.
> 
> Like the following?

Yes.  LGTM.

>       PR tree-optimization/121753
>       * tree-vect-patterns.cc (vect_synth_mult_by_constant): Properly
>       bail when synth_shift_p and an alg_shift use.  Handle other
>       problematic cases.
> ---
>  gcc/tree-vect-patterns.cc | 7 +++++++
>  1 file changed, 7 insertions(+)
> 
> diff --git a/gcc/tree-vect-patterns.cc b/gcc/tree-vect-patterns.cc
> index 64a49cccc24..d0bf2f9e799 100644
> --- a/gcc/tree-vect-patterns.cc
> +++ b/gcc/tree-vect-patterns.cc
> @@ -4329,7 +4329,14 @@ vect_synth_mult_by_constant (vec_info *vinfo, tree op, 
> tree val,
>         case alg_add_t2_m:
>         case alg_sub_t2_m:
>           op_uses++;
> +         /* Fallthru.  */
> +       case alg_shift:
> +         if (synth_shift_p && alg.log[i])
> +           return NULL;
>           break;
> +       case alg_add_factor:
> +       case alg_sub_factor:
> +         return NULL;
>         default:
>           break;
>         }

        Jakub

Reply via email to