torsava / rpms / python3

Forked from rpms/python3 6 years ago
Clone
aa2fa3b
diff -up Python-3.1.2/Modules/audioop.c.CVE-2010-2089 Python-3.1.2/Modules/audioop.c
aa2fa3b
--- Python-3.1.2/Modules/audioop.c.CVE-2010-2089	2010-06-04 14:55:04.281964205 -0400
aa2fa3b
+++ Python-3.1.2/Modules/audioop.c	2010-06-04 15:04:32.896088959 -0400
aa2fa3b
@@ -295,6 +295,29 @@ static int stepsizeTable[89] = {
aa2fa3b
 
aa2fa3b
 static PyObject *AudioopError;
aa2fa3b
 
aa2fa3b
+static int
aa2fa3b
+audioop_check_size(int size)
aa2fa3b
+{
aa2fa3b
+        if ( size != 1 && size != 2 && size != 4 ) {
aa2fa3b
+                PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
+                return 0;
aa2fa3b
+        } else {
aa2fa3b
+                return 1;
aa2fa3b
+        }
aa2fa3b
+}
aa2fa3b
+
aa2fa3b
+static int
aa2fa3b
+audioop_check_parameters(int len, int size)
aa2fa3b
+{
aa2fa3b
+        if (!audioop_check_size(size))
aa2fa3b
+                return 0;
aa2fa3b
+        if ( len % size != 0 ) {
aa2fa3b
+                PyErr_SetString(AudioopError, "not a whole number of frames");
aa2fa3b
+                return 0;
aa2fa3b
+        }
aa2fa3b
+        return 1;
aa2fa3b
+}
aa2fa3b
+
aa2fa3b
 static PyObject *
aa2fa3b
 audioop_getsample(PyObject *self, PyObject *args)
aa2fa3b
 {
aa2fa3b
@@ -304,10 +327,8 @@ audioop_getsample(PyObject *self, PyObje
aa2fa3b
 
aa2fa3b
     if ( !PyArg_ParseTuple(args, "s#ii:getsample", &cp, &len, &size, &i) )
aa2fa3b
         return 0;
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4 ) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
     if ( i < 0 || i >= len/size ) {
aa2fa3b
         PyErr_SetString(AudioopError, "Index out of range");
aa2fa3b
         return 0;
aa2fa3b
@@ -328,10 +349,8 @@ audioop_max(PyObject *self, PyObject *ar
aa2fa3b
 
aa2fa3b
     if ( !PyArg_ParseTuple(args, "s#i:max", &cp, &len, &size) )
aa2fa3b
         return 0;
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4 ) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
     for ( i=0; i
aa2fa3b
         if ( size == 1 )      val = (int)*CHARP(cp, i);
aa2fa3b
         else if ( size == 2 ) val = (int)*SHORTP(cp, i);
aa2fa3b
@@ -352,10 +371,8 @@ audioop_minmax(PyObject *self, PyObject 
aa2fa3b
 
aa2fa3b
     if (!PyArg_ParseTuple(args, "s#i:minmax", &cp, &len, &size))
aa2fa3b
         return NULL;
aa2fa3b
-    if (size != 1 && size != 2 && size != 4) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
         return NULL;
aa2fa3b
-    }
aa2fa3b
     for (i = 0; i < len; i += size) {
aa2fa3b
         if (size == 1) val = (int) *CHARP(cp, i);
aa2fa3b
         else if (size == 2) val = (int) *SHORTP(cp, i);
aa2fa3b
@@ -376,10 +393,8 @@ audioop_avg(PyObject *self, PyObject *ar
aa2fa3b
 
aa2fa3b
     if ( !PyArg_ParseTuple(args, "s#i:avg", &cp, &len, &size) )
aa2fa3b
         return 0;
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4 ) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
     for ( i=0; i
aa2fa3b
         if ( size == 1 )      val = (int)*CHARP(cp, i);
aa2fa3b
         else if ( size == 2 ) val = (int)*SHORTP(cp, i);
aa2fa3b
@@ -403,10 +418,8 @@ audioop_rms(PyObject *self, PyObject *ar
aa2fa3b
 
aa2fa3b
     if ( !PyArg_ParseTuple(args, "s#i:rms", &cp, &len, &size) )
aa2fa3b
         return 0;
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4 ) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
     for ( i=0; i
aa2fa3b
         if ( size == 1 )      val = (int)*CHARP(cp, i);
aa2fa3b
         else if ( size == 2 ) val = (int)*SHORTP(cp, i);
aa2fa3b
@@ -614,10 +627,8 @@ audioop_avgpp(PyObject *self, PyObject *
aa2fa3b
 
aa2fa3b
     if ( !PyArg_ParseTuple(args, "s#i:avgpp", &cp, &len, &size) )
aa2fa3b
         return 0;
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4 ) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
     /* Compute first delta value ahead. Also automatically makes us
aa2fa3b
     ** skip the first extreme value
aa2fa3b
     */
aa2fa3b
@@ -671,10 +682,8 @@ audioop_maxpp(PyObject *self, PyObject *
aa2fa3b
 
aa2fa3b
     if ( !PyArg_ParseTuple(args, "s#i:maxpp", &cp, &len, &size) )
aa2fa3b
         return 0;
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4 ) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
     /* Compute first delta value ahead. Also automatically makes us
aa2fa3b
     ** skip the first extreme value
aa2fa3b
     */
aa2fa3b
@@ -722,10 +731,8 @@ audioop_cross(PyObject *self, PyObject *
aa2fa3b
 
aa2fa3b
     if ( !PyArg_ParseTuple(args, "s#i:cross", &cp, &len, &size) )
aa2fa3b
         return 0;
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4 ) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
     ncross = -1;
aa2fa3b
     prevval = 17; /* Anything <> 0,1 */
aa2fa3b
     for ( i=0; i
aa2fa3b
@@ -751,6 +758,9 @@ audioop_mul(PyObject *self, PyObject *ar
aa2fa3b
     if ( !PyArg_ParseTuple(args, "s#id:mul", &cp, &len, &size, &factor ) )
aa2fa3b
         return 0;
aa2fa3b
 
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
+
aa2fa3b
     if ( size == 1 ) maxval = (double) 0x7f;
aa2fa3b
     else if ( size == 2 ) maxval = (double) 0x7fff;
aa2fa3b
     else if ( size == 4 ) maxval = (double) 0x7fffffff;
aa2fa3b
@@ -793,6 +803,14 @@ audioop_tomono(PyObject *self, PyObject 
aa2fa3b
     if ( !PyArg_ParseTuple(args, "s*idd:tomono",
aa2fa3b
                            &pcp, &size, &fac1, &fac2 ) )
aa2fa3b
         return 0;
aa2fa3b
+
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
+    if ( ((len / size) & 1) != 0 ) {
aa2fa3b
+        PyErr_SetString(AudioopError, "not a whole number of frames");
aa2fa3b
+        return NULL;
aa2fa3b
+    }
aa2fa3b
+
aa2fa3b
     cp = pcp.buf;
aa2fa3b
     len = pcp.len;
aa2fa3b
 
aa2fa3b
@@ -843,6 +861,9 @@ audioop_tostereo(PyObject *self, PyObjec
aa2fa3b
                            &cp, &len, &size, &fac1, &fac2 ) )
aa2fa3b
         return 0;
aa2fa3b
 
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
+
aa2fa3b
     if ( size == 1 ) maxval = (double) 0x7f;
aa2fa3b
     else if ( size == 2 ) maxval = (double) 0x7fff;
aa2fa3b
     else if ( size == 4 ) maxval = (double) 0x7fffffff;
aa2fa3b
@@ -901,6 +922,9 @@ audioop_add(PyObject *self, PyObject *ar
aa2fa3b
                       &cp1, &len1, &cp2, &len2, &size ) )
aa2fa3b
         return 0;
aa2fa3b
 
aa2fa3b
+    if (!audioop_check_parameters(len1, size))
aa2fa3b
+        return NULL;
aa2fa3b
+
aa2fa3b
     if ( len1 != len2 ) {
aa2fa3b
         PyErr_SetString(AudioopError, "Lengths should be the same");
aa2fa3b
         return 0;
aa2fa3b
@@ -955,10 +979,8 @@ audioop_bias(PyObject *self, PyObject *a
aa2fa3b
                       &cp, &len, &size , &bias) )
aa2fa3b
         return 0;
aa2fa3b
 
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
 
aa2fa3b
     rv = PyBytes_FromStringAndSize(NULL, len);
aa2fa3b
     if ( rv == 0 )
aa2fa3b
@@ -991,10 +1013,8 @@ audioop_reverse(PyObject *self, PyObject
aa2fa3b
                       &cp, &len, &size) )
aa2fa3b
         return 0;
aa2fa3b
 
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4 ) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
 
aa2fa3b
     rv = PyBytes_FromStringAndSize(NULL, len);
aa2fa3b
     if ( rv == 0 )
aa2fa3b
@@ -1028,11 +1048,10 @@ audioop_lin2lin(PyObject *self, PyObject
aa2fa3b
                       &cp, &len, &size, &size2) )
aa2fa3b
         return 0;
aa2fa3b
 
aa2fa3b
-    if ( (size != 1 && size != 2 && size != 4) ||
aa2fa3b
-         (size2 != 1 && size2 != 2 && size2 != 4)) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
+    if (!audioop_check_size(size2))
aa2fa3b
+        return NULL;
aa2fa3b
 
aa2fa3b
     if (len/size > INT_MAX/size2) {
aa2fa3b
         PyErr_SetString(PyExc_MemoryError,
aa2fa3b
@@ -1082,10 +1101,8 @@ audioop_ratecv(PyObject *self, PyObject 
aa2fa3b
                           &nchannels, &inrate, &outrate, &state,
aa2fa3b
                           &weightA, &weightB))
aa2fa3b
         return NULL;
aa2fa3b
-    if (size != 1 && size != 2 && size != 4) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
+    if (!audioop_check_size(size))
aa2fa3b
         return NULL;
aa2fa3b
-    }
aa2fa3b
     if (nchannels < 1) {
aa2fa3b
         PyErr_SetString(AudioopError, "# of channels should be >= 1");
aa2fa3b
         return NULL;
aa2fa3b
@@ -1261,10 +1278,8 @@ audioop_lin2ulaw(PyObject *self, PyObjec
aa2fa3b
                            &cp, &len, &size) )
aa2fa3b
         return 0 ;
aa2fa3b
 
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
 
aa2fa3b
     rv = PyBytes_FromStringAndSize(NULL, len/size);
aa2fa3b
     if ( rv == 0 )
aa2fa3b
@@ -1295,10 +1310,8 @@ audioop_ulaw2lin(PyObject *self, PyObjec
aa2fa3b
                            &cp, &len, &size) )
aa2fa3b
         return 0;
aa2fa3b
 
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_size(size))
aa2fa3b
+        return NULL;
aa2fa3b
 
aa2fa3b
     if (len > INT_MAX/size) {
aa2fa3b
         PyErr_SetString(PyExc_MemoryError,
aa2fa3b
@@ -1334,10 +1347,8 @@ audioop_lin2alaw(PyObject *self, PyObjec
aa2fa3b
                            &cp, &len, &size) )
aa2fa3b
         return 0;
aa2fa3b
 
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
 
aa2fa3b
     rv = PyBytes_FromStringAndSize(NULL, len/size);
aa2fa3b
     if ( rv == 0 )
aa2fa3b
@@ -1368,10 +1379,8 @@ audioop_alaw2lin(PyObject *self, PyObjec
aa2fa3b
                            &cp, &len, &size) )
aa2fa3b
         return 0;
aa2fa3b
 
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_size(size))
aa2fa3b
+        return NULL;
aa2fa3b
 
aa2fa3b
     if (len > INT_MAX/size) {
aa2fa3b
         PyErr_SetString(PyExc_MemoryError,
aa2fa3b
@@ -1409,10 +1418,8 @@ audioop_lin2adpcm(PyObject *self, PyObje
aa2fa3b
         return 0;
aa2fa3b
 
aa2fa3b
 
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_parameters(len, size))
aa2fa3b
+        return NULL;
aa2fa3b
 
aa2fa3b
     str = PyBytes_FromStringAndSize(NULL, len/(size*2));
aa2fa3b
     if ( str == 0 )
aa2fa3b
@@ -1516,10 +1523,8 @@ audioop_adpcm2lin(PyObject *self, PyObje
aa2fa3b
                            &cp, &len, &size, &state) )
aa2fa3b
         return 0;
aa2fa3b
 
aa2fa3b
-    if ( size != 1 && size != 2 && size != 4) {
aa2fa3b
-        PyErr_SetString(AudioopError, "Size should be 1, 2 or 4");
aa2fa3b
-        return 0;
aa2fa3b
-    }
aa2fa3b
+    if (!audioop_check_size(size))
aa2fa3b
+        return NULL;
aa2fa3b
 
aa2fa3b
     /* Decode state, should have (value, step) */
aa2fa3b
     if ( state == Py_None ) {