blob: db67e7625b81161b93721a3cd423eeeeb5d1b3e5 [file] [log] [blame]
Howard Hinnant8f73c632010-09-27 21:17:38 +00001// -*- C++ -*-
2//===--------------------------- atomic -----------------------------------===//
3//
4// The LLVM Compiler Infrastructure
5//
6// This file is distributed under the University of Illinois Open Source
7// License. See LICENSE.TXT for details.
8//
9//===----------------------------------------------------------------------===//
10
11#ifndef _LIBCPP_ATOMIC
12#define _LIBCPP_ATOMIC
13
14/*
15 atomic synopsis
16
17namespace std
18{
19
20// order and consistency
21
22typedef enum memory_order
23{
Howard Hinnantd1176e22010-09-28 17:13:38 +000024 memory_order_relaxed,
25 memory_order_consume, // load-consume
26 memory_order_acquire, // load-acquire
27 memory_order_release, // store-release
28 memory_order_acq_rel, // store-release load-acquire
29 memory_order_seq_cst // store-release load-acquire
Howard Hinnant8f73c632010-09-27 21:17:38 +000030} memory_order;
31
Howard Hinnant300c67a2012-04-11 20:14:21 +000032template <class T> T kill_dependency(T y) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +000033
34// lock-free property
35
Howard Hinnant7b9d6a82013-01-21 20:39:41 +000036#define ATOMIC_BOOL_LOCK_FREE unspecified
Howard Hinnant8f73c632010-09-27 21:17:38 +000037#define ATOMIC_CHAR_LOCK_FREE unspecified
38#define ATOMIC_CHAR16_T_LOCK_FREE unspecified
39#define ATOMIC_CHAR32_T_LOCK_FREE unspecified
40#define ATOMIC_WCHAR_T_LOCK_FREE unspecified
41#define ATOMIC_SHORT_LOCK_FREE unspecified
42#define ATOMIC_INT_LOCK_FREE unspecified
43#define ATOMIC_LONG_LOCK_FREE unspecified
44#define ATOMIC_LLONG_LOCK_FREE unspecified
Howard Hinnant7b9d6a82013-01-21 20:39:41 +000045#define ATOMIC_POINTER_LOCK_FREE unspecified
Howard Hinnant8f73c632010-09-27 21:17:38 +000046
Howard Hinnant8f73c632010-09-27 21:17:38 +000047// flag type and operations
48
49typedef struct atomic_flag
50{
Howard Hinnant300c67a2012-04-11 20:14:21 +000051 bool test_and_set(memory_order m = memory_order_seq_cst) volatile noexcept;
52 bool test_and_set(memory_order m = memory_order_seq_cst) noexcept;
53 void clear(memory_order m = memory_order_seq_cst) volatile noexcept;
54 void clear(memory_order m = memory_order_seq_cst) noexcept;
55 atomic_flag() noexcept = default;
Howard Hinnant8f73c632010-09-27 21:17:38 +000056 atomic_flag(const atomic_flag&) = delete;
57 atomic_flag& operator=(const atomic_flag&) = delete;
58 atomic_flag& operator=(const atomic_flag&) volatile = delete;
59} atomic_flag;
60
Howard Hinnant4777bf22010-12-06 23:10:08 +000061bool
Howard Hinnant300c67a2012-04-11 20:14:21 +000062 atomic_flag_test_and_set(volatile atomic_flag* obj) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +000063
64bool
Howard Hinnant300c67a2012-04-11 20:14:21 +000065 atomic_flag_test_and_set(atomic_flag* obj) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +000066
67bool
68 atomic_flag_test_and_set_explicit(volatile atomic_flag* obj,
Howard Hinnant300c67a2012-04-11 20:14:21 +000069 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +000070
71bool
Howard Hinnant300c67a2012-04-11 20:14:21 +000072 atomic_flag_test_and_set_explicit(atomic_flag* obj, memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +000073
74void
Howard Hinnant300c67a2012-04-11 20:14:21 +000075 atomic_flag_clear(volatile atomic_flag* obj) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +000076
77void
Howard Hinnant300c67a2012-04-11 20:14:21 +000078 atomic_flag_clear(atomic_flag* obj) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +000079
80void
Howard Hinnant300c67a2012-04-11 20:14:21 +000081 atomic_flag_clear_explicit(volatile atomic_flag* obj, memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +000082
83void
Howard Hinnant300c67a2012-04-11 20:14:21 +000084 atomic_flag_clear_explicit(atomic_flag* obj, memory_order m) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +000085
86#define ATOMIC_FLAG_INIT see below
Howard Hinnante7385012010-10-19 16:51:18 +000087#define ATOMIC_VAR_INIT(value) see below
Howard Hinnant8f73c632010-09-27 21:17:38 +000088
Howard Hinnant8f73c632010-09-27 21:17:38 +000089template <class T>
90struct atomic
91{
Howard Hinnant300c67a2012-04-11 20:14:21 +000092 bool is_lock_free() const volatile noexcept;
93 bool is_lock_free() const noexcept;
94 void store(T desr, memory_order m = memory_order_seq_cst) volatile noexcept;
95 void store(T desr, memory_order m = memory_order_seq_cst) noexcept;
96 T load(memory_order m = memory_order_seq_cst) const volatile noexcept;
97 T load(memory_order m = memory_order_seq_cst) const noexcept;
98 operator T() const volatile noexcept;
99 operator T() const noexcept;
100 T exchange(T desr, memory_order m = memory_order_seq_cst) volatile noexcept;
101 T exchange(T desr, memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000102 bool compare_exchange_weak(T& expc, T desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000103 memory_order s, memory_order f) volatile noexcept;
104 bool compare_exchange_weak(T& expc, T desr, memory_order s, memory_order f) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000105 bool compare_exchange_strong(T& expc, T desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000106 memory_order s, memory_order f) volatile noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000107 bool compare_exchange_strong(T& expc, T desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000108 memory_order s, memory_order f) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000109 bool compare_exchange_weak(T& expc, T desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000110 memory_order m = memory_order_seq_cst) volatile noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000111 bool compare_exchange_weak(T& expc, T desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000112 memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000113 bool compare_exchange_strong(T& expc, T desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000114 memory_order m = memory_order_seq_cst) volatile noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000115 bool compare_exchange_strong(T& expc, T desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000116 memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +0000117
Howard Hinnant300c67a2012-04-11 20:14:21 +0000118 atomic() noexcept = default;
119 constexpr atomic(T desr) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +0000120 atomic(const atomic&) = delete;
121 atomic& operator=(const atomic&) = delete;
122 atomic& operator=(const atomic&) volatile = delete;
Howard Hinnant300c67a2012-04-11 20:14:21 +0000123 T operator=(T) volatile noexcept;
124 T operator=(T) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +0000125};
126
127template <>
Howard Hinnant4777bf22010-12-06 23:10:08 +0000128struct atomic<integral>
Howard Hinnant8f73c632010-09-27 21:17:38 +0000129{
Howard Hinnant300c67a2012-04-11 20:14:21 +0000130 bool is_lock_free() const volatile noexcept;
131 bool is_lock_free() const noexcept;
132 void store(integral desr, memory_order m = memory_order_seq_cst) volatile noexcept;
133 void store(integral desr, memory_order m = memory_order_seq_cst) noexcept;
134 integral load(memory_order m = memory_order_seq_cst) const volatile noexcept;
135 integral load(memory_order m = memory_order_seq_cst) const noexcept;
136 operator integral() const volatile noexcept;
137 operator integral() const noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000138 integral exchange(integral desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000139 memory_order m = memory_order_seq_cst) volatile noexcept;
140 integral exchange(integral desr, memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000141 bool compare_exchange_weak(integral& expc, integral desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000142 memory_order s, memory_order f) volatile noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000143 bool compare_exchange_weak(integral& expc, integral desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000144 memory_order s, memory_order f) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000145 bool compare_exchange_strong(integral& expc, integral desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000146 memory_order s, memory_order f) volatile noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000147 bool compare_exchange_strong(integral& expc, integral desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000148 memory_order s, memory_order f) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000149 bool compare_exchange_weak(integral& expc, integral desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000150 memory_order m = memory_order_seq_cst) volatile noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000151 bool compare_exchange_weak(integral& expc, integral desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000152 memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000153 bool compare_exchange_strong(integral& expc, integral desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000154 memory_order m = memory_order_seq_cst) volatile noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000155 bool compare_exchange_strong(integral& expc, integral desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000156 memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +0000157
Howard Hinnant4777bf22010-12-06 23:10:08 +0000158 integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000159 fetch_add(integral op, memory_order m = memory_order_seq_cst) volatile noexcept;
160 integral fetch_add(integral op, memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000161 integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000162 fetch_sub(integral op, memory_order m = memory_order_seq_cst) volatile noexcept;
163 integral fetch_sub(integral op, memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000164 integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000165 fetch_and(integral op, memory_order m = memory_order_seq_cst) volatile noexcept;
166 integral fetch_and(integral op, memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000167 integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000168 fetch_or(integral op, memory_order m = memory_order_seq_cst) volatile noexcept;
169 integral fetch_or(integral op, memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000170 integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000171 fetch_xor(integral op, memory_order m = memory_order_seq_cst) volatile noexcept;
172 integral fetch_xor(integral op, memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +0000173
Howard Hinnant300c67a2012-04-11 20:14:21 +0000174 atomic() noexcept = default;
175 constexpr atomic(integral desr) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +0000176 atomic(const atomic&) = delete;
177 atomic& operator=(const atomic&) = delete;
178 atomic& operator=(const atomic&) volatile = delete;
Howard Hinnant300c67a2012-04-11 20:14:21 +0000179 integral operator=(integral desr) volatile noexcept;
180 integral operator=(integral desr) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +0000181
Howard Hinnant300c67a2012-04-11 20:14:21 +0000182 integral operator++(int) volatile noexcept;
183 integral operator++(int) noexcept;
184 integral operator--(int) volatile noexcept;
185 integral operator--(int) noexcept;
186 integral operator++() volatile noexcept;
187 integral operator++() noexcept;
188 integral operator--() volatile noexcept;
189 integral operator--() noexcept;
190 integral operator+=(integral op) volatile noexcept;
191 integral operator+=(integral op) noexcept;
192 integral operator-=(integral op) volatile noexcept;
193 integral operator-=(integral op) noexcept;
194 integral operator&=(integral op) volatile noexcept;
195 integral operator&=(integral op) noexcept;
196 integral operator|=(integral op) volatile noexcept;
197 integral operator|=(integral op) noexcept;
198 integral operator^=(integral op) volatile noexcept;
199 integral operator^=(integral op) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +0000200};
201
202template <class T>
203struct atomic<T*>
Howard Hinnant8f73c632010-09-27 21:17:38 +0000204{
Howard Hinnant300c67a2012-04-11 20:14:21 +0000205 bool is_lock_free() const volatile noexcept;
206 bool is_lock_free() const noexcept;
207 void store(T* desr, memory_order m = memory_order_seq_cst) volatile noexcept;
208 void store(T* desr, memory_order m = memory_order_seq_cst) noexcept;
209 T* load(memory_order m = memory_order_seq_cst) const volatile noexcept;
210 T* load(memory_order m = memory_order_seq_cst) const noexcept;
211 operator T*() const volatile noexcept;
212 operator T*() const noexcept;
213 T* exchange(T* desr, memory_order m = memory_order_seq_cst) volatile noexcept;
214 T* exchange(T* desr, memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000215 bool compare_exchange_weak(T*& expc, T* desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000216 memory_order s, memory_order f) volatile noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000217 bool compare_exchange_weak(T*& expc, T* desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000218 memory_order s, memory_order f) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000219 bool compare_exchange_strong(T*& expc, T* desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000220 memory_order s, memory_order f) volatile noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000221 bool compare_exchange_strong(T*& expc, T* desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000222 memory_order s, memory_order f) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000223 bool compare_exchange_weak(T*& expc, T* desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000224 memory_order m = memory_order_seq_cst) volatile noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000225 bool compare_exchange_weak(T*& expc, T* desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000226 memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000227 bool compare_exchange_strong(T*& expc, T* desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000228 memory_order m = memory_order_seq_cst) volatile noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000229 bool compare_exchange_strong(T*& expc, T* desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000230 memory_order m = memory_order_seq_cst) noexcept;
231 T* fetch_add(ptrdiff_t op, memory_order m = memory_order_seq_cst) volatile noexcept;
232 T* fetch_add(ptrdiff_t op, memory_order m = memory_order_seq_cst) noexcept;
233 T* fetch_sub(ptrdiff_t op, memory_order m = memory_order_seq_cst) volatile noexcept;
234 T* fetch_sub(ptrdiff_t op, memory_order m = memory_order_seq_cst) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000235
Howard Hinnant300c67a2012-04-11 20:14:21 +0000236 atomic() noexcept = default;
237 constexpr atomic(T* desr) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +0000238 atomic(const atomic&) = delete;
239 atomic& operator=(const atomic&) = delete;
240 atomic& operator=(const atomic&) volatile = delete;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000241
Howard Hinnant300c67a2012-04-11 20:14:21 +0000242 T* operator=(T*) volatile noexcept;
243 T* operator=(T*) noexcept;
244 T* operator++(int) volatile noexcept;
245 T* operator++(int) noexcept;
246 T* operator--(int) volatile noexcept;
247 T* operator--(int) noexcept;
248 T* operator++() volatile noexcept;
249 T* operator++() noexcept;
250 T* operator--() volatile noexcept;
251 T* operator--() noexcept;
252 T* operator+=(ptrdiff_t op) volatile noexcept;
253 T* operator+=(ptrdiff_t op) noexcept;
254 T* operator-=(ptrdiff_t op) volatile noexcept;
255 T* operator-=(ptrdiff_t op) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +0000256};
257
Howard Hinnant4777bf22010-12-06 23:10:08 +0000258
259template <class T>
260 bool
Howard Hinnant300c67a2012-04-11 20:14:21 +0000261 atomic_is_lock_free(const volatile atomic<T>* obj) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000262
263template <class T>
264 bool
Howard Hinnant300c67a2012-04-11 20:14:21 +0000265 atomic_is_lock_free(const atomic<T>* obj) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000266
267template <class T>
268 void
Howard Hinnant300c67a2012-04-11 20:14:21 +0000269 atomic_init(volatile atomic<T>* obj, T desr) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000270
271template <class T>
272 void
Howard Hinnant300c67a2012-04-11 20:14:21 +0000273 atomic_init(atomic<T>* obj, T desr) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000274
275template <class T>
276 void
Howard Hinnant300c67a2012-04-11 20:14:21 +0000277 atomic_store(volatile atomic<T>* obj, T desr) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000278
279template <class T>
280 void
Howard Hinnant300c67a2012-04-11 20:14:21 +0000281 atomic_store(atomic<T>* obj, T desr) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000282
283template <class T>
284 void
Howard Hinnant300c67a2012-04-11 20:14:21 +0000285 atomic_store_explicit(volatile atomic<T>* obj, T desr, memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000286
287template <class T>
288 void
Howard Hinnant300c67a2012-04-11 20:14:21 +0000289 atomic_store_explicit(atomic<T>* obj, T desr, memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000290
291template <class T>
292 T
Howard Hinnant300c67a2012-04-11 20:14:21 +0000293 atomic_load(const volatile atomic<T>* obj) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000294
295template <class T>
296 T
Howard Hinnant300c67a2012-04-11 20:14:21 +0000297 atomic_load(const atomic<T>* obj) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000298
299template <class T>
300 T
Howard Hinnant300c67a2012-04-11 20:14:21 +0000301 atomic_load_explicit(const volatile atomic<T>* obj, memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000302
303template <class T>
304 T
Howard Hinnant300c67a2012-04-11 20:14:21 +0000305 atomic_load_explicit(const atomic<T>* obj, memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000306
307template <class T>
308 T
Howard Hinnant300c67a2012-04-11 20:14:21 +0000309 atomic_exchange(volatile atomic<T>* obj, T desr) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000310
311template <class T>
312 T
Howard Hinnant300c67a2012-04-11 20:14:21 +0000313 atomic_exchange(atomic<T>* obj, T desr) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000314
315template <class T>
316 T
Howard Hinnant300c67a2012-04-11 20:14:21 +0000317 atomic_exchange_explicit(volatile atomic<T>* obj, T desr, memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000318
319template <class T>
320 T
Howard Hinnant300c67a2012-04-11 20:14:21 +0000321 atomic_exchange_explicit(atomic<T>* obj, T desr, memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000322
323template <class T>
324 bool
Howard Hinnant300c67a2012-04-11 20:14:21 +0000325 atomic_compare_exchange_weak(volatile atomic<T>* obj, T* expc, T desr) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000326
327template <class T>
328 bool
Howard Hinnant300c67a2012-04-11 20:14:21 +0000329 atomic_compare_exchange_weak(atomic<T>* obj, T* expc, T desr) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000330
331template <class T>
332 bool
Howard Hinnant300c67a2012-04-11 20:14:21 +0000333 atomic_compare_exchange_strong(volatile atomic<T>* obj, T* expc, T desr) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000334
335template <class T>
336 bool
Howard Hinnant300c67a2012-04-11 20:14:21 +0000337 atomic_compare_exchange_strong(atomic<T>* obj, T* expc, T desr) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000338
339template <class T>
340 bool
341 atomic_compare_exchange_weak_explicit(volatile atomic<T>* obj, T* expc,
342 T desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000343 memory_order s, memory_order f) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000344
345template <class T>
346 bool
347 atomic_compare_exchange_weak_explicit(atomic<T>* obj, T* expc, T desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000348 memory_order s, memory_order f) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000349
350template <class T>
351 bool
352 atomic_compare_exchange_strong_explicit(volatile atomic<T>* obj,
353 T* expc, T desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000354 memory_order s, memory_order f) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000355
356template <class T>
357 bool
358 atomic_compare_exchange_strong_explicit(atomic<T>* obj, T* expc,
359 T desr,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000360 memory_order s, memory_order f) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000361
362template <class Integral>
363 Integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000364 atomic_fetch_add(volatile atomic<Integral>* obj, Integral op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000365
366template <class Integral>
367 Integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000368 atomic_fetch_add(atomic<Integral>* obj, Integral op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000369
370template <class Integral>
371 Integral
372 atomic_fetch_add_explicit(volatile atomic<Integral>* obj, Integral op,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000373 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000374template <class Integral>
375 Integral
376 atomic_fetch_add_explicit(atomic<Integral>* obj, Integral op,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000377 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000378template <class Integral>
379 Integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000380 atomic_fetch_sub(volatile atomic<Integral>* obj, Integral op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000381
382template <class Integral>
383 Integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000384 atomic_fetch_sub(atomic<Integral>* obj, Integral op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000385
386template <class Integral>
387 Integral
388 atomic_fetch_sub_explicit(volatile atomic<Integral>* obj, Integral op,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000389 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000390template <class Integral>
391 Integral
392 atomic_fetch_sub_explicit(atomic<Integral>* obj, Integral op,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000393 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000394template <class Integral>
395 Integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000396 atomic_fetch_and(volatile atomic<Integral>* obj, Integral op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000397
398template <class Integral>
399 Integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000400 atomic_fetch_and(atomic<Integral>* obj, Integral op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000401
402template <class Integral>
403 Integral
404 atomic_fetch_and_explicit(volatile atomic<Integral>* obj, Integral op,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000405 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000406template <class Integral>
407 Integral
408 atomic_fetch_and_explicit(atomic<Integral>* obj, Integral op,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000409 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000410template <class Integral>
411 Integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000412 atomic_fetch_or(volatile atomic<Integral>* obj, Integral op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000413
414template <class Integral>
415 Integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000416 atomic_fetch_or(atomic<Integral>* obj, Integral op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000417
418template <class Integral>
419 Integral
420 atomic_fetch_or_explicit(volatile atomic<Integral>* obj, Integral op,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000421 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000422template <class Integral>
423 Integral
424 atomic_fetch_or_explicit(atomic<Integral>* obj, Integral op,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000425 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000426template <class Integral>
427 Integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000428 atomic_fetch_xor(volatile atomic<Integral>* obj, Integral op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000429
430template <class Integral>
431 Integral
Howard Hinnant300c67a2012-04-11 20:14:21 +0000432 atomic_fetch_xor(atomic<Integral>* obj, Integral op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000433
434template <class Integral>
435 Integral
436 atomic_fetch_xor_explicit(volatile atomic<Integral>* obj, Integral op,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000437 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000438template <class Integral>
439 Integral
440 atomic_fetch_xor_explicit(atomic<Integral>* obj, Integral op,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000441 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000442
443template <class T>
444 T*
Howard Hinnant300c67a2012-04-11 20:14:21 +0000445 atomic_fetch_add(volatile atomic<T*>* obj, ptrdiff_t op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000446
447template <class T>
448 T*
Howard Hinnant300c67a2012-04-11 20:14:21 +0000449 atomic_fetch_add(atomic<T*>* obj, ptrdiff_t op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000450
451template <class T>
452 T*
453 atomic_fetch_add_explicit(volatile atomic<T*>* obj, ptrdiff_t op,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000454 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000455template <class T>
456 T*
Howard Hinnant300c67a2012-04-11 20:14:21 +0000457 atomic_fetch_add_explicit(atomic<T*>* obj, ptrdiff_t op, memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000458
459template <class T>
460 T*
Howard Hinnant300c67a2012-04-11 20:14:21 +0000461 atomic_fetch_sub(volatile atomic<T*>* obj, ptrdiff_t op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000462
463template <class T>
464 T*
Howard Hinnant300c67a2012-04-11 20:14:21 +0000465 atomic_fetch_sub(atomic<T*>* obj, ptrdiff_t op) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000466
467template <class T>
468 T*
469 atomic_fetch_sub_explicit(volatile atomic<T*>* obj, ptrdiff_t op,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000470 memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000471template <class T>
472 T*
Howard Hinnant300c67a2012-04-11 20:14:21 +0000473 atomic_fetch_sub_explicit(atomic<T*>* obj, ptrdiff_t op, memory_order m) noexcept;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000474
475// Atomics for standard typedef types
476
Howard Hinnant6ae47052013-01-04 18:58:50 +0000477typedef atomic<bool> atomic_bool;
Howard Hinnant4777bf22010-12-06 23:10:08 +0000478typedef atomic<char> atomic_char;
479typedef atomic<signed char> atomic_schar;
480typedef atomic<unsigned char> atomic_uchar;
481typedef atomic<short> atomic_short;
482typedef atomic<unsigned short> atomic_ushort;
483typedef atomic<int> atomic_int;
484typedef atomic<unsigned int> atomic_uint;
485typedef atomic<long> atomic_long;
486typedef atomic<unsigned long> atomic_ulong;
487typedef atomic<long long> atomic_llong;
488typedef atomic<unsigned long long> atomic_ullong;
489typedef atomic<char16_t> atomic_char16_t;
490typedef atomic<char32_t> atomic_char32_t;
491typedef atomic<wchar_t> atomic_wchar_t;
492
493typedef atomic<int_least8_t> atomic_int_least8_t;
494typedef atomic<uint_least8_t> atomic_uint_least8_t;
495typedef atomic<int_least16_t> atomic_int_least16_t;
496typedef atomic<uint_least16_t> atomic_uint_least16_t;
497typedef atomic<int_least32_t> atomic_int_least32_t;
498typedef atomic<uint_least32_t> atomic_uint_least32_t;
499typedef atomic<int_least64_t> atomic_int_least64_t;
500typedef atomic<uint_least64_t> atomic_uint_least64_t;
501
502typedef atomic<int_fast8_t> atomic_int_fast8_t;
503typedef atomic<uint_fast8_t> atomic_uint_fast8_t;
504typedef atomic<int_fast16_t> atomic_int_fast16_t;
505typedef atomic<uint_fast16_t> atomic_uint_fast16_t;
506typedef atomic<int_fast32_t> atomic_int_fast32_t;
507typedef atomic<uint_fast32_t> atomic_uint_fast32_t;
508typedef atomic<int_fast64_t> atomic_int_fast64_t;
509typedef atomic<uint_fast64_t> atomic_uint_fast64_t;
510
511typedef atomic<intptr_t> atomic_intptr_t;
512typedef atomic<uintptr_t> atomic_uintptr_t;
513typedef atomic<size_t> atomic_size_t;
514typedef atomic<ptrdiff_t> atomic_ptrdiff_t;
515typedef atomic<intmax_t> atomic_intmax_t;
516typedef atomic<uintmax_t> atomic_uintmax_t;
517
Howard Hinnant8f73c632010-09-27 21:17:38 +0000518// fences
519
Howard Hinnant300c67a2012-04-11 20:14:21 +0000520void atomic_thread_fence(memory_order m) noexcept;
521void atomic_signal_fence(memory_order m) noexcept;
Howard Hinnant8f73c632010-09-27 21:17:38 +0000522
523} // std
524
525*/
526
527#include <__config>
Howard Hinnant4777bf22010-12-06 23:10:08 +0000528#include <cstddef>
529#include <cstdint>
530#include <type_traits>
Howard Hinnant8f73c632010-09-27 21:17:38 +0000531
Howard Hinnant08e17472011-10-17 20:05:10 +0000532#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
Howard Hinnant8f73c632010-09-27 21:17:38 +0000533#pragma GCC system_header
Howard Hinnant08e17472011-10-17 20:05:10 +0000534#endif
Howard Hinnant8f73c632010-09-27 21:17:38 +0000535
536_LIBCPP_BEGIN_NAMESPACE_STD
537
Howard Hinnant154002b2011-03-31 16:39:39 +0000538#if !__has_feature(cxx_atomic)
539#error <atomic> is not implemented
540#else
541
Howard Hinnantd1176e22010-09-28 17:13:38 +0000542typedef enum memory_order
543{
544 memory_order_relaxed, memory_order_consume, memory_order_acquire,
545 memory_order_release, memory_order_acq_rel, memory_order_seq_cst
546} memory_order;
547
548template <class _Tp>
549inline _LIBCPP_INLINE_VISIBILITY
550_Tp
Howard Hinnant300c67a2012-04-11 20:14:21 +0000551kill_dependency(_Tp __y) _NOEXCEPT
Howard Hinnantd1176e22010-09-28 17:13:38 +0000552{
553 return __y;
554}
Howard Hinnant8f73c632010-09-27 21:17:38 +0000555
Howard Hinnant91e2f262010-12-07 20:46:14 +0000556// general atomic<T>
557
558template <class _Tp, bool = is_integral<_Tp>::value && !is_same<_Tp, bool>::value>
559struct __atomic_base // false
560{
Howard Hinnant7eb9f1e2012-09-16 20:33:09 +0000561 mutable _Atomic(_Tp) __a_;
Howard Hinnant91e2f262010-12-07 20:46:14 +0000562
563 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000564 bool is_lock_free() const volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000565 {return __c11_atomic_is_lock_free(sizeof(_Tp));}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000566 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000567 bool is_lock_free() const _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000568 {return __c11_atomic_is_lock_free(sizeof(_Tp));}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000569 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000570 void store(_Tp __d, memory_order __m = memory_order_seq_cst) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000571 {__c11_atomic_store(&__a_, __d, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000572 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000573 void store(_Tp __d, memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000574 {__c11_atomic_store(&__a_, __d, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000575 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000576 _Tp load(memory_order __m = memory_order_seq_cst) const volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000577 {return __c11_atomic_load(&__a_, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000578 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000579 _Tp load(memory_order __m = memory_order_seq_cst) const _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000580 {return __c11_atomic_load(&__a_, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000581 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000582 operator _Tp() const volatile _NOEXCEPT {return load();}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000583 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000584 operator _Tp() const _NOEXCEPT {return load();}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000585 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000586 _Tp exchange(_Tp __d, memory_order __m = memory_order_seq_cst) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000587 {return __c11_atomic_exchange(&__a_, __d, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000588 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000589 _Tp exchange(_Tp __d, memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000590 {return __c11_atomic_exchange(&__a_, __d, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000591 _LIBCPP_INLINE_VISIBILITY
592 bool compare_exchange_weak(_Tp& __e, _Tp __d,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000593 memory_order __s, memory_order __f) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000594 {return __c11_atomic_compare_exchange_weak(&__a_, &__e, __d, __s, __f);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000595 _LIBCPP_INLINE_VISIBILITY
596 bool compare_exchange_weak(_Tp& __e, _Tp __d,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000597 memory_order __s, memory_order __f) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000598 {return __c11_atomic_compare_exchange_weak(&__a_, &__e, __d, __s, __f);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000599 _LIBCPP_INLINE_VISIBILITY
600 bool compare_exchange_strong(_Tp& __e, _Tp __d,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000601 memory_order __s, memory_order __f) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000602 {return __c11_atomic_compare_exchange_strong(&__a_, &__e, __d, __s, __f);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000603 _LIBCPP_INLINE_VISIBILITY
604 bool compare_exchange_strong(_Tp& __e, _Tp __d,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000605 memory_order __s, memory_order __f) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000606 {return __c11_atomic_compare_exchange_strong(&__a_, &__e, __d, __s, __f);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000607 _LIBCPP_INLINE_VISIBILITY
608 bool compare_exchange_weak(_Tp& __e, _Tp __d,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000609 memory_order __m = memory_order_seq_cst) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000610 {return __c11_atomic_compare_exchange_weak(&__a_, &__e, __d, __m, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000611 _LIBCPP_INLINE_VISIBILITY
612 bool compare_exchange_weak(_Tp& __e, _Tp __d,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000613 memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000614 {return __c11_atomic_compare_exchange_weak(&__a_, &__e, __d, __m, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000615 _LIBCPP_INLINE_VISIBILITY
616 bool compare_exchange_strong(_Tp& __e, _Tp __d,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000617 memory_order __m = memory_order_seq_cst) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000618 {return __c11_atomic_compare_exchange_strong(&__a_, &__e, __d, __m, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000619 _LIBCPP_INLINE_VISIBILITY
620 bool compare_exchange_strong(_Tp& __e, _Tp __d,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000621 memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000622 {return __c11_atomic_compare_exchange_strong(&__a_, &__e, __d, __m, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000623
624 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000625 __atomic_base() _NOEXCEPT {} // = default;
Howard Hinnant91e2f262010-12-07 20:46:14 +0000626 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000627 _LIBCPP_CONSTEXPR __atomic_base(_Tp __d) _NOEXCEPT : __a_(__d) {}
Howard Hinnant770d1c42010-12-08 17:20:28 +0000628#ifndef _LIBCPP_HAS_NO_DELETED_FUNCTIONS
Howard Hinnant91e2f262010-12-07 20:46:14 +0000629 __atomic_base(const __atomic_base&) = delete;
630 __atomic_base& operator=(const __atomic_base&) = delete;
631 __atomic_base& operator=(const __atomic_base&) volatile = delete;
Howard Hinnant770d1c42010-12-08 17:20:28 +0000632#else // _LIBCPP_HAS_NO_DELETED_FUNCTIONS
633private:
634 __atomic_base(const __atomic_base&);
635 __atomic_base& operator=(const __atomic_base&);
636 __atomic_base& operator=(const __atomic_base&) volatile;
637#endif // _LIBCPP_HAS_NO_DELETED_FUNCTIONS
Howard Hinnant91e2f262010-12-07 20:46:14 +0000638};
639
640// atomic<Integral>
641
642template <class _Tp>
643struct __atomic_base<_Tp, true>
644 : public __atomic_base<_Tp, false>
645{
646 typedef __atomic_base<_Tp, false> __base;
647 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000648 __atomic_base() _NOEXCEPT {} // = default;
Howard Hinnant91e2f262010-12-07 20:46:14 +0000649 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000650 _LIBCPP_CONSTEXPR __atomic_base(_Tp __d) _NOEXCEPT : __base(__d) {}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000651
652 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000653 _Tp fetch_add(_Tp __op, memory_order __m = memory_order_seq_cst) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000654 {return __c11_atomic_fetch_add(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000655 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000656 _Tp fetch_add(_Tp __op, memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000657 {return __c11_atomic_fetch_add(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000658 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000659 _Tp fetch_sub(_Tp __op, memory_order __m = memory_order_seq_cst) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000660 {return __c11_atomic_fetch_sub(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000661 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000662 _Tp fetch_sub(_Tp __op, memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000663 {return __c11_atomic_fetch_sub(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000664 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000665 _Tp fetch_and(_Tp __op, memory_order __m = memory_order_seq_cst) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000666 {return __c11_atomic_fetch_and(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000667 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000668 _Tp fetch_and(_Tp __op, memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000669 {return __c11_atomic_fetch_and(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000670 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000671 _Tp fetch_or(_Tp __op, memory_order __m = memory_order_seq_cst) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000672 {return __c11_atomic_fetch_or(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000673 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000674 _Tp fetch_or(_Tp __op, memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000675 {return __c11_atomic_fetch_or(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000676 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000677 _Tp fetch_xor(_Tp __op, memory_order __m = memory_order_seq_cst) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000678 {return __c11_atomic_fetch_xor(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000679 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000680 _Tp fetch_xor(_Tp __op, memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000681 {return __c11_atomic_fetch_xor(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000682
683 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000684 _Tp operator++(int) volatile _NOEXCEPT {return fetch_add(_Tp(1));}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000685 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000686 _Tp operator++(int) _NOEXCEPT {return fetch_add(_Tp(1));}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000687 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000688 _Tp operator--(int) volatile _NOEXCEPT {return fetch_sub(_Tp(1));}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000689 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000690 _Tp operator--(int) _NOEXCEPT {return fetch_sub(_Tp(1));}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000691 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000692 _Tp operator++() volatile _NOEXCEPT {return fetch_add(_Tp(1)) + _Tp(1);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000693 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000694 _Tp operator++() _NOEXCEPT {return fetch_add(_Tp(1)) + _Tp(1);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000695 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000696 _Tp operator--() volatile _NOEXCEPT {return fetch_sub(_Tp(1)) - _Tp(1);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000697 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000698 _Tp operator--() _NOEXCEPT {return fetch_sub(_Tp(1)) - _Tp(1);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000699 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000700 _Tp operator+=(_Tp __op) volatile _NOEXCEPT {return fetch_add(__op) + __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000701 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000702 _Tp operator+=(_Tp __op) _NOEXCEPT {return fetch_add(__op) + __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000703 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000704 _Tp operator-=(_Tp __op) volatile _NOEXCEPT {return fetch_sub(__op) - __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000705 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000706 _Tp operator-=(_Tp __op) _NOEXCEPT {return fetch_sub(__op) - __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000707 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000708 _Tp operator&=(_Tp __op) volatile _NOEXCEPT {return fetch_and(__op) & __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000709 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000710 _Tp operator&=(_Tp __op) _NOEXCEPT {return fetch_and(__op) & __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000711 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000712 _Tp operator|=(_Tp __op) volatile _NOEXCEPT {return fetch_or(__op) | __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000713 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000714 _Tp operator|=(_Tp __op) _NOEXCEPT {return fetch_or(__op) | __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000715 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000716 _Tp operator^=(_Tp __op) volatile _NOEXCEPT {return fetch_xor(__op) ^ __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000717 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000718 _Tp operator^=(_Tp __op) _NOEXCEPT {return fetch_xor(__op) ^ __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000719};
720
721// atomic<T>
722
723template <class _Tp>
724struct atomic
725 : public __atomic_base<_Tp>
726{
727 typedef __atomic_base<_Tp> __base;
728 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000729 atomic() _NOEXCEPT {} // = default;
Howard Hinnant91e2f262010-12-07 20:46:14 +0000730 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000731 _LIBCPP_CONSTEXPR atomic(_Tp __d) _NOEXCEPT : __base(__d) {}
Howard Hinnantd2f6afb2010-12-07 23:24:41 +0000732
733 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000734 _Tp operator=(_Tp __d) volatile _NOEXCEPT
Howard Hinnantd2f6afb2010-12-07 23:24:41 +0000735 {__base::store(__d); return __d;}
736 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000737 _Tp operator=(_Tp __d) _NOEXCEPT
Howard Hinnantd2f6afb2010-12-07 23:24:41 +0000738 {__base::store(__d); return __d;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000739};
740
741// atomic<T*>
742
743template <class _Tp>
744struct atomic<_Tp*>
745 : public __atomic_base<_Tp*>
746{
Howard Hinnantd2f6afb2010-12-07 23:24:41 +0000747 typedef __atomic_base<_Tp*> __base;
Howard Hinnant91e2f262010-12-07 20:46:14 +0000748 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000749 atomic() _NOEXCEPT {} // = default;
Howard Hinnant91e2f262010-12-07 20:46:14 +0000750 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000751 _LIBCPP_CONSTEXPR atomic(_Tp* __d) _NOEXCEPT : __base(__d) {}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000752
753 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000754 _Tp* operator=(_Tp* __d) volatile _NOEXCEPT
Howard Hinnantd2f6afb2010-12-07 23:24:41 +0000755 {__base::store(__d); return __d;}
756 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000757 _Tp* operator=(_Tp* __d) _NOEXCEPT
Howard Hinnantd2f6afb2010-12-07 23:24:41 +0000758 {__base::store(__d); return __d;}
759
760 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant91e2f262010-12-07 20:46:14 +0000761 _Tp* fetch_add(ptrdiff_t __op, memory_order __m = memory_order_seq_cst)
Howard Hinnant300c67a2012-04-11 20:14:21 +0000762 volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000763 {return __c11_atomic_fetch_add(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000764 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000765 _Tp* fetch_add(ptrdiff_t __op, memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000766 {return __c11_atomic_fetch_add(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000767 _LIBCPP_INLINE_VISIBILITY
768 _Tp* fetch_sub(ptrdiff_t __op, memory_order __m = memory_order_seq_cst)
Howard Hinnant300c67a2012-04-11 20:14:21 +0000769 volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000770 {return __c11_atomic_fetch_sub(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000771 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000772 _Tp* fetch_sub(ptrdiff_t __op, memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +0000773 {return __c11_atomic_fetch_sub(&this->__a_, __op, __m);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000774
775 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000776 _Tp* operator++(int) volatile _NOEXCEPT {return fetch_add(1);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000777 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000778 _Tp* operator++(int) _NOEXCEPT {return fetch_add(1);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000779 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000780 _Tp* operator--(int) volatile _NOEXCEPT {return fetch_sub(1);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000781 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000782 _Tp* operator--(int) _NOEXCEPT {return fetch_sub(1);}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000783 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000784 _Tp* operator++() volatile _NOEXCEPT {return fetch_add(1) + 1;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000785 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000786 _Tp* operator++() _NOEXCEPT {return fetch_add(1) + 1;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000787 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000788 _Tp* operator--() volatile _NOEXCEPT {return fetch_sub(1) - 1;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000789 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000790 _Tp* operator--() _NOEXCEPT {return fetch_sub(1) - 1;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000791 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000792 _Tp* operator+=(ptrdiff_t __op) volatile _NOEXCEPT {return fetch_add(__op) + __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000793 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000794 _Tp* operator+=(ptrdiff_t __op) _NOEXCEPT {return fetch_add(__op) + __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000795 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000796 _Tp* operator-=(ptrdiff_t __op) volatile _NOEXCEPT {return fetch_sub(__op) - __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000797 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +0000798 _Tp* operator-=(ptrdiff_t __op) _NOEXCEPT {return fetch_sub(__op) - __op;}
Howard Hinnant91e2f262010-12-07 20:46:14 +0000799};
Howard Hinnant4777bf22010-12-06 23:10:08 +0000800
801// atomic_is_lock_free
802
803template <class _Tp>
804inline _LIBCPP_INLINE_VISIBILITY
805bool
Howard Hinnant300c67a2012-04-11 20:14:21 +0000806atomic_is_lock_free(const volatile atomic<_Tp>* __o) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000807{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000808 return __o->is_lock_free();
Howard Hinnant4777bf22010-12-06 23:10:08 +0000809}
810
811template <class _Tp>
812inline _LIBCPP_INLINE_VISIBILITY
813bool
Howard Hinnant300c67a2012-04-11 20:14:21 +0000814atomic_is_lock_free(const atomic<_Tp>* __o) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000815{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000816 return __o->is_lock_free();
Howard Hinnant4777bf22010-12-06 23:10:08 +0000817}
818
819// atomic_init
820
821template <class _Tp>
822inline _LIBCPP_INLINE_VISIBILITY
823void
Howard Hinnant300c67a2012-04-11 20:14:21 +0000824atomic_init(volatile atomic<_Tp>* __o, _Tp __d) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000825{
Richard Smith6186c7f2012-04-11 18:55:46 +0000826 __c11_atomic_init(&__o->__a_, __d);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000827}
828
829template <class _Tp>
830inline _LIBCPP_INLINE_VISIBILITY
831void
Howard Hinnant300c67a2012-04-11 20:14:21 +0000832atomic_init(atomic<_Tp>* __o, _Tp __d) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000833{
Richard Smith6186c7f2012-04-11 18:55:46 +0000834 __c11_atomic_init(&__o->__a_, __d);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000835}
836
837// atomic_store
838
839template <class _Tp>
840inline _LIBCPP_INLINE_VISIBILITY
841void
Howard Hinnant300c67a2012-04-11 20:14:21 +0000842atomic_store(volatile atomic<_Tp>* __o, _Tp __d) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000843{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000844 __o->store(__d);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000845}
846
847template <class _Tp>
848inline _LIBCPP_INLINE_VISIBILITY
849void
Howard Hinnant300c67a2012-04-11 20:14:21 +0000850atomic_store(atomic<_Tp>* __o, _Tp __d) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000851{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000852 __o->store(__d);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000853}
854
855// atomic_store_explicit
856
857template <class _Tp>
858inline _LIBCPP_INLINE_VISIBILITY
859void
Howard Hinnant300c67a2012-04-11 20:14:21 +0000860atomic_store_explicit(volatile atomic<_Tp>* __o, _Tp __d, memory_order __m) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000861{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000862 __o->store(__d, __m);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000863}
864
865template <class _Tp>
866inline _LIBCPP_INLINE_VISIBILITY
867void
Howard Hinnant300c67a2012-04-11 20:14:21 +0000868atomic_store_explicit(atomic<_Tp>* __o, _Tp __d, memory_order __m) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000869{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000870 __o->store(__d, __m);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000871}
872
873// atomic_load
874
875template <class _Tp>
876inline _LIBCPP_INLINE_VISIBILITY
877_Tp
Howard Hinnant300c67a2012-04-11 20:14:21 +0000878atomic_load(const volatile atomic<_Tp>* __o) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000879{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000880 return __o->load();
Howard Hinnant4777bf22010-12-06 23:10:08 +0000881}
882
883template <class _Tp>
884inline _LIBCPP_INLINE_VISIBILITY
885_Tp
Howard Hinnant300c67a2012-04-11 20:14:21 +0000886atomic_load(const atomic<_Tp>* __o) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000887{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000888 return __o->load();
Howard Hinnant4777bf22010-12-06 23:10:08 +0000889}
890
891// atomic_load_explicit
892
893template <class _Tp>
894inline _LIBCPP_INLINE_VISIBILITY
895_Tp
Howard Hinnant300c67a2012-04-11 20:14:21 +0000896atomic_load_explicit(const volatile atomic<_Tp>* __o, memory_order __m) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000897{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000898 return __o->load(__m);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000899}
900
901template <class _Tp>
902inline _LIBCPP_INLINE_VISIBILITY
903_Tp
Howard Hinnant300c67a2012-04-11 20:14:21 +0000904atomic_load_explicit(const atomic<_Tp>* __o, memory_order __m) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000905{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000906 return __o->load(__m);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000907}
908
909// atomic_exchange
910
911template <class _Tp>
912inline _LIBCPP_INLINE_VISIBILITY
913_Tp
Howard Hinnant300c67a2012-04-11 20:14:21 +0000914atomic_exchange(volatile atomic<_Tp>* __o, _Tp __d) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000915{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000916 return __o->exchange(__d);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000917}
918
919template <class _Tp>
920inline _LIBCPP_INLINE_VISIBILITY
921_Tp
Howard Hinnant300c67a2012-04-11 20:14:21 +0000922atomic_exchange(atomic<_Tp>* __o, _Tp __d) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000923{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000924 return __o->exchange(__d);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000925}
926
927// atomic_exchange_explicit
928
929template <class _Tp>
930inline _LIBCPP_INLINE_VISIBILITY
931_Tp
Howard Hinnant300c67a2012-04-11 20:14:21 +0000932atomic_exchange_explicit(volatile atomic<_Tp>* __o, _Tp __d, memory_order __m) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000933{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000934 return __o->exchange(__d, __m);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000935}
936
937template <class _Tp>
938inline _LIBCPP_INLINE_VISIBILITY
939_Tp
Howard Hinnant300c67a2012-04-11 20:14:21 +0000940atomic_exchange_explicit(atomic<_Tp>* __o, _Tp __d, memory_order __m) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000941{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000942 return __o->exchange(__d, __m);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000943}
944
945// atomic_compare_exchange_weak
946
947template <class _Tp>
948inline _LIBCPP_INLINE_VISIBILITY
949bool
Howard Hinnant300c67a2012-04-11 20:14:21 +0000950atomic_compare_exchange_weak(volatile atomic<_Tp>* __o, _Tp* __e, _Tp __d) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000951{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000952 return __o->compare_exchange_weak(*__e, __d);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000953}
954
955template <class _Tp>
956inline _LIBCPP_INLINE_VISIBILITY
957bool
Howard Hinnant300c67a2012-04-11 20:14:21 +0000958atomic_compare_exchange_weak(atomic<_Tp>* __o, _Tp* __e, _Tp __d) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000959{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000960 return __o->compare_exchange_weak(*__e, __d);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000961}
962
963// atomic_compare_exchange_strong
964
965template <class _Tp>
966inline _LIBCPP_INLINE_VISIBILITY
967bool
Howard Hinnant300c67a2012-04-11 20:14:21 +0000968atomic_compare_exchange_strong(volatile atomic<_Tp>* __o, _Tp* __e, _Tp __d) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000969{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000970 return __o->compare_exchange_strong(*__e, __d);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000971}
972
973template <class _Tp>
974inline _LIBCPP_INLINE_VISIBILITY
975bool
Howard Hinnant300c67a2012-04-11 20:14:21 +0000976atomic_compare_exchange_strong(atomic<_Tp>* __o, _Tp* __e, _Tp __d) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000977{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000978 return __o->compare_exchange_strong(*__e, __d);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000979}
980
981// atomic_compare_exchange_weak_explicit
982
983template <class _Tp>
984inline _LIBCPP_INLINE_VISIBILITY
985bool
986atomic_compare_exchange_weak_explicit(volatile atomic<_Tp>* __o, _Tp* __e,
987 _Tp __d,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000988 memory_order __s, memory_order __f) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000989{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000990 return __o->compare_exchange_weak(*__e, __d, __s, __f);
Howard Hinnant4777bf22010-12-06 23:10:08 +0000991}
992
993template <class _Tp>
994inline _LIBCPP_INLINE_VISIBILITY
995bool
996atomic_compare_exchange_weak_explicit(atomic<_Tp>* __o, _Tp* __e, _Tp __d,
Howard Hinnant300c67a2012-04-11 20:14:21 +0000997 memory_order __s, memory_order __f) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +0000998{
Howard Hinnant91e2f262010-12-07 20:46:14 +0000999 return __o->compare_exchange_weak(*__e, __d, __s, __f);
Howard Hinnant4777bf22010-12-06 23:10:08 +00001000}
1001
1002// atomic_compare_exchange_strong_explicit
1003
1004template <class _Tp>
1005inline _LIBCPP_INLINE_VISIBILITY
1006bool
1007atomic_compare_exchange_strong_explicit(volatile atomic<_Tp>* __o,
1008 _Tp* __e, _Tp __d,
Howard Hinnant300c67a2012-04-11 20:14:21 +00001009 memory_order __s, memory_order __f) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +00001010{
Howard Hinnant91e2f262010-12-07 20:46:14 +00001011 return __o->compare_exchange_strong(*__e, __d, __s, __f);
Howard Hinnant4777bf22010-12-06 23:10:08 +00001012}
1013
1014template <class _Tp>
1015inline _LIBCPP_INLINE_VISIBILITY
1016bool
1017atomic_compare_exchange_strong_explicit(atomic<_Tp>* __o, _Tp* __e,
1018 _Tp __d,
Howard Hinnant300c67a2012-04-11 20:14:21 +00001019 memory_order __s, memory_order __f) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +00001020{
Howard Hinnant91e2f262010-12-07 20:46:14 +00001021 return __o->compare_exchange_strong(*__e, __d, __s, __f);
Howard Hinnant4777bf22010-12-06 23:10:08 +00001022}
1023
Howard Hinnant91e2f262010-12-07 20:46:14 +00001024// atomic_fetch_add
Howard Hinnant4777bf22010-12-06 23:10:08 +00001025
1026template <class _Tp>
Howard Hinnant91e2f262010-12-07 20:46:14 +00001027inline _LIBCPP_INLINE_VISIBILITY
1028typename enable_if
1029<
1030 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1031 _Tp
1032>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001033atomic_fetch_add(volatile atomic<_Tp>* __o, _Tp __op) _NOEXCEPT
Howard Hinnant4777bf22010-12-06 23:10:08 +00001034{
Howard Hinnant91e2f262010-12-07 20:46:14 +00001035 return __o->fetch_add(__op);
1036}
Howard Hinnant4777bf22010-12-06 23:10:08 +00001037
Howard Hinnant91e2f262010-12-07 20:46:14 +00001038template <class _Tp>
1039inline _LIBCPP_INLINE_VISIBILITY
1040typename enable_if
1041<
1042 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1043 _Tp
1044>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001045atomic_fetch_add(atomic<_Tp>* __o, _Tp __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001046{
1047 return __o->fetch_add(__op);
1048}
Howard Hinnant4777bf22010-12-06 23:10:08 +00001049
Howard Hinnant91e2f262010-12-07 20:46:14 +00001050template <class _Tp>
1051inline _LIBCPP_INLINE_VISIBILITY
1052_Tp*
Howard Hinnant300c67a2012-04-11 20:14:21 +00001053atomic_fetch_add(volatile atomic<_Tp*>* __o, ptrdiff_t __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001054{
1055 return __o->fetch_add(__op);
1056}
1057
1058template <class _Tp>
1059inline _LIBCPP_INLINE_VISIBILITY
1060_Tp*
Howard Hinnant300c67a2012-04-11 20:14:21 +00001061atomic_fetch_add(atomic<_Tp*>* __o, ptrdiff_t __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001062{
1063 return __o->fetch_add(__op);
1064}
1065
1066// atomic_fetch_add_explicit
1067
1068template <class _Tp>
1069inline _LIBCPP_INLINE_VISIBILITY
1070typename enable_if
1071<
1072 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1073 _Tp
1074>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001075atomic_fetch_add_explicit(volatile atomic<_Tp>* __o, _Tp __op, memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001076{
1077 return __o->fetch_add(__op, __m);
1078}
1079
1080template <class _Tp>
1081inline _LIBCPP_INLINE_VISIBILITY
1082typename enable_if
1083<
1084 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1085 _Tp
1086>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001087atomic_fetch_add_explicit(atomic<_Tp>* __o, _Tp __op, memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001088{
1089 return __o->fetch_add(__op, __m);
1090}
1091
1092template <class _Tp>
1093inline _LIBCPP_INLINE_VISIBILITY
1094_Tp*
1095atomic_fetch_add_explicit(volatile atomic<_Tp*>* __o, ptrdiff_t __op,
Howard Hinnant300c67a2012-04-11 20:14:21 +00001096 memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001097{
1098 return __o->fetch_add(__op, __m);
1099}
1100
1101template <class _Tp>
1102inline _LIBCPP_INLINE_VISIBILITY
1103_Tp*
Howard Hinnant300c67a2012-04-11 20:14:21 +00001104atomic_fetch_add_explicit(atomic<_Tp*>* __o, ptrdiff_t __op, memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001105{
1106 return __o->fetch_add(__op, __m);
1107}
1108
1109// atomic_fetch_sub
1110
1111template <class _Tp>
1112inline _LIBCPP_INLINE_VISIBILITY
1113typename enable_if
1114<
1115 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1116 _Tp
1117>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001118atomic_fetch_sub(volatile atomic<_Tp>* __o, _Tp __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001119{
1120 return __o->fetch_sub(__op);
1121}
1122
1123template <class _Tp>
1124inline _LIBCPP_INLINE_VISIBILITY
1125typename enable_if
1126<
1127 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1128 _Tp
1129>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001130atomic_fetch_sub(atomic<_Tp>* __o, _Tp __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001131{
1132 return __o->fetch_sub(__op);
1133}
1134
1135template <class _Tp>
1136inline _LIBCPP_INLINE_VISIBILITY
1137_Tp*
Howard Hinnant300c67a2012-04-11 20:14:21 +00001138atomic_fetch_sub(volatile atomic<_Tp*>* __o, ptrdiff_t __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001139{
1140 return __o->fetch_sub(__op);
1141}
1142
1143template <class _Tp>
1144inline _LIBCPP_INLINE_VISIBILITY
1145_Tp*
Howard Hinnant300c67a2012-04-11 20:14:21 +00001146atomic_fetch_sub(atomic<_Tp*>* __o, ptrdiff_t __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001147{
1148 return __o->fetch_sub(__op);
1149}
1150
1151// atomic_fetch_sub_explicit
1152
1153template <class _Tp>
1154inline _LIBCPP_INLINE_VISIBILITY
1155typename enable_if
1156<
1157 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1158 _Tp
1159>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001160atomic_fetch_sub_explicit(volatile atomic<_Tp>* __o, _Tp __op, memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001161{
1162 return __o->fetch_sub(__op, __m);
1163}
1164
1165template <class _Tp>
1166inline _LIBCPP_INLINE_VISIBILITY
1167typename enable_if
1168<
1169 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1170 _Tp
1171>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001172atomic_fetch_sub_explicit(atomic<_Tp>* __o, _Tp __op, memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001173{
1174 return __o->fetch_sub(__op, __m);
1175}
1176
1177template <class _Tp>
1178inline _LIBCPP_INLINE_VISIBILITY
1179_Tp*
1180atomic_fetch_sub_explicit(volatile atomic<_Tp*>* __o, ptrdiff_t __op,
Howard Hinnant300c67a2012-04-11 20:14:21 +00001181 memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001182{
1183 return __o->fetch_sub(__op, __m);
1184}
1185
1186template <class _Tp>
1187inline _LIBCPP_INLINE_VISIBILITY
1188_Tp*
Howard Hinnant300c67a2012-04-11 20:14:21 +00001189atomic_fetch_sub_explicit(atomic<_Tp*>* __o, ptrdiff_t __op, memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001190{
1191 return __o->fetch_sub(__op, __m);
1192}
1193
1194// atomic_fetch_and
1195
1196template <class _Tp>
1197inline _LIBCPP_INLINE_VISIBILITY
1198typename enable_if
1199<
1200 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1201 _Tp
1202>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001203atomic_fetch_and(volatile atomic<_Tp>* __o, _Tp __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001204{
1205 return __o->fetch_and(__op);
1206}
1207
1208template <class _Tp>
1209inline _LIBCPP_INLINE_VISIBILITY
1210typename enable_if
1211<
1212 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1213 _Tp
1214>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001215atomic_fetch_and(atomic<_Tp>* __o, _Tp __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001216{
1217 return __o->fetch_and(__op);
1218}
1219
1220// atomic_fetch_and_explicit
1221
1222template <class _Tp>
1223inline _LIBCPP_INLINE_VISIBILITY
1224typename enable_if
1225<
1226 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1227 _Tp
1228>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001229atomic_fetch_and_explicit(volatile atomic<_Tp>* __o, _Tp __op, memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001230{
1231 return __o->fetch_and(__op, __m);
1232}
1233
1234template <class _Tp>
1235inline _LIBCPP_INLINE_VISIBILITY
1236typename enable_if
1237<
1238 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1239 _Tp
1240>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001241atomic_fetch_and_explicit(atomic<_Tp>* __o, _Tp __op, memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001242{
1243 return __o->fetch_and(__op, __m);
1244}
1245
1246// atomic_fetch_or
1247
1248template <class _Tp>
1249inline _LIBCPP_INLINE_VISIBILITY
1250typename enable_if
1251<
1252 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1253 _Tp
1254>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001255atomic_fetch_or(volatile atomic<_Tp>* __o, _Tp __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001256{
1257 return __o->fetch_or(__op);
1258}
1259
1260template <class _Tp>
1261inline _LIBCPP_INLINE_VISIBILITY
1262typename enable_if
1263<
1264 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1265 _Tp
1266>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001267atomic_fetch_or(atomic<_Tp>* __o, _Tp __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001268{
1269 return __o->fetch_or(__op);
1270}
1271
1272// atomic_fetch_or_explicit
1273
1274template <class _Tp>
1275inline _LIBCPP_INLINE_VISIBILITY
1276typename enable_if
1277<
1278 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1279 _Tp
1280>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001281atomic_fetch_or_explicit(volatile atomic<_Tp>* __o, _Tp __op, memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001282{
1283 return __o->fetch_or(__op, __m);
1284}
1285
1286template <class _Tp>
1287inline _LIBCPP_INLINE_VISIBILITY
1288typename enable_if
1289<
1290 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1291 _Tp
1292>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001293atomic_fetch_or_explicit(atomic<_Tp>* __o, _Tp __op, memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001294{
1295 return __o->fetch_or(__op, __m);
1296}
1297
1298// atomic_fetch_xor
1299
1300template <class _Tp>
1301inline _LIBCPP_INLINE_VISIBILITY
1302typename enable_if
1303<
1304 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1305 _Tp
1306>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001307atomic_fetch_xor(volatile atomic<_Tp>* __o, _Tp __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001308{
1309 return __o->fetch_xor(__op);
1310}
1311
1312template <class _Tp>
1313inline _LIBCPP_INLINE_VISIBILITY
1314typename enable_if
1315<
1316 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1317 _Tp
1318>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001319atomic_fetch_xor(atomic<_Tp>* __o, _Tp __op) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001320{
1321 return __o->fetch_xor(__op);
1322}
1323
1324// atomic_fetch_xor_explicit
1325
1326template <class _Tp>
1327inline _LIBCPP_INLINE_VISIBILITY
1328typename enable_if
1329<
1330 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1331 _Tp
1332>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001333atomic_fetch_xor_explicit(volatile atomic<_Tp>* __o, _Tp __op, memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001334{
1335 return __o->fetch_xor(__op, __m);
1336}
1337
1338template <class _Tp>
1339inline _LIBCPP_INLINE_VISIBILITY
1340typename enable_if
1341<
1342 is_integral<_Tp>::value && !is_same<_Tp, bool>::value,
1343 _Tp
1344>::type
Howard Hinnant300c67a2012-04-11 20:14:21 +00001345atomic_fetch_xor_explicit(atomic<_Tp>* __o, _Tp __op, memory_order __m) _NOEXCEPT
Howard Hinnant91e2f262010-12-07 20:46:14 +00001346{
1347 return __o->fetch_xor(__op, __m);
1348}
Howard Hinnant4777bf22010-12-06 23:10:08 +00001349
Howard Hinnant770d1c42010-12-08 17:20:28 +00001350// flag type and operations
1351
1352typedef struct atomic_flag
1353{
David Chisnall83b2c842011-12-19 11:44:20 +00001354 _Atomic(bool) __a_;
Howard Hinnant770d1c42010-12-08 17:20:28 +00001355
1356 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +00001357 bool test_and_set(memory_order __m = memory_order_seq_cst) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +00001358 {return __c11_atomic_exchange(&__a_, true, __m);}
Howard Hinnant770d1c42010-12-08 17:20:28 +00001359 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +00001360 bool test_and_set(memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +00001361 {return __c11_atomic_exchange(&__a_, true, __m);}
Howard Hinnant770d1c42010-12-08 17:20:28 +00001362 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +00001363 void clear(memory_order __m = memory_order_seq_cst) volatile _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +00001364 {__c11_atomic_store(&__a_, false, __m);}
Howard Hinnant770d1c42010-12-08 17:20:28 +00001365 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +00001366 void clear(memory_order __m = memory_order_seq_cst) _NOEXCEPT
Richard Smith6186c7f2012-04-11 18:55:46 +00001367 {__c11_atomic_store(&__a_, false, __m);}
Howard Hinnant770d1c42010-12-08 17:20:28 +00001368
1369 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +00001370 atomic_flag() _NOEXCEPT {} // = default;
Howard Hinnant770d1c42010-12-08 17:20:28 +00001371 _LIBCPP_INLINE_VISIBILITY
Howard Hinnant300c67a2012-04-11 20:14:21 +00001372 atomic_flag(bool __b) _NOEXCEPT : __a_(__b) {}
Howard Hinnant770d1c42010-12-08 17:20:28 +00001373
1374#ifndef _LIBCPP_HAS_NO_DELETED_FUNCTIONS
1375 atomic_flag(const atomic_flag&) = delete;
1376 atomic_flag& operator=(const atomic_flag&) = delete;
1377 atomic_flag& operator=(const atomic_flag&) volatile = delete;
1378#else // _LIBCPP_HAS_NO_DELETED_FUNCTIONS
1379private:
1380 atomic_flag(const atomic_flag&);
1381 atomic_flag& operator=(const atomic_flag&);
1382 atomic_flag& operator=(const atomic_flag&) volatile;
1383#endif // _LIBCPP_HAS_NO_DELETED_FUNCTIONS
1384} atomic_flag;
1385
1386inline _LIBCPP_INLINE_VISIBILITY
1387bool
Howard Hinnant300c67a2012-04-11 20:14:21 +00001388atomic_flag_test_and_set(volatile atomic_flag* __o) _NOEXCEPT
Howard Hinnant770d1c42010-12-08 17:20:28 +00001389{
1390 return __o->test_and_set();
1391}
1392
1393inline _LIBCPP_INLINE_VISIBILITY
1394bool
Howard Hinnant300c67a2012-04-11 20:14:21 +00001395atomic_flag_test_and_set(atomic_flag* __o) _NOEXCEPT
Howard Hinnant770d1c42010-12-08 17:20:28 +00001396{
1397 return __o->test_and_set();
1398}
1399
1400inline _LIBCPP_INLINE_VISIBILITY
1401bool
Howard Hinnant300c67a2012-04-11 20:14:21 +00001402atomic_flag_test_and_set_explicit(volatile atomic_flag* __o, memory_order __m) _NOEXCEPT
Howard Hinnant770d1c42010-12-08 17:20:28 +00001403{
1404 return __o->test_and_set(__m);
1405}
1406
1407inline _LIBCPP_INLINE_VISIBILITY
1408bool
Howard Hinnant300c67a2012-04-11 20:14:21 +00001409atomic_flag_test_and_set_explicit(atomic_flag* __o, memory_order __m) _NOEXCEPT
Howard Hinnant770d1c42010-12-08 17:20:28 +00001410{
1411 return __o->test_and_set(__m);
1412}
1413
1414inline _LIBCPP_INLINE_VISIBILITY
1415void
Howard Hinnant300c67a2012-04-11 20:14:21 +00001416atomic_flag_clear(volatile atomic_flag* __o) _NOEXCEPT
Howard Hinnant770d1c42010-12-08 17:20:28 +00001417{
1418 __o->clear();
1419}
1420
1421inline _LIBCPP_INLINE_VISIBILITY
1422void
Howard Hinnant300c67a2012-04-11 20:14:21 +00001423atomic_flag_clear(atomic_flag* __o) _NOEXCEPT
Howard Hinnant770d1c42010-12-08 17:20:28 +00001424{
1425 __o->clear();
1426}
1427
1428inline _LIBCPP_INLINE_VISIBILITY
1429void
Howard Hinnant300c67a2012-04-11 20:14:21 +00001430atomic_flag_clear_explicit(volatile atomic_flag* __o, memory_order __m) _NOEXCEPT
Howard Hinnant770d1c42010-12-08 17:20:28 +00001431{
1432 __o->clear(__m);
1433}
1434
1435inline _LIBCPP_INLINE_VISIBILITY
1436void
Howard Hinnant300c67a2012-04-11 20:14:21 +00001437atomic_flag_clear_explicit(atomic_flag* __o, memory_order __m) _NOEXCEPT
Howard Hinnant770d1c42010-12-08 17:20:28 +00001438{
1439 __o->clear(__m);
1440}
1441
1442// fences
1443
1444inline _LIBCPP_INLINE_VISIBILITY
1445void
Howard Hinnant300c67a2012-04-11 20:14:21 +00001446atomic_thread_fence(memory_order __m) _NOEXCEPT
Howard Hinnant770d1c42010-12-08 17:20:28 +00001447{
Richard Smith6186c7f2012-04-11 18:55:46 +00001448 __c11_atomic_thread_fence(__m);
Howard Hinnant770d1c42010-12-08 17:20:28 +00001449}
1450
1451inline _LIBCPP_INLINE_VISIBILITY
1452void
Howard Hinnant300c67a2012-04-11 20:14:21 +00001453atomic_signal_fence(memory_order __m) _NOEXCEPT
Howard Hinnant770d1c42010-12-08 17:20:28 +00001454{
Richard Smith6186c7f2012-04-11 18:55:46 +00001455 __c11_atomic_signal_fence(__m);
Howard Hinnant770d1c42010-12-08 17:20:28 +00001456}
1457
Howard Hinnantd2f6afb2010-12-07 23:24:41 +00001458// Atomics for standard typedef types
1459
Howard Hinnant6ae47052013-01-04 18:58:50 +00001460typedef atomic<bool> atomic_bool;
Howard Hinnantd2f6afb2010-12-07 23:24:41 +00001461typedef atomic<char> atomic_char;
1462typedef atomic<signed char> atomic_schar;
1463typedef atomic<unsigned char> atomic_uchar;
1464typedef atomic<short> atomic_short;
1465typedef atomic<unsigned short> atomic_ushort;
1466typedef atomic<int> atomic_int;
1467typedef atomic<unsigned int> atomic_uint;
1468typedef atomic<long> atomic_long;
1469typedef atomic<unsigned long> atomic_ulong;
1470typedef atomic<long long> atomic_llong;
1471typedef atomic<unsigned long long> atomic_ullong;
1472typedef atomic<char16_t> atomic_char16_t;
1473typedef atomic<char32_t> atomic_char32_t;
1474typedef atomic<wchar_t> atomic_wchar_t;
1475
1476typedef atomic<int_least8_t> atomic_int_least8_t;
1477typedef atomic<uint_least8_t> atomic_uint_least8_t;
1478typedef atomic<int_least16_t> atomic_int_least16_t;
1479typedef atomic<uint_least16_t> atomic_uint_least16_t;
1480typedef atomic<int_least32_t> atomic_int_least32_t;
1481typedef atomic<uint_least32_t> atomic_uint_least32_t;
1482typedef atomic<int_least64_t> atomic_int_least64_t;
1483typedef atomic<uint_least64_t> atomic_uint_least64_t;
1484
1485typedef atomic<int_fast8_t> atomic_int_fast8_t;
1486typedef atomic<uint_fast8_t> atomic_uint_fast8_t;
1487typedef atomic<int_fast16_t> atomic_int_fast16_t;
1488typedef atomic<uint_fast16_t> atomic_uint_fast16_t;
1489typedef atomic<int_fast32_t> atomic_int_fast32_t;
1490typedef atomic<uint_fast32_t> atomic_uint_fast32_t;
1491typedef atomic<int_fast64_t> atomic_int_fast64_t;
1492typedef atomic<uint_fast64_t> atomic_uint_fast64_t;
1493
1494typedef atomic<intptr_t> atomic_intptr_t;
1495typedef atomic<uintptr_t> atomic_uintptr_t;
1496typedef atomic<size_t> atomic_size_t;
1497typedef atomic<ptrdiff_t> atomic_ptrdiff_t;
1498typedef atomic<intmax_t> atomic_intmax_t;
1499typedef atomic<uintmax_t> atomic_uintmax_t;
1500
Howard Hinnant767ae2b2010-09-29 21:20:03 +00001501#define ATOMIC_FLAG_INIT {false}
Howard Hinnant611fdaf2010-10-04 18:52:54 +00001502#define ATOMIC_VAR_INIT(__v) {__v}
1503
Howard Hinnant770d1c42010-12-08 17:20:28 +00001504// lock-free property
Howard Hinnant611fdaf2010-10-04 18:52:54 +00001505
Howard Hinnant7b9d6a82013-01-21 20:39:41 +00001506#define ATOMIC_BOOL_LOCK_FREE __GCC_ATOMIC_BOOL_LOCK_FREE
1507#define ATOMIC_CHAR_LOCK_FREE __GCC_ATOMIC_CHAR_LOCK_FREE
1508#define ATOMIC_CHAR16_T_LOCK_FREE __GCC_ATOMIC_CHAR16_T_LOCK_FREE
1509#define ATOMIC_CHAR32_T_LOCK_FREE __GCC_ATOMIC_CHAR32_T_LOCK_FREE
1510#define ATOMIC_WCHAR_T_LOCK_FREE __GCC_ATOMIC_WCHAR_T_LOCK_FREE
1511#define ATOMIC_SHORT_LOCK_FREE __GCC_ATOMIC_SHORT_LOCK_FREE
1512#define ATOMIC_INT_LOCK_FREE __GCC_ATOMIC_INT_LOCK_FREE
1513#define ATOMIC_LONG_LOCK_FREE __GCC_ATOMIC_LONG_LOCK_FREE
1514#define ATOMIC_LLONG_LOCK_FREE __GCC_ATOMIC_LLONG_LOCK_FREE
1515#define ATOMIC_POINTER_LOCK_FREE __GCC_ATOMIC_POINTER_LOCK_FREE
Howard Hinnant770d1c42010-12-08 17:20:28 +00001516
Howard Hinnant154002b2011-03-31 16:39:39 +00001517#endif // !__has_feature(cxx_atomic)
1518
Howard Hinnant8f73c632010-09-27 21:17:38 +00001519_LIBCPP_END_NAMESPACE_STD
1520
1521#endif // _LIBCPP_ATOMIC