mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-10 01:48:00 +00:00
sshshare: notify cl when last downstream goes away.
The check_termination function in ssh2connection is supposed to be called whenever it's possible that we've run out of (a) channels, and (b) sharing downstreams. I've been calling it on every channel close, but apparently completely forgot to add a callback from sshshare.c that also arranges to call it when we run out of downstreams.
This commit is contained in:
parent
5a6608bda8
commit
57553bdaac
5
ssh.h
5
ssh.h
@ -236,6 +236,9 @@ struct ConnectionLayerVtable {
|
|||||||
void (*sharing_queue_global_request)(
|
void (*sharing_queue_global_request)(
|
||||||
ConnectionLayer *cl, ssh_sharing_connstate *connstate);
|
ConnectionLayer *cl, ssh_sharing_connstate *connstate);
|
||||||
|
|
||||||
|
/* Indicate that the last downstream has disconnected */
|
||||||
|
void (*sharing_no_more_downstreams)(ConnectionLayer *cl);
|
||||||
|
|
||||||
/* Query whether the connection layer is doing agent forwarding */
|
/* Query whether the connection layer is doing agent forwarding */
|
||||||
int (*agent_forwarding_permitted)(ConnectionLayer *cl);
|
int (*agent_forwarding_permitted)(ConnectionLayer *cl);
|
||||||
|
|
||||||
@ -281,6 +284,8 @@ struct ConnectionLayer {
|
|||||||
((cl)->vt->delete_sharing_channel(cl, ch))
|
((cl)->vt->delete_sharing_channel(cl, ch))
|
||||||
#define ssh_sharing_queue_global_request(cl, cs) \
|
#define ssh_sharing_queue_global_request(cl, cs) \
|
||||||
((cl)->vt->sharing_queue_global_request(cl, cs))
|
((cl)->vt->sharing_queue_global_request(cl, cs))
|
||||||
|
#define ssh_sharing_no_more_downstreams(cl) \
|
||||||
|
((cl)->vt->sharing_no_more_downstreams(cl))
|
||||||
#define ssh_agent_forwarding_permitted(cl) \
|
#define ssh_agent_forwarding_permitted(cl) \
|
||||||
((cl)->vt->agent_forwarding_permitted(cl))
|
((cl)->vt->agent_forwarding_permitted(cl))
|
||||||
#define ssh_terminal_size(cl, w, h) ((cl)->vt->terminal_size(cl, w, h))
|
#define ssh_terminal_size(cl, w, h) ((cl)->vt->terminal_size(cl, w, h))
|
||||||
|
@ -119,6 +119,7 @@ static const struct ConnectionLayerVtable ssh1_connlayer_vtable = {
|
|||||||
NULL /* alloc_sharing_channel */,
|
NULL /* alloc_sharing_channel */,
|
||||||
NULL /* delete_sharing_channel */,
|
NULL /* delete_sharing_channel */,
|
||||||
NULL /* sharing_queue_global_request */,
|
NULL /* sharing_queue_global_request */,
|
||||||
|
NULL /* sharing_no_more_downstreams */,
|
||||||
ssh1_agent_forwarding_permitted,
|
ssh1_agent_forwarding_permitted,
|
||||||
ssh1_terminal_size,
|
ssh1_terminal_size,
|
||||||
ssh1_stdout_unthrottle,
|
ssh1_stdout_unthrottle,
|
||||||
|
@ -127,6 +127,7 @@ static void ssh2_delete_sharing_channel(
|
|||||||
ConnectionLayer *cl, unsigned localid);
|
ConnectionLayer *cl, unsigned localid);
|
||||||
static void ssh2_sharing_queue_global_request(
|
static void ssh2_sharing_queue_global_request(
|
||||||
ConnectionLayer *cl, ssh_sharing_connstate *share_ctx);
|
ConnectionLayer *cl, ssh_sharing_connstate *share_ctx);
|
||||||
|
static void ssh2_sharing_no_more_downstreams(ConnectionLayer *cl);
|
||||||
static int ssh2_agent_forwarding_permitted(ConnectionLayer *cl);
|
static int ssh2_agent_forwarding_permitted(ConnectionLayer *cl);
|
||||||
static void ssh2_terminal_size(ConnectionLayer *cl, int width, int height);
|
static void ssh2_terminal_size(ConnectionLayer *cl, int width, int height);
|
||||||
static void ssh2_stdout_unthrottle(ConnectionLayer *cl, int bufsize);
|
static void ssh2_stdout_unthrottle(ConnectionLayer *cl, int bufsize);
|
||||||
@ -144,6 +145,7 @@ static const struct ConnectionLayerVtable ssh2_connlayer_vtable = {
|
|||||||
ssh2_alloc_sharing_channel,
|
ssh2_alloc_sharing_channel,
|
||||||
ssh2_delete_sharing_channel,
|
ssh2_delete_sharing_channel,
|
||||||
ssh2_sharing_queue_global_request,
|
ssh2_sharing_queue_global_request,
|
||||||
|
ssh2_sharing_no_more_downstreams,
|
||||||
ssh2_agent_forwarding_permitted,
|
ssh2_agent_forwarding_permitted,
|
||||||
ssh2_terminal_size,
|
ssh2_terminal_size,
|
||||||
ssh2_stdout_unthrottle,
|
ssh2_stdout_unthrottle,
|
||||||
@ -2096,6 +2098,13 @@ static void ssh2_sharing_queue_global_request(
|
|||||||
ssh2_queue_global_request_handler(s, ssh2_sharing_globreq_response, cs);
|
ssh2_queue_global_request_handler(s, ssh2_sharing_globreq_response, cs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void ssh2_sharing_no_more_downstreams(ConnectionLayer *cl)
|
||||||
|
{
|
||||||
|
struct ssh2_connection_state *s =
|
||||||
|
FROMFIELD(cl, struct ssh2_connection_state, cl);
|
||||||
|
queue_toplevel_callback(ssh2_check_termination_callback, s);
|
||||||
|
}
|
||||||
|
|
||||||
static struct X11FakeAuth *ssh2_add_sharing_x11_display(
|
static struct X11FakeAuth *ssh2_add_sharing_x11_display(
|
||||||
ConnectionLayer *cl, int authtype, ssh_sharing_connstate *share_cs,
|
ConnectionLayer *cl, int authtype, ssh_sharing_connstate *share_cs,
|
||||||
share_channel *share_chan)
|
share_channel *share_chan)
|
||||||
|
12
sshshare.c
12
sshshare.c
@ -905,12 +905,22 @@ static void share_try_cleanup(struct ssh_sharing_connstate *cs)
|
|||||||
if (count234(cs->halfchannels) == 0 &&
|
if (count234(cs->halfchannels) == 0 &&
|
||||||
count234(cs->channels_by_us) == 0 &&
|
count234(cs->channels_by_us) == 0 &&
|
||||||
count234(cs->forwardings) == 0) {
|
count234(cs->forwardings) == 0) {
|
||||||
|
struct ssh_sharing_state *sharestate = cs->parent;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Now we're _really_ done, so we can get rid of cs completely.
|
* Now we're _really_ done, so we can get rid of cs completely.
|
||||||
*/
|
*/
|
||||||
del234(cs->parent->connections, cs);
|
del234(sharestate->connections, cs);
|
||||||
log_downstream(cs, "disconnected");
|
log_downstream(cs, "disconnected");
|
||||||
share_connstate_free(cs);
|
share_connstate_free(cs);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* And if this was the last downstream, notify the connection
|
||||||
|
* layer, because it might now be time to wind up the whole
|
||||||
|
* SSH connection.
|
||||||
|
*/
|
||||||
|
if (count234(sharestate->connections) == 0 && sharestate->cl)
|
||||||
|
ssh_sharing_no_more_downstreams(sharestate->cl);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user