mirror of
https://github.com/odin-lang/Odin.git
synced 2025-12-29 01:14:40 +00:00
Make ThreadPool.is_running atomic
This commit is contained in:
@@ -11,10 +11,10 @@ struct WorkerTask {
|
||||
|
||||
|
||||
struct ThreadPool {
|
||||
BlockingMutex mutex;
|
||||
Semaphore sem_available;
|
||||
std::atomic<i32> processing_work_count;
|
||||
bool is_running;
|
||||
BlockingMutex mutex;
|
||||
Semaphore sem_available;
|
||||
std::atomic<i32> processing_work_count;
|
||||
std::atomic<bool> is_running;
|
||||
|
||||
gbAllocator allocator;
|
||||
|
||||
@@ -74,7 +74,7 @@ void thread_pool_start(ThreadPool *pool) {
|
||||
}
|
||||
|
||||
void thread_pool_join(ThreadPool *pool) {
|
||||
pool->is_running = false;
|
||||
pool->is_running.store(false);
|
||||
|
||||
semaphore_post(&pool->sem_available, cast(i32)pool->thread_count);
|
||||
|
||||
@@ -153,7 +153,7 @@ void thread_pool_wait_to_process(ThreadPool *pool) {
|
||||
|
||||
THREAD_PROC(worker_thread_internal) {
|
||||
ThreadPool *pool = cast(ThreadPool *)thread->user_data;
|
||||
while (pool->is_running) {
|
||||
while (pool->is_running.load()) {
|
||||
semaphore_wait(&pool->sem_available);
|
||||
|
||||
WorkerTask task = {};
|
||||
|
||||
Reference in New Issue
Block a user