From: Miss Islington (bot) <31488909+miss-islington@users.noreply.github.com> Date: Sun, 29 Jun 2025 07:36:04 +0000 (+0200) Subject: [3.14] gh-136053: Check error for TYPE_SLICE in marshal.c (GH-136054) (GH-136092) X-Git-Tag: v3.14.0b4~71 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=ce659561776b14f074d197078909891af9c1eeb0;p=thirdparty%2FPython%2Fcpython.git [3.14] gh-136053: Check error for TYPE_SLICE in marshal.c (GH-136054) (GH-136092) Fix a possible crash when deserializing a large marshal data (at least several GiBs) containing a slice. (cherry picked from commit 30ba03ea8ed98522b0500d6856b22727c88e818f) Co-authored-by: Akshat Gupta --- diff --git a/Misc/NEWS.d/next/Security/2025-06-27-21-23-19.gh-issue-136053.QZxcee.rst b/Misc/NEWS.d/next/Security/2025-06-27-21-23-19.gh-issue-136053.QZxcee.rst new file mode 100644 index 000000000000..93caed3aa3b9 --- /dev/null +++ b/Misc/NEWS.d/next/Security/2025-06-27-21-23-19.gh-issue-136053.QZxcee.rst @@ -0,0 +1 @@ +:mod:`marshal`: fix a possible crash when deserializing :class:`slice` objects. diff --git a/Python/marshal.c b/Python/marshal.c index b39c1a5b1ade..a0f3e0a9f566 100644 --- a/Python/marshal.c +++ b/Python/marshal.c @@ -1656,6 +1656,9 @@ r_object(RFILE *p) case TYPE_SLICE: { Py_ssize_t idx = r_ref_reserve(flag, p); + if (idx < 0) { + break; + } PyObject *stop = NULL; PyObject *step = NULL; PyObject *start = r_object(p);