]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
[3.11] gh-109795: `_thread.start_new_thread`: allocate thread bootstate usin… (#109852)
authorVictor Stinner <vstinner@python.org>
Mon, 25 Sep 2023 16:12:43 +0000 (18:12 +0200)
committerGitHub <noreply@github.com>
Mon, 25 Sep 2023 16:12:43 +0000 (18:12 +0200)
gh-109795: `_thread.start_new_thread`: allocate thread bootstate using raw memory allocator (#109808)

(cherry picked from commit 1b8f2366b38c87b0450d9c15bdfdd4c4a2fc3a01)

Co-authored-by: Radislav Chugunov <52372310+chgnrdv@users.noreply.github.com>
Modules/_threadmodule.c

index ac49ee5c35d4b366c54e74ce0d58ad5a6aaa755e..72eda4917ab860cb0b88985315f140226f60d892 100644 (file)
@@ -1068,7 +1068,7 @@ thread_bootstate_free(struct bootstate *boot, int decref)
         Py_DECREF(boot->args);
         Py_XDECREF(boot->kwargs);
     }
-    PyMem_Free(boot);
+    PyMem_RawFree(boot);
 }
 
 
@@ -1164,13 +1164,16 @@ thread_PyThread_start_new_thread(PyObject *self, PyObject *fargs)
         return NULL;
     }
 
-    struct bootstate *boot = PyMem_NEW(struct bootstate, 1);
+    // gh-109795: Use PyMem_RawMalloc() instead of PyMem_Malloc(),
+    // because it should be possible to call thread_bootstate_free()
+    // without holding the GIL.
+    struct bootstate *boot = PyMem_RawMalloc(sizeof(struct bootstate));
     if (boot == NULL) {
         return PyErr_NoMemory();
     }
     boot->tstate = _PyThreadState_Prealloc(interp);
     if (boot->tstate == NULL) {
-        PyMem_Free(boot);
+        PyMem_RawFree(boot);
         return PyErr_NoMemory();
     }
     boot->func = Py_NewRef(func);