From: Marek Polacek Date: Thu, 3 Mar 2016 11:42:19 +0000 (+0000) Subject: re PR middle-end/70050 (ICE: tree check: expected integer_type or enumeral_type or... X-Git-Tag: basepoints/gcc-7~608 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=a2a743a13a0a32b6ac147762707d95aacd1f605a;p=thirdparty%2Fgcc.git re PR middle-end/70050 (ICE: tree check: expected integer_type or enumeral_type or boolean_type or real_type or fixed_point_type, have vector_type in generic_simplify_162, at generic-match.c:6175) PR middle-end/70050 * match.pd (X % -Y): Add INTEGRAL_TYPE_P check. * gcc.dg/pr70050.c: New test. From-SVN: r233937 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index e232f5294261..c7b8c172c77b 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2016-03-03 Marek Polacek + + PR middle-end/70050 + * match.pd (X % -Y): Add INTEGRAL_TYPE_P check. + 2016-03-03 Martin Liska PR tree-optimization/70043 diff --git a/gcc/match.pd b/gcc/match.pd index 590378250c32..112deb3abbd8 100644 --- a/gcc/match.pd +++ b/gcc/match.pd @@ -293,7 +293,8 @@ DEFINE_INT_AND_FLOAT_ROUND_FN (RINT) /* X % -Y is the same as X % Y. */ (simplify (trunc_mod @0 (convert? (negate @1))) - (if (!TYPE_UNSIGNED (type) + (if (INTEGRAL_TYPE_P (type) + && !TYPE_UNSIGNED (type) && !TYPE_OVERFLOW_TRAPS (type) && tree_nop_conversion_p (type, TREE_TYPE (@1)) /* Avoid this transformation if X might be INT_MIN or diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 875de1a5fb4e..9949f9c11ff8 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2016-03-03 Marek Polacek + + PR middle-end/70050 + * gcc.dg/pr70050.c: New test. + 2016-03-03 James Greenhalgh * gcc.dg/vect/bb-slp-34.c: Don't XFAIL for ARM/AArch64. diff --git a/gcc/testsuite/gcc.dg/pr70050.c b/gcc/testsuite/gcc.dg/pr70050.c new file mode 100644 index 000000000000..feedd3f31a02 --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr70050.c @@ -0,0 +1,11 @@ +/* PR middle-end/70025 */ +/* { dg-do compile } */ +/* { dg-options "-Wno-psabi" } */ + +typedef int v8si __attribute__ ((vector_size (32))); + +v8si +foo (v8si v) +{ + return v %= -v; +}