aboutsummaryrefslogtreecommitdiff
path: root/gcc/c
diff options
context:
space:
mode:
authorMarek Polacek <polacek@redhat.com>2016-03-04 13:26:25 +0000
committerMarek Polacek <mpolacek@gcc.gnu.org>2016-03-04 13:26:25 +0000
commit7ff6ca3899e0cae8460f7dc30770002559bc0553 (patch)
tree4ca9771c72769236beaba3b26955cd20839b2e53 /gcc/c
parenta6bf62d5f85e91c7545bfc5cf2f8a5364814423b (diff)
downloadgcc-7ff6ca3899e0cae8460f7dc30770002559bc0553.zip
gcc-7ff6ca3899e0cae8460f7dc30770002559bc0553.tar.gz
gcc-7ff6ca3899e0cae8460f7dc30770002559bc0553.tar.bz2
re PR c/69798 (ICE on invalid code on x86_64-linux-gnu in c_parser_braced_init, at c/c-parser.c:4338)
PR c/69798 * c-parser.c (c_parser_postfix_expression): Call c_parser_cast_expression rather than c_parser_postfix_expression. * gcc.dg/cilk-plus/pr69798-1.c: New test. * gcc.dg/cilk-plus/pr69798-2.c: New test. From-SVN: r233965
Diffstat (limited to 'gcc/c')
-rw-r--r--gcc/c/ChangeLog6
-rw-r--r--gcc/c/c-parser.c10
2 files changed, 11 insertions, 5 deletions
diff --git a/gcc/c/ChangeLog b/gcc/c/ChangeLog
index 004d7c5..1fe4f82 100644
--- a/gcc/c/ChangeLog
+++ b/gcc/c/ChangeLog
@@ -1,3 +1,9 @@
+2016-03-04 Marek Polacek <polacek@redhat.com>
+
+ PR c/69798
+ * c-parser.c (c_parser_postfix_expression): Call
+ c_parser_cast_expression rather than c_parser_postfix_expression.
+
2016-03-01 Jakub Jelinek <jakub@redhat.com>
PR c/69796
diff --git a/gcc/c/c-parser.c b/gcc/c/c-parser.c
index bb508b7..a7d5827 100644
--- a/gcc/c/c-parser.c
+++ b/gcc/c/c-parser.c
@@ -8024,8 +8024,8 @@ c_parser_postfix_expression (c_parser *parser)
{
error_at (loc, "-fcilkplus must be enabled to use "
"%<_Cilk_spawn%>");
- expr = c_parser_postfix_expression (parser);
- expr.value = error_mark_node;
+ expr = c_parser_cast_expression (parser, NULL);
+ expr.value = error_mark_node;
}
else if (c_parser_peek_token (parser)->keyword == RID_CILK_SPAWN)
{
@@ -8034,14 +8034,14 @@ c_parser_postfix_expression (c_parser *parser)
/* Now flush out all the _Cilk_spawns. */
while (c_parser_peek_token (parser)->keyword == RID_CILK_SPAWN)
c_parser_consume_token (parser);
- expr = c_parser_postfix_expression (parser);
+ expr = c_parser_cast_expression (parser, NULL);
}
else
{
- expr = c_parser_postfix_expression (parser);
+ expr = c_parser_cast_expression (parser, NULL);
expr.value = build_cilk_spawn (loc, expr.value);
}
- break;
+ break;
default:
c_parser_error (parser, "expected expression");
expr.value = error_mark_node;