blob: 50ad2fc83a361cbefe3e691fa096fefe03a44747 [file] [log] [blame]
Eric Snow2ebc5ce2017-09-07 23:51:28 -06001#ifndef Py_INTERNAL_PYSTATE_H
2#define Py_INTERNAL_PYSTATE_H
3#ifdef __cplusplus
4extern "C" {
5#endif
6
7#include "pystate.h"
8#include "pyatomic.h"
9#include "pythread.h"
10
11#include "internal/mem.h"
12#include "internal/ceval.h"
13#include "internal/warnings.h"
14
15
16/* GIL state */
17
18struct _gilstate_runtime_state {
19 int check_enabled;
20 /* Assuming the current thread holds the GIL, this is the
21 PyThreadState for the current thread. */
22 _Py_atomic_address tstate_current;
23 PyThreadFrameGetter getframe;
24 /* The single PyInterpreterState used by this process'
25 GILState implementation
26 */
27 /* TODO: Given interp_main, it may be possible to kill this ref */
28 PyInterpreterState *autoInterpreterState;
Masayuki Yamamoto731e1892017-10-06 19:41:34 +090029 Py_tss_t autoTSSkey;
Eric Snow2ebc5ce2017-09-07 23:51:28 -060030};
31
32/* hook for PyEval_GetFrame(), requested for Psyco */
33#define _PyThreadState_GetFrame _PyRuntime.gilstate.getframe
34
35/* Issue #26558: Flag to disable PyGILState_Check().
36 If set to non-zero, PyGILState_Check() always return 1. */
37#define _PyGILState_check_enabled _PyRuntime.gilstate.check_enabled
38
39
Victor Stinnerb64de462017-12-01 18:27:09 +010040typedef struct {
41 /* Full path to the Python program */
42 wchar_t *program_full_path;
43 wchar_t *prefix;
44#ifdef MS_WINDOWS
45 wchar_t *dll_path;
46#else
47 wchar_t *exec_prefix;
48#endif
49 /* Set by Py_SetPath(), or computed by _PyPathConfig_Init() */
50 wchar_t *module_search_path;
51} _PyPathConfig;
52
53#define _PyPathConfig_INIT {.module_search_path = NULL}
54
55
Eric Snow2ebc5ce2017-09-07 23:51:28 -060056/* Full Python runtime state */
57
58typedef struct pyruntimestate {
59 int initialized;
60 int core_initialized;
61 PyThreadState *finalizing;
62
63 struct pyinterpreters {
64 PyThread_type_lock mutex;
65 PyInterpreterState *head;
66 PyInterpreterState *main;
67 /* _next_interp_id is an auto-numbered sequence of small
68 integers. It gets initialized in _PyInterpreterState_Init(),
69 which is called in Py_Initialize(), and used in
70 PyInterpreterState_New(). A negative interpreter ID
71 indicates an error occurred. The main interpreter will
72 always have an ID of 0. Overflow results in a RuntimeError.
73 If that becomes a problem later then we can adjust, e.g. by
74 using a Python int. */
75 int64_t next_id;
76 } interpreters;
77
78#define NEXITFUNCS 32
79 void (*exitfuncs[NEXITFUNCS])(void);
80 int nexitfuncs;
81 void (*pyexitfunc)(void);
82
Eric Snow2ebc5ce2017-09-07 23:51:28 -060083 struct _gc_runtime_state gc;
Eric Snow2ebc5ce2017-09-07 23:51:28 -060084 struct _warnings_runtime_state warnings;
85 struct _ceval_runtime_state ceval;
86 struct _gilstate_runtime_state gilstate;
87
88 // XXX Consolidate globals found via the check-c-globals script.
89} _PyRuntimeState;
90
Victor Stinnerf7e5b562017-11-15 15:48:08 -080091#define _PyRuntimeState_INIT {.initialized = 0, .core_initialized = 0}
92
Eric Snow2ebc5ce2017-09-07 23:51:28 -060093PyAPI_DATA(_PyRuntimeState) _PyRuntime;
Victor Stinnerf7e5b562017-11-15 15:48:08 -080094PyAPI_FUNC(_PyInitError) _PyRuntimeState_Init(_PyRuntimeState *);
Eric Snow2ebc5ce2017-09-07 23:51:28 -060095PyAPI_FUNC(void) _PyRuntimeState_Fini(_PyRuntimeState *);
96
Victor Stinnerf7e5b562017-11-15 15:48:08 -080097/* Initialize _PyRuntimeState.
98 Return NULL on success, or return an error message on failure. */
99PyAPI_FUNC(_PyInitError) _PyRuntime_Initialize(void);
100
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600101#define _Py_CURRENTLY_FINALIZING(tstate) \
102 (_PyRuntime.finalizing == tstate)
103
104
105/* Other */
106
Victor Stinnera7368ac2017-11-15 18:11:45 -0800107PyAPI_FUNC(_PyInitError) _PyInterpreterState_Enable(_PyRuntimeState *);
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600108
109#ifdef __cplusplus
110}
111#endif
112#endif /* !Py_INTERNAL_PYSTATE_H */