One Level Up
Top Level
src/event/ngx_event_timer.c - nginx-1.7.10
Global variables defined
Functions defined
Source code
- #include <ngx_config.h>
- #include <ngx_core.h>
- #include <ngx_event.h>
- ngx_rbtree_t ngx_event_timer_rbtree;
- static ngx_rbtree_node_t ngx_event_timer_sentinel;
- ngx_int_t
- ngx_event_timer_init(ngx_log_t *log)
- {
- ngx_rbtree_init(&ngx_event_timer_rbtree, &ngx_event_timer_sentinel,
- ngx_rbtree_insert_timer_value);
- return NGX_OK;
- }
- ngx_msec_t
- ngx_event_find_timer(void)
- {
- ngx_msec_int_t timer;
- ngx_rbtree_node_t *node, *root, *sentinel;
- if (ngx_event_timer_rbtree.root == &ngx_event_timer_sentinel) {
- return NGX_TIMER_INFINITE;
- }
- root = ngx_event_timer_rbtree.root;
- sentinel = ngx_event_timer_rbtree.sentinel;
- node = ngx_rbtree_min(root, sentinel);
- timer = (ngx_msec_int_t) (node->key - ngx_current_msec);
- return (ngx_msec_t) (timer > 0 ? timer : 0);
- }
- void
- ngx_event_expire_timers(void)
- {
- ngx_event_t *ev;
- ngx_rbtree_node_t *node, *root, *sentinel;
- sentinel = ngx_event_timer_rbtree.sentinel;
- for ( ;; ) {
- root = ngx_event_timer_rbtree.root;
- if (root == sentinel) {
- return;
- }
- node = ngx_rbtree_min(root, sentinel);
-
- if ((ngx_msec_int_t) (node->key - ngx_current_msec) > 0) {
- return;
- }
- ev = (ngx_event_t *) ((char *) node - offsetof(ngx_event_t, timer));
- ngx_log_debug2(NGX_LOG_DEBUG_EVENT, ev->log, 0,
- "event timer del: %d: %M",
- ngx_event_ident(ev->data), ev->timer.key);
- ngx_rbtree_delete(&ngx_event_timer_rbtree, &ev->timer);
- #if (NGX_DEBUG)
- ev->timer.left = NULL;
- ev->timer.right = NULL;
- ev->timer.parent = NULL;
- #endif
- ev->timer_set = 0;
- ev->timedout = 1;
- ev->handler(ev);
- }
- }
- void
- ngx_event_cancel_timers(void)
- {
- ngx_event_t *ev;
- ngx_rbtree_node_t *node, *root, *sentinel;
- sentinel = ngx_event_timer_rbtree.sentinel;
- for ( ;; ) {
- root = ngx_event_timer_rbtree.root;
- if (root == sentinel) {
- return;
- }
- node = ngx_rbtree_min(root, sentinel);
- ev = (ngx_event_t *) ((char *) node - offsetof(ngx_event_t, timer));
- if (!ev->cancelable) {
- return;
- }
- ngx_log_debug2(NGX_LOG_DEBUG_EVENT, ev->log, 0,
- "event timer cancel: %d: %M",
- ngx_event_ident(ev->data), ev->timer.key);
- ngx_rbtree_delete(&ngx_event_timer_rbtree, &ev->timer);
- #if (NGX_DEBUG)
- ev->timer.left = NULL;
- ev->timer.right = NULL;
- ev->timer.parent = NULL;
- #endif
- ev->timer_set = 0;
- ev->handler(ev);
- }
- }
One Level Up
Top Level