From: Roger Sayle Date: Fri, 21 Jul 2023 19:37:59 +0000 (+0100) Subject: PR c/110699: Defend against error_mark_node in gimplify.cc. X-Git-Tag: basepoints/gcc-15~7418 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=cfe53af09364d94fb86013f85ef598a1d47e0657;p=thirdparty%2Fgcc.git PR c/110699: Defend against error_mark_node in gimplify.cc. This patch resolves PR c/110669, an ICE-after-error regression, by adding a check that the array type isn't error_mark_node in gimplify_compound_lval. 2023-07-21 Roger Sayle Richard Biener gcc/ChangeLog PR c/110699 * gimplify.cc (gimplify_compound_lval): If the array's type is error_mark_node then return GS_ERROR. gcc/testsuite/ChangeLog PR c/110699 * gcc.dg/pr110699.c: New test case. --- diff --git a/gcc/gimplify.cc b/gcc/gimplify.cc index 36e5df050b9c..320920ed74c0 100644 --- a/gcc/gimplify.cc +++ b/gcc/gimplify.cc @@ -3209,6 +3209,9 @@ gimplify_compound_lval (tree *expr_p, gimple_seq *pre_p, gimple_seq *post_p, { tree t = expr_stack[i]; + if (error_operand_p (TREE_OPERAND (t, 0))) + return GS_ERROR; + if (TREE_CODE (t) == ARRAY_REF || TREE_CODE (t) == ARRAY_RANGE_REF) { /* Deal with the low bound and element type size and put them into diff --git a/gcc/testsuite/gcc.dg/pr110699.c b/gcc/testsuite/gcc.dg/pr110699.c new file mode 100644 index 000000000000..be7761358c2a --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr110699.c @@ -0,0 +1,14 @@ +/* { dg-do compile } */ +/* { dg-options "-O2" } */ + +typedef __attribute__((__vector_size__(64))) int T; + +void f(void) { + extern char a[64], b[64]; /* { dg-message "previous" "note" } */ + void *p = a; + T q = *(T *)&b[0]; +} + +void g() { + extern char b; /* { dg-error "conflicting types" } */ +}