]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
GH-96678: Fix undefined behavior in ceval.c (GH-96708)
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Sat, 10 Sep 2022 13:58:45 +0000 (06:58 -0700)
committerGitHub <noreply@github.com>
Sat, 10 Sep 2022 13:58:45 +0000 (06:58 -0700)
(cherry picked from commit 50a70a083d34305a52fac4f5901bff2ead152d68)

Co-authored-by: Mark Shannon <mark@hotpy.org>
Misc/NEWS.d/next/Core and Builtins/2022-09-09-13-13-27.gh-issue-96678.vMxi9F.rst [new file with mode: 0644]
Python/ceval.c

diff --git a/Misc/NEWS.d/next/Core and Builtins/2022-09-09-13-13-27.gh-issue-96678.vMxi9F.rst b/Misc/NEWS.d/next/Core and Builtins/2022-09-09-13-13-27.gh-issue-96678.vMxi9F.rst
new file mode 100644 (file)
index 0000000..575b52b
--- /dev/null
@@ -0,0 +1 @@
+Fix case of undefined behavior in ceval.c
index 461439b1edae37a8a31c48f68395cbcfb221118e..66fa2eabbdc91a8e04f03e205d407486bf88c567 100644 (file)
@@ -6166,7 +6166,13 @@ initialize_locals(PyThreadState *tstate, PyFunctionObject *func,
     /* Pack other positional arguments into the *args argument */
     if (co->co_flags & CO_VARARGS) {
         PyObject *u = NULL;
-        u = _PyTuple_FromArraySteal(args + n, argcount - n);
+        if (argcount == n) {
+            u = Py_NewRef(&_Py_SINGLETON(tuple_empty));
+        }
+        else {
+            assert(args != NULL);
+            u = _PyTuple_FromArraySteal(args + n, argcount - n);
+        }
         if (u == NULL) {
             goto fail_post_positional;
         }