diff options
author | Colin Watson <cjwatson@debian.org> | 2014-02-09 16:09:51 +0000 |
---|---|---|
committer | Colin Watson <cjwatson@debian.org> | 2014-03-20 00:24:49 +0000 |
commit | 789d58ed3df120c7b80d07fb2d259c216194a29c (patch) | |
tree | c109880627e3fd4a3f01732f037e129e13c2b651 /clientloop.c | |
parent | d422205e757aaf23e8e0e787f842ef37f6a170a2 (diff) |
Partial server keep-alive implementation for SSH1
Bug: https://bugzilla.mindrot.org/show_bug.cgi?id=1712
Last-Update: 2013-09-14
Patch-Name: ssh1-keepalive.patch
Diffstat (limited to 'clientloop.c')
-rw-r--r-- | clientloop.c | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/clientloop.c b/clientloop.c index 6d8cd7ddb..73a800ce6 100644 --- a/clientloop.c +++ b/clientloop.c | |||
@@ -563,16 +563,21 @@ client_global_request_reply(int type, u_int32_t seq, void *ctxt) | |||
563 | static void | 563 | static void |
564 | server_alive_check(void) | 564 | server_alive_check(void) |
565 | { | 565 | { |
566 | if (packet_inc_alive_timeouts() > options.server_alive_count_max) { | 566 | if (compat20) { |
567 | logit("Timeout, server %s not responding.", host); | 567 | if (packet_inc_alive_timeouts() > options.server_alive_count_max) { |
568 | cleanup_exit(255); | 568 | logit("Timeout, server %s not responding.", host); |
569 | cleanup_exit(255); | ||
570 | } | ||
571 | packet_start(SSH2_MSG_GLOBAL_REQUEST); | ||
572 | packet_put_cstring("keepalive@openssh.com"); | ||
573 | packet_put_char(1); /* boolean: want reply */ | ||
574 | packet_send(); | ||
575 | /* Insert an empty placeholder to maintain ordering */ | ||
576 | client_register_global_confirm(NULL, NULL); | ||
577 | } else { | ||
578 | packet_send_ignore(0); | ||
579 | packet_send(); | ||
569 | } | 580 | } |
570 | packet_start(SSH2_MSG_GLOBAL_REQUEST); | ||
571 | packet_put_cstring("keepalive@openssh.com"); | ||
572 | packet_put_char(1); /* boolean: want reply */ | ||
573 | packet_send(); | ||
574 | /* Insert an empty placeholder to maintain ordering */ | ||
575 | client_register_global_confirm(NULL, NULL); | ||
576 | } | 581 | } |
577 | 582 | ||
578 | /* | 583 | /* |
@@ -634,7 +639,7 @@ client_wait_until_can_do_something(fd_set **readsetp, fd_set **writesetp, | |||
634 | */ | 639 | */ |
635 | 640 | ||
636 | timeout_secs = INT_MAX; /* we use INT_MAX to mean no timeout */ | 641 | timeout_secs = INT_MAX; /* we use INT_MAX to mean no timeout */ |
637 | if (options.server_alive_interval > 0 && compat20) { | 642 | if (options.server_alive_interval > 0) { |
638 | timeout_secs = options.server_alive_interval; | 643 | timeout_secs = options.server_alive_interval; |
639 | server_alive_time = now + options.server_alive_interval; | 644 | server_alive_time = now + options.server_alive_interval; |
640 | } | 645 | } |