aboutsummaryrefslogtreecommitdiff
path: root/gcc/c
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2020-12-09 09:56:59 +0100
committerRichard Biener <rguenther@suse.de>2020-12-09 11:45:48 +0100
commit42bdf814493c2c39e7a6bd3fb2dd4491352ce5d9 (patch)
treeb6bb740b240055a5fe54dc9f89de1433ee1e280d /gcc/c
parent1cb2d1d5ce178cb68f0bd475299d2e0b25a4a756 (diff)
downloadgcc-42bdf814493c2c39e7a6bd3fb2dd4491352ce5d9.zip
gcc-42bdf814493c2c39e7a6bd3fb2dd4491352ce5d9.tar.gz
gcc-42bdf814493c2c39e7a6bd3fb2dd4491352ce5d9.tar.bz2
c/98200 - improve error recovery for GIMPLE FE
This avoids ICEing by making sure to propagate error early. 2020-12-09 Richard Biener <rguenther@suse.de> PR c/98200 gcc/c/ * gimple-parser.c (c_parser_gimple_postfix_expression): Return early on error. gcc/testsuite/ * gcc.dg/gimplefe-error-8.c: New testcase.
Diffstat (limited to 'gcc/c')
-rw-r--r--gcc/c/gimple-parser.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/gcc/c/gimple-parser.c b/gcc/c/gimple-parser.c
index 5c0ed82..473cb90 100644
--- a/gcc/c/gimple-parser.c
+++ b/gcc/c/gimple-parser.c
@@ -1700,6 +1700,8 @@ c_parser_gimple_postfix_expression (gimple_parser &parser)
expr.set_error ();
break;
}
+ if (expr.value == error_mark_node)
+ return expr;
return c_parser_gimple_postfix_expression_after_primary
(parser, EXPR_LOC_OR_LOC (expr.value, loc), expr);
}