summaryrefslogtreecommitdiffstats
path: root/Python
diff options
context:
space:
mode:
authorVictor Stinner <vstinner@python.org>2020-05-05 14:52:52 (GMT)
committerGitHub <noreply@github.com>2020-05-05 14:52:52 (GMT)
commit4e30ed3af06ae655f4cb8aad8cba21f341384250 (patch)
treebb32e34e7c6a587446b41fea6a8f7ffac8a0c6d9 /Python
parent627f7012353411590434a7d5777ddcbcc8d97fcd (diff)
downloadcpython-4e30ed3af06ae655f4cb8aad8cba21f341384250.zip
cpython-4e30ed3af06ae655f4cb8aad8cba21f341384250.tar.gz
cpython-4e30ed3af06ae655f4cb8aad8cba21f341384250.tar.bz2
bpo-40513: Per-interpreter recursion_limit (GH-19929)
Move recursion_limit member from _PyRuntimeState.ceval to PyInterpreterState.ceval. * Py_SetRecursionLimit() now only sets _Py_CheckRecursionLimit of ceval.c if the current Python thread is part of the main interpreter. * Inline _Py_MakeEndRecCheck() into _Py_LeaveRecursiveCall(). * Convert _Py_RecursionLimitLowerWaterMark() macro into a static inline function.
Diffstat (limited to 'Python')
-rw-r--r--Python/ceval.c24
1 files changed, 14 insertions, 10 deletions
diff --git a/Python/ceval.c b/Python/ceval.c
index 6b00273..601e21a 100644
--- a/Python/ceval.c
+++ b/Python/ceval.c
@@ -699,7 +699,6 @@ int _Py_CheckRecursionLimit = Py_DEFAULT_RECURSION_LIMIT;
void
_PyEval_InitRuntimeState(struct _ceval_runtime_state *ceval)
{
- ceval->recursion_limit = Py_DEFAULT_RECURSION_LIMIT;
_Py_CheckRecursionLimit = Py_DEFAULT_RECURSION_LIMIT;
_gil_initialize(&ceval->gil);
}
@@ -707,6 +706,8 @@ _PyEval_InitRuntimeState(struct _ceval_runtime_state *ceval)
int
_PyEval_InitState(struct _ceval_state *ceval)
{
+ ceval->recursion_limit = Py_DEFAULT_RECURSION_LIMIT;
+
struct _pending_calls *pending = &ceval->pending;
assert(pending->lock == NULL);
@@ -730,16 +731,18 @@ _PyEval_FiniState(struct _ceval_state *ceval)
int
Py_GetRecursionLimit(void)
{
- struct _ceval_runtime_state *ceval = &_PyRuntime.ceval;
- return ceval->recursion_limit;
+ PyThreadState *tstate = _PyThreadState_GET();
+ return tstate->interp->ceval.recursion_limit;
}
void
Py_SetRecursionLimit(int new_limit)
{
- struct _ceval_runtime_state *ceval = &_PyRuntime.ceval;
- ceval->recursion_limit = new_limit;
- _Py_CheckRecursionLimit = new_limit;
+ PyThreadState *tstate = _PyThreadState_GET();
+ tstate->interp->ceval.recursion_limit = new_limit;
+ if (_Py_IsMainInterpreter(tstate)) {
+ _Py_CheckRecursionLimit = new_limit;
+ }
}
/* The function _Py_EnterRecursiveCall() only calls _Py_CheckRecursiveCall()
@@ -750,8 +753,7 @@ Py_SetRecursionLimit(int new_limit)
int
_Py_CheckRecursiveCall(PyThreadState *tstate, const char *where)
{
- _PyRuntimeState *runtime = tstate->interp->runtime;
- int recursion_limit = runtime->ceval.recursion_limit;
+ int recursion_limit = tstate->interp->ceval.recursion_limit;
#ifdef USE_STACKCHECK
tstate->stackcheck_counter = 0;
@@ -760,8 +762,10 @@ _Py_CheckRecursiveCall(PyThreadState *tstate, const char *where)
_PyErr_SetString(tstate, PyExc_MemoryError, "Stack overflow");
return -1;
}
- /* Needed for ABI backwards-compatibility (see bpo-31857) */
- _Py_CheckRecursionLimit = recursion_limit;
+ if (_Py_IsMainInterpreter(tstate)) {
+ /* Needed for ABI backwards-compatibility (see bpo-31857) */
+ _Py_CheckRecursionLimit = recursion_limit;
+ }
#endif
if (tstate->recursion_critical)
/* Somebody asked that we don't check for recursion. */