Will be committed for 2.37
commit
302bf01641d0addebe2aea69b9924bd781f76d81
Author: Samuel Thibault <samuel.thibault@ens-lyon.org>
Date: Thu Jul 28 22:01:49 2022 +0200
htl: Let pthread_self and cancellability called early
When applications redirect some functions they might get called before
libpthread is fully initialized. They may still expected pthread_self
and cancellable functions to work, so cope with such calls in that
situation.
Gbp-Pq: Topic hurd-i386
Gbp-Pq: Name git-htl-pthread-self-early.diff
struct __pthread *p = _pthread_self ();
int oldtype;
+ if (___pthread_self == NULL)
+ /* We are not initialized yet, we can't be cancelled anyway. */
+ return PTHREAD_CANCEL_DEFERRED;
+
__pthread_mutex_lock (&p->cancel_lock);
oldtype = p->cancel_type;
p->cancel_type = PTHREAD_CANCEL_ASYNCHRONOUS;
{
struct __pthread *p = _pthread_self ();
+ if (___pthread_self == NULL)
+ /* We are not initialized yet, we can't be cancelled anyway. */
+ return;
+
__pthread_mutex_lock (&p->cancel_lock);
p->cancel_type = oldtype;
__pthread_mutex_unlock (&p->cancel_lock);
pthread_t
__pthread_self (void)
{
- struct __pthread *self = _pthread_self ();
+ struct __pthread *self;
+
+ if (___pthread_self == NULL)
+ /* We are not initialized yet, we are the first thread. */
+ return 1;
+
+ self = _pthread_self ();
assert (self != NULL);
return self->thread;