Kaydet (Commit) 85c24979 authored tarafından Serhiy Storchaka's avatar Serhiy Storchaka

Issue #16404: Add checks for return value of PyLong_FromLong() in

sys.getwindowsversion() and ossaudiodev.setparameters().
Reported by Ned Batchelder.
...@@ -564,7 +564,6 @@ oss_setparameters(oss_audio_t *self, PyObject *args) ...@@ -564,7 +564,6 @@ oss_setparameters(oss_audio_t *self, PyObject *args)
{ {
int wanted_fmt, wanted_channels, wanted_rate, strict=0; int wanted_fmt, wanted_channels, wanted_rate, strict=0;
int fmt, channels, rate; int fmt, channels, rate;
PyObject * rv; /* return tuple (fmt, channels, rate) */
if (!_is_fd_valid(self->fd)) if (!_is_fd_valid(self->fd))
return NULL; return NULL;
...@@ -609,13 +608,7 @@ oss_setparameters(oss_audio_t *self, PyObject *args) ...@@ -609,13 +608,7 @@ oss_setparameters(oss_audio_t *self, PyObject *args)
/* Construct the return value: a (fmt, channels, rate) tuple that /* Construct the return value: a (fmt, channels, rate) tuple that
tells what the audio hardware was actually set to. */ tells what the audio hardware was actually set to. */
rv = PyTuple_New(3); return Py_BuildValue("(iii)", fmt, channels, rate);
if (rv == NULL)
return NULL;
PyTuple_SET_ITEM(rv, 0, PyLong_FromLong(fmt));
PyTuple_SET_ITEM(rv, 1, PyLong_FromLong(channels));
PyTuple_SET_ITEM(rv, 2, PyLong_FromLong(rate));
return rv;
} }
static int static int
......
...@@ -801,6 +801,10 @@ sys_getwindowsversion(PyObject *self) ...@@ -801,6 +801,10 @@ sys_getwindowsversion(PyObject *self)
PyStructSequence_SET_ITEM(version, pos++, PyLong_FromLong(ver.wSuiteMask)); PyStructSequence_SET_ITEM(version, pos++, PyLong_FromLong(ver.wSuiteMask));
PyStructSequence_SET_ITEM(version, pos++, PyLong_FromLong(ver.wProductType)); PyStructSequence_SET_ITEM(version, pos++, PyLong_FromLong(ver.wProductType));
if (PyErr_Occurred()) {
Py_DECREF(version);
return NULL;
}
return version; return version;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment