https://gcc.gnu.org/bugzilla/show_bug.cgi?id=118727
--- Comment #6 from Xi Ruoyao <xry111 at gcc dot gnu.org> ---
Hmm now me the easiest way is just not to run
vect_look_through_possible_promotion:
diff --git a/gcc/tree-vect-patterns.cc b/gcc/tree-vect-patterns.cc
index 45fcec40a28..533f4816270 100644
--- a/gcc/tree-vect-patterns.cc
+++ b/gcc/tree-vect-patterns.cc
@@ -1407,7 +1407,7 @@ vect_recog_sad_pattern (vec_info *vinfo,
tree abd_oprnd0 = gimple_call_arg (abd_stmt, 0);
tree abd_oprnd1 = gimple_call_arg (abd_stmt, 1);
- if (gimple_call_internal_fn (abd_stmt) == IFN_ABD)
+ if (gimple_call_internal_fn (abd_stmt) == IFN_ABD/*)
{
if (!vect_look_through_possible_promotion (vinfo, abd_oprnd0,
&unprom[0])
@@ -1416,7 +1416,7 @@ vect_recog_sad_pattern (vec_info *vinfo,
return NULL;
abd_optype = TREE_TYPE (abd_oprnd0);
}
- else if (gimple_call_internal_fn (abd_stmt) == IFN_VEC_WIDEN_ABD)
+ else if (*/|| gimple_call_internal_fn (abd_stmt) == IFN_VEC_WIDEN_ABD)
{
unprom[0].op = abd_oprnd0;
unprom[0].type = TREE_TYPE (abd_oprnd0);
I cannot see any bad effect from this. I'll bootstrap it.