re PR tree-optimization/51583 (One more missing force_gimple_operand in SRA)
authorMartin Jambor <mjambor@suse.cz>
Mon, 19 Dec 2011 14:33:18 +0000 (15:33 +0100)
committerMartin Jambor <jamborm@gcc.gnu.org>
Mon, 19 Dec 2011 14:33:18 +0000 (15:33 +0100)
2011-12-19  Martin Jambor  <mjambor@suse.cz>

PR tree-optimization/51583
* tree-sra.c (load_assign_lhs_subreplacements): Call
force_gimple_operand_gsi when necessary also in case of no
corresponding replacement on the RHS.

* testsuite/gcc.dg/tree-ssa/pr51583.c: New test.

From-SVN: r182483

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/tree-ssa/pr51583.c [new file with mode: 0644]
gcc/tree-sra.c

index 974af002d5eae695dfb1289c9bdaec4ebe86d250..7c60f7eeeb488f658a20dcc12340a20dbf44efc9 100644 (file)
@@ -1,3 +1,10 @@
+2011-12-19  Martin Jambor  <mjambor@suse.cz>
+
+       PR tree-optimization/51583
+       * tree-sra.c (load_assign_lhs_subreplacements): Call
+       force_gimple_operand_gsi when necessary also in case of no
+       corresponding replacement on the RHS.
+
 2011-12-19  Jakub Jelinek  <jakub@redhat.com>
 
        * gimple.h (gimplify_seq_add_stmt): Rename to...
index a7c1c48a37cf871f55cccc0169c1d95d81bb5caf..b1a3762b47516d2d696dc6b31ef94d6ac67b2839 100644 (file)
@@ -1,3 +1,8 @@
+2011-12-19  Martin Jambor  <mjambor@suse.cz>
+
+       PR tree-optimization/51583
+       * gcc.dg/tree-ssa/pr51583.c: New test.
+
 2011-12-19  Jakub Jelinek  <jakub@redhat.com>
 
        PR tree-optimization/51596
diff --git a/gcc/testsuite/gcc.dg/tree-ssa/pr51583.c b/gcc/testsuite/gcc.dg/tree-ssa/pr51583.c
new file mode 100644 (file)
index 0000000..2c4ec47
--- /dev/null
@@ -0,0 +1,34 @@
+/* { dg-do compile } */
+/* { dg-options "-O1" } */
+
+typedef __complex__ double Value;
+
+union U
+{
+  Value v;
+  char c[sizeof(Value)];
+};
+
+struct S
+{
+  union U u;
+  int i,j;
+};
+
+Value gv;
+int gi, gj;
+
+Value foo (void)
+{
+  struct S s,t;
+
+  t.i = gi;
+  t.j = gj;
+  t.u.v = gv;
+  t.u.c[0] = 0;
+
+  s = t;
+  __imag__ s.u.v += s.i;
+
+  return s.u.v;
+}
index 84cbc84621493b091b28b91972598f5c2c886498..db9b9bf4452338a524bdef01c02ac14fb7b03687 100644 (file)
@@ -2752,6 +2752,9 @@ load_assign_lhs_subreplacements (struct access *lacc, struct access *top_racc,
              else
                rhs = build_ref_for_model (loc, top_racc->base, offset, lacc,
                                            new_gsi, true);
+             if (lacc->grp_partial_lhs)
+               rhs = force_gimple_operand_gsi (new_gsi, rhs, true, NULL_TREE,
+                                               false, GSI_NEW_STMT);
            }
 
          stmt = gimple_build_assign (get_access_replacement (lacc), rhs);