mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-10 01:48:00 +00:00
Fix crash when disconnecting in verstring phase.
If we disconnect because the two ends' SSH protocol versions don't match, ssh_initiate_connection_close triggers a call to the BPP's handle_output method, and sshverstring's one of those unconditionally fails an assertion on the basis that nobody should be trying to send SSH packets at that stage of the connection. In fact this call to handle_output is only precautionary, and it's unproblematic because there aren't any packets on the output queue. So the assertion is now conditional on there actually being an erroneous packet.
This commit is contained in:
parent
2ea356c46c
commit
e3e434537d
@ -409,8 +409,10 @@ static PktOut *ssh_verstring_new_pktout(int type)
|
|||||||
|
|
||||||
static void ssh_verstring_handle_output(BinaryPacketProtocol *bpp)
|
static void ssh_verstring_handle_output(BinaryPacketProtocol *bpp)
|
||||||
{
|
{
|
||||||
assert(0 && "Should never try to send packets during SSH version "
|
if (pq_peek(&bpp->out_pq)) {
|
||||||
"string exchange");
|
assert(0 && "Should never try to send packets during SSH version "
|
||||||
|
"string exchange");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user