middle-end: replace GET_MODE_WIDER_MODE with GET_MODE_NEXT_MODE

After the fix to the addsub patch yesterday for bootstrap I had only regtested on x86.
While looking today it seemed the new tests were failing, this was caused
by a change in the behavior of the GET_MODE_WIDER_MODE macro on trunk.

gcc/ChangeLog:

	* match.pd: Replace GET_MODE_WIDER_MODE with
	custom code.
This commit is contained in:
Tamar Christina 2022-11-17 08:14:44 +00:00
parent 2b2f2ee49a
commit 1bc7efa948

View File

@ -7940,12 +7940,15 @@ and,
vec_perm_indices sel (builder, 2, nelts);
machine_mode vec_mode = TYPE_MODE (type);
machine_mode wide_mode;
scalar_mode wide_elt_mode;
poly_uint64 wide_nunits;
scalar_mode inner_mode = GET_MODE_INNER (vec_mode);
}
(if (sel.series_p (0, 2, 0, 2)
&& GET_MODE_WIDER_MODE (vec_mode).exists (&wide_mode)
&& VECTOR_MODE_P (wide_mode)
&& (GET_MODE_UNIT_BITSIZE (vec_mode) * 2
== GET_MODE_UNIT_BITSIZE (wide_mode)))
&& GET_MODE_2XWIDER_MODE (inner_mode).exists (&wide_elt_mode)
&& multiple_p (GET_MODE_NUNITS (vec_mode), 2, &wide_nunits)
&& related_vector_mode (vec_mode, wide_elt_mode,
wide_nunits).exists (&wide_mode))
(with
{
tree stype