[Python-checkins] bpo-40170: Fix PyType_Ready() refleak on static type (GH-23236)
vstinner
webhook-mailer at python.org
Wed Nov 11 08:28:01 EST 2020
https://github.com/python/cpython/commit/ba2958ed40d284228836735cbed4a155190e0998
commit: ba2958ed40d284228836735cbed4a155190e0998
branch: master
author: Victor Stinner <vstinner at python.org>
committer: vstinner <vstinner at python.org>
date: 2020-11-11T14:27:32+01:00
summary:
bpo-40170: Fix PyType_Ready() refleak on static type (GH-23236)
bpo-1635741, bpo-40170: When called on a static type with NULL
tp_base, PyType_Ready() no longer increments the reference count of
the PyBaseObject_Type ("object). PyTypeObject.tp_base is a strong
reference on a heap type, but it is borrowed reference on a static
type.
Fix 99 reference leaks at Python exit (showrefcount 18623 => 18524).
files:
M Include/cpython/object.h
M Objects/typeobject.c
diff --git a/Include/cpython/object.h b/Include/cpython/object.h
index ec6a364767776..43b0be37557a3 100644
--- a/Include/cpython/object.h
+++ b/Include/cpython/object.h
@@ -244,6 +244,7 @@ struct _typeobject {
struct PyMethodDef *tp_methods;
struct PyMemberDef *tp_members;
struct PyGetSetDef *tp_getset;
+ // Strong reference on a heap type, borrowed reference on a static type
struct _typeobject *tp_base;
PyObject *tp_dict;
descrgetfunc tp_descr_get;
diff --git a/Objects/typeobject.c b/Objects/typeobject.c
index 4d0a3faeceb89..fd018b8b032fe 100644
--- a/Objects/typeobject.c
+++ b/Objects/typeobject.c
@@ -5487,8 +5487,13 @@ PyType_Ready(PyTypeObject *type)
/* Initialize tp_base (defaults to BaseObject unless that's us) */
base = type->tp_base;
if (base == NULL && type != &PyBaseObject_Type) {
- base = type->tp_base = &PyBaseObject_Type;
- Py_INCREF(base);
+ base = &PyBaseObject_Type;
+ if (type->tp_flags & Py_TPFLAGS_HEAPTYPE) {
+ type->tp_base = (PyTypeObject*)Py_NewRef((PyObject*)base);
+ }
+ else {
+ type->tp_base = base;
+ }
}
/* Now the only way base can still be NULL is if type is
More information about the Python-checkins
mailing list