From d328cbbdc256197d02ec03eef0022b4122d38bb8 Mon Sep 17 00:00:00 2001 From: David Timber Date: Sun, 19 Jan 2020 13:12:29 +1100 Subject: bin pack redesign. resolv bug fix --- src/resolv_worker.c | 8 ++++++++ 1 file changed, 8 insertions(+) (limited to 'src/resolv_worker.c') diff --git a/src/resolv_worker.c b/src/resolv_worker.c index 20cc8cf..a178771 100644 --- a/src/resolv_worker.c +++ b/src/resolv_worker.c @@ -1190,6 +1190,10 @@ static void resolv_proc_expired (prne_resolv_wkr_ctx_t ctx) { static void resolv_wkr_free (void *p) { DECL_CTX_PTR(p); + if (p == NULL) { + return; + } + prne_free_wkr_timeout_slot(ctx->sckop_to_slot); prne_free_wkr_timeout_slot(ctx->err_to_slot); prne_free_wkr_pollfd_slot(ctx->evt_pfd_slot); @@ -1202,6 +1206,9 @@ static void resolv_wkr_free (void *p) { mbedtls_ssl_config_free(&ctx->ssl.conf); mbedtls_ssl_free(&ctx->ssl.ctx); + prne_close(ctx->act_dns_fd); + prne_close(ctx->dnss_fd[0]); + prne_close(ctx->dnss_fd[1]); prne_close(ctx->evtfd[0]); prne_close(ctx->evtfd[1]); @@ -1297,6 +1304,7 @@ prne_resolv_wkr_ctx_t prne_alloc_resolv_worker (prne_worker_t *w, prne_wkr_sched ctx->sck_pfd_slot[1] = prne_alloc_wkr_pollfd_slot(wsr); ctx->act_dns_fd = -1; ctx->ctx_state = RESOLV_CTX_STATE_NONE; + ctx->wkr_state = RESOLV_WKR_STATE_OK; ctx->ssl.ctr_drbg = ctr_drbg; prne_init_llist(&ctx->qlist); prne_init_imap(&ctx->qid_map); -- cgit