mirror of
https://github.com/python/cpython.git
synced 2025-08-31 14:07:50 +00:00
gh-81057: Move Threading-Related Globals to _PyRuntimeState (#100084)
https://github.com/python/cpython/issues/81057
This commit is contained in:
parent
bc8cdf8c3d
commit
1160001b34
11 changed files with 114 additions and 54 deletions
|
@ -8,15 +8,7 @@
|
|||
#include "Python.h"
|
||||
#include "pycore_pystate.h" // _PyInterpreterState_GET()
|
||||
#include "pycore_structseq.h" // _PyStructSequence_FiniType()
|
||||
|
||||
#ifndef _POSIX_THREADS
|
||||
/* This means pthreads are not implemented in libc headers, hence the macro
|
||||
not present in unistd.h. But they still can be implemented as an external
|
||||
library (e.g. gnu pth in pthread emulation) */
|
||||
# ifdef HAVE_PTHREAD_H
|
||||
# include <pthread.h> /* _POSIX_THREADS */
|
||||
# endif
|
||||
#endif
|
||||
#include "pycore_pythread.h"
|
||||
|
||||
#ifndef DONT_HAVE_STDIO_H
|
||||
#include <stdio.h>
|
||||
|
@ -24,33 +16,17 @@
|
|||
|
||||
#include <stdlib.h>
|
||||
|
||||
#ifndef _POSIX_THREADS
|
||||
|
||||
/* Check if we're running on HP-UX and _SC_THREADS is defined. If so, then
|
||||
enough of the Posix threads package is implemented to support python
|
||||
threads.
|
||||
|
||||
This is valid for HP-UX 11.23 running on an ia64 system. If needed, add
|
||||
a check of __ia64 to verify that we're running on an ia64 system instead
|
||||
of a pa-risc system.
|
||||
*/
|
||||
#ifdef __hpux
|
||||
#ifdef _SC_THREADS
|
||||
#define _POSIX_THREADS
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#endif /* _POSIX_THREADS */
|
||||
|
||||
static int initialized;
|
||||
|
||||
static void PyThread__init_thread(void); /* Forward */
|
||||
|
||||
#define initialized _PyRuntime.threads.initialized
|
||||
|
||||
void
|
||||
PyThread_init_thread(void)
|
||||
{
|
||||
if (initialized)
|
||||
if (initialized) {
|
||||
return;
|
||||
}
|
||||
initialized = 1;
|
||||
PyThread__init_thread();
|
||||
}
|
||||
|
@ -58,7 +34,7 @@ PyThread_init_thread(void)
|
|||
#if defined(HAVE_PTHREAD_STUBS)
|
||||
# define PYTHREAD_NAME "pthread-stubs"
|
||||
# include "thread_pthread_stubs.h"
|
||||
#elif defined(_POSIX_THREADS)
|
||||
#elif defined(_USE_PTHREADS) /* AKA _PTHREADS */
|
||||
# if defined(__EMSCRIPTEN__) && !defined(__EMSCRIPTEN_PTHREADS__)
|
||||
# define PYTHREAD_NAME "pthread-stubs"
|
||||
# else
|
||||
|
|
|
@ -152,11 +152,12 @@ unsigned long PyThread_get_thread_native_id(void);
|
|||
#endif
|
||||
|
||||
/*
|
||||
* Initialization of the C package, should not be needed.
|
||||
* Initialization for the current runtime.
|
||||
*/
|
||||
static void
|
||||
PyThread__init_thread(void)
|
||||
{
|
||||
// Initialization of the C package should not be needed.
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
|
@ -119,20 +119,16 @@
|
|||
* pthread_cond support
|
||||
*/
|
||||
|
||||
#if defined(HAVE_PTHREAD_CONDATTR_SETCLOCK) && defined(HAVE_CLOCK_GETTIME) && defined(CLOCK_MONOTONIC)
|
||||
// monotonic is supported statically. It doesn't mean it works on runtime.
|
||||
#define CONDATTR_MONOTONIC
|
||||
#endif
|
||||
|
||||
// NULL when pthread_condattr_setclock(CLOCK_MONOTONIC) is not supported.
|
||||
static pthread_condattr_t *condattr_monotonic = NULL;
|
||||
#define condattr_monotonic _PyRuntime.threads._condattr_monotonic.ptr
|
||||
|
||||
static void
|
||||
init_condattr(void)
|
||||
{
|
||||
#ifdef CONDATTR_MONOTONIC
|
||||
static pthread_condattr_t ca;
|
||||
# define ca _PyRuntime.threads._condattr_monotonic.val
|
||||
// XXX We need to check the return code?
|
||||
pthread_condattr_init(&ca);
|
||||
// XXX We need to run pthread_condattr_destroy() during runtime fini.
|
||||
if (pthread_condattr_setclock(&ca, CLOCK_MONOTONIC) == 0) {
|
||||
condattr_monotonic = &ca; // Use monotonic clock
|
||||
}
|
||||
|
@ -192,15 +188,21 @@ typedef struct {
|
|||
"%s: %s\n", name, strerror(status)); error = 1; }
|
||||
|
||||
/*
|
||||
* Initialization.
|
||||
* Initialization for the current runtime.
|
||||
*/
|
||||
static void
|
||||
PyThread__init_thread(void)
|
||||
{
|
||||
// The library is only initialized once in the process,
|
||||
// regardless of how many times the Python runtime is initialized.
|
||||
static int lib_initialized = 0;
|
||||
if (!lib_initialized) {
|
||||
lib_initialized = 1;
|
||||
#if defined(_AIX) && defined(__GNUC__)
|
||||
extern void pthread_init(void);
|
||||
pthread_init();
|
||||
extern void pthread_init(void);
|
||||
pthread_init();
|
||||
#endif
|
||||
}
|
||||
init_condattr();
|
||||
}
|
||||
|
||||
|
|
|
@ -124,13 +124,10 @@ pthread_attr_destroy(pthread_attr_t *attr)
|
|||
return 0;
|
||||
}
|
||||
|
||||
// pthread_key
|
||||
typedef struct {
|
||||
bool in_use;
|
||||
void *value;
|
||||
} py_tls_entry;
|
||||
|
||||
static py_tls_entry py_tls_entries[PTHREAD_KEYS_MAX] = {0};
|
||||
typedef struct py_stub_tls_entry py_tls_entry;
|
||||
|
||||
#define py_tls_entries (_PyRuntime.threads.stubs.tls_entries)
|
||||
|
||||
int
|
||||
pthread_key_create(pthread_key_t *key, void (*destr_function)(void *))
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue