Bug report
Bug description:
Bug report
Description
In builtin_sum_impl() (Python/bltinmodule.c), the complex-number fast
path tests items with PyFloat_Check() but releases them with
_Py_DECREF_SPECIALIZED(item, _PyFloat_ExactDealloc).
PyFloat_Check() also matches subclasses of float, whereas
_PyFloat_ExactDealloc is only valid for exact float objects. When a
float subclass instance reaches refcount 0 through this path, it is
deallocated as an exact float, bypassing its real tp_dealloc
(instance __dict__, weakref list, and GC bookkeeping). This can leak
memory and leave the cyclic GC in an inconsistent state.
The adjacent float fast path in the same function already guards the
identical specialized dealloc with PyFloat_CheckExact(); only the
complex branch uses the broader PyFloat_Check().
Reproducer
class F(float):
pass
# complex start value selects the complex fast path
sum([F(1.0), F(2.0)], 0j)
Proposed fix
In the complex branch, use PyFloat_CheckExact(item) instead of
PyFloat_Check(item), so subclass instances fall through to the generic
PyNumber_Add path with a normal Py_DECREF. Numeric behavior is
unchanged.
Environment
- CPython: main branch (please confirm the line is still present)
CPython versions tested on:
CPython main branch
Operating systems tested on:
Linux
Linked PRs
Bug report
Bug description:
Bug report
Description
In
builtin_sum_impl()(Python/bltinmodule.c), the complex-number fastpath tests items with
PyFloat_Check()but releases them with_Py_DECREF_SPECIALIZED(item, _PyFloat_ExactDealloc).PyFloat_Check()also matches subclasses offloat, whereas_PyFloat_ExactDeallocis only valid for exactfloatobjects. When afloatsubclass instance reaches refcount 0 through this path, it isdeallocated as an exact float, bypassing its real
tp_dealloc(instance
__dict__, weakref list, and GC bookkeeping). This can leakmemory and leave the cyclic GC in an inconsistent state.
The adjacent float fast path in the same function already guards the
identical specialized dealloc with
PyFloat_CheckExact(); only thecomplex branch uses the broader
PyFloat_Check().Reproducer
Proposed fix
In the complex branch, use
PyFloat_CheckExact(item)instead ofPyFloat_Check(item), so subclass instances fall through to the genericPyNumber_Addpath with a normalPy_DECREF. Numeric behavior isunchanged.
Environment
CPython versions tested on:
CPython main branch
Operating systems tested on:
Linux
Linked PRs