summaryrefslogtreecommitdiff
path: root/src/internal
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2018-05-04 14:26:31 -0400
committerRich Felker <dalias@aerifal.cx>2018-05-05 11:09:51 -0400
commit526e64f54d729947b35fd39129bc86cbc0b5f098 (patch)
treed13eff2e89069dadfff5ea537c56f422847f8def /src/internal
parent4df42163511182bfd6fc55e85250b93786dcce7e (diff)
downloadmusl-526e64f54d729947b35fd39129bc86cbc0b5f098.tar.gz
musl-526e64f54d729947b35fd39129bc86cbc0b5f098.tar.bz2
musl-526e64f54d729947b35fd39129bc86cbc0b5f098.tar.xz
musl-526e64f54d729947b35fd39129bc86cbc0b5f098.zip
improve pthread_exit synchronization with functions targeting tid
if the last thread exited via pthread_exit, the logic that marked it dead did not account for the possibility of it targeting itself via atexit handlers. for example, an atexit handler calling pthread_kill(pthread_self(), SIGKILL) would return success (previously, ESRCH) rather than causing termination via the signal. move the release of killlock after the determination is made whether the exiting thread is the last thread. in the case where it's not, move the release all the way to the end of the function. this way we can clear the tid rather than spending storage on a dedicated dead-flag. clearing the tid is also preferable in that it hardens against inadvertent use of the value after the thread has terminated but before it is joined.
Diffstat (limited to 'src/internal')
-rw-r--r--src/internal/pthread_impl.h1
1 files changed, 0 insertions, 1 deletions
diff --git a/src/internal/pthread_impl.h b/src/internal/pthread_impl.h
index f2805b89..3b4ad94d 100644
--- a/src/internal/pthread_impl.h
+++ b/src/internal/pthread_impl.h
@@ -34,7 +34,6 @@ struct pthread {
void *result;
struct __ptcb *cancelbuf;
void **tsd;
- volatile int dead;
struct {
volatile void *volatile head;
long off;