From: Tian Gao Date: Thu, 12 Oct 2023 14:10:21 +0000 (-0700) Subject: gh-110752: Reset `ceval.eval_breaker` to 0 in `interpreter_clear` (GH-110753) X-Git-Tag: v3.13.0a1~15 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=1e3460d9faaffb35b3c6175c666b1f45aea2c1d8;p=thirdparty%2FPython%2Fcpython.git gh-110752: Reset `ceval.eval_breaker` to 0 in `interpreter_clear` (GH-110753) --- diff --git a/Misc/NEWS.d/next/Core and Builtins/2023-10-12-06-32-25.gh-issue-110752.FYfI0h.rst b/Misc/NEWS.d/next/Core and Builtins/2023-10-12-06-32-25.gh-issue-110752.FYfI0h.rst new file mode 100644 index 000000000000..fa1a59ec927b --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/2023-10-12-06-32-25.gh-issue-110752.FYfI0h.rst @@ -0,0 +1 @@ +Reset ``ceval.eval_breaker`` in :func:`interpreter_clear` diff --git a/Python/pystate.c b/Python/pystate.c index 2086bd619df9..92cf741f4ca4 100644 --- a/Python/pystate.c +++ b/Python/pystate.c @@ -890,6 +890,10 @@ interpreter_clear(PyInterpreterState *interp, PyThreadState *tstate) Py_CLEAR(interp->audit_hooks); + // At this time, all the threads should be cleared so we don't need + // atomic operations for eval_breaker + interp->ceval.eval_breaker = 0; + for (int i = 0; i < _PY_MONITORING_UNGROUPED_EVENTS; i++) { interp->monitors.tools[i] = 0; }