]> git.proxmox.com Git - ceph.git/blame - ceph/src/boost/boost/asio/detail/win_event.hpp
import new upstream nautilus stable release 14.2.8
[ceph.git] / ceph / src / boost / boost / asio / detail / win_event.hpp
CommitLineData
7c673cae
FG
1//
2// detail/win_event.hpp
3// ~~~~~~~~~~~~~~~~~~~~
4//
92f5a8d4 5// Copyright (c) 2003-2019 Christopher M. Kohlhoff (chris at kohlhoff dot com)
7c673cae
FG
6//
7// Distributed under the Boost Software License, Version 1.0. (See accompanying
8// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
9//
10
11#ifndef BOOST_ASIO_DETAIL_WIN_EVENT_HPP
12#define BOOST_ASIO_DETAIL_WIN_EVENT_HPP
13
14#if defined(_MSC_VER) && (_MSC_VER >= 1200)
15# pragma once
16#endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
17
18#include <boost/asio/detail/config.hpp>
19
20#if defined(BOOST_ASIO_WINDOWS)
21
22#include <boost/asio/detail/assert.hpp>
23#include <boost/asio/detail/noncopyable.hpp>
24#include <boost/asio/detail/socket_types.hpp>
25
26#include <boost/asio/detail/push_options.hpp>
27
28namespace boost {
29namespace asio {
30namespace detail {
31
32class win_event
33 : private noncopyable
34{
35public:
36 // Constructor.
37 BOOST_ASIO_DECL win_event();
38
39 // Destructor.
40 BOOST_ASIO_DECL ~win_event();
41
42 // Signal the event. (Retained for backward compatibility.)
43 template <typename Lock>
44 void signal(Lock& lock)
45 {
46 this->signal_all(lock);
47 }
48
49 // Signal all waiters.
50 template <typename Lock>
51 void signal_all(Lock& lock)
52 {
53 BOOST_ASIO_ASSERT(lock.locked());
54 (void)lock;
55 state_ |= 1;
56 ::SetEvent(events_[0]);
57 }
58
59 // Unlock the mutex and signal one waiter.
60 template <typename Lock>
61 void unlock_and_signal_one(Lock& lock)
62 {
63 BOOST_ASIO_ASSERT(lock.locked());
64 state_ |= 1;
65 bool have_waiters = (state_ > 1);
66 lock.unlock();
67 if (have_waiters)
68 ::SetEvent(events_[1]);
69 }
70
71 // If there's a waiter, unlock the mutex and signal it.
72 template <typename Lock>
73 bool maybe_unlock_and_signal_one(Lock& lock)
74 {
75 BOOST_ASIO_ASSERT(lock.locked());
76 state_ |= 1;
77 if (state_ > 1)
78 {
79 lock.unlock();
80 ::SetEvent(events_[1]);
81 return true;
82 }
83 return false;
84 }
85
86 // Reset the event.
87 template <typename Lock>
88 void clear(Lock& lock)
89 {
90 BOOST_ASIO_ASSERT(lock.locked());
91 (void)lock;
92 ::ResetEvent(events_[0]);
93 state_ &= ~std::size_t(1);
94 }
95
96 // Wait for the event to become signalled.
97 template <typename Lock>
98 void wait(Lock& lock)
99 {
100 BOOST_ASIO_ASSERT(lock.locked());
101 while ((state_ & 1) == 0)
102 {
103 state_ += 2;
104 lock.unlock();
105#if defined(BOOST_ASIO_WINDOWS_APP)
106 ::WaitForMultipleObjectsEx(2, events_, false, INFINITE, false);
107#else // defined(BOOST_ASIO_WINDOWS_APP)
108 ::WaitForMultipleObjects(2, events_, false, INFINITE);
109#endif // defined(BOOST_ASIO_WINDOWS_APP)
110 lock.lock();
111 state_ -= 2;
112 }
113 }
114
b32b8144
FG
115 // Timed wait for the event to become signalled.
116 template <typename Lock>
117 bool wait_for_usec(Lock& lock, long usec)
118 {
119 BOOST_ASIO_ASSERT(lock.locked());
120 if ((state_ & 1) == 0)
121 {
122 state_ += 2;
123 lock.unlock();
124 DWORD msec = usec > 0 ? (usec < 1000 ? 1 : usec / 1000) : 0;
125#if defined(BOOST_ASIO_WINDOWS_APP)
126 ::WaitForMultipleObjectsEx(2, events_, false, msec, false);
127#else // defined(BOOST_ASIO_WINDOWS_APP)
128 ::WaitForMultipleObjects(2, events_, false, msec);
129#endif // defined(BOOST_ASIO_WINDOWS_APP)
130 lock.lock();
131 state_ -= 2;
132 }
133 return (state_ & 1) != 0;
134 }
135
7c673cae
FG
136private:
137 HANDLE events_[2];
138 std::size_t state_;
139};
140
141} // namespace detail
142} // namespace asio
143} // namespace boost
144
145#include <boost/asio/detail/pop_options.hpp>
146
147#if defined(BOOST_ASIO_HEADER_ONLY)
148# include <boost/asio/detail/impl/win_event.ipp>
149#endif // defined(BOOST_ASIO_HEADER_ONLY)
150
151#endif // defined(BOOST_ASIO_WINDOWS)
152
153#endif // BOOST_ASIO_DETAIL_WIN_EVENT_HPP