summaryrefslogtreecommitdiffhomepage
path: root/src/event/ngx_event_timer.c
diff options
context:
space:
mode:
authorIgor Sysoev <igor@sysoev.ru>2004-02-29 21:03:02 +0000
committerIgor Sysoev <igor@sysoev.ru>2004-02-29 21:03:02 +0000
commitd94049b6320504f3213adfaad939493676e83a3a (patch)
tree7a25b794030cbee22cca6e2bf27aa3569f915d2c /src/event/ngx_event_timer.c
parent898446c8bacb5b0e1c223dfec4643ebee8d07f8e (diff)
downloadnginx-d94049b6320504f3213adfaad939493676e83a3a.tar.gz
nginx-d94049b6320504f3213adfaad939493676e83a3a.tar.bz2
nginx-0.0.2-2004-03-01-00:03:02 import
Diffstat (limited to 'src/event/ngx_event_timer.c')
-rw-r--r--src/event/ngx_event_timer.c13
1 files changed, 9 insertions, 4 deletions
diff --git a/src/event/ngx_event_timer.c b/src/event/ngx_event_timer.c
index 498fd9fa0..8983d997b 100644
--- a/src/event/ngx_event_timer.c
+++ b/src/event/ngx_event_timer.c
@@ -9,22 +9,26 @@ ngx_mutex_t *ngx_event_timer_mutex;
#endif
-ngx_rbtree_t *ngx_event_timer_rbtree;
-ngx_rbtree_t ngx_event_timer_sentinel;
+volatile ngx_rbtree_t *ngx_event_timer_rbtree;
+ngx_rbtree_t ngx_event_timer_sentinel;
ngx_int_t ngx_event_timer_init(ngx_log_t *log)
{
if (ngx_event_timer_rbtree) {
+#if (NGX_THREADS)
ngx_event_timer_mutex->log = log;
+#endif
return NGX_OK;
}
ngx_event_timer_rbtree = &ngx_event_timer_sentinel;
+#if (NGX_THREADS)
if (!(ngx_event_timer_mutex = ngx_mutex_init(log, 0))) {
return NGX_ERROR;
}
+#endif
return NGX_OK;
}
@@ -44,7 +48,8 @@ ngx_msec_t ngx_event_find_timer(void)
}
#endif
- node = ngx_rbtree_min(ngx_event_timer_rbtree, &ngx_event_timer_sentinel);
+ node = ngx_rbtree_min((ngx_rbtree_t *) ngx_event_timer_rbtree,
+ &ngx_event_timer_sentinel);
#if (NGX_THREADS)
ngx_mutex_unlock(ngx_event_timer_mutex);
@@ -76,7 +81,7 @@ void ngx_event_expire_timers(ngx_msec_t timer)
}
#endif
- node = ngx_rbtree_min(ngx_event_timer_rbtree,
+ node = ngx_rbtree_min((ngx_rbtree_t *) ngx_event_timer_rbtree,
&ngx_event_timer_sentinel);
#if (NGX_THREADS)