Kaydet (Commit) 4507e645 authored tarafından Jesus Cea's avatar Jesus Cea

Close #13022: _multiprocessing.recvfd() doesn't check that file descriptor was actually received

üst d0b10a64
...@@ -1632,6 +1632,23 @@ class _TestConnection(BaseTestCase): ...@@ -1632,6 +1632,23 @@ class _TestConnection(BaseTestCase):
with open(test.support.TESTFN, "rb") as f: with open(test.support.TESTFN, "rb") as f:
self.assertEqual(f.read(), b"bar") self.assertEqual(f.read(), b"bar")
@classmethod
def _send_data_without_fd(self, conn):
os.write(conn.fileno(), b"\0")
@unittest.skipIf(sys.platform == "win32", "doesn't make sense on Windows")
def test_missing_fd_transfer(self):
# Check that exception is raised when received data is not
# accompanied by a file descriptor in ancillary data.
if self.TYPE != 'processes':
self.skipTest("only makes sense with processes")
conn, child_conn = self.Pipe(duplex=True)
p = self.Process(target=self._send_data_without_fd, args=(child_conn,))
p.daemon = True
p.start()
self.assertRaises(RuntimeError, reduction.recv_handle, conn)
p.join()
class _TestListenerClient(BaseTestCase): class _TestListenerClient(BaseTestCase):
......
...@@ -78,6 +78,9 @@ Tests ...@@ -78,6 +78,9 @@ Tests
Extension Modules Extension Modules
----------------- -----------------
- Issue #13022: Fix: _multiprocessing.recvfd() doesn't check that
file descriptor was actually received.
- Issue #12483: ctypes: Fix a crash when the destruction of a callback - Issue #12483: ctypes: Fix a crash when the destruction of a callback
object triggers the garbage collector. object triggers the garbage collector.
......
...@@ -177,6 +177,17 @@ multiprocessing_recvfd(PyObject *self, PyObject *args) ...@@ -177,6 +177,17 @@ multiprocessing_recvfd(PyObject *self, PyObject *args)
if (res < 0) if (res < 0)
return PyErr_SetFromErrno(PyExc_OSError); return PyErr_SetFromErrno(PyExc_OSError);
if (msg.msg_controllen < CMSG_LEN(sizeof(int)) ||
(cmsg = CMSG_FIRSTHDR(&msg)) == NULL ||
cmsg->cmsg_level != SOL_SOCKET ||
cmsg->cmsg_type != SCM_RIGHTS ||
cmsg->cmsg_len < CMSG_LEN(sizeof(int))) {
/* If at least one control message is present, there should be
no room for any further data in the buffer. */
PyErr_SetString(PyExc_RuntimeError, "No file descriptor received");
return NULL;
}
fd = * (int *) CMSG_DATA(cmsg); fd = * (int *) CMSG_DATA(cmsg);
return Py_BuildValue("i", fd); return Py_BuildValue("i", fd);
} }
......
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