summaryrefslogtreecommitdiffhomepage
path: root/common-channel.c
diff options
context:
space:
mode:
authorMatt Johnston <matt@ucc.asn.au>2013-10-20 21:07:05 +0800
committerMatt Johnston <matt@ucc.asn.au>2013-10-20 21:07:05 +0800
commit27510a6e9eb8f54a8f109fa9f29481e8f8170862 (patch)
tree3f2bc382407148b2e3eae7ecccce24e645ff5340 /common-channel.c
parent7fda6418e15a92fd538a5e72682de94f90b6e060 (diff)
parent45bd0edae52c07daa2d54ca7f7c0a57d51130791 (diff)
merge
--HG-- branch : ecc
Diffstat (limited to 'common-channel.c')
-rw-r--r--common-channel.c5
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