]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
backport: re PR middle-end/46734 (ICE in create_tmp_var, at gimplify.c:505)
authorMartin Jambor <mjambor@suse.cz>
Tue, 21 Dec 2010 11:05:49 +0000 (12:05 +0100)
committerMartin Jambor <jamborm@gcc.gnu.org>
Tue, 21 Dec 2010 11:05:49 +0000 (12:05 +0100)
2010-12-21  Martin Jambor  <mjambor@suse.cz>

Backport from mainline:
2010-12-09  Martin Jambor  <mjambor@suse.cz>

PR middle-end/46734
* tree-sra.c (splice_param_accesses): Check that there are not
multiple ADDRESSABLE types.

* testsuite/g++.dg/tree-ssa/pr46734.C: New test.

From-SVN: r168109

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/tree-ssa/pr46734.C [new file with mode: 0644]
gcc/tree-sra.c

index 925094d4cc2fd8c4c180cedc884cc4ab76c3a052..257d125c55fafd182736c52eb5f40d93673b5407 100644 (file)
@@ -1,3 +1,12 @@
+2010-12-21  Martin Jambor  <mjambor@suse.cz>
+
+       Backport from mainline:
+       2010-12-09  Martin Jambor  <mjambor@suse.cz>
+
+       PR middle-end/46734
+       * tree-sra.c (splice_param_accesses): Check that there are not
+       multiple ADDRESSABLE types.
+
 2010-12-19  John David Anglin  <dave.anglin@nrc-cnrc.gc.ca>
 
        Backport from mainline:
index f720112b233d38665b9188d7519381ac04f51bc3..3ed2ee7fcc5726ebff1776c0b732d6515749d8f6 100644 (file)
@@ -1,3 +1,8 @@
+2010-12-21  Martin Jambor  <mjambor@suse.cz>
+
+       PR middle-end/46734
+       * g++.dg/tree-ssa/pr46734.C: New test.
+
 2010-12-18  Alexandre Oliva  <aoliva@redhat.com>
 
        PR debug/46756
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr46734.C b/gcc/testsuite/g++.dg/tree-ssa/pr46734.C
new file mode 100644 (file)
index 0000000..e95c620
--- /dev/null
@@ -0,0 +1,34 @@
+/* { dg-do compile } */
+/* { dg-options "-O -fipa-sra" } */
+
+struct A
+{
+  int *p;
+  A() {p = (int *) -1;}
+  ~A() {if (p && p != (int *) -1) *p = 0;}
+};
+
+struct B
+{
+  A a;
+  char data[23];
+  B() : a() {data[0] = 0;}
+};
+
+extern A ga;
+extern int *gi;
+extern void *gz;
+extern B *gb;
+
+static int * __attribute__ ((noinline)) foo (B *b, void *z)
+{
+  __builtin_memcpy (gz, z, 28);
+  ga = b->a;
+  return b->a.p;
+}
+
+int *bar (B *b, void *z)
+{
+  gb = b;
+  return foo (b, z);
+}
index 05ca33cb37850c00d96a13caef22a1bf94db1331..06d2cdf718135a156ce263ce93be8c614b6912ed 100644 (file)
@@ -3413,7 +3413,10 @@ splice_param_accesses (tree parm, bool *ro_grp)
          else if (ac2->size != access->size)
            return NULL;
 
-         if (access_precludes_ipa_sra_p (ac2))
+         if (access_precludes_ipa_sra_p (ac2)
+             || (ac2->type != access->type
+                 && (TREE_ADDRESSABLE (ac2->type)
+                     || TREE_ADDRESSABLE (access->type))))
            return NULL;
 
          modification |= ac2->write;