diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 2e537361359f8a8b782947fb145ab8ff3c838238..e449baa16ecc7c4fbe6bf445142873583660aab2 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2005-11-03 Andrew Pinski <pinskia@physics.uc.edu> + + PR middle-end/24589 + * gimplify.c (gimplify_expr) <case CONSTRUCTOR>: Add the + expressions to a statement list instead of gimplifying them. + 2005-11-03 Eric Botcazou <ebotcazou@libertysurf.fr> PR rtl-optimization/23585 diff --git a/gcc/gimplify.c b/gcc/gimplify.c index b7d891e041e4531500e908954f1088023e0878d2..52e70bdad5ea7cdcfab6c3818a976f654270be14 100644 --- a/gcc/gimplify.c +++ b/gcc/gimplify.c @@ -4312,18 +4312,19 @@ gimplify_expr (tree *expr_p, tree *pre_p, tree *post_p, { unsigned HOST_WIDE_INT ix; constructor_elt *ce; + tree temp = NULL_TREE; for (ix = 0; VEC_iterate (constructor_elt, CONSTRUCTOR_ELTS (*expr_p), ix, ce); ix++) if (TREE_SIDE_EFFECTS (ce->value)) - gimplify_expr (&ce->value, pre_p, post_p, - gimple_test_f, fallback); + append_to_statement_list (ce->value, &temp); - *expr_p = NULL_TREE; + *expr_p = temp; + ret = GS_OK; } - - ret = GS_ALL_DONE; + else + ret = GS_ALL_DONE; break; /* The following are special cases that are not handled by the diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 82124c6a9d1ca23182c5e5354a04b437ba46f39d..ffb3ee094092b9f21ca907558e242595c6b241b3 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2005-11-03 Andrew Pinski <pinskia@physics.uc.edu> + + PR middle-end/24589 + * gcc.c-torture/execute/zero-struct-2.c: New test. + 2005-11-03 Andrew Pinski <pinskia@physics.uc.edu> PR c++/24582 diff --git a/gcc/testsuite/gcc.c-torture/execute/zero-struct-2.c b/gcc/testsuite/gcc.c-torture/execute/zero-struct-2.c new file mode 100644 index 0000000000000000000000000000000000000000..ed1d5a027b33c639a4ee4eb619dd6f0b404ea43e --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/zero-struct-2.c @@ -0,0 +1,20 @@ +void abort (void); +int ii; +typedef struct {} raw_spinlock_t; +typedef struct { + raw_spinlock_t raw_lock; +} spinlock_t; +raw_spinlock_t one_raw_spinlock (void) +{ + raw_spinlock_t raw_lock; + ii++; + return raw_lock; +} +int main(void) +{ + spinlock_t lock = (spinlock_t) { .raw_lock = one_raw_spinlock() }; + if (ii != 1) + abort (); + return 0; +} +