Kaydet (Commit) 2ecd3c36 authored tarafından Jack Diederich's avatar Jack Diederich

bounds check arguments to mmap.move(). All of them. Really.

fixes crasher on OS X 10.5
üst ce3d2214
...@@ -359,15 +359,22 @@ class MmapTests(unittest.TestCase): ...@@ -359,15 +359,22 @@ class MmapTests(unittest.TestCase):
m.move(source, dest, size) m.move(source, dest, size)
except ValueError: except ValueError:
pass pass
self.assertRaises(ValueError, m.move, -1, -1, -1)
self.assertRaises(ValueError, m.move, -1, -1, 0) offsets = [(-1, -1, -1), (-1, -1, 0), (-1, 0, -1), (0, -1, -1),
self.assertRaises(ValueError, m.move, -1, 0, -1) (-1, 0, 0), (0, -1, 0), (0, 0, -1)]
self.assertRaises(ValueError, m.move, 0, -1, -1) for source, dest, size in offsets:
self.assertRaises(ValueError, m.move, -1, 0, 0) self.assertRaises(ValueError, m.move, source, dest, size)
self.assertRaises(ValueError, m.move, 0, -1, 0)
self.assertRaises(ValueError, m.move, 0, 0, -1)
m.close() m.close()
m = mmap.mmap(-1, 1) # single byte
self.assertRaises(ValueError, m.move, 0, 0, 2)
self.assertRaises(ValueError, m.move, 1, 0, 1)
self.assertRaises(ValueError, m.move, 0, 1, 1)
m.move(0, 0, 1)
m.move(0, 0, 0)
def test_anonymous(self): def test_anonymous(self):
# anonymous mmap.mmap(-1, PAGE) # anonymous mmap.mmap(-1, PAGE)
m = mmap.mmap(-1, PAGESIZE) m = mmap.mmap(-1, PAGESIZE)
......
...@@ -609,23 +609,23 @@ mmap_seek_method(mmap_object *self, PyObject *args) ...@@ -609,23 +609,23 @@ mmap_seek_method(mmap_object *self, PyObject *args)
static PyObject * static PyObject *
mmap_move_method(mmap_object *self, PyObject *args) mmap_move_method(mmap_object *self, PyObject *args)
{ {
unsigned long dest, src, count; unsigned long dest, src, cnt;
CHECK_VALID(NULL); CHECK_VALID(NULL);
if (!PyArg_ParseTuple(args, "kkk:move", &dest, &src, &count) || if (!PyArg_ParseTuple(args, "kkk:move", &dest, &src, &cnt) ||
!is_writeable(self)) { !is_writeable(self)) {
return NULL; return NULL;
} else { } else {
/* bounds check the values */ /* bounds check the values */
unsigned long pos = src > dest ? src : dest; if (cnt < 0 || (cnt + dest) < cnt || (cnt + src) < cnt ||
if (self->size < pos || count > self->size - pos) { src < 0 || src > self->size || (src + cnt) > self->size ||
dest < 0 || dest > self->size || (dest + cnt) > self->size) {
PyErr_SetString(PyExc_ValueError, PyErr_SetString(PyExc_ValueError,
"source or destination out of range"); "source, destination, or count out of range");
return NULL; return NULL;
} else {
memmove(self->data+dest, self->data+src, count);
Py_INCREF(Py_None);
return Py_None;
} }
memmove(self->data+dest, self->data+src, cnt);
Py_INCREF(Py_None);
return Py_None;
} }
} }
......
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