]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
gh-116447: Fix possible UB in `arraymodule` and `getargs` (#116459)
authorNikita Sobolev <mail@sobolevn.me>
Fri, 8 Mar 2024 10:49:52 +0000 (13:49 +0300)
committerGitHub <noreply@github.com>
Fri, 8 Mar 2024 10:49:52 +0000 (13:49 +0300)
Modules/arraymodule.c
Python/getargs.c

index df09d9d84789f7329adbfd7dfb125efa8618a663..317f4974814945ecd383b6313e3c203fa3b0cd5a 100644 (file)
@@ -247,7 +247,7 @@ BB_setitem(arrayobject *ap, Py_ssize_t i, PyObject *v)
     if (!PyArg_Parse(v, "b;array item must be integer", &x))
         return -1;
     if (i >= 0)
-        ((char *)ap->ob_item)[i] = x;
+        ((unsigned char *)ap->ob_item)[i] = x;
     return 0;
 }
 
index 08e97ee3e627b5a5abd2addad7390b0388521928..bec981698767ca0b2e97f59c9cddd261965451ac 100644 (file)
@@ -612,7 +612,7 @@ convertsimple(PyObject *arg, const char **p_format, va_list *p_va, int flags,
     switch (c) {
 
     case 'b': { /* unsigned byte -- very short int */
-        char *p = va_arg(*p_va, char *);
+        unsigned char *p = va_arg(*p_va, unsigned char *);
         long ival = PyLong_AsLong(arg);
         if (ival == -1 && PyErr_Occurred())
             RETURN_ERR_OCCURRED;
@@ -633,7 +633,7 @@ convertsimple(PyObject *arg, const char **p_format, va_list *p_va, int flags,
 
     case 'B': {/* byte sized bitfield - both signed and unsigned
                   values allowed */
-        char *p = va_arg(*p_va, char *);
+        unsigned char *p = va_arg(*p_va, unsigned char *);
         unsigned long ival = PyLong_AsUnsignedLongMask(arg);
         if (ival == (unsigned long)-1 && PyErr_Occurred())
             RETURN_ERR_OCCURRED;