]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
bpo-36854: Fix refleak in subinterpreter (GH-17331)
authorVictor Stinner <vstinner@python.org>
Fri, 22 Nov 2019 09:58:00 +0000 (10:58 +0100)
committerGitHub <noreply@github.com>
Fri, 22 Nov 2019 09:58:00 +0000 (10:58 +0100)
finalize_interp_clear() now explicitly clears the codec registry and
then trigger a GC collection to clear all references.

Modules/_testcapimodule.c
Python/pylifecycle.c

index baa6907b7e4f66d93c3eca895d0ce8f5fac1b73b..0908f3457f580d51607b3d7c405f9e3cdc473c0b 100644 (file)
@@ -6721,11 +6721,14 @@ PyInit__testcapi(void)
     PyModule_AddObject(m, "instancemethod", (PyObject *)&PyInstanceMethod_Type);
 
     PyModule_AddIntConstant(m, "the_number_three", 3);
+    PyObject *v;
 #ifdef WITH_PYMALLOC
-    PyModule_AddObject(m, "WITH_PYMALLOC", Py_True);
+    v = Py_True;
 #else
-    PyModule_AddObject(m, "WITH_PYMALLOC", Py_False);
+    v = Py_False;
 #endif
+    Py_INCREF(v);
+    PyModule_AddObject(m, "WITH_PYMALLOC", v);
 
     TestError = PyErr_NewException("_testcapi.error", NULL, NULL);
     Py_INCREF(TestError);
index 7591f069b455d2c38ddd8df2a13d553bf776ec07..8c508e33800eff529682fbdf3bbac485753c0624 100644 (file)
@@ -1210,6 +1210,14 @@ finalize_interp_clear(PyThreadState *tstate)
 {
     int is_main_interp = _Py_IsMainInterpreter(tstate);
 
+    /* bpo-36854: Explicitly clear the codec registry
+       and trigger a GC collection */
+    PyInterpreterState *interp = tstate->interp;
+    Py_CLEAR(interp->codec_search_path);
+    Py_CLEAR(interp->codec_search_cache);
+    Py_CLEAR(interp->codec_error_registry);
+    _PyGC_CollectNoFail();
+
     /* Clear interpreter state and all thread states */
     PyInterpreterState_Clear(tstate->interp);