diff options
| author | glisse <glisse@138bc75d-0d04-0410-961f-82ee72b054a4> | 2013-05-16 10:26:51 +0000 |
|---|---|---|
| committer | glisse <glisse@138bc75d-0d04-0410-961f-82ee72b054a4> | 2013-05-16 10:26:51 +0000 |
| commit | ea1b629e1679f508df9743680ac0eb3985ef48b5 (patch) | |
| tree | 9493047601849c95b5770ec075bca0b02745c32d | |
| parent | d70b714028b62982297ee5ebf8bfe6a572dc7fa3 (diff) | |
| download | ppe42-gcc-ea1b629e1679f508df9743680ac0eb3985ef48b5.tar.gz ppe42-gcc-ea1b629e1679f508df9743680ac0eb3985ef48b5.zip | |
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.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@198964 138bc75d-0d04-0410-961f-82ee72b054a4
| -rw-r--r-- | gcc/ChangeLog | 6 | ||||
| -rw-r--r-- | gcc/fold-const.c | 6 | ||||
| -rw-r--r-- | gcc/testsuite/ChangeLog | 8 | ||||
| -rw-r--r-- | gcc/testsuite/g++.dg/ext/vector22.C | 4 | ||||
| -rw-r--r-- | gcc/testsuite/gcc.dg/pr57286.c | 7 | ||||
| -rw-r--r-- | gcc/testsuite/gcc.dg/vector-shift-2.c | 2 |
6 files changed, 31 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index a54dceca35c..3a0929cd122 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 e02f0c60d9a..97b5216eb71 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 e608612d2d1..6ec937c4ad5 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 ab569c7dffa..47f64e7e7a7 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 00000000000..c6f45305487 --- /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 14fff121c5e..380f2dfb307 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) { |

