//===----------------------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // UNSUPPORTED: libcpp-has-no-threads // UNSUPPORTED: c++98, c++03 // There's currently no release of OS X whose dylib contains the patch for // PR38682. Since the fix for future is in the dylib, this test may fail. // UNSUPPORTED: with_system_cxx_lib=macosx10.14 // UNSUPPORTED: with_system_cxx_lib=macosx10.13 // UNSUPPORTED: with_system_cxx_lib=macosx10.12 // UNSUPPORTED: with_system_cxx_lib=macosx10.11 // UNSUPPORTED: with_system_cxx_lib=macosx10.10 // UNSUPPORTED: with_system_cxx_lib=macosx10.9 // UNSUPPORTED: with_system_cxx_lib=macosx10.8 // UNSUPPORTED: with_system_cxx_lib=macosx10.7 // This test is designed to cause and allow TSAN to detect a race condition // in std::async, as reported in https://bugs.llvm.org/show_bug.cgi?id=38682. #include #include #include #include #include #include "test_macros.h" static int worker(std::vector const& data) { return std::accumulate(data.begin(), data.end(), 0); } static int& worker_ref(int& i) { return i; } static void worker_void() { } int main(int, char**) { // future { std::vector const v{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; for (int i = 0; i != 20; ++i) { std::future fut = std::async(std::launch::async, worker, v); int answer = fut.get(); assert(answer == 55); } } // future { for (int i = 0; i != 20; ++i) { std::future fut = std::async(std::launch::async, worker_ref, std::ref(i)); int& answer = fut.get(); assert(answer == i); } } // future { for (int i = 0; i != 20; ++i) { std::future fut = std::async(std::launch::async, worker_void); fut.get(); } } return 0; }