summaryrefslogtreecommitdiffstats
path: root/Python
diff options
context:
space:
mode:
authorVictor Stinner <vstinner@python.org>2020-03-10 22:49:16 (GMT)
committerGitHub <noreply@github.com>2020-03-10 22:49:16 (GMT)
commit4e53abb0f4773e1cce68a4f41ddbb43e74364c5f (patch)
tree355a5073945fa5045a4b1354f9468c589d6d9158 /Python
parent88f82b2b9ea3514359cb6e3218121f75334063ac (diff)
downloadcpython-4e53abb0f4773e1cce68a4f41ddbb43e74364c5f.zip
cpython-4e53abb0f4773e1cce68a4f41ddbb43e74364c5f.tar.gz
cpython-4e53abb0f4773e1cce68a4f41ddbb43e74364c5f.tar.bz2
bpo-38631: _PyGILState_Init() returns PyStatus (GH-18908)
_PyGILState_Init() now returns PyStatus rather than calling Py_FatalError() on failure.
Diffstat (limited to 'Python')
-rw-r--r--Python/pylifecycle.c5
-rw-r--r--Python/pystate.c5
2 files changed, 7 insertions, 3 deletions
diff --git a/Python/pylifecycle.c b/Python/pylifecycle.c
index d00bf82..bc32eff 100644
--- a/Python/pylifecycle.c
+++ b/Python/pylifecycle.c
@@ -551,7 +551,10 @@ pycore_create_interpreter(_PyRuntimeState *runtime,
_PyEval_FiniThreads(&runtime->ceval);
/* Auto-thread-state API */
- _PyGILState_Init(tstate);
+ status = _PyGILState_Init(tstate);
+ if (_PyStatus_EXCEPTION(status)) {
+ return status;
+ }
/* Create the GIL */
status = _PyEval_InitThreads(tstate);
diff --git a/Python/pystate.c b/Python/pystate.c
index a926e97..504f5f4 100644
--- a/Python/pystate.c
+++ b/Python/pystate.c
@@ -1147,7 +1147,7 @@ PyThreadState_IsCurrent(PyThreadState *tstate)
/* Internal initialization/finalization functions called by
Py_Initialize/Py_FinalizeEx
*/
-void
+PyStatus
_PyGILState_Init(PyThreadState *tstate)
{
/* must init with valid states */
@@ -1157,13 +1157,14 @@ _PyGILState_Init(PyThreadState *tstate)
struct _gilstate_runtime_state *gilstate = &tstate->interp->runtime->gilstate;
if (PyThread_tss_create(&gilstate->autoTSSkey) != 0) {
- Py_FatalError("Could not allocate TSS entry");
+ return _PyStatus_NO_MEMORY();
}
gilstate->autoInterpreterState = tstate->interp;
assert(PyThread_tss_get(&gilstate->autoTSSkey) == NULL);
assert(tstate->gilstate_counter == 0);
_PyGILState_NoteThreadState(gilstate, tstate);
+ return _PyStatus_OK();
}
PyInterpreterState *