Feature or enhancement
CPython's current reference counting implementation would not be thread-safe without the GIL. In --disable-gil builds, we should implement biased reference counting, which is thread-safe and has lower execution overhead compared to plain atomic reference counting. The design is described in the "Biased Reference Counting" section of PEP 703.
This will require changing the PyObject struct in --disable-gil builds. I expect the --disable-gil struct to look like:
struct _object {
uintptr_t ob_tid;
uint16_t _padding;
uint8_t ob_mutex;
uint8_t ob_gc_bits;
uint32_t ob_ref_local;
Py_ssize_t ob_ref_shared;
PyTypeObject *ob_type;
};
Not all the fields will be used immediately, but it will be easier to include them as part of implementing this change.
I intend to split the implementation across (at least) two PRs to make it easier to review.
- The first PR will add the new
PyObject fields and implement the core biased reference counting operations, but not the inter-thread queue to reduce the initial complexity. (done)
- A later PR will implement the inter-thread queue. (not yet implemented)
The inter-thread queue is needed eventually (before actually disabling the GIL), but since the --disable-gil builds still currently require the GIL, it doesn't have to be in the initial PR.
Linked PRs
Feature or enhancement
CPython's current reference counting implementation would not be thread-safe without the GIL. In
--disable-gilbuilds, we should implement biased reference counting, which is thread-safe and has lower execution overhead compared to plain atomic reference counting. The design is described in the "Biased Reference Counting" section of PEP 703.This will require changing the
PyObjectstruct in--disable-gilbuilds. I expect the--disable-gilstruct to look like:Not all the fields will be used immediately, but it will be easier to include them as part of implementing this change.
I intend to split the implementation across (at least) two PRs to make it easier to review.
PyObjectfields and implement the core biased reference counting operations, but not the inter-thread queue to reduce the initial complexity. (done)The inter-thread queue is needed eventually (before actually disabling the GIL), but since the
--disable-gilbuilds still currently require the GIL, it doesn't have to be in the initial PR.Linked PRs
is_shared_refcnt_dead. #111974