mirror of
https://github.com/johndoe6345789/typthon.git
synced 2026-05-02 17:45:51 +00:00
b198f511d2
Massive automated renaming of all Py_/PyObject/etc. prefixes to Ty_/TyObject/etc. This includes: - All public API types (TyObject, TyTypeObject, etc.) - All public API functions (Ty_Initialize, Ty_BuildValue, etc.) - All internal API (_Ty_ prefixes) - Reference counting macros (Ty_INCREF, Ty_DECREF, etc.) - Type flags (Ty_TPFLAGS_*) - Debug flags (Ty_DEBUG, Ty_TRACE_REFS, etc.) - All object type APIs (TyList_, TyDict_, TyUnicode_, etc.) This changes over 60,000 occurrences across 1000+ files. Co-authored-by: johndoe6345789 <224850594+johndoe6345789@users.noreply.github.com>
67 lines
2.1 KiB
C
67 lines
2.1 KiB
C
#ifndef Ty_INTERNAL_GIL_H
|
|
#define Ty_INTERNAL_GIL_H
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#ifndef Ty_BUILD_CORE
|
|
# error "this header requires Ty_BUILD_CORE define"
|
|
#endif
|
|
|
|
#include "pycore_condvar.h" // PyCOND_T
|
|
|
|
#ifndef Ty_HAVE_CONDVAR
|
|
# error You need either a POSIX-compatible or a Windows system!
|
|
#endif
|
|
|
|
/* Enable if you want to force the switching of threads at least
|
|
every `interval`. */
|
|
#undef FORCE_SWITCHING
|
|
#define FORCE_SWITCHING
|
|
|
|
struct _gil_runtime_state {
|
|
#ifdef Ty_GIL_DISABLED
|
|
/* If this GIL is disabled, enabled == 0.
|
|
|
|
If this GIL is enabled transiently (most likely to initialize a module
|
|
of unknown safety), enabled indicates the number of active transient
|
|
requests.
|
|
|
|
If this GIL is enabled permanently, enabled == INT_MAX.
|
|
|
|
It must not be modified directly; use _TyEval_EnableGILTransiently(),
|
|
_TyEval_EnableGILPermanently(), and _TyEval_DisableGIL()
|
|
|
|
It is always read and written atomically, but a thread can assume its
|
|
value will be stable as long as that thread is attached or knows that no
|
|
other threads are attached (e.g., during a stop-the-world.). */
|
|
int enabled;
|
|
#endif
|
|
/* microseconds (the Python API uses seconds, though) */
|
|
unsigned long interval;
|
|
/* Last PyThreadState holding / having held the GIL. This helps us
|
|
know whether anyone else was scheduled after we dropped the GIL. */
|
|
PyThreadState* last_holder;
|
|
/* Whether the GIL is already taken (-1 if uninitialized). This is
|
|
atomic because it can be read without any lock taken in ceval.c. */
|
|
int locked;
|
|
/* Number of GIL switches since the beginning. */
|
|
unsigned long switch_number;
|
|
/* This condition variable allows one or several threads to wait
|
|
until the GIL is released. In addition, the mutex also protects
|
|
the above variables. */
|
|
PyCOND_T cond;
|
|
PyMUTEX_T mutex;
|
|
#ifdef FORCE_SWITCHING
|
|
/* This condition variable helps the GIL-releasing thread wait for
|
|
a GIL-awaiting thread to be scheduled and take the GIL. */
|
|
PyCOND_T switch_cond;
|
|
PyMUTEX_T switch_mutex;
|
|
#endif
|
|
};
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif /* !Ty_INTERNAL_GIL_H */
|