1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-10 09:58:01 +00:00

Improve comments in winhandl.c.

To understand the handle leak bug that I fixed in git commit
7549f2da40, I had to think fairly hard
to remind myself what all this code was doing, which means the
comments weren't good enough. Expanded and rewritten some of them in
the hope that things will be clearer next time.

(cherry picked from commit a87a14ae0f)

Cherry-picker's notes: this apparently pointless commit is required on
this branch because it's a dependency of the rather less pointless
9fec2e7738.
This commit is contained in:
Simon Tatham 2015-02-07 11:48:49 +00:00
parent 2713396c91
commit d0aa8b2380

View File

@ -167,13 +167,27 @@ static DWORD WINAPI handle_input_threadfunc(void *param)
SetEvent(ctx->ev_to_main); SetEvent(ctx->ev_to_main);
if (!ctx->len) if (!ctx->len) {
/*
* The read operation has returned end-of-file. Telling
* that to the main thread will cause it to set its
* 'defunct' flag and dispose of the handle structure at
* the next opportunity, so we must not touch ctx at all
* after this.
*/
break; break;
}
WaitForSingleObject(ctx->ev_from_main, INFINITE); WaitForSingleObject(ctx->ev_from_main, INFINITE);
if (ctx->done) { if (ctx->done) {
/*
* The main thread has asked us to shut down. Send back an
* event indicating that we've done so. Hereafter we must
* not touch ctx at all, because the main thread might
* have freed it.
*/
SetEvent(ctx->ev_to_main); SetEvent(ctx->ev_to_main);
break; /* main thread told us to shut down */ break;
} }
} }
@ -280,6 +294,12 @@ static DWORD WINAPI handle_output_threadfunc(void *param)
while (1) { while (1) {
WaitForSingleObject(ctx->ev_from_main, INFINITE); WaitForSingleObject(ctx->ev_from_main, INFINITE);
if (ctx->done) { if (ctx->done) {
/*
* The main thread has asked us to shut down. Send back an
* event indicating that we've done so. Hereafter we must
* not touch ctx at all, because the main thread might
* have freed it.
*/
SetEvent(ctx->ev_to_main); SetEvent(ctx->ev_to_main);
break; break;
} }
@ -304,8 +324,16 @@ static DWORD WINAPI handle_output_threadfunc(void *param)
} }
SetEvent(ctx->ev_to_main); SetEvent(ctx->ev_to_main);
if (!writeret) if (!writeret) {
/*
* The write operation has suffered an error. Telling that
* to the main thread will cause it to set its 'defunct'
* flag and dispose of the handle structure at the next
* opportunity, so we must not touch ctx at all after
* this.
*/
break; break;
}
} }
if (povl) if (povl)
@ -601,10 +629,12 @@ void handle_got_event(HANDLE event)
if (h->u.g.moribund) { if (h->u.g.moribund) {
/* /*
* A moribund handle is already treated as dead from the * A moribund handle is one which we have either already
* external user's point of view, so do nothing with the * signalled to die, or are waiting until its current I/O op
* actual event. Just signal the thread to die if * completes to do so. Either way, it's treated as already
* necessary, or destroy the handle if not. * dead from the external user's point of view, so we ignore
* the actual I/O result. We just signal the thread to die if
* we haven't yet done so, or destroy the handle if not.
*/ */
if (h->u.g.done) { if (h->u.g.done) {
handle_destroy(h); handle_destroy(h);