summaryrefslogtreecommitdiffstats
path: root/clientloop.c
diff options
context:
space:
mode:
authorDamien Miller <djm@mindrot.org>2006-10-24 03:02:41 +1000
committerDamien Miller <djm@mindrot.org>2006-10-24 03:02:41 +1000
commit985a4485f57af55cd8f097ab437fdf87c365ea96 (patch)
tree4b92d3258e969d0742120e1315f5b18a028e25f8 /clientloop.c
parentf4bcd10c4c9b53e7c0c2821825addaf3a13d7c1a (diff)
- markus@cvs.openbsd.org 2006/10/11 12:38:03
[clientloop.c serverloop.c] exit instead of doing a blocking tcp send if we detect a client/server timeout, since the tcp sendqueue might be already full (of alive requests); ok dtucker, report mpf
Diffstat (limited to 'clientloop.c')
-rw-r--r--clientloop.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/clientloop.c b/clientloop.c
index 88dfb1f3..4c510819 100644
--- a/clientloop.c
+++ b/clientloop.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: clientloop.c,v 1.175 2006/08/03 03:34:42 deraadt Exp $ */
+/* $OpenBSD: clientloop.c,v 1.176 2006/10/11 12:38:03 markus Exp $ */
/*
* Author: Tatu Ylonen <ylo@cs.hut.fi>
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
@@ -464,8 +464,10 @@ client_global_request_reply(int type, u_int32_t seq, void *ctxt)
static void
server_alive_check(void)
{
- if (++server_alive_timeouts > options.server_alive_count_max)
- packet_disconnect("Timeout, server not responding.");
+ if (++server_alive_timeouts > options.server_alive_count_max) {
+ logit("Timeout, server not responding.");
+ cleanup_exit(255);
+ }
packet_start(SSH2_MSG_GLOBAL_REQUEST);
packet_put_cstring("keepalive@openssh.com");
packet_put_char(1); /* boolean: want reply */