On Fri, Dec 22, 2017 at 04:18:05PM +0100, Martin Liška wrote:
> In order to fix the PR, I save temporary expression to a SSA_NAME that
> is then used in the gcall.

You need to do that only if (!is_gimple_val (arg1_len)).
Can you please emit the additional stmt only if that isn't true?

> --- a/gcc/tree-ssa-strlen.c
> +++ b/gcc/tree-ssa-strlen.c
> @@ -3005,12 +3005,17 @@ fold_strstr_to_strncmp (tree rhs1, tree rhs2, gimple 
> *stmt)
>           {
>             gimple_stmt_iterator gsi = gsi_for_stmt (call_stmt);
>             tree strncmp_decl = builtin_decl_explicit (BUILT_IN_STRNCMP);
> +
> +           tree arg1_len_tmp = make_ssa_name (TREE_TYPE (arg1_len));
> +           gassign *arg1_stmt = gimple_build_assign (arg1_len_tmp, arg1_len);
>             gcall *strncmp_call = gimple_build_call (strncmp_decl, 3,
> -                                                   arg0, arg1, arg1_len);
> +                                                   arg0, arg1,
> +                                                   arg1_len_tmp);
>             tree strncmp_lhs = make_ssa_name (integer_type_node);
>             gimple_set_vuse (strncmp_call, gimple_vuse (call_stmt));
>             gimple_call_set_lhs (strncmp_call, strncmp_lhs);
>             gsi_remove (&gsi, true);
> +           gsi_insert_before (&gsi, arg1_stmt, GSI_SAME_STMT);
>             gsi_insert_before (&gsi, strncmp_call, GSI_SAME_STMT);
>             tree zero = build_zero_cst (TREE_TYPE (strncmp_lhs));
>  
> 


        Jakub

Reply via email to