]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR lto/60150 (ICE in function_and_variable_visibility, at ipa.c:1000)
authorJan Hubicka <hubicka@ucw.cz>
Sun, 2 Mar 2014 22:19:37 +0000 (23:19 +0100)
committerJan Hubicka <hubicka@gcc.gnu.org>
Sun, 2 Mar 2014 22:19:37 +0000 (22:19 +0000)
PR ipa/60150
* ipa.c (function_and_variable_visibility): When dissolving comdat
group, also set all symbols to local.
* g++.dg/lto/pr60150.H: New testcase.
* g++.dg/lto/pr60150_0.C: New testcase.
* g++.dg/lto/pr60150_1.C: New testcase.

From-SVN: r208262

gcc/ChangeLog
gcc/ipa.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/lto/pr60150.H [new file with mode: 0644]
gcc/testsuite/g++.dg/lto/pr60150_0.C [new file with mode: 0644]
gcc/testsuite/g++.dg/lto/pr60150_1.C [new file with mode: 0644]

index b6f1dac00ad6bdb7445c917b56ab337cf67f019e..c05694693b060c75c4446fe616f988c37ede34d3 100644 (file)
@@ -1,3 +1,9 @@
+2014-03-02  Jan Hubicka  <hubicka@ucw.cz>
+
+       PR ipa/60150
+       * ipa.c (function_and_variable_visibility): When dissolving comdat
+       group, also set all symbols to local.
+
 2014-03-02  Jan Hubicka  <hubicka@ucw.cz>
        
        PR ipa/60306
index 405ee644c365df483b88fefe3b2567358d9eda2c..da9755425c5609b759d396468a4104941528e34c 100644 (file)
--- a/gcc/ipa.c
+++ b/gcc/ipa.c
@@ -970,15 +970,32 @@ function_and_variable_visibility (bool whole_program)
          gcc_assert (whole_program || in_lto_p
                      || !TREE_PUBLIC (node->decl));
          node->unique_name = ((node->resolution == LDPR_PREVAILING_DEF_IRONLY
-                                     || node->resolution == LDPR_PREVAILING_DEF_IRONLY_EXP)
-                                     && TREE_PUBLIC (node->decl));
+                               || node->unique_name
+                               || node->resolution == LDPR_PREVAILING_DEF_IRONLY_EXP)
+                               && TREE_PUBLIC (node->decl));
          node->resolution = LDPR_PREVAILING_DEF_IRONLY;
          if (node->same_comdat_group && TREE_PUBLIC (node->decl))
-           /* cgraph_externally_visible_p has already checked all other nodes
-              in the group and they will all be made local.  We need to
-              dissolve the group at once so that the predicate does not
-              segfault though. */
-           symtab_dissolve_same_comdat_group_list (node);
+           {
+             symtab_node *next = node;
+
+             /* Set all members of comdat group local.  */
+             if (node->same_comdat_group)
+               for (next = node->same_comdat_group;
+                    next != node;
+                    next = next->same_comdat_group)
+               {
+                 symtab_make_decl_local (next->decl);
+                 next->unique_name = ((next->resolution == LDPR_PREVAILING_DEF_IRONLY
+                                       || next->unique_name
+                                       || next->resolution == LDPR_PREVAILING_DEF_IRONLY_EXP)
+                                       && TREE_PUBLIC (next->decl));
+               }
+             /* cgraph_externally_visible_p has already checked all other nodes
+                in the group and they will all be made local.  We need to
+                dissolve the group at once so that the predicate does not
+                segfault though. */
+             symtab_dissolve_same_comdat_group_list (node);
+           }
          symtab_make_decl_local (node->decl);
        }
 
index 864057e435d12f5e3290c8265952999f77a6903d..7db73e4067590582ed03d28e98ed4414710c31c0 100644 (file)
@@ -1,3 +1,10 @@
+2014-03-02  Jan Hubicka  <hubicka@ucw.cz>
+
+       PR ipa/60150
+       * g++.dg/lto/pr60150.H: New testcase.
+       * g++.dg/lto/pr60150_0.C: New testcase.
+       * g++.dg/lto/pr60150_1.C: New testcase.
+
 2014-03-02  Jan Hubicka  <hubicka@ucw.cz>
 
        PR ipa/60306
diff --git a/gcc/testsuite/g++.dg/lto/pr60150.H b/gcc/testsuite/g++.dg/lto/pr60150.H
new file mode 100644 (file)
index 0000000..6afe37a
--- /dev/null
@@ -0,0 +1,20 @@
+struct Base {
+  virtual void f() = 0;
+};
+
+struct X : public Base { };
+struct Y : public Base { };
+struct Z : public Base { };
+struct T : public Base { };
+
+struct S : public X, public Y, public Z
+#ifdef XXX
+, public T
+#endif
+{
+  void f()
+#ifdef XXX
+  { }
+#endif
+  ;
+};
diff --git a/gcc/testsuite/g++.dg/lto/pr60150_0.C b/gcc/testsuite/g++.dg/lto/pr60150_0.C
new file mode 100644 (file)
index 0000000..cc21820
--- /dev/null
@@ -0,0 +1,8 @@
+// { dg-lto-do run }
+#include "pr60150.H"
+
+int main()
+{
+  S s;
+  return 0;
+}
diff --git a/gcc/testsuite/g++.dg/lto/pr60150_1.C b/gcc/testsuite/g++.dg/lto/pr60150_1.C
new file mode 100644 (file)
index 0000000..294e5f0
--- /dev/null
@@ -0,0 +1,4 @@
+// { dg-options "-fno-lto" }
+#include "pr60150.H"
+
+void S::f() { }