mirror of https://github.com/python/cpython
gh-118561: Fix crash involving list.extend in free-threaded build (#118723)
The `list_preallocate_exact` function did not zero initialize array contents. In the free-threaded build, this could expose uninitialized memory to concurrent readers between the call to `list_preallocate_exact` and the filling of the array contents with items.
This commit is contained in:
parent
82abe75e77
commit
2402715e10
|
@ -0,0 +1,2 @@
|
||||||
|
Fix race condition in free-threaded build where :meth:`list.extend` could expose
|
||||||
|
uninitialied memory to concurrent readers.
|
|
@ -192,6 +192,7 @@ list_preallocate_exact(PyListObject *self, Py_ssize_t size)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
items = array->ob_item;
|
items = array->ob_item;
|
||||||
|
memset(items, 0, size * sizeof(PyObject *));
|
||||||
#else
|
#else
|
||||||
items = PyMem_New(PyObject*, size);
|
items = PyMem_New(PyObject*, size);
|
||||||
if (items == NULL) {
|
if (items == NULL) {
|
||||||
|
@ -199,7 +200,7 @@ list_preallocate_exact(PyListObject *self, Py_ssize_t size)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
self->ob_item = items;
|
FT_ATOMIC_STORE_PTR_RELEASE(self->ob_item, items);
|
||||||
self->allocated = size;
|
self->allocated = size;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue