aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2019-03-21 14:27:32 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2019-03-21 14:27:32 +0000
commit6d1a7fd4507f94d5ba1ac3216330280a4751a599 (patch)
tree18b7ef21746ac24ef6c1d79d6e6d37f58ce0d026
parente2186cd88ed9015ad0cd6f265daa164648d30f74 (diff)
downloadgcc-6d1a7fd4507f94d5ba1ac3216330280a4751a599.zip
gcc-6d1a7fd4507f94d5ba1ac3216330280a4751a599.tar.gz
gcc-6d1a7fd4507f94d5ba1ac3216330280a4751a599.tar.bz2
re PR middle-end/89779 (internal compiler error: tree check: expected class ‘type’, have ‘exceptional’ (error_mark) in tree_nop_conversion_p, at tree.c:12798)
2019-03-21 Richard Biener <rguenther@suse.de> PR tree-optimization/89779 * tree.c (tree_nop_conversion): Consolidate and fix defensive checks with respect to released SSA names now having error_mark_node type. * fold-const.c (operand_equal_p): Likewise. * gcc.dg/torture/pr89779.c: New testcase. From-SVN: r269838
-rw-r--r--gcc/ChangeLog8
-rw-r--r--gcc/fold-const.c5
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/torture/pr89779.c20
-rw-r--r--gcc/tree.c5
5 files changed, 34 insertions, 9 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 7774af8..717e2f2 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,11 @@
+2019-03-21 Richard Biener <rguenther@suse.de>
+
+ PR tree-optimization/89779
+ * tree.c (tree_nop_conversion): Consolidate and fix defensive
+ checks with respect to released SSA names now having error_mark_node
+ type.
+ * fold-const.c (operand_equal_p): Likewise.
+
2019-03-20 Andreas Krebbel <krebbel@linux.ibm.com>
PR target/89775
diff --git a/gcc/fold-const.c b/gcc/fold-const.c
index ec28b43..86ad2cb 100644
--- a/gcc/fold-const.c
+++ b/gcc/fold-const.c
@@ -2973,11 +2973,6 @@ operand_equal_p (const_tree arg0, const_tree arg1, unsigned int flags)
|| TREE_TYPE (arg1) == error_mark_node)
return 0;
- /* Similar, if either does not have a type (like a released SSA name),
- they aren't equal. */
- if (!TREE_TYPE (arg0) || !TREE_TYPE (arg1))
- return 0;
-
/* We cannot consider pointers to different address space equal. */
if (POINTER_TYPE_P (TREE_TYPE (arg0))
&& POINTER_TYPE_P (TREE_TYPE (arg1))
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 5a343b6..c8f9492 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2019-03-21 Richard Biener <rguenther@suse.de>
+
+ PR tree-optimization/89779
+ * gcc.dg/torture/pr89779.c: New testcase.
+
2019-03-21 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/78645
diff --git a/gcc/testsuite/gcc.dg/torture/pr89779.c b/gcc/testsuite/gcc.dg/torture/pr89779.c
new file mode 100644
index 0000000..2a9d240
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/torture/pr89779.c
@@ -0,0 +1,20 @@
+/* { dg-do compile } */
+
+typedef int a;
+void h(a);
+void c(a *d, int b)
+{
+ int e, f, g;
+ for (; e; e++)
+ for (f = 0; f < 4; f++)
+ if (d)
+ for (g = e + 1; g; g++)
+ h(d[g]);
+}
+void i()
+{
+ a *j;
+ int k, l;
+ for (; k; k++)
+ c(j, l);
+}
diff --git a/gcc/tree.c b/gcc/tree.c
index 8ea4251..ae8ff08 100644
--- a/gcc/tree.c
+++ b/gcc/tree.c
@@ -12812,13 +12812,10 @@ tree_nop_conversion (const_tree exp)
if (!CONVERT_EXPR_P (exp)
&& TREE_CODE (exp) != NON_LVALUE_EXPR)
return false;
- if (TREE_OPERAND (exp, 0) == error_mark_node)
- return false;
outer_type = TREE_TYPE (exp);
inner_type = TREE_TYPE (TREE_OPERAND (exp, 0));
-
- if (!inner_type)
+ if (!inner_type || inner_type == error_mark_node)
return false;
return tree_nop_conversion_p (outer_type, inner_type);