aboutsummaryrefslogtreecommitdiff
path: root/src/event/ngx_event_timer.c
diff options
context:
space:
mode:
authorIgor Sysoev <igor@sysoev.ru>2003-01-24 16:09:40 +0000
committerIgor Sysoev <igor@sysoev.ru>2003-01-24 16:09:40 +0000
commit830c4ce7afd0da40a06d47c176534a5fa03c0b36 (patch)
tree0448c34b3071f16c8f921ac0e1142bccee7f85bb /src/event/ngx_event_timer.c
parent404326f68ffe52b6f166ac961f01bb8889945fa8 (diff)
downloadnginx-830c4ce7afd0da40a06d47c176534a5fa03c0b36.tar.gz
nginx-830c4ce7afd0da40a06d47c176534a5fa03c0b36.zip
nginx-0.0.1-2003-01-24-19:09:40 import
Diffstat (limited to 'src/event/ngx_event_timer.c')
-rw-r--r--src/event/ngx_event_timer.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/src/event/ngx_event_timer.c b/src/event/ngx_event_timer.c
index 5663f5481..8b2616160 100644
--- a/src/event/ngx_event_timer.c
+++ b/src/event/ngx_event_timer.c
@@ -14,6 +14,7 @@
ngx_event_t *ngx_timer_queue;
int ngx_timer_hash_size;
+static int ngx_timer_cur_queue;
int ngx_event_init_timer(ngx_log_t *log)
@@ -21,6 +22,7 @@ int ngx_event_init_timer(ngx_log_t *log)
int i;
ngx_timer_hash_size = NGX_TIMER_HASH_SIZE;
+ ngx_timer_cur_queue = 0;
ngx_test_null(ngx_timer_queue,
ngx_alloc(ngx_timer_hash_size * sizeof(ngx_event_t), log),
@@ -37,7 +39,6 @@ int ngx_event_init_timer(ngx_log_t *log)
void ngx_event_add_timer(ngx_event_t *ev, ngx_msec_t timer)
{
- int n;
ngx_event_t *e;
#if (NGX_DEBUG_EVENT)
@@ -50,18 +51,22 @@ void ngx_event_add_timer(ngx_event_t *ev, ngx_msec_t timer)
return;
}
- n = timer % ngx_timer_hash_size;
#if (NGX_DEBUG_EVENT)
- ngx_log_debug(ev->log, "timer slot: %d" _ n);
+ ngx_log_debug(ev->log, "timer slot: %d" _ ngx_timer_cur_queue);
#endif
- for (e = ngx_timer_queue[n].timer_next;
- e != &ngx_timer_queue[n] && timer > e->timer_delta;
+ for (e = ngx_timer_queue[ngx_timer_cur_queue].timer_next;
+ e != &ngx_timer_queue[ngx_timer_cur_queue] && timer > e->timer_delta;
e = e->timer_next)
{
timer -= e->timer_delta;
}
+ ngx_timer_cur_queue++;
+ if (ngx_timer_cur_queue >= ngx_timer_hash_size) {
+ ngx_timer_cur_queue = 0;
+ }
+
ev->timer_delta = timer;
ev->timer_next = e;