mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-10 01:48:00 +00:00
Fix crash on early connection of a sharing downstream.
If you start up two sharing-enabled PuTTYs to the same host simultaneously, the one that ends up being the downstream can connect to the upstream before the upstream has provided a ConnectionLayer to the sharestate, which means that log_downstream() will dereference cs->parent->cl->frontend to find its Frontend and fail because cl is NULL. Fixed by providing a dummy initial ConnectionLayer containing nothing but a frontend pointer, which is then replaced by the real one later.
This commit is contained in:
parent
cea1329b9e
commit
2ea356c46c
10
ssh.c
10
ssh.c
@ -91,6 +91,12 @@ struct Ssh {
|
|||||||
*/
|
*/
|
||||||
ConnectionLayer *cl;
|
ConnectionLayer *cl;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* A dummy ConnectionLayer that can be used for logging sharing
|
||||||
|
* downstreams that connect before the real one is ready.
|
||||||
|
*/
|
||||||
|
ConnectionLayer cl_dummy;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* session_started is FALSE until we initialise the main protocol
|
* session_started is FALSE until we initialise the main protocol
|
||||||
* layers. So it distinguishes between base_layer==NULL meaning
|
* layers. So it distinguishes between base_layer==NULL meaning
|
||||||
@ -106,6 +112,7 @@ struct Ssh {
|
|||||||
int need_random_unref;
|
int need_random_unref;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#define ssh_logevent(params) ( \
|
#define ssh_logevent(params) ( \
|
||||||
logevent_and_free((ssh)->frontend, dupprintf params))
|
logevent_and_free((ssh)->frontend, dupprintf params))
|
||||||
|
|
||||||
@ -640,6 +647,8 @@ static const char *connect_to_host(Ssh *ssh, const char *host, int port,
|
|||||||
ssh->s = ssh_connection_sharing_init(
|
ssh->s = ssh_connection_sharing_init(
|
||||||
ssh->savedhost, ssh->savedport, ssh->conf, ssh->frontend,
|
ssh->savedhost, ssh->savedport, ssh->conf, ssh->frontend,
|
||||||
&ssh->plug, &ssh->connshare);
|
&ssh->plug, &ssh->connshare);
|
||||||
|
if (ssh->connshare)
|
||||||
|
ssh_connshare_provide_connlayer(ssh->connshare, &ssh->cl_dummy);
|
||||||
ssh->attempting_connshare = FALSE;
|
ssh->attempting_connshare = FALSE;
|
||||||
if (ssh->s != NULL) {
|
if (ssh->s != NULL) {
|
||||||
/*
|
/*
|
||||||
@ -805,6 +814,7 @@ static const char *ssh_init(Frontend *frontend, Backend **backend_handle,
|
|||||||
*backend_handle = &ssh->backend;
|
*backend_handle = &ssh->backend;
|
||||||
|
|
||||||
ssh->frontend = frontend;
|
ssh->frontend = frontend;
|
||||||
|
ssh->cl_dummy.frontend = frontend;
|
||||||
|
|
||||||
random_ref(); /* do this now - may be needed by sharing setup code */
|
random_ref(); /* do this now - may be needed by sharing setup code */
|
||||||
ssh->need_random_unref = TRUE;
|
ssh->need_random_unref = TRUE;
|
||||||
|
Loading…
Reference in New Issue
Block a user