htl: Fix cleaning the reply port
authorSamuel Thibault <samuel.thibault@ens-lyon.org>
Sat, 22 Jan 2022 00:12:05 +0000 (00:12 +0000)
committerSamuel Thibault <samuel.thibault@ens-lyon.org>
Sat, 22 Jan 2022 01:17:19 +0000 (02:17 +0100)
commit8c86ba446367fd676457e51eb44d7af2e5d9a392
tree110b0549f3a5708a1b27714d752fa1551e465f70
parente22a4557eb39d7cba9a74d70f4582c13f1a7a83a
htl: Fix cleaning the reply port

If any RPC fails, the reply port will already be deallocated.
__pthread_thread_terminate thus has to defer taking its name until the very last
__thread_terminate_release which doesn't reply a message.  But then we
have to read from the pthread structure.

This introduces __pthread_dealloc_finish() which does the recording of
the thread termination, so the slot can be reused really only just before
the __thread_terminate_release call. Only the real thread can set it, so
let's decouple this from the pthread_state by just removing the
PTHREAD_TERMINATED state and add a terminated field.
htl/pt-alloc.c
htl/pt-create.c
htl/pt-dealloc.c
htl/pt-detach.c
htl/pt-internal.h
htl/pt-join.c
sysdeps/mach/htl/pt-thread-terminate.c