diff options
author | Jakub Jelinek <jakub@redhat.com> | 2002-02-06 20:32:04 +0100 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2002-02-06 20:32:04 +0100 |
commit | d51292889314d94fcfda6bbab347b312492927e4 (patch) | |
tree | 654cde6cce3717203a888f9a81d627b599e6eae0 /gcc | |
parent | 5364626ac42b3eb2efc7462f6832a352db03439b (diff) | |
download | gcc-d51292889314d94fcfda6bbab347b312492927e4.zip gcc-d51292889314d94fcfda6bbab347b312492927e4.tar.gz gcc-d51292889314d94fcfda6bbab347b312492927e4.tar.bz2 |
re PR c/5482 (cyclone-0.2, ICE in emit_move_insn, at expr.c:2746)
PR c/5482:
* c-common.c (c_expand_expr) [STMT_EXPR]: If last expression is not
EXPR_STMT, but COMPOUND_STMT, recurse into it.
* gcc.c-torture/execute/20020206-1.c: New test.
From-SVN: r49549
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/c-common.c | 34 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 2 | ||||
-rw-r--r-- | gcc/testsuite/gcc.c-torture/execute/20020206-1.c | 29 |
4 files changed, 59 insertions, 12 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index f9b0744..86fc062 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2002-02-06 Jakub Jelinek <jakub@redhat.com> + + PR c/5482: + * c-common.c (c_expand_expr) [STMT_EXPR]: If last expression is not + EXPR_STMT, but COMPOUND_STMT, recurse into it. + 2002-02-06 Richard Henderson <rth@redhat.com> * cfganal.c (keep_with_call_p): Source for fixed_reg dest must diff --git a/gcc/c-common.c b/gcc/c-common.c index bbccf4a..dd535ed 100644 --- a/gcc/c-common.c +++ b/gcc/c-common.c @@ -3466,22 +3466,32 @@ c_expand_expr (exp, target, tmode, modifier) /* If we want the result of this expression, find the last EXPR_STMT in the COMPOUND_STMT and mark it as addressable. */ - if (target != const0_rtx - && TREE_CODE (STMT_EXPR_STMT (exp)) == COMPOUND_STMT - && TREE_CODE (COMPOUND_BODY (STMT_EXPR_STMT (exp))) == SCOPE_STMT) + if (target != const0_rtx) { - tree expr = COMPOUND_BODY (STMT_EXPR_STMT (exp)); - tree last = TREE_CHAIN (expr); + tree expr = STMT_EXPR_STMT (exp); + tree last; - while (TREE_CHAIN (last)) + while (TREE_CODE (expr) == COMPOUND_STMT + && TREE_CODE (COMPOUND_BODY (expr)) == SCOPE_STMT) { - expr = last; - last = TREE_CHAIN (last); + expr = COMPOUND_BODY (expr); + last = TREE_CHAIN (expr); + + while (TREE_CHAIN (last)) + { + expr = last; + last = TREE_CHAIN (last); + } + + if (TREE_CODE (last) != SCOPE_STMT) + abort (); + + if (TREE_CODE (expr) == EXPR_STMT) + { + TREE_ADDRESSABLE (expr) = 1; + break; + } } - - if (TREE_CODE (last) == SCOPE_STMT - && TREE_CODE (expr) == EXPR_STMT) - TREE_ADDRESSABLE (expr) = 1; } expand_stmt (STMT_EXPR_STMT (exp)); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 30b219e..8cf3dc4 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,7 @@ 2002-02-06 Jakub Jelinek <jakub@redhat.com> + * gcc.c-torture/execute/20020206-1.c: New test. + PR optimization/5429: * gcc.c-torture/compile/20020206-1.c: New test. diff --git a/gcc/testsuite/gcc.c-torture/execute/20020206-1.c b/gcc/testsuite/gcc.c-torture/execute/20020206-1.c new file mode 100644 index 0000000..93147c9 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/20020206-1.c @@ -0,0 +1,29 @@ +/* This testcase ICEd because c_expand_expr did not mark statement expression + return value as one which shouldn't be ignored. */ + +struct A { + unsigned int a, b, c; +}; + +extern void abort (void); +extern void exit (int); + +struct A bar (void) +{ + return (struct A) { 176, 52, 31 }; +} + +void baz (struct A *a) +{ + if (a->a != 176 || a->b != 52 || a->c != 31) + abort (); +} + +int main () +{ + struct A d; + + d = ({ { bar (); } }); + baz (&d); + exit (0); +} |