mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
[3.13] gh-119247: Add macros to use PySequence_Fast safely in free-threaded build (GH-119315) (#119419)
Add `Py_BEGIN_CRITICAL_SECTION_SEQUENCE_FAST` and
`Py_END_CRITICAL_SECTION_SEQUENCE_FAST` macros and update `str.join` to use
them. Also add a regression test that would crash reliably without this
patch.
(cherry picked from commit baf347d916
)
Co-authored-by: Josh {*()} Rosenberg <26495692+MojoVampire@users.noreply.github.com>
This commit is contained in:
parent
cd39da75af
commit
08416065a7
4 changed files with 106 additions and 3 deletions
|
@ -44,6 +44,7 @@ OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|||
#include "pycore_bytesobject.h" // _PyBytes_Repeat()
|
||||
#include "pycore_ceval.h" // _PyEval_GetBuiltin()
|
||||
#include "pycore_codecs.h" // _PyCodec_Lookup()
|
||||
#include "pycore_critical_section.h" // Py_*_CRITICAL_SECTION_SEQUENCE_FAST
|
||||
#include "pycore_format.h" // F_LJUST
|
||||
#include "pycore_initconfig.h" // _PyStatus_OK()
|
||||
#include "pycore_interp.h" // PyInterpreterState.fs_codec
|
||||
|
@ -9559,13 +9560,14 @@ PyUnicode_Join(PyObject *separator, PyObject *seq)
|
|||
return NULL;
|
||||
}
|
||||
|
||||
/* NOTE: the following code can't call back into Python code,
|
||||
* so we are sure that fseq won't be mutated.
|
||||
*/
|
||||
Py_BEGIN_CRITICAL_SECTION_SEQUENCE_FAST(seq);
|
||||
|
||||
items = PySequence_Fast_ITEMS(fseq);
|
||||
seqlen = PySequence_Fast_GET_SIZE(fseq);
|
||||
res = _PyUnicode_JoinArray(separator, items, seqlen);
|
||||
|
||||
Py_END_CRITICAL_SECTION_SEQUENCE_FAST();
|
||||
|
||||
Py_DECREF(fseq);
|
||||
return res;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue