https://gcc.gnu.org/g:9fd86361676064a06ed61d4e7ae82492a14185a3

commit r15-4694-g9fd86361676064a06ed61d4e7ae82492a14185a3
Author: Richard Biener <rguent...@suse.de>
Date:   Fri Oct 25 14:20:23 2024 +0200

    Finish vectorizer pattern proper COND_EXPR transition
    
    This fixes up vect_recog_ctz_ffs_pattern.
    
            * tree-vect-patterns.cc (vect_recog_ctz_ffs_pattern): Create
            a separate pattern stmt for the comparison in the generated
            COND_EXPR.

Diff:
---
 gcc/tree-vect-patterns.cc | 7 +++++--
 1 file changed, 5 insertions(+), 2 deletions(-)

diff --git a/gcc/tree-vect-patterns.cc b/gcc/tree-vect-patterns.cc
index d9fe49378583..46aa3129bb30 100644
--- a/gcc/tree-vect-patterns.cc
+++ b/gcc/tree-vect-patterns.cc
@@ -2072,8 +2072,11 @@ vect_recog_ctz_ffs_pattern (vec_info *vinfo, 
stmt_vec_info stmt_vinfo,
       tree ret_var = vect_recog_temp_ssa_var (lhs_type, NULL);
       rhs_oprnd = gimple_call_arg (call_stmt, 0);
       rhs_type = TREE_TYPE (rhs_oprnd);
-      tree cmp = build2_loc (loc, NE_EXPR, boolean_type_node,
-                            rhs_oprnd, build_zero_cst (rhs_type));
+      tree cmp = vect_recog_temp_ssa_var (boolean_type_node, NULL);
+      pattern_stmt = gimple_build_assign (cmp, NE_EXPR, rhs_oprnd,
+                                         build_zero_cst (rhs_type));
+      append_pattern_def_seq (vinfo, stmt_vinfo, pattern_stmt,
+                             truth_type_for (vec_type), rhs_type);
       pattern_stmt = gimple_build_assign (ret_var, COND_EXPR, cmp,
                                          new_var,
                                          build_int_cst (lhs_type, val));

Reply via email to