re PR middle-end/61654 (ICE in release_function_body, at cgraph.c:1699)
authorMartin Jambor <mjambor@suse.cz>
Wed, 10 Sep 2014 11:34:09 +0000 (13:34 +0200)
committerMartin Jambor <jamborm@gcc.gnu.org>
Wed, 10 Sep 2014 11:34:09 +0000 (13:34 +0200)
2014-09-10  Martin Jambor  <mjambor@suse.cz>

PR ipa/61654
* cgraphclones.c (duplicate_thunk_for_node): Copy arguments of the
new decl properly.  Analyze the new thunk if it is expanded.

gcc/testsuite/
* g++.dg/ipa/pr61654.C: New test.

From-SVN: r215122

gcc/ChangeLog
gcc/cgraphclones.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/ipa/pr61654.C [new file with mode: 0644]

index aab2439f2e10f260a58034d3b6b6e5abf7e0ccbb..3c919063c9fe14383752e552852100f0300f9d6c 100644 (file)
@@ -1,3 +1,9 @@
+2014-09-10  Martin Jambor  <mjambor@suse.cz>
+
+       PR ipa/61654
+       * cgraphclones.c (duplicate_thunk_for_node): Copy arguments of the
+       new decl properly.  Analyze the new thunk if it is expanded.
+
 2014-09-10  Andreas Schwab  <schwab@suse.de>
 
        * coretypes.h (struct _dont_use_rtx_insn_here_, rtx_insn)
index eb044184fe1b090e1b43b9639bc70db4260a4fd2..2a17de5d552538280e8073551681395ce3f581c3 100644 (file)
@@ -334,6 +334,22 @@ duplicate_thunk_for_node (cgraph_node *thunk, cgraph_node *node)
                                                node->clone.args_to_skip,
                                                false);
     }
+
+  tree *link = &DECL_ARGUMENTS (new_decl);
+  int i = 0;
+  for (tree pd = DECL_ARGUMENTS (thunk->decl); pd; pd = DECL_CHAIN (pd), i++)
+    {
+      if (!node->clone.args_to_skip
+         || !bitmap_bit_p (node->clone.args_to_skip, i))
+       {
+         tree nd = copy_node (pd);
+         DECL_CONTEXT (nd) = new_decl;
+         *link = nd;
+         link = &DECL_CHAIN (nd);
+       }
+    }
+  *link = NULL_TREE;
+
   gcc_checking_assert (!DECL_STRUCT_FUNCTION (new_decl));
   gcc_checking_assert (!DECL_INITIAL (new_decl));
   gcc_checking_assert (!DECL_RESULT (new_decl));
@@ -357,6 +373,11 @@ duplicate_thunk_for_node (cgraph_node *thunk, cgraph_node *node)
   symtab->call_edge_duplication_hooks (thunk->callees, e);
   if (!new_thunk->expand_thunk (false, false))
     new_thunk->analyzed = true;
+  else
+    {
+      new_thunk->thunk.thunk_p = false;
+      new_thunk->analyze ();
+    }
 
   symtab->call_cgraph_duplication_hooks (thunk, new_thunk);
   return new_thunk;
index b6b96fddcdec8a8d598bbb8d77095e7459b2dcc9..e4fc660c1a79aea51b2e181e59fda10db7cc3277 100644 (file)
@@ -1,3 +1,8 @@
+2014-09-10  Martin Jambor  <mjambor@suse.cz>
+
+       PR ipa/61654
+       * g++.dg/ipa/pr61654.C: New test.
+
 2014-09-10  Jakub Jelinek  <jakub@redhat.com>
 
        * c-c++-common/ubsan/attrib-3.c: New test.
diff --git a/gcc/testsuite/g++.dg/ipa/pr61654.C b/gcc/testsuite/g++.dg/ipa/pr61654.C
new file mode 100644 (file)
index 0000000..d07e458
--- /dev/null
@@ -0,0 +1,40 @@
+/* { dg-do compile } */
+/* { dg-options "-O3" } */
+
+/* The bug only presented itself on a 32 bit i386 but in theory it might also
+   pop up elsewhere and we do not want to put -m32 options to testcase
+   options.  */
+
+struct A
+{
+  virtual int a (int, int = 0) = 0;
+  void b ();
+  void c ();
+  int d;
+};
+
+struct B : virtual A
+{
+  int a (int, int);
+  int e;
+};
+
+int f;
+
+void
+A::b ()
+{
+  a (0);
+}
+
+void
+A::c ()
+{
+  a (f);
+}
+
+int
+B::a (int, int)
+{
+  return e;
+}