diff options
author | Brandt Bucher <brandtbucher@microsoft.com> | 2022-11-09 21:55:20 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-11-09 21:55:20 (GMT) |
commit | 283ab0e1c002f2d7459d581df6b4b8599e7d1a4d (patch) | |
tree | 15460072aff7041886d8e09b37c09c4051bddf40 | |
parent | 58ee5d8677fbd4c6c58b7a78117835bccede6bcd (diff) | |
download | cpython-283ab0e1c002f2d7459d581df6b4b8599e7d1a4d.zip cpython-283ab0e1c002f2d7459d581df6b4b8599e7d1a4d.tar.gz cpython-283ab0e1c002f2d7459d581df6b4b8599e7d1a4d.tar.bz2 |
GH-99205: Mark new interpreters and threads as non-static (GH-99268)
-rw-r--r-- | Misc/NEWS.d/next/Core and Builtins/2022-11-08-16-35-25.gh-issue-99205.2YOoFT.rst | 2 | ||||
-rw-r--r-- | Python/pystate.c | 8 |
2 files changed, 10 insertions, 0 deletions
diff --git a/Misc/NEWS.d/next/Core and Builtins/2022-11-08-16-35-25.gh-issue-99205.2YOoFT.rst b/Misc/NEWS.d/next/Core and Builtins/2022-11-08-16-35-25.gh-issue-99205.2YOoFT.rst new file mode 100644 index 0000000..8ad0e14 --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/2022-11-08-16-35-25.gh-issue-99205.2YOoFT.rst @@ -0,0 +1,2 @@ +Fix an issue that prevented :c:type:`PyThreadState` and +:c:type:`PyInterpreterState` memory from being freed properly. diff --git a/Python/pystate.c b/Python/pystate.c index dd6d6e9..df0f4e2 100644 --- a/Python/pystate.c +++ b/Python/pystate.c @@ -356,6 +356,7 @@ PyInterpreterState_New(void) interp = &runtime->_main_interpreter; assert(interp->id == 0); assert(interp->next == NULL); + assert(interp->_static); interpreters->main = interp; } @@ -370,6 +371,9 @@ PyInterpreterState_New(void) // Set to _PyInterpreterState_INIT. memcpy(interp, &initial._main_interpreter, sizeof(*interp)); + // We need to adjust any fields that are different from the initial + // interpreter (as defined in _PyInterpreterState_INIT): + interp->_static = false; if (id < 0) { /* overflow or Py_Initialize() not called yet! */ @@ -837,6 +841,7 @@ new_threadstate(PyInterpreterState *interp) assert(id == 1); used_newtstate = 0; tstate = &interp->_initial_thread; + assert(tstate->_static); } else { // Every valid interpreter must have at least one thread. @@ -848,6 +853,9 @@ new_threadstate(PyInterpreterState *interp) memcpy(tstate, &initial._main_interpreter._initial_thread, sizeof(*tstate)); + // We need to adjust any fields that are different from the initial + // thread (as defined in _PyThreadState_INIT): + tstate->_static = false; } interp->threads.head = tstate; |