Commit a234e148 authored by Victor Stinner's avatar Victor Stinner Committed by GitHub

bpo-32710: Fix leak in Overlapped_WSASend() (GH-11469)

Fix a memory leak in asyncio in the ProactorEventLoop when ReadFile()
or WSASend() overlapped operation fail immediately: release the
internal buffer.
parent 872bd2b5
Fix a memory leak in asyncio in the ProactorEventLoop when ``ReadFile()`` or
``WSASend()`` overlapped operation fail immediately: release the internal
buffer.
...@@ -723,6 +723,7 @@ do_ReadFile(OverlappedObject *self, HANDLE handle, ...@@ -723,6 +723,7 @@ do_ReadFile(OverlappedObject *self, HANDLE handle,
case ERROR_IO_PENDING: case ERROR_IO_PENDING:
Py_RETURN_NONE; Py_RETURN_NONE;
default: default:
PyBuffer_Release(&self->user_buffer);
self->type = TYPE_NOT_STARTED; self->type = TYPE_NOT_STARTED;
return SetFromWindowsErr(err); return SetFromWindowsErr(err);
} }
...@@ -1011,6 +1012,7 @@ Overlapped_WSASend(OverlappedObject *self, PyObject *args) ...@@ -1011,6 +1012,7 @@ Overlapped_WSASend(OverlappedObject *self, PyObject *args)
case ERROR_IO_PENDING: case ERROR_IO_PENDING:
Py_RETURN_NONE; Py_RETURN_NONE;
default: default:
PyBuffer_Release(&self->user_buffer);
self->type = TYPE_NOT_STARTED; self->type = TYPE_NOT_STARTED;
return SetFromWindowsErr(err); return SetFromWindowsErr(err);
} }
......
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