void test_lib__common__multithread_c(void) { pthread_t tid; main_thread.loop = create_loop(); main_thread.queue = h2o_multithread_create_queue(main_thread.loop); h2o_multithread_register_receiver(main_thread.queue, &main_thread.pong_receiver, on_pong); h2o_multithread_register_receiver(main_thread.queue, &main_thread.shutdown_receiver, on_shutdown); worker_thread.loop = create_loop(); worker_thread.queue = h2o_multithread_create_queue(worker_thread.loop); h2o_multithread_register_receiver(worker_thread.queue, &worker_thread.ping_receiver, on_ping); pthread_create(&tid, NULL, worker_main, NULL); /* send first message */ send_empty_message(&worker_thread.ping_receiver); while (!main_thread.received_shutdown) { #if H2O_USE_LIBUV uv_run(main_thread.loop, UV_RUN_ONCE); #else h2o_evloop_run(main_thread.loop, INT32_MAX); #endif } pthread_join(tid, NULL); h2o_multithread_unregister_receiver(worker_thread.queue, &worker_thread.ping_receiver); h2o_multithread_destroy_queue(worker_thread.queue); destroy_loop(worker_thread.loop); h2o_multithread_unregister_receiver(main_thread.queue, &main_thread.pong_receiver); h2o_multithread_unregister_receiver(main_thread.queue, &main_thread.shutdown_receiver); h2o_multithread_destroy_queue(main_thread.queue); destroy_loop(main_thread.loop); ok(1); }
void h2o_context_init(h2o_context_t *ctx, h2o_loop_t *loop, h2o_globalconf_t *config) { size_t i, j; assert(config->hosts[0] != NULL); memset(ctx, 0, sizeof(*ctx)); ctx->loop = loop; ctx->globalconf = config; h2o_timeout_init(ctx->loop, &ctx->zero_timeout, 0); h2o_timeout_init(ctx->loop, &ctx->one_sec_timeout, 1000); h2o_timeout_init(ctx->loop, &ctx->hundred_ms_timeout, 100); ctx->queue = h2o_multithread_create_queue(loop); h2o_multithread_register_receiver(ctx->queue, &ctx->receivers.hostinfo_getaddr, h2o_hostinfo_getaddr_receiver); ctx->filecache = h2o_filecache_create(config->filecache.capacity); h2o_timeout_init(ctx->loop, &ctx->handshake_timeout, config->handshake_timeout); h2o_timeout_init(ctx->loop, &ctx->http1.req_timeout, config->http1.req_timeout); h2o_linklist_init_anchor(&ctx->http1._conns); h2o_timeout_init(ctx->loop, &ctx->http2.idle_timeout, config->http2.idle_timeout); h2o_linklist_init_anchor(&ctx->http2._conns); ctx->proxy.client_ctx.loop = loop; h2o_timeout_init(ctx->loop, &ctx->proxy.io_timeout, config->proxy.io_timeout); ctx->proxy.client_ctx.getaddr_receiver = &ctx->receivers.hostinfo_getaddr; ctx->proxy.client_ctx.io_timeout = &ctx->proxy.io_timeout; ctx->proxy.client_ctx.ssl_ctx = config->proxy.ssl_ctx; ctx->_module_configs = h2o_mem_alloc(sizeof(*ctx->_module_configs) * config->_num_config_slots); memset(ctx->_module_configs, 0, sizeof(*ctx->_module_configs) * config->_num_config_slots); static pthread_mutex_t mutex = PTHREAD_MUTEX_INITIALIZER; pthread_mutex_lock(&mutex); for (i = 0; config->hosts[i] != NULL; ++i) { h2o_hostconf_t *hostconf = config->hosts[i]; for (j = 0; j != hostconf->paths.size; ++j) { h2o_pathconf_t *pathconf = hostconf->paths.entries + j; h2o_context_init_pathconf_context(ctx, pathconf); } h2o_context_init_pathconf_context(ctx, &hostconf->fallback_path); } pthread_mutex_unlock(&mutex); }