mirror of
https://github.com/python/cpython.git
synced 2025-08-31 22:18:28 +00:00
gh-111926: Make weakrefs thread-safe in free-threaded builds (#117168)
Most mutable data is protected by a striped lock that is keyed on the referenced object's address. The weakref's hash is protected using the weakref's per-object lock. Note that this only affects free-threaded builds. Apart from some minor refactoring, the added code is all either gated by `ifdef`s or is a no-op (e.g. `Py_BEGIN_CRITICAL_SECTION`).
This commit is contained in:
parent
e16062dd34
commit
df73179048
17 changed files with 490 additions and 326 deletions
|
@ -4,7 +4,6 @@
|
|||
|
||||
#include "blob.h"
|
||||
#include "util.h"
|
||||
#include "pycore_weakref.h" // _PyWeakref_GET_REF()
|
||||
|
||||
#define clinic_state() (pysqlite_get_state_by_type(Py_TYPE(self)))
|
||||
#include "clinic/blob.c.h"
|
||||
|
@ -102,8 +101,8 @@ pysqlite_close_all_blobs(pysqlite_Connection *self)
|
|||
{
|
||||
for (int i = 0; i < PyList_GET_SIZE(self->blobs); i++) {
|
||||
PyObject *weakref = PyList_GET_ITEM(self->blobs, i);
|
||||
PyObject *blob = _PyWeakref_GET_REF(weakref);
|
||||
if (blob == NULL) {
|
||||
PyObject *blob;
|
||||
if (!PyWeakref_GetRef(weakref, &blob)) {
|
||||
continue;
|
||||
}
|
||||
close_blob((pysqlite_Blob *)blob);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue