]> granicus.if.org Git - python/commitdiff
Merged revisions 83407 via svnmerge from
authorBrian Curtin <brian.curtin@gmail.com>
Sun, 1 Aug 2010 15:44:11 +0000 (15:44 +0000)
committerBrian Curtin <brian.curtin@gmail.com>
Sun, 1 Aug 2010 15:44:11 +0000 (15:44 +0000)
svn+ssh://pythondev@svn.python.org/python/branches/py3k

........
  r83407 | brian.curtin | 2010-08-01 10:26:26 -0500 (Sun, 01 Aug 2010) | 3 lines

  Fix #8105. Add validation to mmap.mmap so invalid file descriptors
  don't cause a crash on Windows.
........

Lib/test/test_mmap.py
Misc/NEWS
Modules/mmapmodule.c

index eae4157edc38bb23b45bb0150f9e6fa8bcee63c9..b3869a6317fd9d89b0b08a3bed243efb87c843ce 100644 (file)
@@ -1,6 +1,6 @@
 from test.support import TESTFN, run_unittest, import_module
 import unittest
-import os, re, itertools
+import os, re, itertools, socket
 
 # Skip test if we can't import mmap.
 mmap = import_module('mmap')
@@ -586,6 +586,16 @@ class MmapTests(unittest.TestCase):
                 pass
             m.close()
 
+        def test_invalid_descriptor(self):
+            # socket file descriptors are valid, but out of range
+            # for _get_osfhandle, causing a crash when validating the
+            # parameters to _get_osfhandle.
+            s = socket.socket()
+            try:
+                with self.assertRaises(mmap.error):
+                    m = mmap.mmap(s.fileno(), 10)
+            finally:
+                s.close()
 
 def test_main():
     run_unittest(MmapTests)
index 96abd0de0645e39d7d6d31a9d0ec9402d48d1942..7cf087b3f73a6819298c12159a7531cfd23b21df 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -332,6 +332,8 @@ Library
 Extension Modules
 -----------------
 
+- Issue #8105: Validate file descriptor passed to mmap.mmap on Windows.
+
 - Issue #9422: Fix memory leak when re-initializing a struct.Struct object.
 
 - Issue #7900: The getgroups(2) system call on MacOSX behaves rather oddly
index 9714ddff16728ee3680a9e1cff7fca35927e8ccb..b170b3885ebb366c594bc75470ff3fb1fc4967fd 100644 (file)
@@ -1203,6 +1203,11 @@ new_mmap_object(PyTypeObject *type, PyObject *args, PyObject *kwdict)
                      1);
      */
     if (fileno != -1 && fileno != 0) {
+        /* Ensure that fileno is within the CRT's valid range */
+        if (_PyVerify_fd(fileno) == 0) {
+            PyErr_SetFromErrno(mmap_module_error);
+            return NULL;
+        }
         fh = (HANDLE)_get_osfhandle(fileno);
         if (fh==(HANDLE)-1) {
             PyErr_SetFromErrno(mmap_module_error);