From cb70ac69322eb923fd089c7ced319dc8221d0775 Mon Sep 17 00:00:00 2001 From: ridiculousfish Date: Sun, 29 Jan 2017 21:35:22 -0800 Subject: [PATCH] Use a std::atomic in test_iothread Reduces noise from thread-sanitizer --- src/fish_tests.cpp | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/fish_tests.cpp b/src/fish_tests.cpp index 2746d184e..53a8334e5 100644 --- a/src/fish_tests.cpp +++ b/src/fish_tests.cpp @@ -25,6 +25,7 @@ #include #include #include +#include #include #include #include @@ -512,7 +513,7 @@ static void test_tokenizer() { } // Little function that runs in a background thread, bouncing to the main. -static int test_iothread_thread_call(int *addr) { +static int test_iothread_thread_call(std::atomic *addr) { int before = *addr; iothread_perform_on_main([=]() { *addr += 1; }); int after = *addr; @@ -526,7 +527,7 @@ static int test_iothread_thread_call(int *addr) { static void test_iothread(void) { say(L"Testing iothreads"); - std::unique_ptr int_ptr = make_unique(0); + std::unique_ptr> int_ptr = make_unique>(0); int iterations = 50000; int max_achieved_thread_count = 0; double start = timef(); @@ -541,7 +542,7 @@ static void test_iothread(void) { // Should have incremented it once per thread. if (*int_ptr != iterations) { - say(L"Expected int to be %d, but instead it was %d", iterations, *int_ptr); + say(L"Expected int to be %d, but instead it was %d", iterations, int_ptr->load()); } say(L" (%.02f msec, with max of %d threads)", (end - start) * 1000.0,