gh-128691: Use deferred reference counting on _thread._local (#128693)

This change, along with the LOAD_ATTR specializations, makes the
"thread_local_read" micro benchmark in Tools/ftscalingbench/ftscalingbench.py
scale well to multiple threads.
This commit is contained in:
Sam Gross
2025-01-09 19:59:10 -05:00
committed by GitHub
parent 087bb48aca
commit c1417487e9

View File

@@ -1414,6 +1414,10 @@ local_new(PyTypeObject *type, PyObject *args, PyObject *kw)
return NULL;
}
// gh-128691: Use deferred reference counting for thread-locals to avoid
// contention on the shared object.
_PyObject_SetDeferredRefcount((PyObject *)self);
self->args = Py_XNewRef(args);
self->kw = Py_XNewRef(kw);