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

do_ssh1_connection: get packets from a PacketQueue.

Even with my love of verbose commit messages, I don't think there's
anything interesting to say about this commit that the previous few
similar ones haven't mentioned already. This is just more of the same
transformations.
This commit is contained in:
Simon Tatham 2018-05-18 07:22:58 +01:00
parent 7c47a17b4e
commit 38fccbf4aa

63
ssh.c
View File

@ -969,6 +969,9 @@ struct ssh_tag {
struct PacketQueue pq_ssh1_login; struct PacketQueue pq_ssh1_login;
struct IdempotentCallback ssh1_login_icb; struct IdempotentCallback ssh1_login_icb;
struct PacketQueue pq_ssh1_connection;
struct IdempotentCallback ssh1_connection_icb;
struct PacketQueue pq_ssh2_authconn; struct PacketQueue pq_ssh2_authconn;
struct IdempotentCallback ssh2_authconn_icb; struct IdempotentCallback ssh2_authconn_icb;
@ -6023,8 +6026,11 @@ int ssh_agent_forwarding_permitted(Ssh ssh)
return conf_get_int(ssh->conf, CONF_agentfwd) && agent_exists(); return conf_get_int(ssh->conf, CONF_agentfwd) && agent_exists();
} }
static void do_ssh1_connection(Ssh ssh, struct Packet *pktin) static void do_ssh1_connection(void *vctx)
{ {
Ssh ssh = (Ssh)vctx;
struct Packet *pktin;
crBegin(ssh->do_ssh1_connection_crstate); crBegin(ssh->do_ssh1_connection_crstate);
ssh->packet_dispatch[SSH1_SMSG_STDOUT_DATA] = ssh->packet_dispatch[SSH1_SMSG_STDOUT_DATA] =
@ -6044,9 +6050,7 @@ static void do_ssh1_connection(Ssh ssh, struct Packet *pktin)
if (ssh_agent_forwarding_permitted(ssh)) { if (ssh_agent_forwarding_permitted(ssh)) {
logevent("Requesting agent forwarding"); logevent("Requesting agent forwarding");
send_packet(ssh, SSH1_CMSG_AGENT_REQUEST_FORWARDING, PKT_END); send_packet(ssh, SSH1_CMSG_AGENT_REQUEST_FORWARDING, PKT_END);
do { crMaybeWaitUntilV((pktin = pq_pop(&ssh->pq_ssh1_connection)) != NULL);
crReturnV;
} while (!pktin);
if (pktin->type != SSH1_SMSG_SUCCESS if (pktin->type != SSH1_SMSG_SUCCESS
&& pktin->type != SSH1_SMSG_FAILURE) { && pktin->type != SSH1_SMSG_FAILURE) {
bombout(("Protocol confusion")); bombout(("Protocol confusion"));
@ -6086,9 +6090,8 @@ static void do_ssh1_connection(Ssh ssh, struct Packet *pktin)
PKT_STR, ssh->x11auth->datastring, PKT_STR, ssh->x11auth->datastring,
PKT_END); PKT_END);
} }
do { crMaybeWaitUntilV((pktin = pq_pop(&ssh->pq_ssh1_connection))
crReturnV; != NULL);
} while (!pktin);
if (pktin->type != SSH1_SMSG_SUCCESS if (pktin->type != SSH1_SMSG_SUCCESS
&& pktin->type != SSH1_SMSG_FAILURE) { && pktin->type != SSH1_SMSG_FAILURE) {
bombout(("Protocol confusion")); bombout(("Protocol confusion"));
@ -6127,9 +6130,7 @@ static void do_ssh1_connection(Ssh ssh, struct Packet *pktin)
ssh_pkt_addbyte(pkt, SSH_TTY_OP_END); ssh_pkt_addbyte(pkt, SSH_TTY_OP_END);
s_wrpkt(ssh, pkt); s_wrpkt(ssh, pkt);
ssh->state = SSH_STATE_INTERMED; ssh->state = SSH_STATE_INTERMED;
do { crMaybeWaitUntilV((pktin = pq_pop(&ssh->pq_ssh1_connection)) != NULL);
crReturnV;
} while (!pktin);
if (pktin->type != SSH1_SMSG_SUCCESS if (pktin->type != SSH1_SMSG_SUCCESS
&& pktin->type != SSH1_SMSG_FAILURE) { && pktin->type != SSH1_SMSG_FAILURE) {
bombout(("Protocol confusion")); bombout(("Protocol confusion"));
@ -6148,9 +6149,7 @@ static void do_ssh1_connection(Ssh ssh, struct Packet *pktin)
if (conf_get_int(ssh->conf, CONF_compression)) { if (conf_get_int(ssh->conf, CONF_compression)) {
send_packet(ssh, SSH1_CMSG_REQUEST_COMPRESSION, PKT_INT, 6, PKT_END); send_packet(ssh, SSH1_CMSG_REQUEST_COMPRESSION, PKT_INT, 6, PKT_END);
do { crMaybeWaitUntilV((pktin = pq_pop(&ssh->pq_ssh1_connection)) != NULL);
crReturnV;
} while (!pktin);
if (pktin->type != SSH1_SMSG_SUCCESS if (pktin->type != SSH1_SMSG_SUCCESS
&& pktin->type != SSH1_SMSG_FAILURE) { && pktin->type != SSH1_SMSG_FAILURE) {
bombout(("Protocol confusion")); bombout(("Protocol confusion"));
@ -6206,8 +6205,7 @@ static void do_ssh1_connection(Ssh ssh, struct Packet *pktin)
* attention to the unusual ones. * attention to the unusual ones.
*/ */
crReturnV; while ((pktin = pq_pop(&ssh->pq_ssh1_connection)) != NULL) {
if (pktin) {
if (pktin->type == SSH1_SMSG_SUCCESS) { if (pktin->type == SSH1_SMSG_SUCCESS) {
/* may be from EXEC_SHELL on some servers */ /* may be from EXEC_SHELL on some servers */
} else if (pktin->type == SSH1_SMSG_FAILURE) { } else if (pktin->type == SSH1_SMSG_FAILURE) {
@ -6217,19 +6215,19 @@ static void do_ssh1_connection(Ssh ssh, struct Packet *pktin)
bombout(("Strange packet received: type %d", pktin->type)); bombout(("Strange packet received: type %d", pktin->type));
crStopV; crStopV;
} }
} else {
while (bufchain_size(&ssh->user_input) > 0) {
void *data;
int len;
bufchain_prefix(&ssh->user_input, &data, &len);
if (len > 512)
len = 512;
send_packet(ssh, SSH1_CMSG_STDIN_DATA,
PKT_INT, len, PKT_DATA, data, len,
PKT_END);
bufchain_consume(&ssh->user_input, len);
}
} }
while (bufchain_size(&ssh->user_input) > 0) {
void *data;
int len;
bufchain_prefix(&ssh->user_input, &data, &len);
if (len > 512)
len = 512;
send_packet(ssh, SSH1_CMSG_STDIN_DATA,
PKT_INT, len, PKT_DATA, data, len,
PKT_END);
bufchain_consume(&ssh->user_input, len);
}
crReturnV;
} }
crFinishV; crFinishV;
@ -6270,7 +6268,7 @@ static void ssh1_login_input(Ssh ssh)
static void ssh1_connection_input(Ssh ssh) static void ssh1_connection_input(Ssh ssh)
{ {
do_ssh1_connection(ssh, NULL); do_ssh1_connection(ssh);
} }
static void ssh1_coro_wrapper_initial(Ssh ssh, struct Packet *pktin) static void ssh1_coro_wrapper_initial(Ssh ssh, struct Packet *pktin)
@ -6282,7 +6280,9 @@ static void ssh1_coro_wrapper_initial(Ssh ssh, struct Packet *pktin)
static void ssh1_coro_wrapper_session(Ssh ssh, struct Packet *pktin) static void ssh1_coro_wrapper_session(Ssh ssh, struct Packet *pktin)
{ {
do_ssh1_connection(ssh, pktin); pktin->refcount++; /* avoid packet being freed when we return */
pq_push(&ssh->pq_ssh1_connection, pktin);
queue_idempotent_callback(&ssh->ssh1_connection_icb);
} }
static void ssh1_protocol_setup(Ssh ssh) static void ssh1_protocol_setup(Ssh ssh)
@ -12302,6 +12302,10 @@ static const char *ssh_init(void *frontend_handle, void **backend_handle,
ssh->ssh1_login_icb.fn = do_ssh1_login; ssh->ssh1_login_icb.fn = do_ssh1_login;
ssh->ssh1_login_icb.ctx = ssh; ssh->ssh1_login_icb.ctx = ssh;
ssh->ssh1_login_icb.queued = FALSE; ssh->ssh1_login_icb.queued = FALSE;
pq_init(&ssh->pq_ssh1_connection);
ssh->ssh1_connection_icb.fn = do_ssh1_connection;
ssh->ssh1_connection_icb.ctx = ssh;
ssh->ssh1_connection_icb.queued = FALSE;
pq_init(&ssh->pq_ssh2_authconn); pq_init(&ssh->pq_ssh2_authconn);
ssh->ssh2_authconn_icb.fn = do_ssh2_authconn; ssh->ssh2_authconn_icb.fn = do_ssh2_authconn;
ssh->ssh2_authconn_icb.ctx = ssh; ssh->ssh2_authconn_icb.ctx = ssh;
@ -12485,6 +12489,7 @@ static void ssh_free(void *handle)
sfree(ssh->incoming_data_eof_message); sfree(ssh->incoming_data_eof_message);
pq_clear(&ssh->pq_full); pq_clear(&ssh->pq_full);
pq_clear(&ssh->pq_ssh1_login); pq_clear(&ssh->pq_ssh1_login);
pq_clear(&ssh->pq_ssh1_connection);
pq_clear(&ssh->pq_ssh2_authconn); pq_clear(&ssh->pq_ssh2_authconn);
bufchain_clear(&ssh->user_input); bufchain_clear(&ssh->user_input);
sfree(ssh->v_c); sfree(ssh->v_c);