aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2002-02-06 20:37:31 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2002-02-06 20:37:31 +0100
commitcaaf2272c0eeb365b2c98d60f3ecf8f8f78cdb1f (patch)
tree1f50cf5060ea9a645f3920964e18dfd6c6ba1739
parentd51292889314d94fcfda6bbab347b312492927e4 (diff)
downloadgcc-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/ChangeLog6
-rw-r--r--gcc/c-common.c6
-rw-r--r--gcc/testsuite/ChangeLog2
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/20020206-2.c24
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);
+}