* sysdeps/generic/dl-tls.c (_dl_allocate_tls_init): Fix inner loop
authorRoland McGrath <roland@gnu.org>
Mon, 12 Aug 2002 08:48:51 +0000 (08:48 +0000)
committerRoland McGrath <roland@gnu.org>
Mon, 12 Aug 2002 08:48:51 +0000 (08:48 +0000)
start count condition, use TOTAL instead of variable that was never
set.  Fix outer loop termination condition to TOTAL >= after update.

* sysdeps/generic/libc-tls.c (__libc_setup_tls): Initialize
dl_tls_static_align and dl_tls_static_nelem.

ChangeLog
sysdeps/generic/dl-tls.c
sysdeps/generic/libc-tls.c

index da29fd2..f8678cf 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,12 @@
+2002-08-12  Roland McGrath  <roland@redhat.com>
+
+       * sysdeps/generic/dl-tls.c (_dl_allocate_tls_init): Fix inner loop
+       start count condition, use TOTAL instead of variable that was never
+       set.  Fix outer loop termination condition to TOTAL >= after update.
+
+       * sysdeps/generic/libc-tls.c (__libc_setup_tls): Initialize
+       dl_tls_static_align and dl_tls_static_nelem.
+
 2002-08-11  Roland McGrath  <roland@redhat.com>
 
        * elf/tst-tlsmod4.c (in_dso): Insert a random library call before use
index 887f037..cb46460 100644 (file)
@@ -248,7 +248,6 @@ _dl_allocate_tls_init (void *result)
 {
   dtv_t *dtv = GET_DTV (result);
   struct dtv_slotinfo_list *listp;
-  bool first_block = true;
   size_t total = 0;
 
   /* We have to look prepare the dtv for all currently loaded
@@ -259,7 +258,7 @@ _dl_allocate_tls_init (void *result)
     {
       size_t cnt;
 
-      for (cnt = first_block ? 1 : 0; cnt < listp->len; ++cnt)
+      for (cnt = total == 0 ? 1 : 0; cnt < listp->len; ++cnt)
        {
          struct link_map *map;
          void *dest;
@@ -300,7 +299,7 @@ _dl_allocate_tls_init (void *result)
        }
 
       total += cnt;
-      if (total > GL(dl_tls_max_dtv_idx))
+      if (total >= GL(dl_tls_max_dtv_idx))
        break;
 
       listp = listp->next;
index af8b886..cc56a44 100644 (file)
@@ -162,11 +162,15 @@ __libc_setup_tls (size_t tcbsize, size_t tcbalign)
   GL(dl_tls_dtv_slotinfo_list) = &static_slotinfo.si;
 
   /* That is the size of the TLS memory for this object.  */
+  GL(dl_tls_static_size) = (roundup (memsz, align ?: 1)
 # if TLS_TCB_AT_TP
-  GL(dl_tls_static_size) = roundup (memsz, align ?: 1) + tcbsize;
-#else
-  GL(dl_tls_static_size) = roundup (memsz, align ?: 1);
-#endif
+                           + tcbsize
+# endif
+                           );
+  /* The alignment requirement for the static TLS block.  */
+  GL(dl_tls_static_align) = MAX (TLS_TCB_ALIGN, max_align);
+  /* Number of elements in the static TLS block.  */
+  GL(dl_tls_static_nelem) = GL(dl_tls_max_dtv_idx);
 }