From 716caafd6c17eacc94a439910bb43eff8a8bad08 Mon Sep 17 00:00:00 2001 From: Andre Puschmann Date: Thu, 27 May 2021 21:38:17 +0200 Subject: [PATCH] multiqueue_test: fix race reported by TSAN --- lib/test/common/multiqueue_test.cc | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/test/common/multiqueue_test.cc b/lib/test/common/multiqueue_test.cc index a82c6b45c..7ef198076 100644 --- a/lib/test/common/multiqueue_test.cc +++ b/lib/test/common/multiqueue_test.cc @@ -118,17 +118,17 @@ int test_multiqueue_threading() int capacity = 4, number = 0, start_number = 2, nof_pushes = capacity + 1; multiqueue_handler multiqueue(capacity); auto qid1 = multiqueue.add_queue(); - auto push_blocking_func = [](queue_handle* qid, int start_value, int nof_pushes, bool* is_running) { + std::atomic t1_running = {true}; + auto push_blocking_func = [&t1_running](queue_handle* qid, int start_value, int nof_pushes) { for (int i = 0; i < nof_pushes; ++i) { qid->push(start_value + i); std::cout << "t1: pushed item " << i << std::endl; } std::cout << "t1: pushed all items\n"; - *is_running = false; + t1_running = false; }; - bool t1_running = true; - std::thread t1(push_blocking_func, &qid1, start_number, nof_pushes, &t1_running); + std::thread t1(push_blocking_func, &qid1, start_number, nof_pushes); // Wait for queue to fill while ((int)qid1.size() != capacity) {