From: Victor Stinner Date: Mon, 24 Jun 2013 21:13:24 +0000 (+0200) Subject: Issue #9566: _winapi.WriteFile() now truncates length to DWORD_MAX (4294967295) X-Git-Tag: v3.4.0a1~400 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=71765770a4a8cb0bc66b8b015e99606e23526957;p=python Issue #9566: _winapi.WriteFile() now truncates length to DWORD_MAX (4294967295) --- diff --git a/Modules/_winapi.c b/Modules/_winapi.c index 1074891ef1..c34d2db267 100644 --- a/Modules/_winapi.c +++ b/Modules/_winapi.c @@ -62,6 +62,8 @@ #define T_HANDLE T_POINTER +#define DWORD_MAX 4294967295U + /* Grab CancelIoEx dynamically from kernel32 */ static int has_CancelIoEx = -1; static BOOL (CALLBACK *Py_CancelIoEx)(HANDLE, LPOVERLAPPED); @@ -1142,7 +1144,7 @@ winapi_WriteFile(PyObject *self, PyObject *args, PyObject *kwds) HANDLE handle; Py_buffer _buf, *buf; PyObject *bufobj; - DWORD written; + DWORD len, written; BOOL ret; int use_overlapped = 0; DWORD err; @@ -1170,7 +1172,8 @@ winapi_WriteFile(PyObject *self, PyObject *args, PyObject *kwds) } Py_BEGIN_ALLOW_THREADS - ret = WriteFile(handle, buf->buf, buf->len, &written, + len = (DWORD)Py_MIN(buf->len, DWORD_MAX); + ret = WriteFile(handle, buf->buf, len, &written, overlapped ? &overlapped->overlapped : NULL); Py_END_ALLOW_THREADS