From: Richard Biener Date: Thu, 21 Mar 2019 14:27:32 +0000 (+0000) Subject: re PR middle-end/89779 (internal compiler error: tree check: expected class ‘type... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=6d1a7fd4507f94d5ba1ac3216330280a4751a599;p=gcc.git 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 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 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 7774af87862..717e2f21d96 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,11 @@ +2019-03-21 Richard Biener + + 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 PR target/89775 diff --git a/gcc/fold-const.c b/gcc/fold-const.c index ec28b431eb8..86ad2cb8487 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 5a343b667f1..c8f9492130e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2019-03-21 Richard Biener + + PR tree-optimization/89779 + * gcc.dg/torture/pr89779.c: New testcase. + 2019-03-21 Paolo Carlini 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 00000000000..2a9d240aa40 --- /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 8ea42512aa7..ae8ff085f95 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);