Fix corner-case bug in WaitEventSetWaitBlock on Windows.
authorRobert Haas <[email protected]>
Wed, 21 Dec 2016 16:01:48 +0000 (11:01 -0500)
committerRobert Haas <[email protected]>
Wed, 21 Dec 2016 16:01:48 +0000 (11:01 -0500)
commit3b790d256f8489d0765c3389d6860f1c6b4a9b2d
tree0bcd59162bb41a6e022df7d1acef3b0023a7082a
parent59649c3f1cbd536314c0060dcabd234deab148b2
Fix corner-case bug in WaitEventSetWaitBlock on Windows.

If we do not reset the FD_READ event, WaitForMultipleObjects won't
return it again again unless we've meanwhile read from the socket,
which is generally true but not guaranteed.  WaitEventSetWaitBlock
itself may fail to return the event to the caller if the latch is
also set, and even if we changed that, the caller isn't obliged to
handle all returned events at once.  On non-Windows systems, the
socket-read event is purely level-triggered, so this issue does
not exist.  To fix, make Windows reset the event when needed.

This bug was introduced by 98a64d0bd713cb89e61bef6432befc4b7b5da59e,
and causes hangs when trying to use the pldebugger extension.

Patch by Amit Kapial.  Reported and tested by Ashutosh Sharma, who
also provided some analysis.  Further analysis by Michael Paquier.
src/backend/storage/ipc/latch.c
src/include/storage/latch.h