aboutsummaryrefslogtreecommitdiff
path: root/gcc/c/c-decl.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2021-04-10 17:01:54 +0200
committerJakub Jelinek <jakub@redhat.com>2021-04-10 17:01:54 +0200
commit9f7d77bd6d65aa1cf2e195d3776052705c6e636b (patch)
tree432dd2899823346bfeafa314486c445e3c5ef9a8 /gcc/c/c-decl.c
parent0344b5b822b310921a432b9ffcb9ea0b3964820d (diff)
downloadgcc-9f7d77bd6d65aa1cf2e195d3776052705c6e636b.zip
gcc-9f7d77bd6d65aa1cf2e195d3776052705c6e636b.tar.gz
gcc-9f7d77bd6d65aa1cf2e195d3776052705c6e636b.tar.bz2
c: Avoid clobbering TREE_TYPE (error_mark_node) [PR99990]
The following testcase ICEs during error recovery, because finish_decl overwrites TREE_TYPE (error_mark_node), which better should stay always to be error_mark_node. 2021-04-10 Jakub Jelinek <jakub@redhat.com> PR c/99990 * c-decl.c (finish_decl): Don't overwrite TREE_TYPE of error_mark_node. * gcc.dg/pr99990.c: New test.
Diffstat (limited to 'gcc/c/c-decl.c')
-rw-r--r--gcc/c/c-decl.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/gcc/c/c-decl.c b/gcc/c/c-decl.c
index 3b2241b..3c25451 100644
--- a/gcc/c/c-decl.c
+++ b/gcc/c/c-decl.c
@@ -5402,7 +5402,7 @@ finish_decl (tree decl, location_t init_loc, tree init,
gcc_unreachable ();
}
- if (DECL_INITIAL (decl))
+ if (DECL_INITIAL (decl) && DECL_INITIAL (decl) != error_mark_node)
TREE_TYPE (DECL_INITIAL (decl)) = type;
relayout_decl (decl);