return NULL;
}
+ context->pt[n].context = context;
+ context->pt[n].tid = n;
context->pt[n].http_header_data = lws_malloc(context->max_http_header_data *
context->max_http_header_pool);
if (!context->pt[n].http_header_data)
return 0;
}
+static void
+lws_uv_timeout_cb(uv_timer_t *timer)
+{
+ struct lws_context_per_thread *pt = container_of(timer,
+ struct lws_context_per_thread, uv_timeout_watcher);
+
+ lwsl_info("%s\n", __func__);
+ /* do timeout check only */
+ lws_service_fd_tsi(pt->context, NULL, pt->tid);
+}
+
static const int sigs[] = { SIGINT, SIGTERM, SIGSEGV, SIGFPE };
LWS_VISIBLE int
uv_poll_start(&wsi->w_read.uv_watcher, UV_READABLE, lws_accept_cb);
}
+ uv_timer_init(pt->io_loop_uv, &pt->uv_timeout_watcher);
+ uv_timer_start(&pt->uv_timeout_watcher, lws_uv_timeout_cb, 1000, 1000);
+
return status;
}
struct lws *rx_draining_ext_list;
struct lws *tx_draining_ext_list;
struct lws *timeout_list;
+ struct lws_context *context;
void *http_header_data;
struct allocated_headers *ah_pool;
struct lws *ah_wait_list;
#if defined(LWS_USE_LIBUV)
uv_loop_t *io_loop_uv;
uv_signal_t signals[8];
+ uv_timer_t uv_timeout_watcher;
#endif
#if defined(LWS_USE_LIBEV)
struct lws_io_watcher w_accept;
unsigned int fds_count;
short ah_count_in_use;
+ unsigned char tid;
};
/*
}
static void
-uv_timeout_cb(uv_timer_t *w)
+uv_timeout_cb_dumb_increment(uv_timer_t *w)
{
- lwsl_info("%s\n", __func__);
lws_callback_on_writable_all_protocol(context,
&protocols[PROTOCOL_DUMB_INCREMENT]);
}
info.gid = -1;
info.uid = -1;
info.max_http_header_pool = 1;
+ info.timeout_secs = 5;
info.options = opts | LWS_SERVER_OPTION_LIBUV;
context = lws_create_context(&info);
lws_uv_initloop(context, NULL, signal_cb, 0);
uv_timer_init(lws_uv_getloop(context, 0), &timeout_watcher);
- uv_timer_start(&timeout_watcher, uv_timeout_cb, 50, 50);
+ uv_timer_start(&timeout_watcher, uv_timeout_cb_dumb_increment, 50, 50);
lws_libuv_run(context, 0);