diff options
author | dtucker <dtucker> | 2010-01-08 05:51:40 +0000 |
---|---|---|
committer | dtucker <dtucker> | 2010-01-08 05:51:40 +0000 |
commit | 8fd1298b08e3051bb7a62fa9c81008392bd0d186 (patch) | |
tree | 4b0b5af4442174a7833639bb58aa4a5cd1bb453e /clientloop.c | |
parent | 02586d23f45924ecfc2be44fc4cd50f318a8e40d (diff) | |
download | openssh-8fd1298b08e3051bb7a62fa9c81008392bd0d186.tar.gz |
- andreas@cvs.openbsd.org 2009/10/24 11:15:29
[clientloop.c]
client_loop() must detect if the session has been suspended and resumed,
and take appropriate action in that case.
From Martin Forssen, maf at appgate dot com
ok markus@
Diffstat (limited to 'clientloop.c')
-rw-r--r-- | clientloop.c | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/clientloop.c b/clientloop.c index 9a7dc0ab..540a6181 100644 --- a/clientloop.c +++ b/clientloop.c @@ -1,4 +1,4 @@ -/* $OpenBSD: clientloop.c,v 1.213 2009/07/05 19:28:33 stevesk Exp $ */ +/* $OpenBSD: clientloop.c,v 1.214 2009/10/24 11:15:29 andreas Exp $ */ /* * Author: Tatu Ylonen <ylo@cs.hut.fi> * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland @@ -161,6 +161,8 @@ static int session_closed = 0; /* In SSH2: login session closed. */ static void client_init_dispatch(void); int session_ident = -1; +int session_resumed = 0; + /* Track escape per proto2 channel */ struct escape_filter_ctx { int escape_pending; @@ -1460,6 +1462,14 @@ client_loop(int have_pty, int escape_char_arg, int ssh2_chan_id) client_process_output(writeset); } + if (session_resumed) { + connection_in = packet_get_connection_in(); + connection_out = packet_get_connection_out(); + max_fd = MAX(max_fd, connection_out); + max_fd = MAX(max_fd, connection_in); + session_resumed = 0; + } + /* * Send as much buffered packet data as possible to the * sender. |