]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
gh-132713: Fix typing.Union[index] race condition (#132802)
authorVictor Stinner <vstinner@python.org>
Wed, 23 Apr 2025 13:45:42 +0000 (15:45 +0200)
committerGitHub <noreply@github.com>
Wed, 23 Apr 2025 13:45:42 +0000 (15:45 +0200)
Add union_init_parameters() helper function. Use a critical section
to initialize the 'parameters' member.

Objects/unionobject.c

index 0b7d4c72bffb978b7bf48d2f78eba5e769c3300a..66435924b6c6c31424b98c1db36ea1c6f142d3bd 100644 (file)
@@ -322,17 +322,29 @@ static PyMemberDef union_members[] = {
         {0}
 };
 
-static PyObject *
-union_getitem(PyObject *self, PyObject *item)
+// Populate __parameters__ if needed.
+static int
+union_init_parameters(unionobject *alias)
 {
-    unionobject *alias = (unionobject *)self;
-    // Populate __parameters__ if needed.
+    int result = 0;
+    Py_BEGIN_CRITICAL_SECTION(alias);
     if (alias->parameters == NULL) {
         alias->parameters = _Py_make_parameters(alias->args);
         if (alias->parameters == NULL) {
-            return NULL;
+            result = -1;
         }
     }
+    Py_END_CRITICAL_SECTION();
+    return result;
+}
+
+static PyObject *
+union_getitem(PyObject *self, PyObject *item)
+{
+    unionobject *alias = (unionobject *)self;
+    if (union_init_parameters(alias) < 0) {
+        return NULL;
+    }
 
     PyObject *newargs = _Py_subs_parameters(self, alias->args, alias->parameters, item);
     if (newargs == NULL) {
@@ -352,11 +364,8 @@ static PyObject *
 union_parameters(PyObject *self, void *Py_UNUSED(unused))
 {
     unionobject *alias = (unionobject *)self;
-    if (alias->parameters == NULL) {
-        alias->parameters = _Py_make_parameters(alias->args);
-        if (alias->parameters == NULL) {
-            return NULL;
-        }
+    if (union_init_parameters(alias) < 0) {
+        return NULL;
     }
     return Py_NewRef(alias->parameters);
 }