diff options
author | Victor Stinner <vstinner@python.org> | 2020-03-09 20:24:14 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-03-09 20:24:14 (GMT) |
commit | 111e4ee52a1739e7c7221adde2fc364ef4954af2 (patch) | |
tree | 5b68666e414dbef941f07667a55ad9c4e45463b9 /Python/ceval.c | |
parent | 3225b9f9739cd4bcca372d0fa939cea1ae5c6402 (diff) | |
download | cpython-111e4ee52a1739e7c7221adde2fc364ef4954af2.zip cpython-111e4ee52a1739e7c7221adde2fc364ef4954af2.tar.gz cpython-111e4ee52a1739e7c7221adde2fc364ef4954af2.tar.bz2 |
bpo-39877: Py_Initialize() pass tstate to PyEval_InitThreads() (GH-18884)
Diffstat (limited to 'Python/ceval.c')
-rw-r--r-- | Python/ceval.c | 30 |
1 files changed, 22 insertions, 8 deletions
diff --git a/Python/ceval.c b/Python/ceval.c index 26cefead..208fdab 100644 --- a/Python/ceval.c +++ b/Python/ceval.c @@ -13,6 +13,7 @@ #include "pycore_call.h" #include "pycore_ceval.h" #include "pycore_code.h" +#include "pycore_initconfig.h" #include "pycore_object.h" #include "pycore_pyerrors.h" #include "pycore_pylifecycle.h" @@ -214,26 +215,39 @@ PyEval_ThreadsInitialized(void) return gil_created(&runtime->ceval.gil); } -void -PyEval_InitThreads(void) +PyStatus +_PyEval_InitThreads(PyThreadState *tstate) { - _PyRuntimeState *runtime = &_PyRuntime; - struct _ceval_runtime_state *ceval = &runtime->ceval; + if (tstate == NULL) { + return _PyStatus_ERR("tstate is NULL"); + } + + struct _ceval_runtime_state *ceval = &tstate->interp->runtime->ceval; struct _gil_runtime_state *gil = &ceval->gil; if (gil_created(gil)) { - return; + return _PyStatus_OK(); } PyThread_init_thread(); create_gil(gil); - PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime); - ensure_tstate_not_null(__func__, tstate); take_gil(ceval, tstate); struct _pending_calls *pending = &ceval->pending; pending->lock = PyThread_allocate_lock(); if (pending->lock == NULL) { - Py_FatalError("Can't initialize threads for pending calls"); + return _PyStatus_NO_MEMORY(); + } + return _PyStatus_OK(); +} + +void +PyEval_InitThreads(void) +{ + PyThreadState *tstate = _PyThreadState_GET(); + + PyStatus status = _PyEval_InitThreads(tstate); + if (_PyStatus_EXCEPTION(status)) { + Py_ExitStatusException(status); } } |