mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
Fix failure to close the outgoing socket.
A second bug in the area of clean SSH-connection closure: I was setting the pending_close flag (formerly send_outgoing_eof) and expecting that once the outgoing backlog was cleared it would cause a socket closure. But of course the function that does that - ssh_bpp_output_raw_data_callback() - will only get called if there _is_ any outgoing backlog to be cleared! So if there was already no backlog, I would set the pending_close flag and nothing would ever check it again. Fixed by manually re-queuing the callback that will check the backlog and the pending_close flag.
This commit is contained in:
parent
1d162fa767
commit
db188040ea
1
ssh.c
1
ssh.c
@ -373,6 +373,7 @@ static void ssh_initiate_connection_close(Ssh ssh)
|
|||||||
* schedule closing the network socket after they go out. */
|
* schedule closing the network socket after they go out. */
|
||||||
ssh_bpp_handle_output(ssh->bpp);
|
ssh_bpp_handle_output(ssh->bpp);
|
||||||
ssh->pending_close = TRUE;
|
ssh->pending_close = TRUE;
|
||||||
|
queue_idempotent_callback(&ssh->ic_out_raw);
|
||||||
|
|
||||||
/* Now we expect the other end to close the connection too in
|
/* Now we expect the other end to close the connection too in
|
||||||
* response, so arrange that we'll receive notification of that
|
* response, so arrange that we'll receive notification of that
|
||||||
|
Loading…
Reference in New Issue
Block a user