diff options
-rw-r--r-- | Lib/test/test_socket.py | 7 | ||||
-rw-r--r-- | Misc/ACKS | 1 | ||||
-rw-r--r-- | Misc/NEWS | 3 | ||||
-rw-r--r-- | Modules/socketmodule.c | 29 |
4 files changed, 32 insertions, 8 deletions
diff --git a/Lib/test/test_socket.py b/Lib/test/test_socket.py index d419301..d77b7dc 100644 --- a/Lib/test/test_socket.py +++ b/Lib/test/test_socket.py @@ -846,6 +846,13 @@ class GeneralModuleTests(unittest.TestCase): srv.listen(0) srv.close() + @unittest.skipUnless(SUPPORTS_IPV6, 'IPv6 required for this test.') + def test_flowinfo(self): + self.assertRaises(OverflowError, socket.getnameinfo, + ('::1',0, 0xffffffff), 0) + with socket.socket(socket.AF_INET6, socket.SOCK_STREAM) as s: + self.assertRaises(OverflowError, s.bind, ('::1', 0, -10)) + @unittest.skipUnless(thread, 'Threading required for this test.') class BasicTCPTest(SocketConnectedTest): @@ -643,6 +643,7 @@ John Nagle Takahiro Nakayama Travers Naran Charles-François Natali +Vilmos Nebehaj Fredrik Nehr Trent Nelson Tony Nelson @@ -345,6 +345,9 @@ Tests Extension Modules ----------------- +- Issue #9975: socket: Fix incorrect use of flowinfo and scope_id. Patch by + Vilmos Nebehaj. + - Issue #13159: FileIO and BZ2File now use a linear-time buffer growth strategy instead of a quadratic-time one. diff --git a/Modules/socketmodule.c b/Modules/socketmodule.c index d3e5c75..320227f 100644 --- a/Modules/socketmodule.c +++ b/Modules/socketmodule.c @@ -1065,10 +1065,10 @@ makesockaddr(SOCKET_T sockfd, struct sockaddr *addr, size_t addrlen, int proto) PyObject *ret = NULL; if (addrobj) { a = (struct sockaddr_in6 *)addr; - ret = Py_BuildValue("Oiii", + ret = Py_BuildValue("OiII", addrobj, ntohs(a->sin6_port), - a->sin6_flowinfo, + ntohl(a->sin6_flowinfo), a->sin6_scope_id); Py_DECREF(addrobj); } @@ -1319,7 +1319,8 @@ getsockaddrarg(PySocketSockObject *s, PyObject *args, { struct sockaddr_in6* addr; char *host; - int port, flowinfo, scope_id, result; + int port, result; + unsigned int flowinfo, scope_id; flowinfo = scope_id = 0; if (!PyTuple_Check(args)) { PyErr_Format( @@ -1329,7 +1330,7 @@ getsockaddrarg(PySocketSockObject *s, PyObject *args, Py_TYPE(args)->tp_name); return 0; } - if (!PyArg_ParseTuple(args, "eti|ii", + if (!PyArg_ParseTuple(args, "eti|II", "idna", &host, &port, &flowinfo, &scope_id)) { return 0; @@ -1346,9 +1347,15 @@ getsockaddrarg(PySocketSockObject *s, PyObject *args, "getsockaddrarg: port must be 0-65535."); return 0; } + if (flowinfo < 0 || flowinfo > 0xfffff) { + PyErr_SetString( + PyExc_OverflowError, + "getsockaddrarg: flowinfo must be 0-1048575."); + return 0; + } addr->sin6_family = s->sock_family; addr->sin6_port = htons((short)port); - addr->sin6_flowinfo = flowinfo; + addr->sin6_flowinfo = htonl(flowinfo); addr->sin6_scope_id = scope_id; *len_ret = sizeof *addr; return 1; @@ -4104,7 +4111,8 @@ socket_getnameinfo(PyObject *self, PyObject *args) PyObject *sa = (PyObject *)NULL; int flags; char *hostp; - int port, flowinfo, scope_id; + int port; + unsigned int flowinfo, scope_id; char hbuf[NI_MAXHOST], pbuf[NI_MAXSERV]; struct addrinfo hints, *res = NULL; int error; @@ -4118,9 +4126,14 @@ socket_getnameinfo(PyObject *self, PyObject *args) "getnameinfo() argument 1 must be a tuple"); return NULL; } - if (!PyArg_ParseTuple(sa, "si|ii", + if (!PyArg_ParseTuple(sa, "si|II", &hostp, &port, &flowinfo, &scope_id)) return NULL; + if (flowinfo < 0 || flowinfo > 0xfffff) { + PyErr_SetString(PyExc_OverflowError, + "getsockaddrarg: flowinfo must be 0-1048575."); + return NULL; + } PyOS_snprintf(pbuf, sizeof(pbuf), "%d", port); memset(&hints, 0, sizeof(hints)); hints.ai_family = AF_UNSPEC; @@ -4155,7 +4168,7 @@ socket_getnameinfo(PyObject *self, PyObject *args) { struct sockaddr_in6 *sin6; sin6 = (struct sockaddr_in6 *)res->ai_addr; - sin6->sin6_flowinfo = flowinfo; + sin6->sin6_flowinfo = htonl(flowinfo); sin6->sin6_scope_id = scope_id; break; } |