Revert "Patch 3/4 of the effort to make TLS access async-signal-safe."
authorAllan McRae <allan@archlinux.org>
Wed, 5 Feb 2014 11:21:00 +0000 (21:21 +1000)
committerAllan McRae <allan@archlinux.org>
Wed, 5 Feb 2014 22:46:20 +0000 (08:46 +1000)
This reverts commit 35e8f7ab94c910659de9d507aa0f3e1f8973d914.

ChangeLog
elf/Versions
elf/dl-tls.c
nptl/allocatestack.c
sysdeps/generic/ldsodefs.h

index cb4615287a3705b5273cb3acfaecafe042fc060c..80cb619b4c92667869c8ee254c02f25bdeb3e982 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
        * manual/install.texi: Suppress menu for plain text output.
        * INSTALL: Regenerated.
 
-2013-12-18  Andrew Hunter  <ahh@google.com>
-
-       * elf/Versions (ld): Add _dl_clear_dtv.
-       * sysdeps/generic/ldsodefs.h (_dl_clear_dtv): New prototype.
-       * elf/dl-tls.c (_dl_clear_dtv): New function.
-       * nptl/allocatestack.c (get_cached_stack): Call _dl_clear_dtv.
-
 2013-12-18  Andrew Hunter  <ahh@google.com>
 
        * sysdeps/generic/ldsodefs.h (_dl_mask_all_signals): New prototype.
index 01b7a59d5e2cd75638c95b0e5b47a206f81edfab..238399232d92a154bb7258d4913c6cacfb7f202b 100644 (file)
@@ -53,7 +53,6 @@ ld {
     _dl_allocate_tls; _dl_allocate_tls_init;
     _dl_argv; _dl_find_dso_for_object; _dl_get_tls_static_info;
     _dl_deallocate_tls; _dl_make_stack_executable; _dl_out_of_memory;
-    _dl_clear_dtv;
     _dl_rtld_di_serinfo; _dl_starting_up; _dl_tls_setup;
     _rtld_global; _rtld_global_ro;
 
index 28e4fbef40d71e0a22e6a7139d570e2482c3b316..dbaea0aa913e566b4516aeb134012643e5009754 100644 (file)
@@ -463,18 +463,6 @@ _dl_allocate_tls (void *mem)
 }
 rtld_hidden_def (_dl_allocate_tls)
 
-void
-internal_function
-_dl_clear_dtv (dtv_t *dtv)
-{
-  for (size_t cnt = 0; cnt < dtv[-1].counter; ++cnt)
-    if (! dtv[1 + cnt].pointer.is_static
-       && dtv[1 + cnt].pointer.val != TLS_DTV_UNALLOCATED)
-      free (dtv[1 + cnt].pointer.val);
-  memset (dtv, '\0', (dtv[-1].counter + 1) * sizeof (dtv_t));
-}
-
-rtld_hidden_def (_dl_clear_dtv)
 
 #ifndef SHARED
 extern dtv_t _dl_static_dtv[];
index 7f6094ebb2b99f73fbdc01a2c1c23e95b6dcddb3..13eca47cf25d105d49a8be2274f1d78f53cc71af 100644 (file)
@@ -242,7 +242,11 @@ get_cached_stack (size_t *sizep, void **memp)
 
   /* Clear the DTV.  */
   dtv_t *dtv = GET_DTV (TLS_TPADJ (result));
-  _dl_clear_dtv (dtv);
+  for (size_t cnt = 0; cnt < dtv[-1].counter; ++cnt)
+    if (! dtv[1 + cnt].pointer.is_static
+       && dtv[1 + cnt].pointer.val != TLS_DTV_UNALLOCATED)
+      free (dtv[1 + cnt].pointer.val);
+  memset (dtv, '\0', (dtv[-1].counter + 1) * sizeof (dtv_t));
 
   /* Re-initialize the TLS.  */
   _dl_allocate_tls_init (TLS_TPADJ (result));
index 5e252267d780c56e70ba21640c3882472795103c..ff3f20f3623bdb5b6a3d39be87cf6504940ce268 100644 (file)
@@ -989,11 +989,6 @@ extern void *_dl_allocate_tls_storage (void)
 extern void *_dl_allocate_tls_init (void *) internal_function;
 rtld_hidden_proto (_dl_allocate_tls_init)
 
-/* Remove all allocated dynamic TLS regions from a DTV
-   for reuse by new thread.  */
-extern void _dl_clear_dtv (dtv_t *dtv) internal_function;
-rtld_hidden_proto (_dl_clear_dtv)
-
 /* Deallocate memory allocated with _dl_allocate_tls.  */
 extern void _dl_deallocate_tls (void *tcb, bool dealloc_tcb) internal_function;
 rtld_hidden_proto (_dl_deallocate_tls)