aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2010-12-06 12:53:38 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2010-12-06 12:53:38 +0000
commitbbb9d2fd5c8f15120726b3da90f539dc25f509f5 (patch)
tree902219551516779dc5bb68148baa49a73d5f026b /gcc
parent6b7fb143ae06d180ae7723c41664db4a1f1d11d0 (diff)
downloadgcc-bbb9d2fd5c8f15120726b3da90f539dc25f509f5.zip
gcc-bbb9d2fd5c8f15120726b3da90f539dc25f509f5.tar.gz
gcc-bbb9d2fd5c8f15120726b3da90f539dc25f509f5.tar.bz2
re PR tree-optimization/46806 (-O3 implies 0 <= 8 <= 7)
2010-12-06 Richard Guenther <rguenther@suse.de> PR tree-optimization/46806 * tree-ssa-copyrename.c (copy_rename_partition_coalesce): Do not coalesce different types. * g++.dg/torture/20100825.C: New testcase. From-SVN: r167490
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/torture/20100825.C15
-rw-r--r--gcc/tree-ssa-copyrename.c6
4 files changed, 29 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index ccb7019..f01b9fe 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,5 +1,11 @@
2010-12-06 Richard Guenther <rguenther@suse.de>
+ PR tree-optimization/46806
+ * tree-ssa-copyrename.c (copy_rename_partition_coalesce): Do not
+ coalesce different types.
+
+2010-12-06 Richard Guenther <rguenther@suse.de>
+
PR tree-optimization/46785
* tree-vect-loop.c (vect_is_simple_reduction_1): Also allow
call statements as operand definition.
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 600655d..5c3b697 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,10 @@
2010-12-06 Richard Guenther <rguenther@suse.de>
+ PR tree-optimization/46806
+ * g++.dg/torture/20100825.C: New testcase.
+
+2010-12-06 Richard Guenther <rguenther@suse.de>
+
PR tree-optimization/46785
* gcc.dg/vect/fast-math-vect-reduc-9.c: New testcase.
diff --git a/gcc/testsuite/g++.dg/torture/20100825.C b/gcc/testsuite/g++.dg/torture/20100825.C
new file mode 100644
index 0000000..460c1b6
--- /dev/null
+++ b/gcc/testsuite/g++.dg/torture/20100825.C
@@ -0,0 +1,15 @@
+// { dg-do run }
+
+typedef enum { zero = 0, one = 1, two = 2, ENUM_MAX = 3 } my_enum;
+my_enum e;
+extern "C" void abort (void);
+int __attribute__((noinline)) foo() { return 10; }
+int main()
+{
+ int r;
+ r = foo();
+ if ((r < 0) || (r >= ENUM_MAX))
+ return 0;
+ e = (my_enum)r;
+ abort ();
+}
diff --git a/gcc/tree-ssa-copyrename.c b/gcc/tree-ssa-copyrename.c
index 41d43a6..abee6b9 100644
--- a/gcc/tree-ssa-copyrename.c
+++ b/gcc/tree-ssa-copyrename.c
@@ -226,11 +226,11 @@ copy_rename_partition_coalesce (var_map map, tree var1, tree var2, FILE *debug)
ign2 = false;
}
- /* Don't coalesce if the two variables aren't type compatible. */
- if (!types_compatible_p (TREE_TYPE (root1), TREE_TYPE (root2)))
+ /* Don't coalesce if the two variables are not of the same type. */
+ if (TREE_TYPE (root1) != TREE_TYPE (root2))
{
if (debug)
- fprintf (debug, " : Incompatible types. No coalesce.\n");
+ fprintf (debug, " : Different types. No coalesce.\n");
return false;
}