[hurd,commited] htl: Destroy thread-specific data before releasing joins

Message ID 20220214182943.2931015-1-samuel.thibault@ens-lyon.org
State Committed, archived
Commit 7a06be051c01b4325927efab5b4e4280bb4a5a42
Headers
Series [hurd,commited] htl: Destroy thread-specific data before releasing joins |

Checks

Context Check Description
dj/TryBot-apply_patch fail Patch failed to apply to master at the time it was sent
dj/TryBot-32bit fail Patch series failed to apply

Commit Message

Samuel Thibault Feb. 14, 2022, 6:29 p.m. UTC
  Applications may want to assume that after pthread_join() returns, all
thread-specific data has been released.
---
 htl/pt-exit.c | 6 +++---
 1 file changed, 3 insertions(+), 3 deletions(-)
  

Patch

diff --git a/htl/pt-exit.c b/htl/pt-exit.c
index db1c14c520..f0759c8738 100644
--- a/htl/pt-exit.c
+++ b/htl/pt-exit.c
@@ -54,6 +54,9 @@  __pthread_exit (void *status)
     /* We are the last thread.  */
     exit (0);
 
+  /* Destroy any thread specific data.  */
+  __pthread_destroy_specific (self);
+
   /* Note that after this point the process can be terminated at any
      point if another thread calls `pthread_exit' and happens to be
      the last thread.  */
@@ -92,9 +95,6 @@  __pthread_exit (void *status)
       break;
     }
 
-  /* Destroy any thread specific data.  */
-  __pthread_destroy_specific (self);
-
   /* Destroy any signal state.  */
   __pthread_sigstate_destroy (self);