X-Git-Url: http://git.dolda2000.com/gitweb/?a=blobdiff_plain;f=lib%2Fcf.c;h=86658f87ccb424f1bfec1776045d58788c143ca0;hb=fc35a3ef51b6f8a2735001b667dac63ae9154ed9;hp=38d98081a260e833c326fd782b3e68e9b2cb817e;hpb=1924fe8c26de2861744fd576631ad15da2759f51;p=ashd.git diff --git a/lib/cf.c b/lib/cf.c index 38d9808..86658f8 100644 --- a/lib/cf.c +++ b/lib/cf.c @@ -23,6 +23,7 @@ #include #include #include +#include #include #ifdef HAVE_CONFIG_H @@ -309,17 +310,19 @@ static int stdhandle(struct child *ch, struct hthead *req, int fd, void (*chinit if(i->type == CH_SOCKET) { if(i->fd < 0) i->fd = stdmkchild(i->argv, chinit, idata); - if(sendreq(i->fd, req, fd)) { + if(sendreq2(i->fd, req, fd, MSG_NOSIGNAL | MSG_DONTWAIT)) { if((errno == EPIPE) || (errno == ECONNRESET)) { /* Assume that the child has crashed and restart it. */ close(i->fd); i->fd = stdmkchild(i->argv, chinit, idata); - if(!sendreq(i->fd, req, fd)) + if(!sendreq2(i->fd, req, fd, MSG_NOSIGNAL | MSG_DONTWAIT)) return(0); } flog(LOG_ERR, "could not pass on request to child %s: %s", ch->name, strerror(errno)); - close(i->fd); - i->fd = -1; + if(errno != EAGAIN) { + close(i->fd); + i->fd = -1; + } return(-1); } } else if(i->type == CH_FORK) {