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

Get rid of ssh_set_frozen.

We used it to suppress reading from the network at every point during
protocol setup where PuTTY was waiting for a user response to a dialog
box (e.g. a host key warning). The purpose of this was to avoid
dropping an important packet while the coroutine was listening to one
of its other input parameters (as it were). But now everything is
queue-based, packets will stay queued until we're ready to look at
them anyway; so it's better _not_ to freeze the connection, so that
messages we _can_ handle in between (e.g. SSH_MSG_DEBUG or
SSH_MSG_IGNORE) can still be processed.

That dispenses with all uses of ssh_set_frozen except for its use by
ssh_throttle_conn to exert back-pressure on the server in SSH1 which
doesn't have per-channel windows. So I've moved that last use _into_
ssh_throttle_conn, and now the function is completely gone.
This commit is contained in:
Simon Tatham 2018-09-19 20:52:12 +01:00
parent 242c074646
commit 04226693e3

36
ssh.c
View File

@ -1284,13 +1284,6 @@ static void ssh_got_ssh_version(struct ssh_version_receiver *rcv,
} }
} }
static void ssh_set_frozen(Ssh ssh, int frozen)
{
if (ssh->s)
sk_set_frozen(ssh->s, frozen);
ssh->frozen = frozen;
}
static void ssh_process_incoming_data(void *ctx) static void ssh_process_incoming_data(void *ctx)
{ {
Ssh ssh = (Ssh)ctx; Ssh ssh = (Ssh)ctx;
@ -1720,13 +1713,23 @@ static const char *connect_to_host(Ssh ssh, const char *host, int port,
static void ssh_throttle_conn(Ssh ssh, int adjust) static void ssh_throttle_conn(Ssh ssh, int adjust)
{ {
int old_count = ssh->conn_throttle_count; int old_count = ssh->conn_throttle_count;
int frozen;
ssh->conn_throttle_count += adjust; ssh->conn_throttle_count += adjust;
assert(ssh->conn_throttle_count >= 0); assert(ssh->conn_throttle_count >= 0);
if (ssh->conn_throttle_count && !old_count) { if (ssh->conn_throttle_count && !old_count) {
ssh_set_frozen(ssh, 1); frozen = TRUE;
} else if (!ssh->conn_throttle_count && old_count) { } else if (!ssh->conn_throttle_count && old_count) {
ssh_set_frozen(ssh, 0); frozen = FALSE;
} else {
return; /* don't change current frozen state */
} }
ssh->frozen = frozen;
if (ssh->s)
sk_set_frozen(ssh->s, frozen);
} }
static void ssh_channel_check_throttle(struct ssh_channel *c) static void ssh_channel_check_throttle(struct ssh_channel *c)
@ -2025,7 +2028,6 @@ static void do_ssh1_login(void *vctx)
sfree(keystr); sfree(keystr);
crStopV; crStopV;
} else if (s->dlgret < 0) { /* none configured; use standard handling */ } else if (s->dlgret < 0) { /* none configured; use standard handling */
ssh_set_frozen(ssh, 1);
s->dlgret = verify_ssh_host_key(ssh->frontend, s->dlgret = verify_ssh_host_key(ssh->frontend,
ssh->savedhost, ssh->savedport, ssh->savedhost, ssh->savedport,
"rsa", keystr, fingerprint, "rsa", keystr, fingerprint,
@ -2039,7 +2041,6 @@ static void do_ssh1_login(void *vctx)
crWaitUntilV(ssh->user_response >= 0); crWaitUntilV(ssh->user_response >= 0);
s->dlgret = ssh->user_response; s->dlgret = ssh->user_response;
} }
ssh_set_frozen(ssh, 0);
if (s->dlgret == 0) { if (s->dlgret == 0) {
ssh_disconnect(ssh, "User aborted at host key verification", ssh_disconnect(ssh, "User aborted at host key verification",
@ -2111,7 +2112,6 @@ static void do_ssh1_login(void *vctx)
/* Warn about chosen cipher if necessary. */ /* Warn about chosen cipher if necessary. */
if (warn) { if (warn) {
ssh_set_frozen(ssh, 1);
s->dlgret = askalg(ssh->frontend, "cipher", cipher_string, s->dlgret = askalg(ssh->frontend, "cipher", cipher_string,
ssh_dialog_callback, ssh); ssh_dialog_callback, ssh);
if (s->dlgret < 0) { if (s->dlgret < 0) {
@ -2119,7 +2119,6 @@ static void do_ssh1_login(void *vctx)
crWaitUntilV(ssh->user_response >= 0); crWaitUntilV(ssh->user_response >= 0);
s->dlgret = ssh->user_response; s->dlgret = ssh->user_response;
} }
ssh_set_frozen(ssh, 0);
if (s->dlgret == 0) { if (s->dlgret == 0) {
ssh_disconnect(ssh, "User aborted at cipher warning", NULL, ssh_disconnect(ssh, "User aborted at cipher warning", NULL,
0, TRUE); 0, TRUE);
@ -4625,7 +4624,6 @@ static void do_ssh2_transport(void *vctx)
BinarySource_UPCAST(pktin)->len + 1); BinarySource_UPCAST(pktin)->len + 1);
if (s->warn_kex) { if (s->warn_kex) {
ssh_set_frozen(ssh, 1);
s->dlgret = askalg(ssh->frontend, "key-exchange algorithm", s->dlgret = askalg(ssh->frontend, "key-exchange algorithm",
ssh->kex->name, ssh->kex->name,
ssh_dialog_callback, ssh); ssh_dialog_callback, ssh);
@ -4634,7 +4632,6 @@ static void do_ssh2_transport(void *vctx)
crWaitUntilV(ssh->user_response >= 0); crWaitUntilV(ssh->user_response >= 0);
s->dlgret = ssh->user_response; s->dlgret = ssh->user_response;
} }
ssh_set_frozen(ssh, 0);
if (s->dlgret == 0) { if (s->dlgret == 0) {
ssh_disconnect(ssh, "User aborted at kex warning", NULL, ssh_disconnect(ssh, "User aborted at kex warning", NULL,
0, TRUE); 0, TRUE);
@ -4646,8 +4643,6 @@ static void do_ssh2_transport(void *vctx)
int j, k; int j, k;
char *betteralgs; char *betteralgs;
ssh_set_frozen(ssh, 1);
/* /*
* Change warning box wording depending on why we chose a * Change warning box wording depending on why we chose a
* warning-level host key algorithm. If it's because * warning-level host key algorithm. If it's because
@ -4695,7 +4690,6 @@ static void do_ssh2_transport(void *vctx)
crWaitUntilV(ssh->user_response >= 0); crWaitUntilV(ssh->user_response >= 0);
s->dlgret = ssh->user_response; s->dlgret = ssh->user_response;
} }
ssh_set_frozen(ssh, 0);
if (s->dlgret == 0) { if (s->dlgret == 0) {
ssh_disconnect(ssh, "User aborted at host key warning", NULL, ssh_disconnect(ssh, "User aborted at host key warning", NULL,
0, TRUE); 0, TRUE);
@ -4704,7 +4698,6 @@ static void do_ssh2_transport(void *vctx)
} }
if (s->warn_cscipher) { if (s->warn_cscipher) {
ssh_set_frozen(ssh, 1);
s->dlgret = askalg(ssh->frontend, s->dlgret = askalg(ssh->frontend,
"client-to-server cipher", "client-to-server cipher",
s->out.cipher->name, s->out.cipher->name,
@ -4714,7 +4707,6 @@ static void do_ssh2_transport(void *vctx)
crWaitUntilV(ssh->user_response >= 0); crWaitUntilV(ssh->user_response >= 0);
s->dlgret = ssh->user_response; s->dlgret = ssh->user_response;
} }
ssh_set_frozen(ssh, 0);
if (s->dlgret == 0) { if (s->dlgret == 0) {
ssh_disconnect(ssh, "User aborted at cipher warning", NULL, ssh_disconnect(ssh, "User aborted at cipher warning", NULL,
0, TRUE); 0, TRUE);
@ -4723,7 +4715,6 @@ static void do_ssh2_transport(void *vctx)
} }
if (s->warn_sccipher) { if (s->warn_sccipher) {
ssh_set_frozen(ssh, 1);
s->dlgret = askalg(ssh->frontend, s->dlgret = askalg(ssh->frontend,
"server-to-client cipher", "server-to-client cipher",
s->in.cipher->name, s->in.cipher->name,
@ -4733,7 +4724,6 @@ static void do_ssh2_transport(void *vctx)
crWaitUntilV(ssh->user_response >= 0); crWaitUntilV(ssh->user_response >= 0);
s->dlgret = ssh->user_response; s->dlgret = ssh->user_response;
} }
ssh_set_frozen(ssh, 0);
if (s->dlgret == 0) { if (s->dlgret == 0) {
ssh_disconnect(ssh, "User aborted at cipher warning", NULL, ssh_disconnect(ssh, "User aborted at cipher warning", NULL,
0, TRUE); 0, TRUE);
@ -5498,7 +5488,6 @@ static void do_ssh2_transport(void *vctx)
bombout(("Host key did not appear in manually configured list")); bombout(("Host key did not appear in manually configured list"));
crStopV; crStopV;
} else if (s->dlgret < 0) { /* none configured; use standard handling */ } else if (s->dlgret < 0) { /* none configured; use standard handling */
ssh_set_frozen(ssh, 1);
s->dlgret = verify_ssh_host_key(ssh->frontend, s->dlgret = verify_ssh_host_key(ssh->frontend,
ssh->savedhost, ssh->savedport, ssh->savedhost, ssh->savedport,
ssh_key_cache_id(s->hkey), ssh_key_cache_id(s->hkey),
@ -5512,7 +5501,6 @@ static void do_ssh2_transport(void *vctx)
crWaitUntilV(ssh->user_response >= 0); crWaitUntilV(ssh->user_response >= 0);
s->dlgret = ssh->user_response; s->dlgret = ssh->user_response;
} }
ssh_set_frozen(ssh, 0);
if (s->dlgret == 0) { if (s->dlgret == 0) {
ssh_disconnect(ssh, "Aborted at host key verification", NULL, ssh_disconnect(ssh, "Aborted at host key verification", NULL,
0, TRUE); 0, TRUE);