| 
									
										
										
										
											2017-09-07 23:51:28 -06:00
										 |  |  | #ifndef Py_INTERNAL_PYSTATE_H
 | 
					
						
							|  |  |  | #define Py_INTERNAL_PYSTATE_H
 | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 23:02:26 +02:00
										 |  |  | #ifndef Py_BUILD_CORE
 | 
					
						
							|  |  |  | #  error "this header requires Py_BUILD_CORE define"
 | 
					
						
							| 
									
										
										
										
											2018-11-01 01:51:40 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-21 20:05:59 +02:00
										 |  |  | #include "pycore_runtime.h"       // _PyRuntime
 | 
					
						
							| 
									
										
										
										
											2017-09-07 23:51:28 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-05 15:46:33 +00:00
										 |  |  | // Values for PyThreadState.state. A thread must be in the "attached" state
 | 
					
						
							|  |  |  | // before calling most Python APIs. If the GIL is enabled, then "attached"
 | 
					
						
							|  |  |  | // implies that the thread holds the GIL and "detached" implies that the
 | 
					
						
							|  |  |  | // thread does not hold the GIL (or is in the process of releasing it). In
 | 
					
						
							|  |  |  | // `--disable-gil` builds, multiple threads may be "attached" to the same
 | 
					
						
							|  |  |  | // interpreter at the same time. Only the "bound" thread may perform the
 | 
					
						
							|  |  |  | // transitions between "attached" and "detached" on its own PyThreadState.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // The "gc" state is used to implement stop-the-world pauses, such as for
 | 
					
						
							|  |  |  | // cyclic garbage collection. It is only used in `--disable-gil` builds. It is
 | 
					
						
							|  |  |  | // similar to the "detached" state, but only the thread performing a
 | 
					
						
							|  |  |  | // stop-the-world pause may transition threads between the "detached" and "gc"
 | 
					
						
							|  |  |  | // states. A thread trying to "attach" from the "gc" state will block until
 | 
					
						
							|  |  |  | // it is transitioned back to "detached" when the stop-the-world pause is
 | 
					
						
							|  |  |  | // complete.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // State transition diagram:
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //            (bound thread)        (stop-the-world thread)
 | 
					
						
							|  |  |  | // [attached]       <->       [detached]       <->       [gc]
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // See `_PyThreadState_Attach()` and `_PyThreadState_Detach()`.
 | 
					
						
							|  |  |  | #define _Py_THREAD_DETACHED     0
 | 
					
						
							|  |  |  | #define _Py_THREAD_ATTACHED     1
 | 
					
						
							|  |  |  | #define _Py_THREAD_GC           2
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 13:38:58 +01:00
										 |  |  | /* Check if the current thread is the main thread.
 | 
					
						
							|  |  |  |    Use _Py_IsMainInterpreter() to check if it's the main interpreter. */ | 
					
						
							|  |  |  | static inline int | 
					
						
							|  |  |  | _Py_IsMainThread(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     unsigned long thread = PyThread_get_thread_ident(); | 
					
						
							|  |  |  |     return (thread == _PyRuntime.main_thread); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-07 18:56:06 -07:00
										 |  |  | static inline PyInterpreterState * | 
					
						
							|  |  |  | _PyInterpreterState_Main(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return _PyRuntime.interpreters.main; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 13:38:58 +01:00
										 |  |  | static inline int | 
					
						
							| 
									
										
										
										
											2021-02-19 13:33:31 +01:00
										 |  |  | _Py_IsMainInterpreter(PyInterpreterState *interp) | 
					
						
							| 
									
										
										
										
											2020-03-20 13:38:58 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2021-12-07 18:56:06 -07:00
										 |  |  |     return (interp == _PyInterpreterState_Main()); | 
					
						
							| 
									
										
										
										
											2020-03-20 13:38:58 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-24 17:23:57 -06:00
										 |  |  | static inline int | 
					
						
							|  |  |  | _Py_IsMainInterpreterFinalizing(PyInterpreterState *interp) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2023-09-27 13:41:06 -06:00
										 |  |  |     /* bpo-39877: Access _PyRuntime directly rather than using
 | 
					
						
							|  |  |  |        tstate->interp->runtime to support calls from Python daemon threads. | 
					
						
							|  |  |  |        After Py_Finalize() has been called, tstate can be a dangling pointer: | 
					
						
							|  |  |  |        point to PyThreadState freed memory. */ | 
					
						
							|  |  |  |     return (_PyRuntimeState_GetFinalizing(&_PyRuntime) != NULL && | 
					
						
							|  |  |  |             interp == &_PyRuntime._main_interpreter); | 
					
						
							| 
									
										
										
										
											2023-04-24 17:23:57 -06:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-02 14:12:12 -06:00
										 |  |  | // Export for _xxsubinterpreters module.
 | 
					
						
							|  |  |  | PyAPI_FUNC(int) _PyInterpreterState_SetRunningMain(PyInterpreterState *); | 
					
						
							|  |  |  | PyAPI_FUNC(void) _PyInterpreterState_SetNotRunningMain(PyInterpreterState *); | 
					
						
							|  |  |  | PyAPI_FUNC(int) _PyInterpreterState_IsRunningMain(PyInterpreterState *); | 
					
						
							| 
									
										
										
										
											2023-10-03 09:20:48 -06:00
										 |  |  | PyAPI_FUNC(int) _PyInterpreterState_FailIfRunningMain(PyInterpreterState *); | 
					
						
							| 
									
										
										
										
											2023-10-02 14:12:12 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 13:38:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-27 10:00:32 -06:00
										 |  |  | static inline const PyConfig * | 
					
						
							|  |  |  | _Py_GetMainConfig(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2021-12-07 18:56:06 -07:00
										 |  |  |     PyInterpreterState *interp = _PyInterpreterState_Main(); | 
					
						
							| 
									
										
										
										
											2021-09-27 10:00:32 -06:00
										 |  |  |     if (interp == NULL) { | 
					
						
							|  |  |  |         return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return _PyInterpreterState_GetConfig(interp); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-20 13:38:58 +01:00
										 |  |  | /* Only handle signals on the main thread of the main interpreter. */ | 
					
						
							|  |  |  | static inline int | 
					
						
							| 
									
										
										
										
											2020-04-08 23:35:05 +02:00
										 |  |  | _Py_ThreadCanHandleSignals(PyInterpreterState *interp) | 
					
						
							| 
									
										
										
										
											2020-03-20 13:38:58 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2021-12-07 18:56:06 -07:00
										 |  |  |     return (_Py_IsMainThread() && _Py_IsMainInterpreter(interp)); | 
					
						
							| 
									
										
										
										
											2020-03-20 13:38:58 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2019-11-20 17:34:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-07 23:51:28 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-04 16:21:01 +02:00
										 |  |  | /* Variable and static inline functions for in-line access to current thread
 | 
					
						
							| 
									
										
										
										
											2018-11-01 01:51:40 +01:00
										 |  |  |    and interpreter state */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-24 11:17:02 -06:00
										 |  |  | #if defined(HAVE_THREAD_LOCAL) && !defined(Py_BUILD_CORE_MODULE)
 | 
					
						
							|  |  |  | extern _Py_thread_local PyThreadState *_Py_tss_tstate; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2023-08-24 17:40:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-08 11:50:46 +02:00
										 |  |  | #ifndef NDEBUG
 | 
					
						
							|  |  |  | extern int _PyThreadState_CheckConsistency(PyThreadState *tstate); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-11 17:27:03 +02:00
										 |  |  | int _PyThreadState_MustExit(PyThreadState *tstate); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-24 17:40:56 +02:00
										 |  |  | // Export for most shared extensions, used via _PyThreadState_GET() static
 | 
					
						
							|  |  |  | // inline function.
 | 
					
						
							| 
									
										
										
										
											2023-07-25 05:48:04 +02:00
										 |  |  | PyAPI_FUNC(PyThreadState *) _PyThreadState_GetCurrent(void); | 
					
						
							| 
									
										
										
										
											2019-05-10 23:39:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-01 01:51:40 +01:00
										 |  |  | /* Get the current Python thread state.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-24 11:17:02 -06:00
										 |  |  |    This function is unsafe: it does not check for error and it can return NULL. | 
					
						
							| 
									
										
										
										
											2018-11-01 01:51:40 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |    The caller must hold the GIL. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-03 18:53:51 +02:00
										 |  |  |    See also PyThreadState_Get() and PyThreadState_GetUnchecked(). */ | 
					
						
							| 
									
										
										
										
											2020-05-05 19:56:48 +02:00
										 |  |  | static inline PyThreadState* | 
					
						
							|  |  |  | _PyThreadState_GET(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2023-04-24 11:17:02 -06:00
										 |  |  | #if defined(HAVE_THREAD_LOCAL) && !defined(Py_BUILD_CORE_MODULE)
 | 
					
						
							|  |  |  |     return _Py_tss_tstate; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |     return _PyThreadState_GetCurrent(); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-05 15:46:33 +00:00
										 |  |  | // Attaches the current thread to the interpreter.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // This may block while acquiring the GIL (if the GIL is enabled) or while
 | 
					
						
							|  |  |  | // waiting for a stop-the-world pause (if the GIL is disabled).
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // High-level code should generally call PyEval_RestoreThread() instead, which
 | 
					
						
							|  |  |  | // calls this function.
 | 
					
						
							|  |  |  | void _PyThreadState_Attach(PyThreadState *tstate); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Detaches the current thread from the interpreter.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // High-level code should generally call PyEval_SaveThread() instead, which
 | 
					
						
							|  |  |  | // calls this function.
 | 
					
						
							|  |  |  | void _PyThreadState_Detach(PyThreadState *tstate); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-24 11:17:02 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-01 16:02:40 +02:00
										 |  |  | static inline void | 
					
						
							|  |  |  | _Py_EnsureFuncTstateNotNULL(const char *func, PyThreadState *tstate) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     if (tstate == NULL) { | 
					
						
							| 
									
										
										
										
											2022-08-24 14:21:01 +01:00
										 |  |  |         _Py_FatalErrorFunc(func, | 
					
						
							|  |  |  |             "the function must be called with the GIL held, " | 
					
						
							|  |  |  |             "after Python initialization and before Python finalization, " | 
					
						
							|  |  |  |             "but the GIL is released (the current Python thread state is NULL)"); | 
					
						
							| 
									
										
										
										
											2020-06-01 16:02:40 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Call Py_FatalError() if tstate is NULL
 | 
					
						
							|  |  |  | #define _Py_EnsureTstateNotNULL(tstate) \
 | 
					
						
							| 
									
										
										
										
											2022-06-20 16:04:52 +02:00
										 |  |  |     _Py_EnsureFuncTstateNotNULL(__func__, (tstate)) | 
					
						
							| 
									
										
										
										
											2020-06-01 16:02:40 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-01 01:51:40 +01:00
										 |  |  | /* Get the current interpreter state.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-04 16:21:01 +02:00
										 |  |  |    The function is unsafe: it does not check for error and it can return NULL. | 
					
						
							| 
									
										
										
										
											2018-11-01 01:51:40 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |    The caller must hold the GIL. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-02 01:44:07 +02:00
										 |  |  |    See also PyInterpreterState_Get() | 
					
						
							| 
									
										
										
										
											2018-11-01 01:51:40 +01:00
										 |  |  |    and _PyGILState_GetInterpreterStateUnsafe(). */ | 
					
						
							| 
									
										
										
										
											2020-04-14 15:14:01 +02:00
										 |  |  | static inline PyInterpreterState* _PyInterpreterState_GET(void) { | 
					
						
							| 
									
										
										
										
											2020-04-08 23:35:05 +02:00
										 |  |  |     PyThreadState *tstate = _PyThreadState_GET(); | 
					
						
							| 
									
										
										
										
											2020-06-01 16:02:40 +02:00
										 |  |  | #ifdef Py_DEBUG
 | 
					
						
							|  |  |  |     _Py_EnsureTstateNotNULL(tstate); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2020-04-08 23:35:05 +02:00
										 |  |  |     return tstate->interp; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-11-01 01:51:40 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-15 16:06:30 +02:00
										 |  |  | // PyThreadState functions
 | 
					
						
							| 
									
										
										
										
											2017-09-07 23:51:28 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-03 09:20:48 -06:00
										 |  |  | extern PyThreadState * _PyThreadState_New( | 
					
						
							|  |  |  |     PyInterpreterState *interp, | 
					
						
							|  |  |  |     int whence); | 
					
						
							| 
									
										
										
										
											2023-07-25 03:49:28 +02:00
										 |  |  | extern void _PyThreadState_Bind(PyThreadState *tstate); | 
					
						
							|  |  |  | extern void _PyThreadState_DeleteExcept(PyThreadState *tstate); | 
					
						
							| 
									
										
										
										
											2023-12-26 11:53:20 -05:00
										 |  |  | extern void _PyThreadState_ClearMimallocHeaps(PyThreadState *tstate); | 
					
						
							| 
									
										
										
										
											2019-05-10 23:39:09 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 03:49:28 +02:00
										 |  |  | // Export for '_testinternalcapi' shared extension
 | 
					
						
							| 
									
										
										
										
											2023-07-02 03:39:38 +02:00
										 |  |  | PyAPI_FUNC(PyObject*) _PyThreadState_GetDict(PyThreadState *tstate); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* The implementation of sys._current_exceptions()  Returns a dict mapping
 | 
					
						
							|  |  |  |    thread id to that thread's current exception. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | extern PyObject* _PyThread_CurrentExceptions(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-15 16:06:30 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Other */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 03:49:28 +02:00
										 |  |  | extern PyThreadState * _PyThreadState_Swap( | 
					
						
							| 
									
										
										
										
											2023-01-19 16:04:14 -07:00
										 |  |  |     _PyRuntimeState *runtime, | 
					
						
							| 
									
										
										
										
											2019-05-10 23:39:09 +02:00
										 |  |  |     PyThreadState *newts); | 
					
						
							| 
									
										
										
										
											2019-04-24 16:47:40 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 03:49:28 +02:00
										 |  |  | extern PyStatus _PyInterpreterState_Enable(_PyRuntimeState *runtime); | 
					
						
							| 
									
										
										
										
											2019-04-24 17:14:33 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-02 15:51:37 +02:00
										 |  |  | #ifdef HAVE_FORK
 | 
					
						
							|  |  |  | extern PyStatus _PyInterpreterState_DeleteExceptMain(_PyRuntimeState *runtime); | 
					
						
							|  |  |  | extern void _PySignal_AfterFork(void); | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2017-09-07 23:51:28 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 03:49:28 +02:00
										 |  |  | // Export for the stable ABI
 | 
					
						
							| 
									
										
										
										
											2023-02-16 14:05:31 -07:00
										 |  |  | PyAPI_FUNC(int) _PyState_AddModule( | 
					
						
							|  |  |  |     PyThreadState *tstate, | 
					
						
							|  |  |  |     PyObject* module, | 
					
						
							|  |  |  |     PyModuleDef* def); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-25 03:49:28 +02:00
										 |  |  | extern int _PyOS_InterruptOccurred(PyThreadState *tstate); | 
					
						
							| 
									
										
										
										
											2020-06-03 14:39:59 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-15 20:39:26 +05:30
										 |  |  | #define HEAD_LOCK(runtime) \
 | 
					
						
							| 
									
										
										
										
											2023-12-07 14:33:40 -05:00
										 |  |  |     PyMutex_LockFlags(&(runtime)->interpreters.mutex, _Py_LOCK_DONT_DETACH) | 
					
						
							| 
									
										
										
										
											2023-01-15 20:39:26 +05:30
										 |  |  | #define HEAD_UNLOCK(runtime) \
 | 
					
						
							| 
									
										
										
										
											2023-12-07 14:33:40 -05:00
										 |  |  |     PyMutex_Unlock(&(runtime)->interpreters.mutex) | 
					
						
							| 
									
										
										
										
											2023-01-15 20:39:26 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-07-02 03:39:38 +02:00
										 |  |  | // Get the configuration of the current interpreter.
 | 
					
						
							|  |  |  | // The caller must hold the GIL.
 | 
					
						
							| 
									
										
										
										
											2023-07-25 03:49:28 +02:00
										 |  |  | // Export for test_peg_generator.
 | 
					
						
							| 
									
										
										
										
											2023-07-02 03:39:38 +02:00
										 |  |  | PyAPI_FUNC(const PyConfig*) _Py_GetConfig(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-29 04:44:38 +02:00
										 |  |  | // Get the single PyInterpreterState used by this process' GILState
 | 
					
						
							|  |  |  | // implementation.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // This function doesn't check for error. Return NULL before _PyGILState_Init()
 | 
					
						
							|  |  |  | // is called and after _PyGILState_Fini() is called.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // See also PyInterpreterState_Get() and _PyInterpreterState_GET().
 | 
					
						
							|  |  |  | extern PyInterpreterState* _PyGILState_GetInterpreterStateUnsafe(void); | 
					
						
							| 
									
										
										
										
											2023-01-15 20:39:26 +05:30
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-07 23:51:28 -06:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* !Py_INTERNAL_PYSTATE_H */
 |