X-Git-Url: http://www.dolda2000.com/gitweb/?p=ashd.git;a=blobdiff_plain;f=src%2Fssl-gnutls.c;h=baa1334bcf8efa5096a5cba8211f88377af72d4e;hp=d4862d4d8535c822143081d5feada70dbe5b30e5;hb=cac13158ac4fdd8b7682f16f879796e9c4e339ff;hpb=9d32586e59d7053a53e54860cbcfbb9c23f59e8a diff --git a/src/ssl-gnutls.c b/src/ssl-gnutls.c index d4862d4..baa1334 100644 --- a/src/ssl-gnutls.c +++ b/src/ssl-gnutls.c @@ -365,7 +365,8 @@ static void listenloop(struct muth *muth, va_list args) while(1) { namelen = sizeof(name); - block(pd->fd, EV_READ, 0); + if(block(pd->fd, EV_READ, 0) == 0) + goto out; ns = accept(pd->fd, (struct sockaddr *)&name, &namelen); if(ns < 0) { flog(LOG_ERR, "accept: %s", strerror(errno)); @@ -606,7 +607,7 @@ void handlegnussl(int argc, char **argp, char **argv) pd->sport = port; pd->creds = creds; pd->ncreds = ncreds.b; - mustart(listenloop, pd); + bufadd(listeners, mustart(listenloop, pd)); if((fd = listensock4(port)) < 0) { if(errno != EADDRINUSE) { flog(LOG_ERR, "could not listen on IPv4 port (port %i): %s", port, strerror(errno)); @@ -617,7 +618,7 @@ void handlegnussl(int argc, char **argp, char **argv) pd->fd = fd; pd->sport = port; pd->creds = creds; - mustart(listenloop, pd); + bufadd(listeners, mustart(listenloop, pd)); } }