diff options
author | Jakub Jelinek <jakub@redhat.com> | 2002-02-06 20:37:31 +0100 |
---|---|---|
committer | Jakub Jelinek <jakub@gcc.gnu.org> | 2002-02-06 20:37:31 +0100 |
commit | caaf2272c0eeb365b2c98d60f3ecf8f8f78cdb1f (patch) | |
tree | 1f50cf5060ea9a645f3920964e18dfd6c6ba1739 | |
parent | d51292889314d94fcfda6bbab347b312492927e4 (diff) | |
download | gcc-caaf2272c0eeb365b2c98d60f3ecf8f8f78cdb1f.zip gcc-caaf2272c0eeb365b2c98d60f3ecf8f8f78cdb1f.tar.gz gcc-caaf2272c0eeb365b2c98d60f3ecf8f8f78cdb1f.tar.bz2 |
re PR c/5420 (bad code generated with gcc3.1/ia64)
PR c/5420:
* c-common.c (c_unsafe_for_reeval): Make COMPOUND_LITERAL_EXPR
unsafe for reevaluation.
* gcc.c-torture/execute/20020206-2.c: New test.
From-SVN: r49550
-rw-r--r-- | gcc/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/c-common.c | 6 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 2 | ||||
-rw-r--r-- | gcc/testsuite/gcc.c-torture/execute/20020206-2.c | 24 |
4 files changed, 36 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 86fc062..96baa91 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,11 @@ 2002-02-06 Jakub Jelinek <jakub@redhat.com> + PR c/5420: + * c-common.c (c_unsafe_for_reeval): Make COMPOUND_LITERAL_EXPR + unsafe for reevaluation. + +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. diff --git a/gcc/c-common.c b/gcc/c-common.c index dd535ed..4b7946b 100644 --- a/gcc/c-common.c +++ b/gcc/c-common.c @@ -3567,8 +3567,10 @@ int c_unsafe_for_reeval (exp) tree exp; { - /* Statement expressions may not be reevaluated. */ - if (TREE_CODE (exp) == STMT_EXPR) + /* Statement expressions may not be reevaluated, likewise compound + literals. */ + if (TREE_CODE (exp) == STMT_EXPR + || TREE_CODE (exp) == COMPOUND_LITERAL_EXPR) return 2; /* Walk all other expressions. */ diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 8cf3dc4..5c8a027 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -2,6 +2,8 @@ * gcc.c-torture/execute/20020206-1.c: New test. + * gcc.c-torture/execute/20020206-2.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-2.c b/gcc/testsuite/gcc.c-torture/execute/20020206-2.c new file mode 100644 index 0000000..097eb30 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/20020206-2.c @@ -0,0 +1,24 @@ +/* Origin: PR c/5420 from David Mosberger <davidm@hpl.hp.com>. + This testcase was miscompiled when tail call optimizing, because a + compound literal initialization was emitted only in the tail call insn + chain, not in the normal call insn chain. */ + +typedef struct { unsigned short a; } A; + +extern void abort (void); +extern void exit (int); + +void foo (unsigned int x) +{ + if (x != 0x800 && x != 0x810) + abort (); +} + +int +main (int argc, char **argv) +{ + int i; + for (i = 0; i < 2; ++i) + foo (((A) { ((!(i >> 4) ? 8 : 64 + (i >> 4)) << 8) + (i << 4) } ).a); + exit (0); +} |