[RISCV] Fix mgather -> riscv.masked.strided.load combine not extending indices (...
[llvm-project.git] / libcxx / test / std / thread / futures / futures.unique_future / wait_until.pass.cpp
blob00c1b8dfedd5ff30b86a3eed06590241ca3bced5
1 //===----------------------------------------------------------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 //
9 // UNSUPPORTED: no-threads
10 // UNSUPPORTED: c++03
12 // <future>
14 // class future<R>
16 // template <class Clock, class Duration>
17 // future_status
18 // wait_until(const chrono::time_point<Clock, Duration>& abs_time) const;
20 #include <atomic>
21 #include <cassert>
22 #include <chrono>
23 #include <future>
25 #include "make_test_thread.h"
26 #include "test_macros.h"
28 enum class WorkerThreadState { Uninitialized, AllowedToRun, Exiting };
29 typedef std::chrono::milliseconds ms;
31 std::atomic<WorkerThreadState> thread_state(WorkerThreadState::Uninitialized);
33 void set_worker_thread_state(WorkerThreadState state)
35 thread_state.store(state, std::memory_order_relaxed);
38 void wait_for_worker_thread_state(WorkerThreadState state)
40 while (thread_state.load(std::memory_order_relaxed) != state)
41 std::this_thread::yield();
44 void func1(std::promise<int> p)
46 wait_for_worker_thread_state(WorkerThreadState::AllowedToRun);
47 p.set_value(3);
48 set_worker_thread_state(WorkerThreadState::Exiting);
51 int j = 0;
53 void func3(std::promise<int&> p)
55 wait_for_worker_thread_state(WorkerThreadState::AllowedToRun);
56 j = 5;
57 p.set_value(j);
58 set_worker_thread_state(WorkerThreadState::Exiting);
61 void func5(std::promise<void> p)
63 wait_for_worker_thread_state(WorkerThreadState::AllowedToRun);
64 p.set_value();
65 set_worker_thread_state(WorkerThreadState::Exiting);
68 int main(int, char**)
70 typedef std::chrono::high_resolution_clock Clock;
72 typedef int T;
73 std::promise<T> p;
74 std::future<T> f = p.get_future();
75 support::make_test_thread(func1, std::move(p)).detach();
76 assert(f.valid());
77 assert(f.wait_until(Clock::now() + ms(10)) == std::future_status::timeout);
78 assert(f.valid());
80 // allow the worker thread to produce the result and wait until the worker is done
81 set_worker_thread_state(WorkerThreadState::AllowedToRun);
82 wait_for_worker_thread_state(WorkerThreadState::Exiting);
84 assert(f.wait_until(Clock::now() + ms(10)) == std::future_status::ready);
85 assert(f.valid());
86 f.wait();
87 assert(f.valid());
90 typedef int& T;
91 std::promise<T> p;
92 std::future<T> f = p.get_future();
93 support::make_test_thread(func3, std::move(p)).detach();
94 assert(f.valid());
95 assert(f.wait_until(Clock::now() + ms(10)) == std::future_status::timeout);
96 assert(f.valid());
98 // allow the worker thread to produce the result and wait until the worker is done
99 set_worker_thread_state(WorkerThreadState::AllowedToRun);
100 wait_for_worker_thread_state(WorkerThreadState::Exiting);
102 assert(f.wait_until(Clock::now() + ms(10)) == std::future_status::ready);
103 assert(f.valid());
104 f.wait();
105 assert(f.valid());
108 typedef void T;
109 std::promise<T> p;
110 std::future<T> f = p.get_future();
111 support::make_test_thread(func5, std::move(p)).detach();
112 assert(f.valid());
113 assert(f.wait_until(Clock::now() + ms(10)) == std::future_status::timeout);
114 assert(f.valid());
116 // allow the worker thread to produce the result and wait until the worker is done
117 set_worker_thread_state(WorkerThreadState::AllowedToRun);
118 wait_for_worker_thread_state(WorkerThreadState::Exiting);
120 assert(f.wait_until(Clock::now() + ms(10)) == std::future_status::ready);
121 assert(f.valid());
122 f.wait();
123 assert(f.valid());
126 return 0;