| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  | #ifndef Py_INTERNAL_RUNTIME_H
 | 
					
						
							|  |  |  | #define Py_INTERNAL_RUNTIME_H
 | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef Py_BUILD_CORE
 | 
					
						
							|  |  |  | #  error "this header requires Py_BUILD_CORE define"
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-05 18:42:02 -06:00
										 |  |  | #include "pycore_atexit.h"          // struct atexit_runtime_state
 | 
					
						
							| 
									
										
										
										
											2021-12-13 18:04:05 -07:00
										 |  |  | #include "pycore_atomic.h"          /* _Py_atomic_address */
 | 
					
						
							| 
									
										
										
										
											2022-12-08 17:17:20 -07:00
										 |  |  | #include "pycore_ceval_state.h"     // struct _ceval_runtime_state
 | 
					
						
							| 
									
										
										
										
											2022-11-16 09:37:14 -07:00
										 |  |  | #include "pycore_floatobject.h"     // struct _Py_float_runtime_state
 | 
					
						
							| 
									
										
										
										
											2022-12-12 09:58:46 -07:00
										 |  |  | #include "pycore_faulthandler.h"    // struct _faulthandler_runtime_state
 | 
					
						
							| 
									
										
										
										
											2021-12-13 18:04:05 -07:00
										 |  |  | #include "pycore_global_objects.h"  // struct _Py_global_objects
 | 
					
						
							| 
									
										
										
										
											2022-11-11 14:16:28 -07:00
										 |  |  | #include "pycore_import.h"          // struct _import_runtime_state
 | 
					
						
							| 
									
										
										
										
											2022-03-03 23:08:07 +01:00
										 |  |  | #include "pycore_interp.h"          // PyInterpreterState
 | 
					
						
							| 
									
										
										
										
											2023-03-20 10:03:04 -06:00
										 |  |  | #include "pycore_object_state.h"    // struct _py_object_runtime_state
 | 
					
						
							| 
									
										
										
										
											2022-12-07 15:56:31 -07:00
										 |  |  | #include "pycore_parser.h"          // struct _parser_runtime_state
 | 
					
						
							| 
									
										
										
										
											2022-11-11 16:30:46 -07:00
										 |  |  | #include "pycore_pymem.h"           // struct _pymem_allocators
 | 
					
						
							| 
									
										
										
										
											2022-11-16 09:37:14 -07:00
										 |  |  | #include "pycore_pyhash.h"          // struct pyhash_runtime_state
 | 
					
						
							| 
									
										
										
										
											2022-12-08 17:50:58 -07:00
										 |  |  | #include "pycore_pythread.h"        // struct _pythread_runtime_state
 | 
					
						
							| 
									
										
										
										
											2022-11-11 16:30:46 -07:00
										 |  |  | #include "pycore_obmalloc.h"        // struct obmalloc_state
 | 
					
						
							| 
									
										
										
										
											2022-12-12 16:50:19 -07:00
										 |  |  | #include "pycore_signal.h"          // struct _signals_runtime_state
 | 
					
						
							| 
									
										
										
										
											2022-12-08 16:46:09 -07:00
										 |  |  | #include "pycore_time.h"            // struct _time_runtime_state
 | 
					
						
							| 
									
										
										
										
											2022-12-12 08:44:23 -07:00
										 |  |  | #include "pycore_tracemalloc.h"     // struct _tracemalloc_runtime_state
 | 
					
						
							| 
									
										
										
										
											2023-04-24 16:30:13 -06:00
										 |  |  | #include "pycore_typeobject.h"      // struct types_runtime_state
 | 
					
						
							| 
									
										
										
										
											2021-12-13 18:04:05 -07:00
										 |  |  | #include "pycore_unicodeobject.h"   // struct _Py_unicode_runtime_ids
 | 
					
						
							| 
									
										
										
										
											2021-11-03 16:22:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-16 23:52:14 +05:30
										 |  |  | struct _getargs_runtime_state { | 
					
						
							| 
									
										
										
										
											2022-11-15 09:45:11 -07:00
										 |  |  |     PyThread_type_lock mutex; | 
					
						
							|  |  |  |     struct _PyArg_Parser *static_parsers; | 
					
						
							| 
									
										
										
										
											2022-08-16 23:52:14 +05:30
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2022-01-12 16:28:46 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  | /* ceval state */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* GIL state */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct _gilstate_runtime_state { | 
					
						
							|  |  |  |     /* bpo-26558: Flag to disable PyGILState_Check().
 | 
					
						
							|  |  |  |        If set to non-zero, PyGILState_Check() always return 1. */ | 
					
						
							|  |  |  |     int check_enabled; | 
					
						
							|  |  |  |     /* The single PyInterpreterState used by this process'
 | 
					
						
							|  |  |  |        GILState implementation | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  |     /* TODO: Given interp_main, it may be possible to kill this ref */ | 
					
						
							|  |  |  |     PyInterpreterState *autoInterpreterState; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Runtime audit hook state */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct _Py_AuditHookEntry { | 
					
						
							|  |  |  |     struct _Py_AuditHookEntry *next; | 
					
						
							|  |  |  |     Py_AuditHookFunction hookCFunction; | 
					
						
							|  |  |  |     void *userData; | 
					
						
							|  |  |  | } _Py_AuditHookEntry; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Full Python runtime state */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-12 16:28:46 -07:00
										 |  |  | /* _PyRuntimeState holds the global state for the CPython runtime.
 | 
					
						
							|  |  |  |    That data is exposed in the internal API as a static variable (_PyRuntime). | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  | typedef struct pyruntimestate { | 
					
						
							| 
									
										
										
										
											2021-12-07 18:59:49 -07:00
										 |  |  |     /* Has been initialized to a safe state.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        In order to be effective, this must be set to 0 during or right | 
					
						
							|  |  |  |        after allocation. */ | 
					
						
							|  |  |  |     int _initialized; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  |     /* Is running Py_PreInitialize()? */ | 
					
						
							|  |  |  |     int preinitializing; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Is Python preinitialized? Set to 1 by Py_PreInitialize() */ | 
					
						
							|  |  |  |     int preinitialized; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Is Python core initialized? Set to 1 by _Py_InitializeCore() */ | 
					
						
							|  |  |  |     int core_initialized; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Is Python fully initialized? Set to 1 by Py_Initialize() */ | 
					
						
							|  |  |  |     int initialized; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Set by Py_FinalizeEx(). Only reset to NULL if Py_Initialize()
 | 
					
						
							|  |  |  |        is called again. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        Use _PyRuntimeState_GetFinalizing() and _PyRuntimeState_SetFinalizing() | 
					
						
							|  |  |  |        to access it, don't access it directly. */ | 
					
						
							|  |  |  |     _Py_atomic_address _finalizing; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-11 16:30:46 -07:00
										 |  |  |     struct _pymem_allocators allocators; | 
					
						
							|  |  |  |     struct _obmalloc_state obmalloc; | 
					
						
							| 
									
										
										
										
											2022-11-16 09:37:14 -07:00
										 |  |  |     struct pyhash_runtime_state pyhash_state; | 
					
						
							| 
									
										
										
										
											2022-12-08 16:46:09 -07:00
										 |  |  |     struct _time_runtime_state time; | 
					
						
							| 
									
										
										
										
											2022-12-08 17:50:58 -07:00
										 |  |  |     struct _pythread_runtime_state threads; | 
					
						
							| 
									
										
										
										
											2022-12-12 16:50:19 -07:00
										 |  |  |     struct _signals_runtime_state signals; | 
					
						
							| 
									
										
										
										
											2022-11-11 16:30:46 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  |     struct pyinterpreters { | 
					
						
							|  |  |  |         PyThread_type_lock mutex; | 
					
						
							| 
									
										
										
										
											2022-01-12 16:28:46 -07:00
										 |  |  |         /* The linked list of interpreters, newest first. */ | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  |         PyInterpreterState *head; | 
					
						
							| 
									
										
										
										
											2022-01-12 16:28:46 -07:00
										 |  |  |         /* The runtime's initial interpreter, which has a special role
 | 
					
						
							|  |  |  |            in the operation of the runtime.  It is also often the only | 
					
						
							|  |  |  |            interpreter. */ | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  |         PyInterpreterState *main; | 
					
						
							| 
									
										
										
										
											2022-09-20 22:54:33 +03:00
										 |  |  |         /* next_id is an auto-numbered sequence of small
 | 
					
						
							|  |  |  |            integers.  It gets initialized in _PyInterpreterState_Enable(), | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  |            which is called in Py_Initialize(), and used in | 
					
						
							|  |  |  |            PyInterpreterState_New().  A negative interpreter ID | 
					
						
							|  |  |  |            indicates an error occurred.  The main interpreter will | 
					
						
							|  |  |  |            always have an ID of 0.  Overflow results in a RuntimeError. | 
					
						
							|  |  |  |            If that becomes a problem later then we can adjust, e.g. by | 
					
						
							|  |  |  |            using a Python int. */ | 
					
						
							|  |  |  |         int64_t next_id; | 
					
						
							|  |  |  |     } interpreters; | 
					
						
							|  |  |  |     // XXX Remove this field once we have a tp_* slot.
 | 
					
						
							|  |  |  |     struct _xidregistry { | 
					
						
							|  |  |  |         PyThread_type_lock mutex; | 
					
						
							|  |  |  |         struct _xidregitem *head; | 
					
						
							|  |  |  |     } xidregistry; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     unsigned long main_thread; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-19 16:04:14 -07:00
										 |  |  |     /* Used for the thread state bound to the current thread. */ | 
					
						
							|  |  |  |     Py_tss_t autoTSSkey; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-23 08:30:20 -07:00
										 |  |  |     /* Used instead of PyThreadState.trash when there is not current tstate. */ | 
					
						
							|  |  |  |     Py_tss_t trashTSSkey; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-07 15:56:31 -07:00
										 |  |  |     PyWideStringList orig_argv; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     struct _parser_runtime_state parser; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-05 18:42:02 -06:00
										 |  |  |     struct _atexit_runtime_state atexit; | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-11 14:16:28 -07:00
										 |  |  |     struct _import_runtime_state imports; | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  |     struct _ceval_runtime_state ceval; | 
					
						
							|  |  |  |     struct _gilstate_runtime_state gilstate; | 
					
						
							| 
									
										
										
										
											2022-08-16 23:52:14 +05:30
										 |  |  |     struct _getargs_runtime_state getargs; | 
					
						
							| 
									
										
										
										
											2022-11-16 09:37:14 -07:00
										 |  |  |     struct _fileutils_state fileutils; | 
					
						
							| 
									
										
										
										
											2022-12-12 09:58:46 -07:00
										 |  |  |     struct _faulthandler_runtime_state faulthandler; | 
					
						
							| 
									
										
										
										
											2022-12-12 08:44:23 -07:00
										 |  |  |     struct _tracemalloc_runtime_state tracemalloc; | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     PyPreConfig preconfig; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-12 10:29:45 +01:00
										 |  |  |     // Audit values must be preserved when Py_Initialize()/Py_Finalize()
 | 
					
						
							|  |  |  |     // is called multiple times.
 | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  |     Py_OpenCodeHookFunction open_code_hook; | 
					
						
							|  |  |  |     void *open_code_userdata; | 
					
						
							|  |  |  |     _Py_AuditHookEntry *audit_hook_head; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-20 10:03:04 -06:00
										 |  |  |     struct _py_object_runtime_state object_state; | 
					
						
							| 
									
										
										
										
											2022-11-16 09:37:14 -07:00
										 |  |  |     struct _Py_float_runtime_state float_state; | 
					
						
							|  |  |  |     struct _Py_unicode_runtime_state unicode_state; | 
					
						
							| 
									
										
										
										
											2023-04-24 16:30:13 -06:00
										 |  |  |     struct _types_runtime_state types; | 
					
						
							| 
									
										
										
										
											2022-11-14 13:50:56 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-12 16:28:46 -07:00
										 |  |  |     /* All the objects that are shared by the runtime's interpreters. */ | 
					
						
							| 
									
										
										
										
											2022-12-14 11:53:57 -07:00
										 |  |  |     struct _Py_static_objects static_objects; | 
					
						
							| 
									
										
										
										
											2022-01-12 16:28:46 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* The following fields are here to avoid allocation during init.
 | 
					
						
							|  |  |  |        The data is exposed through _PyRuntimeState pointer fields. | 
					
						
							|  |  |  |        These fields should not be accessed directly outside of init. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        All other _PyRuntimeState pointer fields are populated when | 
					
						
							|  |  |  |        needed and default to NULL. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        For now there are some exceptions to that rule, which require | 
					
						
							|  |  |  |        allocation during init.  These will be addressed on a case-by-case | 
					
						
							|  |  |  |        basis.  Most notably, we don't pre-allocated the several mutex | 
					
						
							|  |  |  |        (PyThread_type_lock) fields, because on Windows we only ever get | 
					
						
							|  |  |  |        a pointer type. | 
					
						
							|  |  |  |        */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* PyInterpreterState.interpreters.main */ | 
					
						
							|  |  |  |     PyInterpreterState _main_interpreter; | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  | } _PyRuntimeState; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-07 18:59:49 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-12 16:28:46 -07:00
										 |  |  | /* other API */ | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | PyAPI_DATA(_PyRuntimeState) _PyRuntime; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyAPI_FUNC(PyStatus) _PyRuntimeState_Init(_PyRuntimeState *runtime); | 
					
						
							|  |  |  | PyAPI_FUNC(void) _PyRuntimeState_Fini(_PyRuntimeState *runtime); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-15 01:16:24 +09:00
										 |  |  | #ifdef HAVE_FORK
 | 
					
						
							| 
									
										
										
										
											2020-06-02 15:51:37 +02:00
										 |  |  | extern PyStatus _PyRuntimeState_ReInitThreads(_PyRuntimeState *runtime); | 
					
						
							| 
									
										
										
										
											2020-04-15 01:16:24 +09:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2020-04-13 11:45:21 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Initialize _PyRuntimeState.
 | 
					
						
							|  |  |  |    Return NULL on success, or return an error message on failure. */ | 
					
						
							|  |  |  | PyAPI_FUNC(PyStatus) _PyRuntime_Initialize(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyAPI_FUNC(void) _PyRuntime_Finalize(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline PyThreadState* | 
					
						
							|  |  |  | _PyRuntimeState_GetFinalizing(_PyRuntimeState *runtime) { | 
					
						
							|  |  |  |     return (PyThreadState*)_Py_atomic_load_relaxed(&runtime->_finalizing); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void | 
					
						
							|  |  |  | _PyRuntimeState_SetFinalizing(_PyRuntimeState *runtime, PyThreadState *tstate) { | 
					
						
							|  |  |  |     _Py_atomic_store_relaxed(&runtime->_finalizing, (uintptr_t)tstate); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif /* !Py_INTERNAL_RUNTIME_H */
 |