]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR c++/50793 (G++ doesn't value-initialize all members of non-trivial type in...
authorJason Merrill <jason@redhat.com>
Wed, 19 Oct 2011 22:22:25 +0000 (18:22 -0400)
committerJason Merrill <jason@gcc.gnu.org>
Wed, 19 Oct 2011 22:22:25 +0000 (18:22 -0400)
PR c++/50793
* tree.c (bot_manip): Propagate AGGR_INIT_ZERO_FIRST.

From-SVN: r180226

gcc/cp/ChangeLog
gcc/cp/tree.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/init/value9.C [new file with mode: 0644]

index f4da489d6e950f6b3f8510d569e22be6533bd0eb..c61269d97ee74e1a25f65a1266d5d4eca7dbc0b1 100644 (file)
@@ -1,3 +1,8 @@
+2011-10-19  Jason Merrill  <jason@redhat.com>
+
+       PR c++/50793
+       * tree.c (bot_manip): Propagate AGGR_INIT_ZERO_FIRST.
+
 2011-10-13  Jason Merrill  <jason@redhat.com>
 
        PR c++/50618
index c80fa995634fdd52c2cb6d10f7739797b5b08946..c52ae22ffff27bbdbdaf1a5530054bd23e48ca1c 100644 (file)
@@ -1732,7 +1732,11 @@ bot_manip (tree* tp, int* walk_subtrees, void* data)
       tree u;
 
       if (TREE_CODE (TREE_OPERAND (t, 1)) == AGGR_INIT_EXPR)
-       u = build_cplus_new (TREE_TYPE (t), TREE_OPERAND (t, 1));
+       {
+         u = build_cplus_new (TREE_TYPE (t), TREE_OPERAND (t, 1));
+         if (AGGR_INIT_ZERO_FIRST (TREE_OPERAND (t, 1)))
+           AGGR_INIT_ZERO_FIRST (TREE_OPERAND (u, 1)) = true;
+       }
       else
        u = build_target_expr_with_type (TREE_OPERAND (t, 1), TREE_TYPE (t));
 
index fb50220228a56bc4f882eb561ff432dc6c4fe2a1..b408e258443f7d330b0afd834596256d93a363eb 100644 (file)
@@ -1,3 +1,8 @@
+2011-10-19  Jason Merrill  <jason@redhat.com>
+
+       PR c++/50793
+       * g++.dg/init/value9.C: New.
+
 2011-10-13  Jason Merrill  <jason@redhat.com>
 
        PR c++/50618
diff --git a/gcc/testsuite/g++.dg/init/value9.C b/gcc/testsuite/g++.dg/init/value9.C
new file mode 100644 (file)
index 0000000..4899bd8
--- /dev/null
@@ -0,0 +1,32 @@
+// PR c++/50793
+// { dg-do run }
+
+struct NonTrivial
+{
+  NonTrivial() { }
+};
+
+struct S
+{
+  NonTrivial nt;
+  int i;
+};
+
+int f(S s)
+{
+  s.i = 0xdeadbeef;
+  return s.i;
+}
+
+int g(S s = S())
+{
+  return s.i;
+}
+
+int main()
+{
+  f(S());  // make stack dirty
+
+  if ( g() )
+    __builtin_abort();
+}