"Kewen.Lin" <li...@linux.ibm.com> writes:
> Hi,
>
> Commit r14-2267-gb8806f6ffbe72e adjusts the arguments order
> of LEN_STORE from {len,vector,bias} to {len,bias,vector},
> in order to make them consistent with LEN_MASK_STORE and
> MASK_STORE.  But it missed to update the related handlings
> in tree-ssa-sccvn.cc, it caused the failure shown in PR
> 110744.  This patch is to fix the related handlings with
> the correct index.
>
> Bootstrapped and regress-tested on x86_64-redhat-linux,
> powerpc64-linux-gnu P8/P9 and powerpc64le-linux-gnu P9/P10.
>
> Is it ok for trunk?
>
> BR,
> Kewen
> -----
>       PR tree-optimization/110744
>
> gcc/ChangeLog:
>
>       * tree-ssa-sccvn.cc (vn_reference_lookup_3): Correct the index of bias
>       operand for ifn IFN_LEN_STORE.

OK, thanks.

Richard

> ---
>  gcc/tree-ssa-sccvn.cc | 13 ++++++++-----
>  1 file changed, 8 insertions(+), 5 deletions(-)
>
> diff --git a/gcc/tree-ssa-sccvn.cc b/gcc/tree-ssa-sccvn.cc
> index 11061a374a2..c0b3ec420c5 100644
> --- a/gcc/tree-ssa-sccvn.cc
> +++ b/gcc/tree-ssa-sccvn.cc
> @@ -3299,11 +3299,14 @@ vn_reference_lookup_3 (ao_ref *ref, tree vuse, void 
> *data_,
>           return (void *)-1;
>         break;
>       case IFN_LEN_STORE:
> -       len = gimple_call_arg (call, 2);
> -       bias = gimple_call_arg (call, 4);
> -       if (!tree_fits_uhwi_p (len) || !tree_fits_shwi_p (bias))
> -         return (void *)-1;
> -       break;
> +       {
> +         int len_index = internal_fn_len_index (fn);
> +         len = gimple_call_arg (call, len_index);
> +         bias = gimple_call_arg (call, len_index + 1);
> +         if (!tree_fits_uhwi_p (len) || !tree_fits_shwi_p (bias))
> +           return (void *) -1;
> +         break;
> +       }
>       default:
>         return (void *)-1;
>       }
> --
> 2.39.3

Reply via email to