aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarc Glisse <marc.glisse@inria.fr>2013-05-16 12:26:51 +0200
committerMarc Glisse <glisse@gcc.gnu.org>2013-05-16 10:26:51 +0000
commit43bb4dd14d015211a19ccd8c1802cc7e1361d8b7 (patch)
tree9493047601849c95b5770ec075bca0b02745c32d
parent3571dde6ea6bd573390e1b3e91a646c572b6587e (diff)
downloadgcc-43bb4dd14d015211a19ccd8c1802cc7e1361d8b7.zip
gcc-43bb4dd14d015211a19ccd8c1802cc7e1361d8b7.tar.gz
gcc-43bb4dd14d015211a19ccd8c1802cc7e1361d8b7.tar.bz2
re PR middle-end/57286 (infinite recursion in fold-const.c:10037)
2013-05-16 Marc Glisse <marc.glisse@inria.fr> PR middle-end/57286 gcc/ * fold-const.c (fold_ternary_loc) <VEC_COND_EXPR>: Disable some transformations to avoid an infinite loop. gcc/testsuite/ * gcc.dg/pr57286.c: New testcase. * gcc.dg/vector-shift-2.c: Don't assume int has size 4. * g++.dg/ext/vector22.C: Comment out transformations not performed anymore. From-SVN: r198964
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/fold-const.c6
-rw-r--r--gcc/testsuite/ChangeLog8
-rw-r--r--gcc/testsuite/g++.dg/ext/vector22.C4
-rw-r--r--gcc/testsuite/gcc.dg/pr57286.c7
-rw-r--r--gcc/testsuite/gcc.dg/vector-shift-2.c2
6 files changed, 31 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index a54dcec..3a0929c 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2013-05-16 Marc Glisse <marc.glisse@inria.fr>
+
+ PR middle-end/57286
+ * fold-const.c (fold_ternary_loc) <VEC_COND_EXPR>: Disable some
+ transformations to avoid an infinite loop.
+
2013-05-16 Marek Polacek <polacek@redhat.com>
* tree-scalar-evolution.c (scev_const_prop): Add more dumps.
diff --git a/gcc/fold-const.c b/gcc/fold-const.c
index e02f0c6..97b5216 100644
--- a/gcc/fold-const.c
+++ b/gcc/fold-const.c
@@ -14211,6 +14211,12 @@ fold_ternary_loc (location_t loc, enum tree_code code, tree type,
fold_convert_loc (loc, type,
TREE_OPERAND (arg0, 0)));
+ /* Disable the transformations below for vectors, since
+ fold_binary_op_with_conditional_arg may undo them immediately,
+ yielding an infinite loop. */
+ if (code == VEC_COND_EXPR)
+ return NULL_TREE;
+
/* Convert A ? B : 0 into A && B if A and B are truth values. */
if (integer_zerop (op2)
&& truth_value_p (TREE_CODE (arg0))
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index e608612..6ec937c 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,11 @@
+2013-05-16 Marc Glisse <marc.glisse@inria.fr>
+
+ PR middle-end/57286
+ * gcc.dg/pr57286.c: New testcase.
+ * gcc.dg/vector-shift-2.c: Don't assume int has size 4.
+ * g++.dg/ext/vector22.C: Comment out transformations not
+ performed anymore.
+
2013-05-15 Richard Sandiford <rdsandiford@googlemail.com>
PR target/57260
diff --git a/gcc/testsuite/g++.dg/ext/vector22.C b/gcc/testsuite/g++.dg/ext/vector22.C
index ab569c7..47f64e7 100644
--- a/gcc/testsuite/g++.dg/ext/vector22.C
+++ b/gcc/testsuite/g++.dg/ext/vector22.C
@@ -3,13 +3,15 @@
typedef unsigned vec __attribute__((vector_size(4*sizeof(int))));
+/* Disabled after PR57286
void f(vec*a,vec*b){
*a=(*a)?-1:(*b<10);
*b=(*b)?(*a<10):0;
}
+*/
void g(vec*a,vec*b){
*a=(*a)?(*a<*a):-1;
- *b=(*b)?-1:(*b<*b);
+// *b=(*b)?-1:(*b<*b);
}
void h(vec*a){
*a=(~*a==5);
diff --git a/gcc/testsuite/gcc.dg/pr57286.c b/gcc/testsuite/gcc.dg/pr57286.c
new file mode 100644
index 0000000..c6f4530
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr57286.c
@@ -0,0 +1,7 @@
+/* { dg-do compile } */
+/* { dg-options "-O" } */
+
+typedef int vec __attribute__ ((vector_size (4*sizeof(int))));
+void f (vec *x){
+ *x = (*x < 0) | 1;
+}
diff --git a/gcc/testsuite/gcc.dg/vector-shift-2.c b/gcc/testsuite/gcc.dg/vector-shift-2.c
index 14fff12..380f2df 100644
--- a/gcc/testsuite/gcc.dg/vector-shift-2.c
+++ b/gcc/testsuite/gcc.dg/vector-shift-2.c
@@ -1,7 +1,7 @@
/* { dg-do compile } */
/* { dg-options "-O -fdump-tree-ccp1" } */
-typedef unsigned vec __attribute__ ((vector_size (16)));
+typedef unsigned vec __attribute__ ((vector_size (4*sizeof(int))));
void
f (vec *a)
{