diff --git a/src/child.c b/src/child.c index effb2ae..60f8ead 100644 --- a/src/child.c +++ b/src/child.c @@ -206,27 +206,27 @@ static void child_main (struct child_s *ptr) * We have to wait for connections on multiple fds, * so use select. */ - - FD_ZERO(&rfds); - - for (i = 0; i < vector_length(listen_fds); i++) { - int *fd = (int *) vector_getentry(listen_fds, i, NULL); - - ret = socket_nonblocking(*fd); - if (ret != 0) { - log_message(LOG_ERR, "Failed to set the listening " - "socket %d to non-blocking: %s", - fd, strerror(errno)); - exit(1); - } - - FD_SET(*fd, &rfds); - maxfd = max(maxfd, *fd); - } - while (!config.quit) { + int listenfd = -1; + FD_ZERO(&rfds); + + for (i = 0; i < vector_length(listen_fds); i++) { + int *fd = (int *) vector_getentry(listen_fds, i, NULL); + + ret = socket_nonblocking(*fd); + if (ret != 0) { + log_message(LOG_ERR, "Failed to set the listening " + "socket %d to non-blocking: %s", + fd, strerror(errno)); + exit(1); + } + + FD_SET(*fd, &rfds); + maxfd = max(maxfd, *fd); + } + ptr->status = T_WAITING; clilen = sizeof(struct sockaddr_storage);