From 2af94a114ef2d262746362fab22c5afe7878419f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Gonzalo=20Jos=C3=A9=20Carracedo=20Carballal?= Date: Thu, 22 Aug 2019 00:04:39 +0200 Subject: [PATCH] Improper ownership handling of message objects in worker thread (probably fixes #19) --- analyzer/worker.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/analyzer/worker.c b/analyzer/worker.c index 254aae1c..ddfb1de1 100644 --- a/analyzer/worker.c +++ b/analyzer/worker.c @@ -100,7 +100,6 @@ suscan_worker_thread(void *data) /* Callback returns FALSE: remove from message queue */ suscan_worker_callback_destroy(cb); suscan_msg_destroy(msg); - msg = NULL; } else { /* Callback returns TRUE: queue again */ suscan_mq_write_msg(&worker->mq_in, msg); @@ -114,9 +113,14 @@ suscan_worker_thread(void *data) default: SU_WARNING("Unexpected worker message type #%d\n", msg->type); suscan_msg_destroy(msg); /* Destroy message anyways */ - msg = NULL; } + /* + * We reached this point, one way or another, we don't hold the + * ownership of the message anymore. + */ + msg = NULL; + /* Next reads: until queue is empty */ } while ( !worker->halt_req