+2016-04-15 Marek Polacek <polacek@redhat.com>
+
+ PR c/70651
+ * c-common.c (build_va_arg): Change two asserts into errors and return
+ error_mark_node.
+
2016-04-13 Marek Polacek <polacek@redhat.com>
PR c++/70639
/* Verify that &ap is still recognized as having va_list type. */
tree canon_expr_type
= targetm.canonical_va_list_type (TREE_TYPE (expr));
- gcc_assert (canon_expr_type != NULL_TREE);
+ if (canon_expr_type == NULL_TREE)
+ {
+ error_at (loc,
+ "first argument to %<va_arg%> not of type %<va_list%>");
+ return error_mark_node;
+ }
return build_va_arg_1 (loc, type, expr);
}
/* Verify that &ap is still recognized as having va_list type. */
tree canon_expr_type
= targetm.canonical_va_list_type (TREE_TYPE (expr));
- gcc_assert (canon_expr_type != NULL_TREE);
+ if (canon_expr_type == NULL_TREE)
+ {
+ error_at (loc,
+ "first argument to %<va_arg%> not of type %<va_list%>");
+ return error_mark_node;
+ }
}
else
{
+2016-04-15 Marek Polacek <polacek@redhat.com>
+
+ PR c/70651
+ * c-c++-common/pr70651.c: New test.
+
2016-04-15 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
PR rtl-optimization/70681