diff options
author | Rich Felker <dalias@aerifal.cx> | 2018-05-04 14:26:31 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2018-05-05 11:09:51 -0400 |
commit | 526e64f54d729947b35fd39129bc86cbc0b5f098 (patch) | |
tree | d13eff2e89069dadfff5ea537c56f422847f8def /src/internal | |
parent | 4df42163511182bfd6fc55e85250b93786dcce7e (diff) | |
download | musl-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.h | 1 |
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; |