]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
backport: re PR c++/77285 (extern thread_local linkage)
authorJakub Jelinek <jakub@redhat.com>
Tue, 30 May 2017 07:41:57 +0000 (09:41 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Tue, 30 May 2017 07:41:57 +0000 (09:41 +0200)
Backported from mainline
2016-11-18  Jakub Jelinek  <jakub@redhat.com>

PR c++/77285
* mangle.c (mangle_tls_init_fn, mangle_tls_wrapper_fn): Call
check_abi_tags.

* g++.dg/tls/pr77285-1.C: New test.
* g++.dg/tls/pr77285-2.C: New test.

From-SVN: r248624

gcc/cp/ChangeLog
gcc/cp/mangle.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/tls/pr77285-1.C [new file with mode: 0644]
gcc/testsuite/g++.dg/tls/pr77285-2.C [new file with mode: 0644]

index 223b029bf9e4ee26d33b636cc372b84940565125..98bb4fc0b0abfec917f63501f4101ee38c74a250 100644 (file)
@@ -1,6 +1,12 @@
 2017-05-30  Jakub Jelinek  <jakub@redhat.com>
 
        Backported from mainline
+       2016-11-18  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/77285
+       * mangle.c (mangle_tls_init_fn, mangle_tls_wrapper_fn): Call
+       check_abi_tags.
+
        2016-10-31  Jakub Jelinek  <jakub@redhat.com>
 
        PR c++/78089
index 4e0ed225d76b8434a4d150750e247188e99a3a72..5ad7bb7a96bcf3a6ecf3e26200d6411b04c5d0f1 100644 (file)
@@ -3881,6 +3881,7 @@ mangle_guard_variable (const tree variable)
 tree
 mangle_tls_init_fn (const tree variable)
 {
+  check_abi_tags (variable);
   start_mangling (variable);
   write_string ("_ZTH");
   write_guarded_var_name (variable);
@@ -3895,6 +3896,7 @@ mangle_tls_init_fn (const tree variable)
 tree
 mangle_tls_wrapper_fn (const tree variable)
 {
+  check_abi_tags (variable);
   start_mangling (variable);
   write_string (TLS_WRAPPER_PREFIX);
   write_guarded_var_name (variable);
index 78d6ccf89c43610b3353589f65c5dbafe1391b76..a26f8973f937fcc8ab7b141a177f210ad6dc72f4 100644 (file)
@@ -1,6 +1,12 @@
 2017-05-30  Jakub Jelinek  <jakub@redhat.com>
 
        Backported from mainline
+       2016-11-18  Jakub Jelinek  <jakub@redhat.com>
+
+       PR c++/77285
+       * g++.dg/tls/pr77285-1.C: New test.
+       * g++.dg/tls/pr77285-2.C: New test.
+
        2016-11-16  Jakub Jelinek  <jakub@redhat.com>
 
        PR rtl-optimization/78378
diff --git a/gcc/testsuite/g++.dg/tls/pr77285-1.C b/gcc/testsuite/g++.dg/tls/pr77285-1.C
new file mode 100644 (file)
index 0000000..d8f69b2
--- /dev/null
@@ -0,0 +1,7 @@
+// { dg-do link { target c++11 } }
+// { dg-require-effective-target tls }
+// { dg-additional-sources pr77285-2.C }
+
+struct __attribute__((abi_tag("tag"))) X { ~X () {} int i = 0; };
+thread_local X var1;
+X var2;
diff --git a/gcc/testsuite/g++.dg/tls/pr77285-2.C b/gcc/testsuite/g++.dg/tls/pr77285-2.C
new file mode 100644 (file)
index 0000000..bac273a
--- /dev/null
@@ -0,0 +1,17 @@
+// PR c++/77285
+// { dg-do compile { target c++11 } }
+// { dg-require-effective-target tls }
+// { dg-final { scan-assembler "_Z4var1B3tag" } }
+// { dg-final { scan-assembler "_Z4var2B3tag" } }
+// { dg-final { scan-assembler "_ZTH4var1B3tag" } }
+// { dg-final { scan-assembler "_ZTW4var1B3tag" } }
+
+struct __attribute__((abi_tag("tag"))) X { ~X () {} int i = 0; };
+extern thread_local X var1;
+extern X var2;
+
+int
+main ()
+{
+ return var1.i + var2.i;
+}