When disabling the Windows device, wait for pending reads to complete.
authorEtienne Dechamps <etienne@edechamps.fr>
Sat, 14 Mar 2015 17:27:14 +0000 (17:27 +0000)
committerEtienne Dechamps <etienne@edechamps.fr>
Sun, 15 Mar 2015 10:32:18 +0000 (10:32 +0000)
commit675142c7d88c9d325c0ca0bc5761072a5d810c75
treebd4010dc08ae1579878398adc172200262835a13
parent6568cffd52d4803effaf52a9bb9c98d69cf7922a
When disabling the Windows device, wait for pending reads to complete.

On Windows, when disabling the device, tinc uses the CancelIo() to
cancel the pending read operation, and then proceeds to delete the event
handle immediately.

This assumes that CancelIo() blocks until the pending read request is
completely torn down and no references to it remain. While MSDN is not
completely clear on that subject, it does suggest that this is not the
case:

  http://msdn.microsoft.com/en-us/library/windows/desktop/aa363791.aspx
  If the function succeeds [...] the cancel operation for all pending
  I/O operations issued by the calling thread for the specified file
  handle was successfully requested.

This implies that cancellation was merely "requested", and that there
are no guarantees as to the state of the operation when CancelIo()
returns. Therefore, care must be taken not to close event handles
prematurely.

While I'm no aware of this potential race condition causing any problems
in practice, I don't want to take any chances.
src/mingw/device.c