From: Jakub Jelinek Date: Tue, 12 Jan 2016 08:21:53 +0000 (+0100) Subject: re PR c++/66808 (tree check fail in symbol_table::decl_assembler_name_hash) X-Git-Tag: basepoints/gcc-7~1707 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=723033a6b2ce651e9fded5af3a820ad605cbfed0;p=thirdparty%2Fgcc.git re PR c++/66808 (tree check fail in symbol_table::decl_assembler_name_hash) PR c++/66808 PR c++/69000 * pt.c (tsubst_decl): If not local_p, clear DECL_TEMPLATE_INFO. * g++.dg/tls/pr66808.C: New test. * g++.dg/tls/pr69000.C: New test. From-SVN: r232259 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index ba7cf58552cf..c8b81605f43c 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2016-01-12 Jakub Jelinek + + PR c++/66808 + PR c++/69000 + * pt.c (tsubst_decl): If not local_p, clear DECL_TEMPLATE_INFO. + 2016-01-11 Jason Merrill PR c++/69131 diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index ad5099f94bc7..edec774a0c96 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -12292,8 +12292,13 @@ tsubst_decl (tree t, tree args, tsubst_flags_t complain) SET_DECL_IMPLICIT_INSTANTIATION (r); register_specialization (r, gen_tmpl, argvec, false, hash); } - else if (!cp_unevaluated_operand) - register_local_specialization (r, t); + else + { + if (DECL_LANG_SPECIFIC (r)) + DECL_TEMPLATE_INFO (r) = NULL_TREE; + if (!cp_unevaluated_operand) + register_local_specialization (r, t); + } DECL_CHAIN (r) = NULL_TREE; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 97562b918172..1866304b4e33 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,10 @@ +2016-01-12 Jakub Jelinek + + PR c++/66808 + PR c++/69000 + * g++.dg/tls/pr66808.C: New test. + * g++.dg/tls/pr69000.C: New test. + 2016-01-11 Bill Schmidt * gcc.target/powerpc/swaps-p8-23.c: New test. diff --git a/gcc/testsuite/g++.dg/tls/pr66808.C b/gcc/testsuite/g++.dg/tls/pr66808.C new file mode 100644 index 000000000000..e977987bdd70 --- /dev/null +++ b/gcc/testsuite/g++.dg/tls/pr66808.C @@ -0,0 +1,10 @@ +// PR c++/66808 +// { dg-do compile { target c++11 } } +// { dg-require-effective-target tls } + +template +class A { + int *b = foo (); + int *foo () { static __thread int a; return &a; } +}; +A b; diff --git a/gcc/testsuite/g++.dg/tls/pr69000.C b/gcc/testsuite/g++.dg/tls/pr69000.C new file mode 100644 index 000000000000..74cdd4b5eb1d --- /dev/null +++ b/gcc/testsuite/g++.dg/tls/pr69000.C @@ -0,0 +1,19 @@ +// PR c++/69000 +// { dg-do compile } +// { dg-require-effective-target tls } + +class A {}; + +template +struct B +{ + static int *& foo () { static __thread int *c = 0; return c; } +}; + +B d; + +void +bar () +{ + d.foo (); +}