aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2002-02-06 20:32:04 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2002-02-06 20:32:04 +0100
commitd51292889314d94fcfda6bbab347b312492927e4 (patch)
tree654cde6cce3717203a888f9a81d627b599e6eae0 /gcc
parent5364626ac42b3eb2efc7462f6832a352db03439b (diff)
downloadgcc-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/ChangeLog6
-rw-r--r--gcc/c-common.c34
-rw-r--r--gcc/testsuite/ChangeLog2
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/20020206-1.c29
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);
+}