From 6874a4cdb06b662b5e6a5cb096865a14663bdecb Mon Sep 17 00:00:00 2001 From: Bruno Panuto Date: Mon, 16 Jun 2025 00:28:43 -0300 Subject: [PATCH] fix: make pool_finish not hang when pool_start is not called --- core/thread/thread_pool.odin | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/core/thread/thread_pool.odin b/core/thread/thread_pool.odin index 59bf90620..15b3a28d2 100644 --- a/core/thread/thread_pool.odin +++ b/core/thread/thread_pool.odin @@ -120,6 +120,20 @@ pool_join :: proc(pool: ^Pool) { yield() + unstarted_count: int + for t in pool.threads { + flags := intrinsics.atomic_load(&t.flags) + if .Started not_in flags { + unstarted_count += 1 + } + } + + // most likely the user forgot to call `pool_start` + // exit here, so we don't hang forever + if len(pool.threads) == unstarted_count { + return + } + started_count: int for started_count < len(pool.threads) { started_count = 0