[clientloop.c]
     check for open sessions before we call select(); fixes the x11 client
     bug reported by bowman@math.ualberta.ca
This commit is contained in:
Ben Lindstrom 2001-05-17 03:19:40 +00:00
parent 06b08018ef
commit c8b3f47676
2 changed files with 13 additions and 3 deletions

View File

@ -9,6 +9,10 @@
- markus@cvs.openbsd.org 2001/05/16 20:51:57 - markus@cvs.openbsd.org 2001/05/16 20:51:57
[authfile.c] [authfile.c]
return comments for private pem files, too; report from nolan@naic.edu return comments for private pem files, too; report from nolan@naic.edu
- markus@cvs.openbsd.org 2001/05/16 21:53:53
[clientloop.c]
check for open sessions before we call select(); fixes the x11 client
bug reported by bowman@math.ualberta.ca
20010512 20010512
- OpenBSD CVS Sync - OpenBSD CVS Sync
@ -5414,4 +5418,4 @@
- Wrote replacements for strlcpy and mkdtemp - Wrote replacements for strlcpy and mkdtemp
- Released 1.0pre1 - Released 1.0pre1
$Id: ChangeLog,v 1.1221 2001/05/17 03:17:55 mouring Exp $ $Id: ChangeLog,v 1.1222 2001/05/17 03:19:40 mouring Exp $

View File

@ -59,7 +59,7 @@
*/ */
#include "includes.h" #include "includes.h"
RCSID("$OpenBSD: clientloop.c,v 1.70 2001/05/11 14:59:55 markus Exp $"); RCSID("$OpenBSD: clientloop.c,v 1.71 2001/05/16 21:53:53 markus Exp $");
#include "ssh.h" #include "ssh.h"
#include "ssh1.h" #include "ssh1.h"
@ -346,7 +346,13 @@ client_wait_until_can_do_something(fd_set **readsetp, fd_set **writesetp,
if (buffer_len(&stderr_buffer) > 0) if (buffer_len(&stderr_buffer) > 0)
FD_SET(fileno(stderr), *writesetp); FD_SET(fileno(stderr), *writesetp);
} else { } else {
FD_SET(connection_in, *readsetp); /* channel_prepare_select could have closed the last channel */
if (session_closed && !channel_still_open()) {
if (!packet_have_data_to_write())
return;
} else {
FD_SET(connection_in, *readsetp);
}
} }
/* Select server connection if have data to write to the server. */ /* Select server connection if have data to write to the server. */