From 0dac00b290d9c177546e9d545b80be24edd5649f Mon Sep 17 00:00:00 2001 From: Vsevolod Stakhov Date: Mon, 24 Aug 2009 18:20:39 +0400 Subject: [PATCH] * Fix error with controller IO timeouts --- src/controller.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/controller.c b/src/controller.c index d7917508a..65434c974 100644 --- a/src/controller.c +++ b/src/controller.c @@ -82,7 +82,6 @@ static GCompletion *comp; static time_t start_time; static char greetingbuf[1024]; -static struct timeval io_tv; extern rspamd_hash_t *counters; static @@ -554,6 +553,7 @@ accept_socket (int fd, short what, void *arg) struct rspamd_worker *worker = (struct rspamd_worker *)arg; struct sockaddr_storage ss; struct controller_session *new_session; + struct timeval *io_tv; socklen_t addrlen = sizeof(ss); int nfd; @@ -576,8 +576,12 @@ accept_socket (int fd, short what, void *arg) worker->srv->stat->control_connections_count ++; /* Set up dispatcher */ + io_tv = memory_pool_alloc (new_session->session_pool, sizeof (struct timeval)); + io_tv->tv_sec = CONTROLLER_IO_TIMEOUT; + io_tv->tv_usec = 0; + new_session->dispatcher = rspamd_create_dispatcher (nfd, BUFFER_LINE, controller_read_socket, - controller_write_socket, controller_err_socket, &io_tv, + controller_write_socket, controller_err_socket, io_tv, (void *)new_session); rspamd_dispatcher_write (new_session->dispatcher, greetingbuf, strlen (greetingbuf), FALSE, FALSE); } @@ -624,8 +628,6 @@ start_controller (struct rspamd_worker *worker) /* Send SIGUSR2 to parent */ kill (getppid (), SIGUSR2); - io_tv.tv_sec = CONTROLLER_IO_TIMEOUT; - io_tv.tv_usec = 0; event_loop (0); -- 2.39.5