diff options
author | Victor Stinner <vstinner@python.org> | 2023-08-31 18:33:34 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-08-31 18:33:34 +0200 |
commit | 13a00078b81776b23b0b6add69b848382240d1f2 (patch) | |
tree | 612a10a02aeb749d9c5bff72133b2ae1d25a5cc6 /Python/hashtable.c | |
parent | 013a99a47b3299f48cf7f95aa451a116441b029c (diff) | |
download | cpython-13a00078b81776b23b0b6add69b848382240d1f2.tar.gz cpython-13a00078b81776b23b0b6add69b848382240d1f2.zip |
gh-108634: Py_TRACE_REFS uses a hash table (#108663)
Python built with "configure --with-trace-refs" (tracing references)
is now ABI compatible with Python release build and debug build.
Moreover, it now also supports the Limited API.
Change Py_TRACE_REFS build:
* Remove _PyObject_EXTRA_INIT macro.
* The PyObject structure no longer has two extra members (_ob_prev
and _ob_next).
* Use a hash table (_Py_hashtable_t) to trace references (all
objects): PyInterpreterState.object_state.refchain.
* Py_TRACE_REFS build is now ABI compatible with release build and
debug build.
* Limited C API extensions can now be built with Py_TRACE_REFS:
xxlimited, xxlimited_35, _testclinic_limited.
* No longer rename PyModule_Create2() and PyModule_FromDefAndSpec2()
functions to PyModule_Create2TraceRefs() and
PyModule_FromDefAndSpec2TraceRefs().
* _Py_PrintReferenceAddresses() is now called before
finalize_interp_delete() which deletes the refchain hash table.
* test_tracemalloc find_trace() now also filters by size to ignore
the memory allocated by _PyRefchain_Trace().
Test changes for Py_TRACE_REFS:
* Add test.support.Py_TRACE_REFS constant.
* Add test_sys.test_getobjects() to test sys.getobjects() function.
* test_exceptions skips test_recursion_normalizing_with_no_memory()
and test_memory_error_in_PyErr_PrintEx() if Python is built with
Py_TRACE_REFS.
* test_repl skips test_no_memory().
* test_capi skisp test_set_nomemory().
Diffstat (limited to 'Python/hashtable.c')
-rw-r--r-- | Python/hashtable.c | 1 |
1 files changed, 0 insertions, 1 deletions
diff --git a/Python/hashtable.c b/Python/hashtable.c index 4e22a1a5509..8f5e8168ba1 100644 --- a/Python/hashtable.c +++ b/Python/hashtable.c @@ -226,7 +226,6 @@ _Py_hashtable_set(_Py_hashtable_t *ht, const void *key, void *value) assert(entry == NULL); #endif - entry = ht->alloc.malloc(sizeof(_Py_hashtable_entry_t)); if (entry == NULL) { /* memory allocation failed */ |