]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
gh-116604: Correctly honor the gc status when calling _Py_RunGC (#116628)
authorPablo Galindo Salgado <Pablogsal@gmail.com>
Tue, 12 Mar 2024 12:00:49 +0000 (12:00 +0000)
committerGitHub <noreply@github.com>
Tue, 12 Mar 2024 12:00:49 +0000 (12:00 +0000)
Lib/test/test_gc.py
Misc/NEWS.d/next/Core and Builtins/2024-03-11-22-24-59.gh-issue-116604.LCEzAT.rst [new file with mode: 0644]
Python/gc.c

index dd09643788d62fbb5407e169a9d4061c509d3b4b..2aea025fcc140a686037852b6f1435e302a76242 100644 (file)
@@ -1397,6 +1397,31 @@ class GCTogglingTests(unittest.TestCase):
             # empty __dict__.
             self.assertEqual(x, None)
 
+    def test_indirect_calls_with_gc_disabled(self):
+        junk = []
+        i = 0
+        detector = GC_Detector()
+        while not detector.gc_happened:
+            i += 1
+            if i > 10000:
+                self.fail("gc didn't happen after 10000 iterations")
+            junk.append([])  # this will eventually trigger gc
+
+        try:
+            gc.disable()
+            junk = []
+            i = 0
+            detector = GC_Detector()
+            while not detector.gc_happened:
+                i += 1
+                if i > 10000:
+                    break
+                junk.append([])  # this may eventually trigger gc (if it is enabled)
+
+            self.assertEqual(i, 10001)
+        finally:
+            gc.enable()
+
 
 class PythonFinalizationTests(unittest.TestCase):
     def test_ast_fini(self):
diff --git a/Misc/NEWS.d/next/Core and Builtins/2024-03-11-22-24-59.gh-issue-116604.LCEzAT.rst b/Misc/NEWS.d/next/Core and Builtins/2024-03-11-22-24-59.gh-issue-116604.LCEzAT.rst
new file mode 100644 (file)
index 0000000..516edfa
--- /dev/null
@@ -0,0 +1,3 @@
+Respect the status of the garbage collector when indirect calls are made via
+:c:func:`PyErr_CheckSignals` and the evaluation breaker. Patch by Pablo
+Galindo
index ea3b596d1713dfc2ed89e2d2ffc48413cad61edb..6b3316b642ea9e64b8c8eabd02b2128ce9aa32b1 100644 (file)
@@ -1805,6 +1805,10 @@ _PyObject_GC_Link(PyObject *op)
 void
 _Py_RunGC(PyThreadState *tstate)
 {
+    GCState *gcstate = get_gc_state();
+    if (!gcstate->enabled) {
+        return;
+    }
     gc_collect_main(tstate, GENERATION_AUTO, _Py_GC_REASON_HEAP);
 }