mirror of
				https://github.com/python/cpython.git
				synced 2025-10-31 05:31:20 +00:00 
			
		
		
		
	 a3e2f054d2
			
		
	
	
		a3e2f054d2
		
			
		
	
	
	
	
		
			
			`_next_interp_id` appeared on [this commit](e377416c10 (diff-7ac11e526f79b42d6ea9d3592cb99da46775640c69fa5510f4a6de87cced7141R68)) renamed to `next_id` ([by this commit](2ebc5ce42a (diff-bccfc01bd96b58c022dde77486b8a896cbb31d7581bd4a4156b32c3654afe468R59))). Also, now, `next_id` gets initialized in` _PyInterpreterState_Enable()`12c5f328d2/Python/pystate.c (L241-L244)because `_PyInterpreterState_Init()` function doesn't exist at all.
		
			
				
	
	
		
			185 lines
		
	
	
	
		
			5.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			185 lines
		
	
	
	
		
			5.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #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
 | |
| 
 | |
| #include "pycore_atomic.h"          /* _Py_atomic_address */
 | |
| #include "pycore_gil.h"             // struct _gil_runtime_state
 | |
| #include "pycore_global_objects.h"  // struct _Py_global_objects
 | |
| #include "pycore_interp.h"          // PyInterpreterState
 | |
| #include "pycore_unicodeobject.h"   // struct _Py_unicode_runtime_ids
 | |
| 
 | |
| struct _getargs_runtime_state {
 | |
|    PyThread_type_lock mutex;
 | |
| };
 | |
| 
 | |
| /* ceval state */
 | |
| 
 | |
| struct _ceval_runtime_state {
 | |
|     /* Request for checking signals. It is shared by all interpreters (see
 | |
|        bpo-40513). Any thread of any interpreter can receive a signal, but only
 | |
|        the main thread of the main interpreter can handle signals: see
 | |
|        _Py_ThreadCanHandleSignals(). */
 | |
|     _Py_atomic_int signals_pending;
 | |
|     struct _gil_runtime_state gil;
 | |
| };
 | |
| 
 | |
| /* 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;
 | |
|     /* Assuming the current thread holds the GIL, this is the
 | |
|        PyThreadState for the current thread. */
 | |
|     _Py_atomic_address tstate_current;
 | |
|     /* The single PyInterpreterState used by this process'
 | |
|        GILState implementation
 | |
|     */
 | |
|     /* TODO: Given interp_main, it may be possible to kill this ref */
 | |
|     PyInterpreterState *autoInterpreterState;
 | |
|     Py_tss_t autoTSSkey;
 | |
| };
 | |
| 
 | |
| /* Runtime audit hook state */
 | |
| 
 | |
| typedef struct _Py_AuditHookEntry {
 | |
|     struct _Py_AuditHookEntry *next;
 | |
|     Py_AuditHookFunction hookCFunction;
 | |
|     void *userData;
 | |
| } _Py_AuditHookEntry;
 | |
| 
 | |
| /* Full Python runtime state */
 | |
| 
 | |
| /* _PyRuntimeState holds the global state for the CPython runtime.
 | |
|    That data is exposed in the internal API as a static variable (_PyRuntime).
 | |
|    */
 | |
| typedef struct pyruntimestate {
 | |
|     /* 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;
 | |
| 
 | |
|     /* 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;
 | |
| 
 | |
|     struct pyinterpreters {
 | |
|         PyThread_type_lock mutex;
 | |
|         /* The linked list of interpreters, newest first. */
 | |
|         PyInterpreterState *head;
 | |
|         /* The runtime's initial interpreter, which has a special role
 | |
|            in the operation of the runtime.  It is also often the only
 | |
|            interpreter. */
 | |
|         PyInterpreterState *main;
 | |
|         /* next_id is an auto-numbered sequence of small
 | |
|            integers.  It gets initialized in _PyInterpreterState_Enable(),
 | |
|            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;
 | |
| 
 | |
| #define NEXITFUNCS 32
 | |
|     void (*exitfuncs[NEXITFUNCS])(void);
 | |
|     int nexitfuncs;
 | |
| 
 | |
|     struct _ceval_runtime_state ceval;
 | |
|     struct _gilstate_runtime_state gilstate;
 | |
|     struct _getargs_runtime_state getargs;
 | |
| 
 | |
|     PyPreConfig preconfig;
 | |
| 
 | |
|     // Audit values must be preserved when Py_Initialize()/Py_Finalize()
 | |
|     // is called multiple times.
 | |
|     Py_OpenCodeHookFunction open_code_hook;
 | |
|     void *open_code_userdata;
 | |
|     _Py_AuditHookEntry *audit_hook_head;
 | |
| 
 | |
|     struct _Py_unicode_runtime_ids unicode_ids;
 | |
| 
 | |
|     /* All the objects that are shared by the runtime's interpreters. */
 | |
|     struct _Py_global_objects global_objects;
 | |
| 
 | |
|     /* 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;
 | |
| } _PyRuntimeState;
 | |
| 
 | |
| 
 | |
| /* other API */
 | |
| 
 | |
| PyAPI_DATA(_PyRuntimeState) _PyRuntime;
 | |
| 
 | |
| PyAPI_FUNC(PyStatus) _PyRuntimeState_Init(_PyRuntimeState *runtime);
 | |
| PyAPI_FUNC(void) _PyRuntimeState_Fini(_PyRuntimeState *runtime);
 | |
| 
 | |
| #ifdef HAVE_FORK
 | |
| extern PyStatus _PyRuntimeState_ReInitThreads(_PyRuntimeState *runtime);
 | |
| #endif
 | |
| 
 | |
| /* 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 */
 |