From fedbe888e8bde30e6f0b1d9478bac4cf6c982489 Mon Sep 17 00:00:00 2001 From: Robert James Kaes Date: Wed, 23 May 2001 17:56:35 +0000 Subject: [PATCH] Fixed a potential problem with not zeroing the number of connections when the threads are emptied. --- src/thread.c | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/src/thread.c b/src/thread.c index 8975bc7..202c9d6 100644 --- a/src/thread.c +++ b/src/thread.c @@ -1,4 +1,4 @@ -/* $Id: thread.c,v 1.3 2000-12-09 02:35:30 rjkaes Exp $ +/* $Id: thread.c,v 1.4 2001-05-23 17:56:35 rjkaes Exp $ * * Handles the creation/destruction of the various threads required for * processing incoming connections. @@ -25,11 +25,20 @@ static int listenfd; static socklen_t addrlen; + +/* + * Stores the internal data needed for each thread (connection) + */ struct thread_s { pthread_t tid; enum { T_EMPTY, T_WAITING, T_CONNECTED } status; unsigned int connects; }; + +/* + * A pointer to an array of threads. A certain number of threads are + * created when the program is started. + */ static struct thread_s *thread_ptr; static pthread_mutex_t mlock = PTHREAD_MUTEX_INITIALIZER; @@ -117,7 +126,6 @@ static void *thread_main(void *arg) ptr->connects++; if (ptr->connects > thread_config.maxrequestsperchild) { - ptr->connects = 0; ptr->status = T_EMPTY; return NULL; } else { @@ -127,6 +135,7 @@ static void *thread_main(void *arg) } } } + /* * Create the initial pool of threads. */ @@ -179,6 +188,7 @@ int thread_main_loop(void) if (thread_ptr[i].status == T_EMPTY) { pthread_create(&thread_ptr[i].tid, NULL, &thread_main, &thread_ptr[i]); thread_ptr[i].status = T_WAITING; + thread_ptr[i].connects = 0; SERVER_INC();