aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2010-01-31 17:01:38 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2010-01-31 17:01:38 +0000
commit61c7cbf8e5502fe6da677581d5c151193049d850 (patch)
tree4d98e1d16b91ce092b061d30f5405e34bf72230c /gcc
parent6e4a660f122aa663077ebc4250597a40904a0720 (diff)
downloadgcc-61c7cbf8e5502fe6da677581d5c151193049d850.zip
gcc-61c7cbf8e5502fe6da677581d5c151193049d850.tar.gz
gcc-61c7cbf8e5502fe6da677581d5c151193049d850.tar.bz2
re PR middle-end/42898 (volatile structures and compound literal initializers)
2010-01-31 Richard Guenther <rguenther@suse.de> PR middle-end/42898 * gimplify.c (gimplify_init_constructor): For volatile LHS initialize a temporary. * gcc.dg/torture/pr42898.c: New testcase. From-SVN: r156404
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/gimplify.c15
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/torture/pr42898.c23
4 files changed, 49 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index b283f28..d91b75e 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2010-01-31 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/42898
+ * gimplify.c (gimplify_init_constructor): For volatile LHS
+ initialize a temporary.
+
2010-01-31 Matthias Klose <doko@ubuntu.com>
* configure.ac: Fix __stack_chk_fail check for cross builds configured
diff --git a/gcc/gimplify.c b/gcc/gimplify.c
index ccae4d8..fac3fda 100644
--- a/gcc/gimplify.c
+++ b/gcc/gimplify.c
@@ -3745,6 +3745,21 @@ gimplify_init_constructor (tree *expr_p, gimple_seq *pre_p, gimple_seq *post_p,
}
}
+ /* If the target is volatile and we have non-zero elements
+ initialize the target from a temporary. */
+ if (TREE_THIS_VOLATILE (object)
+ && !TREE_ADDRESSABLE (type)
+ && num_nonzero_elements > 0)
+ {
+ tree temp = create_tmp_var (TYPE_MAIN_VARIANT (type), NULL);
+ TREE_OPERAND (*expr_p, 0) = temp;
+ *expr_p = build2 (COMPOUND_EXPR, TREE_TYPE (*expr_p),
+ *expr_p,
+ build2 (MODIFY_EXPR, void_type_node,
+ object, temp));
+ return GS_OK;
+ }
+
if (notify_temp_creation)
return GS_OK;
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 8257646..2373079 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2010-01-31 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/42898
+ * gcc.dg/torture/pr42898.c: New testcase.
+
2010-01-31 Paul Thomas <pault@gcc.gnu.org>
PR fortran/38324
diff --git a/gcc/testsuite/gcc.dg/torture/pr42898.c b/gcc/testsuite/gcc.dg/torture/pr42898.c
new file mode 100644
index 0000000..df8b46a
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/torture/pr42898.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-options "-fdump-tree-optimized" } */
+
+struct hardware {
+ int parm1:8;
+ int :4;
+ int parm2:4;
+ int parm3:15;
+ int parm4:1;
+};
+
+void f1(volatile struct hardware *ptr)
+{
+ *ptr=(struct hardware) {
+ .parm1=42,
+ .parm2=13,
+ .parm3=11850,
+ .parm4=1,
+ };
+}
+
+/* { dg-final { scan-tree-dump-times "\\*ptr" 1 "optimized" } } */
+/* { dg-final { cleanup-tree-dump "optimized" } } */