middle-end/110461 - pattern applying wrongly to vectors

The following guards a match.pd pattern that wasn't supposed to
apply to vectors and thus runs into TYPE_PRECISION checking.  For
vector support the constant case is lacking and the pattern would
have missing optab support checking for the result operation.

	PR middle-end/110461
	* match.pd (bitop (convert@2 @0) (convert?@3 @1)): Disable
	for VECTOR_TYPE_P.

	* gcc.dg/pr110461.c: New testcase.
This commit is contained in:
Richard Biener 2023-06-29 09:15:27 +02:00
parent d81c7a2536
commit 1e6f1659bd
2 changed files with 17 additions and 0 deletions

View file

@ -1853,6 +1853,7 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT)
|| tree_nop_conversion_p (TREE_TYPE (@0), type)))
|| types_match (@0, @1))
&& !POINTER_TYPE_P (TREE_TYPE (@0))
&& !VECTOR_TYPE_P (TREE_TYPE (@0))
&& TREE_CODE (TREE_TYPE (@0)) != OFFSET_TYPE
/* ??? This transform conflicts with fold-const.cc doing
Convert (T)(x & c) into (T)x & (T)c, if c is an integer

View file

@ -0,0 +1,16 @@
/* { dg-do compile } */
/* { dg-options "-O" } */
typedef int v4si __attribute__ ((vector_size (4*sizeof(int))));
typedef short v4hi __attribute__ ((vector_size (4*sizeof(short))));
v4hi res;
v4hi a, b;
void f(void)
{
v4si t = __builtin_convertvector (a, v4si);
v4si t1 = __builtin_convertvector (b, v4si);
t ^= t1;
res = __builtin_convertvector (t, v4hi);
}