annotate DEPENDENCIES/generic/include/boost/thread/pthread/condition_variable_fwd.hpp @ 125:34e428693f5d vext

Vext -> Repoint
author Chris Cannam
date Thu, 14 Jun 2018 11:15:39 +0100
parents 2665513ce2d3
children
rev   line source
Chris@16 1 #ifndef BOOST_THREAD_PTHREAD_CONDITION_VARIABLE_FWD_HPP
Chris@16 2 #define BOOST_THREAD_PTHREAD_CONDITION_VARIABLE_FWD_HPP
Chris@16 3 // Distributed under the Boost Software License, Version 1.0. (See
Chris@16 4 // accompanying file LICENSE_1_0.txt or copy at
Chris@16 5 // http://www.boost.org/LICENSE_1_0.txt)
Chris@16 6 // (C) Copyright 2007-8 Anthony Williams
Chris@16 7 // (C) Copyright 2011-2012 Vicente J. Botet Escriba
Chris@16 8
Chris@16 9 #include <boost/assert.hpp>
Chris@16 10 #include <boost/throw_exception.hpp>
Chris@16 11 #include <pthread.h>
Chris@16 12 #include <boost/thread/cv_status.hpp>
Chris@16 13 #include <boost/thread/mutex.hpp>
Chris@16 14 #include <boost/thread/lock_types.hpp>
Chris@16 15 #include <boost/thread/thread_time.hpp>
Chris@16 16 #include <boost/thread/pthread/timespec.hpp>
Chris@16 17 #if defined BOOST_THREAD_USES_DATETIME
Chris@16 18 #include <boost/thread/xtime.hpp>
Chris@16 19 #endif
Chris@16 20 #ifdef BOOST_THREAD_USES_CHRONO
Chris@16 21 #include <boost/chrono/system_clocks.hpp>
Chris@16 22 #include <boost/chrono/ceil.hpp>
Chris@16 23 #endif
Chris@16 24 #include <boost/thread/detail/delete.hpp>
Chris@16 25 #include <boost/date_time/posix_time/posix_time_duration.hpp>
Chris@16 26
Chris@16 27 #include <boost/config/abi_prefix.hpp>
Chris@16 28
Chris@16 29 namespace boost
Chris@16 30 {
Chris@16 31
Chris@16 32 class condition_variable
Chris@16 33 {
Chris@16 34 private:
Chris@16 35 #if defined BOOST_THREAD_PROVIDES_INTERRUPTIONS
Chris@16 36 pthread_mutex_t internal_mutex;
Chris@16 37 #endif
Chris@16 38 pthread_cond_t cond;
Chris@16 39
Chris@16 40 public:
Chris@16 41 //private: // used by boost::thread::try_join_until
Chris@16 42
Chris@16 43 inline bool do_wait_until(
Chris@16 44 unique_lock<mutex>& lock,
Chris@16 45 struct timespec const &timeout);
Chris@16 46
Chris@16 47 bool do_wait_for(
Chris@16 48 unique_lock<mutex>& lock,
Chris@16 49 struct timespec const &timeout)
Chris@16 50 {
Chris@16 51 return do_wait_until(lock, boost::detail::timespec_plus(timeout, boost::detail::timespec_now()));
Chris@16 52 }
Chris@16 53
Chris@16 54 public:
Chris@16 55 BOOST_THREAD_NO_COPYABLE(condition_variable)
Chris@16 56 condition_variable()
Chris@16 57 {
Chris@16 58 #if defined BOOST_THREAD_PROVIDES_INTERRUPTIONS
Chris@16 59 int const res=pthread_mutex_init(&internal_mutex,NULL);
Chris@16 60 if(res)
Chris@16 61 {
Chris@16 62 boost::throw_exception(thread_resource_error(res, "boost::condition_variable::condition_variable() constructor failed in pthread_mutex_init"));
Chris@16 63 }
Chris@16 64 #endif
Chris@16 65 int const res2=pthread_cond_init(&cond,NULL);
Chris@16 66 if(res2)
Chris@16 67 {
Chris@16 68 #if defined BOOST_THREAD_PROVIDES_INTERRUPTIONS
Chris@16 69 BOOST_VERIFY(!pthread_mutex_destroy(&internal_mutex));
Chris@16 70 #endif
Chris@16 71 boost::throw_exception(thread_resource_error(res2, "boost::condition_variable::condition_variable() constructor failed in pthread_cond_init"));
Chris@16 72 }
Chris@16 73 }
Chris@16 74 ~condition_variable()
Chris@16 75 {
Chris@16 76 int ret;
Chris@16 77 #if defined BOOST_THREAD_PROVIDES_INTERRUPTIONS
Chris@16 78 do {
Chris@16 79 ret = pthread_mutex_destroy(&internal_mutex);
Chris@16 80 } while (ret == EINTR);
Chris@16 81 BOOST_ASSERT(!ret);
Chris@16 82 #endif
Chris@16 83 do {
Chris@16 84 ret = pthread_cond_destroy(&cond);
Chris@16 85 } while (ret == EINTR);
Chris@16 86 BOOST_ASSERT(!ret);
Chris@16 87 }
Chris@16 88
Chris@16 89 void wait(unique_lock<mutex>& m);
Chris@16 90
Chris@16 91 template<typename predicate_type>
Chris@16 92 void wait(unique_lock<mutex>& m,predicate_type pred)
Chris@16 93 {
Chris@16 94 while(!pred()) wait(m);
Chris@16 95 }
Chris@16 96
Chris@16 97
Chris@16 98 #if defined BOOST_THREAD_USES_DATETIME
Chris@16 99 inline bool timed_wait(
Chris@16 100 unique_lock<mutex>& m,
Chris@16 101 boost::system_time const& abs_time)
Chris@16 102 {
Chris@16 103 #if defined BOOST_THREAD_WAIT_BUG
Chris@16 104 struct timespec const timeout=detail::to_timespec(abs_time + BOOST_THREAD_WAIT_BUG);
Chris@16 105 return do_wait_until(m, timeout);
Chris@16 106 #else
Chris@16 107 struct timespec const timeout=detail::to_timespec(abs_time);
Chris@16 108 return do_wait_until(m, timeout);
Chris@16 109 #endif
Chris@16 110 }
Chris@16 111 bool timed_wait(
Chris@16 112 unique_lock<mutex>& m,
Chris@16 113 xtime const& abs_time)
Chris@16 114 {
Chris@16 115 return timed_wait(m,system_time(abs_time));
Chris@16 116 }
Chris@16 117
Chris@16 118 template<typename duration_type>
Chris@16 119 bool timed_wait(
Chris@16 120 unique_lock<mutex>& m,
Chris@16 121 duration_type const& wait_duration)
Chris@16 122 {
Chris@16 123 return timed_wait(m,get_system_time()+wait_duration);
Chris@16 124 }
Chris@16 125
Chris@16 126 template<typename predicate_type>
Chris@16 127 bool timed_wait(
Chris@16 128 unique_lock<mutex>& m,
Chris@16 129 boost::system_time const& abs_time,predicate_type pred)
Chris@16 130 {
Chris@16 131 while (!pred())
Chris@16 132 {
Chris@16 133 if(!timed_wait(m, abs_time))
Chris@16 134 return pred();
Chris@16 135 }
Chris@16 136 return true;
Chris@16 137 }
Chris@16 138
Chris@16 139 template<typename predicate_type>
Chris@16 140 bool timed_wait(
Chris@16 141 unique_lock<mutex>& m,
Chris@16 142 xtime const& abs_time,predicate_type pred)
Chris@16 143 {
Chris@16 144 return timed_wait(m,system_time(abs_time),pred);
Chris@16 145 }
Chris@16 146
Chris@16 147 template<typename duration_type,typename predicate_type>
Chris@16 148 bool timed_wait(
Chris@16 149 unique_lock<mutex>& m,
Chris@16 150 duration_type const& wait_duration,predicate_type pred)
Chris@16 151 {
Chris@16 152 return timed_wait(m,get_system_time()+wait_duration,pred);
Chris@16 153 }
Chris@16 154 #endif
Chris@16 155
Chris@16 156 #ifdef BOOST_THREAD_USES_CHRONO
Chris@16 157
Chris@16 158 template <class Duration>
Chris@16 159 cv_status
Chris@16 160 wait_until(
Chris@16 161 unique_lock<mutex>& lock,
Chris@16 162 const chrono::time_point<chrono::system_clock, Duration>& t)
Chris@16 163 {
Chris@16 164 using namespace chrono;
Chris@16 165 typedef time_point<system_clock, nanoseconds> nano_sys_tmpt;
Chris@16 166 wait_until(lock,
Chris@16 167 nano_sys_tmpt(ceil<nanoseconds>(t.time_since_epoch())));
Chris@16 168 return system_clock::now() < t ? cv_status::no_timeout :
Chris@16 169 cv_status::timeout;
Chris@16 170 }
Chris@16 171
Chris@16 172 template <class Clock, class Duration>
Chris@16 173 cv_status
Chris@16 174 wait_until(
Chris@16 175 unique_lock<mutex>& lock,
Chris@16 176 const chrono::time_point<Clock, Duration>& t)
Chris@16 177 {
Chris@16 178 using namespace chrono;
Chris@16 179 system_clock::time_point s_now = system_clock::now();
Chris@16 180 typename Clock::time_point c_now = Clock::now();
Chris@16 181 wait_until(lock, s_now + ceil<nanoseconds>(t - c_now));
Chris@16 182 return Clock::now() < t ? cv_status::no_timeout : cv_status::timeout;
Chris@16 183 }
Chris@16 184
Chris@16 185 template <class Clock, class Duration, class Predicate>
Chris@16 186 bool
Chris@16 187 wait_until(
Chris@16 188 unique_lock<mutex>& lock,
Chris@16 189 const chrono::time_point<Clock, Duration>& t,
Chris@16 190 Predicate pred)
Chris@16 191 {
Chris@16 192 while (!pred())
Chris@16 193 {
Chris@16 194 if (wait_until(lock, t) == cv_status::timeout)
Chris@16 195 return pred();
Chris@16 196 }
Chris@16 197 return true;
Chris@16 198 }
Chris@16 199
Chris@16 200
Chris@16 201 template <class Rep, class Period>
Chris@16 202 cv_status
Chris@16 203 wait_for(
Chris@16 204 unique_lock<mutex>& lock,
Chris@16 205 const chrono::duration<Rep, Period>& d)
Chris@16 206 {
Chris@16 207 using namespace chrono;
Chris@16 208 system_clock::time_point s_now = system_clock::now();
Chris@16 209 steady_clock::time_point c_now = steady_clock::now();
Chris@16 210 wait_until(lock, s_now + ceil<nanoseconds>(d));
Chris@16 211 return steady_clock::now() - c_now < d ? cv_status::no_timeout :
Chris@16 212 cv_status::timeout;
Chris@16 213
Chris@16 214 }
Chris@16 215
Chris@16 216
Chris@16 217 template <class Rep, class Period, class Predicate>
Chris@16 218 bool
Chris@16 219 wait_for(
Chris@16 220 unique_lock<mutex>& lock,
Chris@16 221 const chrono::duration<Rep, Period>& d,
Chris@16 222 Predicate pred)
Chris@16 223 {
Chris@16 224 return wait_until(lock, chrono::steady_clock::now() + d, boost::move(pred));
Chris@16 225
Chris@16 226 // while (!pred())
Chris@16 227 // {
Chris@16 228 // if (wait_for(lock, d) == cv_status::timeout)
Chris@16 229 // return pred();
Chris@16 230 // }
Chris@16 231 // return true;
Chris@16 232 }
Chris@16 233 #endif
Chris@16 234
Chris@16 235 #define BOOST_THREAD_DEFINES_CONDITION_VARIABLE_NATIVE_HANDLE
Chris@16 236 typedef pthread_cond_t* native_handle_type;
Chris@16 237 native_handle_type native_handle()
Chris@16 238 {
Chris@16 239 return &cond;
Chris@16 240 }
Chris@16 241
Chris@16 242 void notify_one() BOOST_NOEXCEPT;
Chris@16 243 void notify_all() BOOST_NOEXCEPT;
Chris@16 244
Chris@16 245 #ifdef BOOST_THREAD_USES_CHRONO
Chris@16 246 inline cv_status wait_until(
Chris@16 247 unique_lock<mutex>& lk,
Chris@16 248 chrono::time_point<chrono::system_clock, chrono::nanoseconds> tp)
Chris@16 249 {
Chris@16 250 using namespace chrono;
Chris@16 251 nanoseconds d = tp.time_since_epoch();
Chris@16 252 timespec ts = boost::detail::to_timespec(d);
Chris@16 253 if (do_wait_until(lk, ts)) return cv_status::no_timeout;
Chris@16 254 else return cv_status::timeout;
Chris@16 255 }
Chris@16 256 #endif
Chris@16 257 };
Chris@16 258
Chris@16 259 BOOST_THREAD_DECL void notify_all_at_thread_exit(condition_variable& cond, unique_lock<mutex> lk);
Chris@16 260
Chris@16 261 }
Chris@16 262
Chris@16 263
Chris@16 264 #include <boost/config/abi_suffix.hpp>
Chris@16 265
Chris@16 266 #endif