PR middle-end/53161
authorhubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 23 May 2012 09:23:40 +0000 (09:23 +0000)
committerhubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 23 May 2012 09:23:40 +0000 (09:23 +0000)
* symtab.c (symtab_register_node): Fix ordering issue.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@187798 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/symtab.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/torture/pr53161.C [new file with mode: 0644]

index 8b601c9..ee5d718 100644 (file)
@@ -1,3 +1,8 @@
+2012-05-22  Jan Hubicka  <jh@suse.cz>
+
+       PR middle-end/53161
+       * symtab.c (symtab_register_node): Fix ordering issue.
+
 2012-05-22  Steven Drake <sbd@NetBSD.org>
 
        * gcc.c (do_spec_1): Add %M spec token to output multilib_os_dir.
index 1d9fdd8..665ceae 100644 (file)
@@ -177,11 +177,13 @@ symtab_register_node (symtab_node node)
   if (*slot == NULL)
     *slot = node;
 
-  insert_to_assembler_name_hash (node);
+  ipa_empty_ref_list (&node->symbol.ref_list);
 
   node->symbol.order = symtab_order++;
 
-  ipa_empty_ref_list (&node->symbol.ref_list);
+  /* Be sure to do this last; C++ FE might create new nodes via
+     DECL_ASSEMBLER_NAME langhook!  */
+  insert_to_assembler_name_hash (node);
 }
 
 /* Make NODE to be the one symtab hash is pointing to.  Used when reshaping tree
index 21f448d..09bc357 100644 (file)
@@ -1,3 +1,8 @@
+2012-05-22  Jan Hubicka  <jh@suse.cz>
+
+       PR middle-end/53161
+       * g++.dg/torture/pr53161.C: New testcase.
+
 2012-05-22  Tobias Burnus  <burnus@net-b.de>
 
        PR fortran/53389
diff --git a/gcc/testsuite/g++.dg/torture/pr53161.C b/gcc/testsuite/g++.dg/torture/pr53161.C
new file mode 100644 (file)
index 0000000..766f294
--- /dev/null
@@ -0,0 +1,22 @@
+/* { dg-options "-std=c++11" } */
+void gg();
+static __typeof(gg) __gthrw_gg __attribute__((__weakref__("gg")));
+
+template<typename R,typename... A>
+struct data {
+ template<typename Y,typename X>
+ data(Y& y,R(X::*f)(A...));
+};
+
+template<typename Y,typename X,typename R,typename... A>
+data<R,A...> make_data(Y& y,R(X::*f)(A...)) {
+ return data<R,A...>(y,f);
+}
+
+void global(data<void>);
+
+struct test {
+ void bar() {}
+ void doit() { global(make_data(*this,&test::bar)); }
+};
+