From df4b9cfe50b434e67e4d47f7725aa8e37f778e50 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek <jakub@redhat.com> Date: Thu, 29 Sep 2005 23:34:33 +0200 Subject: [PATCH] re PR middle-end/24109 (non unit-at-a-time failure with compound literals) PR middle-end/24109 * c-decl.c (c_write_global_declarations_1): If any wrapup_global_declaration_2 call returned true, restart the loop. * gcc.c-torture/execute/20050929-1.c: New test. From-SVN: r104794 --- gcc/ChangeLog | 6 ++++++ gcc/c-decl.c | 14 +++++++++++-- gcc/testsuite/ChangeLog | 5 +++++ .../gcc.c-torture/execute/20050929-1.c | 20 +++++++++++++++++++ 4 files changed, 43 insertions(+), 2 deletions(-) create mode 100644 gcc/testsuite/gcc.c-torture/execute/20050929-1.c diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 2242dcdf8cd1..799488a696bc 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2005-09-29 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/24109 + * c-decl.c (c_write_global_declarations_1): If any + wrapup_global_declaration_2 call returned true, restart the loop. + 2005-09-29 Daniel Berlin <dberlin@dberlin.org> Fix PR tree-optimization/24117 diff --git a/gcc/c-decl.c b/gcc/c-decl.c index 49c8904fc04b..9c2e829b0c9f 100644 --- a/gcc/c-decl.c +++ b/gcc/c-decl.c @@ -7548,6 +7548,7 @@ static void c_write_global_declarations_1 (tree globals) { tree decl; + bool reconsider; /* Process the decls in the order they were written. */ for (decl = globals; decl; decl = TREE_CHAIN (decl)) @@ -7566,9 +7567,18 @@ c_write_global_declarations_1 (tree globals) } wrapup_global_declaration_1 (decl); - wrapup_global_declaration_2 (decl); - check_global_declaration_1 (decl); } + + do + { + reconsider = false; + for (decl = globals; decl; decl = TREE_CHAIN (decl)) + reconsider |= wrapup_global_declaration_2 (decl); + } + while (reconsider); + + for (decl = globals; decl; decl = TREE_CHAIN (decl)) + check_global_declaration_1 (decl); } /* A subroutine of c_write_global_declarations Emit debug information for each diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index f916b76c2fd3..d595aa3f2f99 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2005-09-29 Jakub Jelinek <jakub@redhat.com> + + PR middle-end/24109 + * gcc.c-torture/execute/20050929-1.c: New test. + 2005-09-29 Steven Bosscher <stevenb@suse.de> * gcc.dg/tree-ssa/ssa-ccp-11.c: Fix the test case and un-xfail. diff --git a/gcc/testsuite/gcc.c-torture/execute/20050929-1.c b/gcc/testsuite/gcc.c-torture/execute/20050929-1.c new file mode 100644 index 000000000000..7be2eb813f74 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/20050929-1.c @@ -0,0 +1,20 @@ +/* PR middle-end/24109 */ + +extern void abort (void); + +struct A { int i; int j; }; +struct B { struct A *a; struct A *b; }; +struct C { struct B *c; struct A *d; }; +struct C e = { &(struct B) { &(struct A) { 1, 2 }, &(struct A) { 3, 4 } }, &(struct A) { 5, 6 } }; + +int +main (void) +{ + if (e.c->a->i != 1 || e.c->a->j != 2) + abort (); + if (e.c->b->i != 3 || e.c->b->j != 4) + abort (); + if (e.d->i != 5 || e.d->j != 6) + abort (); + return 0; +} -- GitLab