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