diff options
author | Matt Johnston <matt@ucc.asn.au> | 2013-10-20 21:07:05 +0800 |
---|---|---|
committer | Matt Johnston <matt@ucc.asn.au> | 2013-10-20 21:07:05 +0800 |
commit | 27510a6e9eb8f54a8f109fa9f29481e8f8170862 (patch) | |
tree | 3f2bc382407148b2e3eae7ecccce24e645ff5340 /common-channel.c | |
parent | 7fda6418e15a92fd538a5e72682de94f90b6e060 (diff) | |
parent | 45bd0edae52c07daa2d54ca7f7c0a57d51130791 (diff) |
merge
--HG--
branch : ecc
Diffstat (limited to 'common-channel.c')
-rw-r--r-- | common-channel.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/common-channel.c b/common-channel.c index 8b7369c..2068904 100644 --- a/common-channel.c +++ b/common-channel.c @@ -307,7 +307,9 @@ static void check_close(struct Channel *channel) { return; } - if (channel->recv_eof && !write_pending(channel)) { + if ((channel->recv_eof && !write_pending(channel)) + /* have a server "session" and child has exited */ + || (channel->type->check_close && close_allowed)) { close_chan_fd(channel, channel->writefd, SHUT_WR); } @@ -336,6 +338,7 @@ static void check_close(struct Channel *channel) { /* And if we can't receive any more data from them either, close up */ if (channel->readfd == FD_CLOSED + && channel->writefd == FD_CLOSED && (ERRFD_IS_WRITE(channel) || channel->errfd == FD_CLOSED) && !channel->sent_close && close_allowed |