summaryrefslogtreecommitdiffstats
path: root/channels.c
diff options
context:
space:
mode:
authorDamien Miller <djm@mindrot.org>2022-01-22 01:38:21 +0100
committerDamien Miller <djm@mindrot.org>2022-01-22 01:38:21 +0100
commite204b34337a965feb439826157c191919fd9ecf8 (patch)
tree0ecfb26b6f7842683a938009be40505fd15b3b6c /channels.c
parentFix signedness bug in Cygwin code (diff)
downloadopenssh-e204b34337a965feb439826157c191919fd9ecf8.tar.xz
openssh-e204b34337a965feb439826157c191919fd9ecf8.zip
restore tty force-read hack
This portable-specific hack fixes a hang on exit for ttyful sessions on Linux and some SysVish Unix variants. It was accidentally disabled in commit 5c79952dfe1a (a precursor to the mainloop poll(2) conversion). Spotted by John in bz3383
Diffstat (limited to 'channels.c')
-rw-r--r--channels.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/channels.c b/channels.c
index 8281e5d3b..dbfec7c00 100644
--- a/channels.c
+++ b/channels.c
@@ -1922,7 +1922,7 @@ channel_handle_rfd(struct ssh *ssh, Channel *c)
force = c->isatty && c->detach_close && c->istate != CHAN_INPUT_CLOSED;
- if ((c->io_ready & SSH_CHAN_IO_RFD) == 0)
+ if (!force && (c->io_ready & SSH_CHAN_IO_RFD) == 0)
return 1;
errno = 0;
@@ -2087,7 +2087,7 @@ channel_handle_efd_read(struct ssh *ssh, Channel *c)
force = c->isatty && c->detach_close && c->istate != CHAN_INPUT_CLOSED;
- if ((c->io_ready & SSH_CHAN_IO_EFD_R) == 0)
+ if (!force && (c->io_ready & SSH_CHAN_IO_EFD_R) == 0)
return 1;
len = read(c->efd, buf, sizeof(buf));