From e738501eb32ba925b87b51e5571bfccf48a1f728 Mon Sep 17 00:00:00 2001 From: Howard Hinnant Date: Tue, 19 Oct 2010 16:51:18 +0000 Subject: [PATCH] atomic_char git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@116813 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/atomic | 685 ++++++++++++++++-- .../atomics.types.integral/bool.pass.cpp | 239 ++++++ .../atomics.types.integral/integral.pass.cpp | 214 ++++++ 3 files changed, 1083 insertions(+), 55 deletions(-) create mode 100644 test/atomics/atomics.types/atomics.types.integral/bool.pass.cpp create mode 100644 test/atomics/atomics.types/atomics.types.integral/integral.pass.cpp diff --git a/include/atomic b/include/atomic index d3423f6ce..1d6a4fb23 100644 --- a/include/atomic +++ b/include/atomic @@ -43,10 +43,6 @@ template T kill_dependency(T y); #define ATOMIC_LLONG_LOCK_FREE unspecified #define ATOMIC_ADDRESS_LOCK_FREE unspecified -// operations on atomic types - -#define ATOMIC_VAR_INIT(value) see below - // flag type and operations typedef struct atomic_flag @@ -71,6 +67,7 @@ void atomic_flag_clear_explicit(volatile atomic_flag*, memory_order); void atomic_flag_clear_explicit(atomic_flag*, memory_order); #define ATOMIC_FLAG_INIT see below +#define ATOMIC_VAR_INIT(value) see below // atomic_bool @@ -106,6 +103,7 @@ typedef struct atomic_bool atomic_bool& operator=(const atomic_bool&) = delete; atomic_bool& operator=(const atomic_bool&) volatile = delete; bool operator=(bool) volatile; + bool operator=(bool); } atomic_bool; bool atomic_is_lock_free(const volatile atomic_bool*); @@ -149,8 +147,7 @@ typedef struct atomic_char char load(memory_order = memory_order_seq_cst) const; operator char() const volatile; operator char() const; - char exchange(char, - memory_order = memory_order_seq_cst) volatile; + char exchange(char, memory_order = memory_order_seq_cst) volatile; char exchange(char, memory_order = memory_order_seq_cst); bool compare_exchange_weak(char&, char, memory_order, memory_order) volatile; @@ -205,8 +202,8 @@ typedef struct atomic_char bool atomic_is_lock_free(const volatile atomic_char*); bool atomic_is_lock_free(const atomic_char*); -void atomic_init(volatile atomic_char*, itype); -void atomic_init(atomic_char*, itype); +void atomic_init(volatile atomic_char*, char); +void atomic_init(atomic_char*, char); void atomic_store(volatile atomic_char*, char); void atomic_store(atomic_char*, char); void atomic_store_explicit(volatile atomic_char*, char, memory_order); @@ -265,7 +262,7 @@ typedef struct atomic_schar operator signed char() const volatile; operator signed char() const; signed char exchange(signed char, - memory_order = memory_order_seq_cst) volatile; + memory_order = memory_order_seq_cst) volatile; signed char exchange(signed char, memory_order = memory_order_seq_cst); bool compare_exchange_weak(signed char&, signed char, memory_order, memory_order) volatile; @@ -327,8 +324,8 @@ typedef struct atomic_schar bool atomic_is_lock_free(const volatile atomic_schar*); bool atomic_is_lock_free(const atomic_schar*); -void atomic_init(volatile atomic_schar*, itype); -void atomic_init(atomic_schar*, itype); +void atomic_init(volatile atomic_schar*, signed char); +void atomic_init(atomic_schar*, signed char); void atomic_store(volatile atomic_schar*, signed char); void atomic_store(atomic_schar*, signed char); void atomic_store_explicit(volatile atomic_schar*, signed char, memory_order); @@ -398,7 +395,7 @@ typedef struct atomic_uchar operator unsigned char() const volatile; operator unsigned char() const; unsigned char exchange(unsigned char, - memory_order = memory_order_seq_cst) volatile; + memory_order = memory_order_seq_cst) volatile; unsigned char exchange(unsigned char, memory_order = memory_order_seq_cst); bool compare_exchange_weak(unsigned char&, unsigned char, memory_order, memory_order) volatile; @@ -460,8 +457,8 @@ typedef struct atomic_uchar bool atomic_is_lock_free(const volatile atomic_uchar*); bool atomic_is_lock_free(const atomic_uchar*); -void atomic_init(volatile atomic_uchar*, itype); -void atomic_init(atomic_uchar*, itype); +void atomic_init(volatile atomic_uchar*, unsigned char); +void atomic_init(atomic_uchar*, unsigned char); void atomic_store(volatile atomic_uchar*, unsigned char); void atomic_store(atomic_uchar*, unsigned char); void atomic_store_explicit(volatile atomic_uchar*, unsigned char, memory_order); @@ -538,8 +535,7 @@ typedef struct atomic_short short load(memory_order = memory_order_seq_cst) const; operator short() const volatile; operator short() const; - short exchange(short, - memory_order = memory_order_seq_cst) volatile; + short exchange(short, memory_order = memory_order_seq_cst) volatile; short exchange(short, memory_order = memory_order_seq_cst); bool compare_exchange_weak(short&, short, memory_order, memory_order) volatile; @@ -594,8 +590,8 @@ typedef struct atomic_short bool atomic_is_lock_free(const volatile atomic_short*); bool atomic_is_lock_free(const atomic_short*); -void atomic_init(volatile atomic_short*, itype); -void atomic_init(atomic_short*, itype); +void atomic_init(volatile atomic_short*, short); +void atomic_init(atomic_short*, short); void atomic_store(volatile atomic_short*, short); void atomic_store(atomic_short*, short); void atomic_store_explicit(volatile atomic_short*, short, memory_order); @@ -654,7 +650,7 @@ typedef struct atomic_ushort operator unsigned short() const volatile; operator unsigned short() const; unsigned short exchange(unsigned short, - memory_order = memory_order_seq_cst) volatile; + memory_order = memory_order_seq_cst) volatile; unsigned short exchange(unsigned short, memory_order = memory_order_seq_cst); bool compare_exchange_weak(unsigned short&, unsigned short, memory_order, @@ -722,8 +718,8 @@ typedef struct atomic_ushort bool atomic_is_lock_free(const volatile atomic_ushort*); bool atomic_is_lock_free(const atomic_ushort*); -void atomic_init(volatile atomic_ushort*, itype); -void atomic_init(atomic_ushort*, itype); +void atomic_init(volatile atomic_ushort*, unsigned short); +void atomic_init(atomic_ushort*, unsigned short); void atomic_store(volatile atomic_ushort*, unsigned short); void atomic_store(atomic_ushort*, unsigned short); void atomic_store_explicit(volatile atomic_ushort*, unsigned short, @@ -803,8 +799,7 @@ typedef struct atomic_int int load(memory_order = memory_order_seq_cst) const; operator int() const volatile; operator int() const; - int exchange(int, - memory_order = memory_order_seq_cst) volatile; + int exchange(int, memory_order = memory_order_seq_cst) volatile; int exchange(int, memory_order = memory_order_seq_cst); bool compare_exchange_weak(int&, int, memory_order, memory_order) volatile; bool compare_exchange_weak(int&, int, memory_order, memory_order); @@ -857,8 +852,8 @@ typedef struct atomic_int bool atomic_is_lock_free(const volatile atomic_int*); bool atomic_is_lock_free(const atomic_int*); -void atomic_init(volatile atomic_int*, itype); -void atomic_init(atomic_int*, itype); +void atomic_init(volatile atomic_int*, int); +void atomic_init(atomic_int*, int); void atomic_store(volatile atomic_int*, int); void atomic_store(atomic_int*, int); void atomic_store_explicit(volatile atomic_int*, int, memory_order); @@ -917,7 +912,7 @@ typedef struct atomic_uint operator unsigned int() const volatile; operator unsigned int() const; unsigned int exchange(unsigned int, - memory_order = memory_order_seq_cst) volatile; + memory_order = memory_order_seq_cst) volatile; unsigned int exchange(unsigned int, memory_order = memory_order_seq_cst); bool compare_exchange_weak(unsigned int&, unsigned int, memory_order, memory_order) volatile; @@ -979,8 +974,8 @@ typedef struct atomic_uint bool atomic_is_lock_free(const volatile atomic_uint*); bool atomic_is_lock_free(const atomic_uint*); -void atomic_init(volatile atomic_uint*, itype); -void atomic_init(atomic_uint*, itype); +void atomic_init(volatile atomic_uint*, unsigned int); +void atomic_init(atomic_uint*, unsigned int); void atomic_store(volatile atomic_uint*, unsigned int); void atomic_store(atomic_uint*, unsigned int); void atomic_store_explicit(volatile atomic_uint*, unsigned int, memory_order); @@ -1054,8 +1049,7 @@ typedef struct atomic_long long load(memory_order = memory_order_seq_cst) const; operator long() const volatile; operator long() const; - long exchange(long, - memory_order = memory_order_seq_cst) volatile; + long exchange(long, memory_order = memory_order_seq_cst) volatile; long exchange(long, memory_order = memory_order_seq_cst); bool compare_exchange_weak(long&, long, memory_order, memory_order) volatile; @@ -1110,8 +1104,8 @@ typedef struct atomic_long bool atomic_is_lock_free(const volatile atomic_long*); bool atomic_is_lock_free(const atomic_long*); -void atomic_init(volatile atomic_long*, itype); -void atomic_init(atomic_long*, itype); +void atomic_init(volatile atomic_long*, long); +void atomic_init(atomic_long*, long); void atomic_store(volatile atomic_long*, long); void atomic_store(atomic_long*, long); void atomic_store_explicit(volatile atomic_long*, long, memory_order); @@ -1170,7 +1164,7 @@ typedef struct atomic_ulong operator unsigned long() const volatile; operator unsigned long() const; unsigned long exchange(unsigned long, - memory_order = memory_order_seq_cst) volatile; + memory_order = memory_order_seq_cst) volatile; unsigned long exchange(unsigned long, memory_order = memory_order_seq_cst); bool compare_exchange_weak(unsigned long&, unsigned long, memory_order, memory_order) volatile; @@ -1232,8 +1226,8 @@ typedef struct atomic_ulong bool atomic_is_lock_free(const volatile atomic_ulong*); bool atomic_is_lock_free(const atomic_ulong*); -void atomic_init(volatile atomic_ulong*, itype); -void atomic_init(atomic_ulong*, itype); +void atomic_init(volatile atomic_ulong*, unsigned long); +void atomic_init(atomic_ulong*, unsigned long); void atomic_store(volatile atomic_ulong*, unsigned long); void atomic_store(atomic_ulong*, unsigned long); void atomic_store_explicit(volatile atomic_ulong*, unsigned long, memory_order); @@ -1310,8 +1304,7 @@ typedef struct atomic_llong long long load(memory_order = memory_order_seq_cst) const; operator long long() const volatile; operator long long() const; - long long exchange(long long, - memory_order = memory_order_seq_cst) volatile; + long long exchange(long long, memory_order = memory_order_seq_cst) volatile; long long exchange(long long, memory_order = memory_order_seq_cst); bool compare_exchange_weak(long long&, long long, memory_order, memory_order) volatile; @@ -1372,8 +1365,8 @@ typedef struct atomic_llong bool atomic_is_lock_free(const volatile atomic_llong*); bool atomic_is_lock_free(const atomic_llong*); -void atomic_init(volatile atomic_llong*, itype); -void atomic_init(atomic_llong*, itype); +void atomic_init(volatile atomic_llong*, long long); +void atomic_init(atomic_llong*, long long); void atomic_store(volatile atomic_llong*, long long); void atomic_store(atomic_llong*, long long); void atomic_store_explicit(volatile atomic_llong*, long long, memory_order); @@ -1444,7 +1437,7 @@ typedef struct atomic_ullong operator unsigned long long() const volatile; operator unsigned long long() const; unsigned long long exchange(unsigned long long, - memory_order = memory_order_seq_cst) volatile; + memory_order = memory_order_seq_cst) volatile; unsigned long long exchange(unsigned long long, memory_order = memory_order_seq_cst); bool compare_exchange_weak(unsigned long long&, unsigned long long, @@ -1512,8 +1505,8 @@ typedef struct atomic_ullong bool atomic_is_lock_free(const volatile atomic_ullong*); bool atomic_is_lock_free(const atomic_ullong*); -void atomic_init(volatile atomic_ullong*, itype); -void atomic_init(atomic_ullong*, itype); +void atomic_init(volatile atomic_ullong*, unsigned long long); +void atomic_init(atomic_ullong*, unsigned long long); void atomic_store(volatile atomic_ullong*, unsigned long long); void atomic_store(atomic_ullong*, unsigned long long); void atomic_store_explicit(volatile atomic_ullong*, unsigned long long, @@ -1600,8 +1593,7 @@ typedef struct atomic_char16_t char16_t load(memory_order = memory_order_seq_cst) const; operator char16_t() const volatile; operator char16_t() const; - char16_t exchange(char16_t, - memory_order = memory_order_seq_cst) volatile; + char16_t exchange(char16_t, memory_order = memory_order_seq_cst) volatile; char16_t exchange(char16_t, memory_order = memory_order_seq_cst); bool compare_exchange_weak(char16_t&, char16_t, memory_order, memory_order) volatile; @@ -1657,8 +1649,8 @@ typedef struct atomic_char16_t bool atomic_is_lock_free(const volatile atomic_char16_t*); bool atomic_is_lock_free(const atomic_char16_t*); -void atomic_init(volatile atomic_char16_t*, itype); -void atomic_init(atomic_char16_t*, itype); +void atomic_init(volatile atomic_char16_t*, char16_t); +void atomic_init(atomic_char16_t*, char16_t); void atomic_store(volatile atomic_char16_t*, char16_t); void atomic_store(atomic_char16_t*, char16_t); void atomic_store_explicit(volatile atomic_char16_t*, char16_t, memory_order); @@ -1728,8 +1720,7 @@ typedef struct atomic_char32_t char32_t load(memory_order = memory_order_seq_cst) const; operator char32_t() const volatile; operator char32_t() const; - char32_t exchange(char32_t, - memory_order = memory_order_seq_cst) volatile; + char32_t exchange(char32_t, memory_order = memory_order_seq_cst) volatile; char32_t exchange(char32_t, memory_order = memory_order_seq_cst); bool compare_exchange_weak(char32_t&, char32_t, memory_order, memory_order) volatile; @@ -1785,8 +1776,8 @@ typedef struct atomic_char32_t bool atomic_is_lock_free(const volatile atomic_char32_t*); bool atomic_is_lock_free(const atomic_char32_t*); -void atomic_init(volatile atomic_char32_t*, itype); -void atomic_init(atomic_char32_t*, itype); +void atomic_init(volatile atomic_char32_t*, char32_t); +void atomic_init(atomic_char32_t*, char32_t); void atomic_store(volatile atomic_char32_t*, char32_t); void atomic_store(atomic_char32_t*, char32_t); void atomic_store_explicit(volatile atomic_char32_t*, char32_t, memory_order); @@ -1856,8 +1847,7 @@ typedef struct atomic_wchar_t wchar_t load(memory_order = memory_order_seq_cst) const; operator wchar_t() const volatile; operator wchar_t() const; - wchar_t exchange(wchar_t, - memory_order = memory_order_seq_cst) volatile; + wchar_t exchange(wchar_t, memory_order = memory_order_seq_cst) volatile; wchar_t exchange(wchar_t, memory_order = memory_order_seq_cst); bool compare_exchange_weak(wchar_t&, wchar_t, memory_order, memory_order) volatile; @@ -1912,8 +1902,8 @@ typedef struct atomic_wchar_t bool atomic_is_lock_free(const volatile atomic_wchar_t*); bool atomic_is_lock_free(const atomic_wchar_t*); -void atomic_init(volatile atomic_wchar_t*, itype); -void atomic_init(atomic_wchar_t*, itype); +void atomic_init(volatile atomic_wchar_t*, wchar_t); +void atomic_init(atomic_wchar_t*, wchar_t); void atomic_store(volatile atomic_wchar_t*, wchar_t); void atomic_store(atomic_wchar_t*, wchar_t); void atomic_store_explicit(volatile atomic_wchar_t*, wchar_t, memory_order); @@ -2690,12 +2680,16 @@ public: _LIBCPP_INLINE_VISIBILITY bool operator=(bool __v) volatile {store(__v); return __v;} + _LIBCPP_INLINE_VISIBILITY + bool operator=(bool __v) + {store(__v); return __v;} } atomic_bool; inline _LIBCPP_INLINE_VISIBILITY bool atomic_is_lock_free(const volatile atomic_bool*) { - return __atomic_is_lock_free(bool); + typedef bool type; + return __atomic_is_lock_free(type); } inline _LIBCPP_INLINE_VISIBILITY @@ -2860,6 +2854,587 @@ bool atomic_compare_exchange_strong_explicit(atomic_bool* __obj, bool* __exp, const_cast(__obj), __exp, __desr, __s, __f); } +// atomic_char + +struct atomic_char; + +bool atomic_is_lock_free(const volatile atomic_char*); +bool atomic_is_lock_free(const atomic_char*); +void atomic_init(volatile atomic_char*, char); +void atomic_init(atomic_char*, char); +void atomic_store(volatile atomic_char*, char); +void atomic_store(atomic_char*, char); +void atomic_store_explicit(volatile atomic_char*, char, memory_order); +void atomic_store_explicit(atomic_char*, char, memory_order); +char atomic_load(const volatile atomic_char*); +char atomic_load(const atomic_char*); +char atomic_load_explicit(const volatile atomic_char*, memory_order); +char atomic_load_explicit(const atomic_char*, memory_order); +char atomic_exchange(volatile atomic_char*, char); +char atomic_exchange(atomic_char*, char); +char atomic_exchange_explicit(volatile atomic_char*, char, memory_order); +char atomic_exchange_explicit(atomic_char*, char, memory_order); +bool atomic_compare_exchange_weak(volatile atomic_char*, char*, char); +bool atomic_compare_exchange_weak(atomic_char*, char*, char); +bool atomic_compare_exchange_strong(volatile atomic_char*, char*, char); +bool atomic_compare_exchange_strong(atomic_char*, char*, char); +bool atomic_compare_exchange_weak_explicit(volatile atomic_char*, char*, char, + memory_order, memory_order); +bool atomic_compare_exchange_weak_explicit(atomic_char*, char*, char, + memory_order, memory_order); +bool atomic_compare_exchange_strong_explicit(volatile atomic_char*, char*, char, + memory_order, memory_order); +bool atomic_compare_exchange_strong_explicit(atomic_char*, char*, char, + memory_order, memory_order); +char atomic_fetch_add(volatile atomic_char*, char); +char atomic_fetch_add(atomic_char*, char); +char atomic_fetch_add_explicit(volatile atomic_char*, char, memory_order); +char atomic_fetch_add_explicit(atomic_char*, char, memory_order); +char atomic_fetch_sub(volatile atomic_char*, char); +char atomic_fetch_sub(atomic_char*, char); +char atomic_fetch_sub_explicit(volatile atomic_char*, char, memory_order); +char atomic_fetch_sub_explicit(atomic_char*, char, memory_order); +char atomic_fetch_and(volatile atomic_char*, char); +char atomic_fetch_and(atomic_char*, char); +char atomic_fetch_and_explicit(volatile atomic_char*, char, memory_order); +char atomic_fetch_and_explicit(atomic_char*, char, memory_order); +char atomic_fetch_or(volatile atomic_char*, char); +char atomic_fetch_or(atomic_char*, char); +char atomic_fetch_or_explicit(volatile atomic_char*, char, memory_order); +char atomic_fetch_or_explicit(atomic_char*, char, memory_order); +char atomic_fetch_xor(volatile atomic_char*, char); +char atomic_fetch_xor(atomic_char*, char); +char atomic_fetch_xor_explicit(volatile atomic_char*, char, memory_order); +char atomic_fetch_xor_explicit(atomic_char*, char, memory_order); + +typedef struct atomic_char +{ + char __v_; + + _LIBCPP_INLINE_VISIBILITY + bool is_lock_free() const volatile + {return atomic_is_lock_free(this);} + _LIBCPP_INLINE_VISIBILITY + bool is_lock_free() const + {return atomic_is_lock_free(this);} + _LIBCPP_INLINE_VISIBILITY + void store(char __v, memory_order __o = memory_order_seq_cst) volatile + {atomic_store_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + void store(char __v, memory_order __o = memory_order_seq_cst) + {atomic_store_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + char load(memory_order __o = memory_order_seq_cst) const volatile + {return atomic_load_explicit(this, __o);} + _LIBCPP_INLINE_VISIBILITY + char load(memory_order __o = memory_order_seq_cst) const + {return atomic_load_explicit(this, __o);} + _LIBCPP_INLINE_VISIBILITY + operator char() const volatile + {return load();} + _LIBCPP_INLINE_VISIBILITY + operator char() const + {return load();} + _LIBCPP_INLINE_VISIBILITY + char exchange(char __v, memory_order __o = memory_order_seq_cst) volatile + {return atomic_exchange_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + char exchange(char __v, memory_order __o = memory_order_seq_cst) + {return atomic_exchange_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + bool compare_exchange_weak(char& __v, char __e, memory_order __s, + memory_order __f) volatile + {return atomic_compare_exchange_weak_explicit(this, &__v, __e, __s, + __f);} + _LIBCPP_INLINE_VISIBILITY + bool compare_exchange_weak(char& __v, char __e, memory_order __s, + memory_order __f) + {return atomic_compare_exchange_weak_explicit(this, &__v, __e, __s, + __f);} + _LIBCPP_INLINE_VISIBILITY + bool compare_exchange_strong(char& __v, char __e, memory_order __s, + memory_order __f) volatile + {return atomic_compare_exchange_strong_explicit(this, &__v, __e, __s, + __f);} + _LIBCPP_INLINE_VISIBILITY + bool compare_exchange_strong(char& __v, char __e, memory_order __s, + memory_order __f) + {return atomic_compare_exchange_strong_explicit(this, &__v, __e, __s, + __f);} + _LIBCPP_INLINE_VISIBILITY + bool compare_exchange_weak(char& __v, char __e, + memory_order __s = memory_order_seq_cst) volatile + {return atomic_compare_exchange_weak_explicit(this, &__v, __e, __s, + __translate_memory_order(__s));} + _LIBCPP_INLINE_VISIBILITY + bool compare_exchange_weak(char& __v, char __e, + memory_order __s = memory_order_seq_cst) + {return atomic_compare_exchange_weak_explicit(this, &__v, __e, __s, + __translate_memory_order(__s));} + _LIBCPP_INLINE_VISIBILITY + bool compare_exchange_strong(char& __v, char __e, + memory_order __s = memory_order_seq_cst) volatile + {return atomic_compare_exchange_strong_explicit(this, &__v, __e, __s, + __translate_memory_order(__s));} + _LIBCPP_INLINE_VISIBILITY + bool compare_exchange_strong(char& __v, char __e, + memory_order __s = memory_order_seq_cst) + {return atomic_compare_exchange_strong_explicit(this, &__v, __e, __s, + __translate_memory_order(__s));} + _LIBCPP_INLINE_VISIBILITY + char fetch_add(char __v, memory_order __o = memory_order_seq_cst) volatile + {return atomic_fetch_add_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + char fetch_add(char __v, memory_order __o = memory_order_seq_cst) + {return atomic_fetch_add_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + char fetch_sub(char __v, memory_order __o = memory_order_seq_cst) volatile + {return atomic_fetch_sub_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + char fetch_sub(char __v, memory_order __o = memory_order_seq_cst) + {return atomic_fetch_sub_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + char fetch_and(char __v, memory_order __o = memory_order_seq_cst) volatile + {return atomic_fetch_and_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + char fetch_and(char __v, memory_order __o = memory_order_seq_cst) + {return atomic_fetch_and_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + char fetch_or(char __v, memory_order __o = memory_order_seq_cst) volatile + {return atomic_fetch_or_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + char fetch_or(char __v, memory_order __o = memory_order_seq_cst) + {return atomic_fetch_or_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + char fetch_xor(char __v, memory_order __o = memory_order_seq_cst) volatile + {return atomic_fetch_xor_explicit(this, __v, __o);} + _LIBCPP_INLINE_VISIBILITY + char fetch_xor(char __v, memory_order __o = memory_order_seq_cst) + {return atomic_fetch_xor_explicit(this, __v, __o);} +#ifndef _LIBCPP_HAS_NO_DEFAULTED_FUNCTIONS + atomic_char() = default; +#else + _LIBCPP_INLINE_VISIBILITY + atomic_char() {} +#endif + _LIBCPP_INLINE_VISIBILITY + /*constexpr*/ atomic_char(char __v) + : __v_(__v) {} +#ifndef _LIBCPP_HAS_NO_DELETED_FUNCTIONS + atomic_char(const atomic_char&) = delete; + atomic_char& operator=(const atomic_char&) = delete; + atomic_char& operator=(const atomic_char&) volatile = delete; +#else +private: + atomic_char(const atomic_char&); + atomic_char& operator=(const atomic_char&); + atomic_char& operator=(const atomic_char&) volatile; +public: +#endif + _LIBCPP_INLINE_VISIBILITY + char operator=(char __v) volatile + {store(__v); return __v;} + _LIBCPP_INLINE_VISIBILITY + char operator=(char __v) + {store(__v); return __v;} + _LIBCPP_INLINE_VISIBILITY + char operator++(int) volatile + {return fetch_add(char(1));} + _LIBCPP_INLINE_VISIBILITY + char operator++(int) + {return fetch_add(char(1));} + _LIBCPP_INLINE_VISIBILITY + char operator--(int) volatile + {return fetch_sub(char(1));} + _LIBCPP_INLINE_VISIBILITY + char operator--(int) + {return fetch_sub(char(1));} + _LIBCPP_INLINE_VISIBILITY + char operator++() volatile + {return char(fetch_add(char(1)) + 1);} + _LIBCPP_INLINE_VISIBILITY + char operator++() + {return char(fetch_add(char(1)) + 1);} + _LIBCPP_INLINE_VISIBILITY + char operator--() volatile + {return char(fetch_sub(char(1)) - 1);} + _LIBCPP_INLINE_VISIBILITY + char operator--() + {return char(fetch_sub(char(1)) - 1);} + _LIBCPP_INLINE_VISIBILITY + char operator+=(char __v) volatile + {return char(fetch_add(__v) + __v);} + _LIBCPP_INLINE_VISIBILITY + char operator+=(char __v) + {return char(fetch_add(__v) + __v);} + _LIBCPP_INLINE_VISIBILITY + char operator-=(char __v) volatile + {return char(fetch_sub(__v) - __v);} + _LIBCPP_INLINE_VISIBILITY + char operator-=(char __v) + {return char(fetch_sub(__v) - __v);} + _LIBCPP_INLINE_VISIBILITY + char operator&=(char __v) volatile + {return char(fetch_and(__v) & __v);} + _LIBCPP_INLINE_VISIBILITY + char operator&=(char __v) + {return char(fetch_and(__v) & __v);} + _LIBCPP_INLINE_VISIBILITY + char operator|=(char __v) volatile + {return char(fetch_or(__v) | __v);} + _LIBCPP_INLINE_VISIBILITY + char operator|=(char __v) + {return char(fetch_or(__v) | __v);} + _LIBCPP_INLINE_VISIBILITY + char operator^=(char __v) volatile + {return char(fetch_xor(__v) ^ __v);} + _LIBCPP_INLINE_VISIBILITY + char operator^=(char __v) + {return char(fetch_xor(__v) ^ __v);} +} atomic_char; + +inline _LIBCPP_INLINE_VISIBILITY +bool +atomic_is_lock_free(const volatile atomic_char*) +{ + typedef char type; + return __atomic_is_lock_free(type); +} + +inline _LIBCPP_INLINE_VISIBILITY +bool +atomic_is_lock_free(const atomic_char* __obj) +{ + return atomic_is_lock_free(const_cast(__obj)); +} + +inline _LIBCPP_INLINE_VISIBILITY +void +atomic_init(volatile atomic_char* __obj, char __desr) +{ + __obj->__v_ = __desr; +} + +inline _LIBCPP_INLINE_VISIBILITY +void +atomic_init(atomic_char* __obj, char __desr) +{ + __obj->__v_ = __desr; +} + +inline _LIBCPP_INLINE_VISIBILITY +void +atomic_store(volatile atomic_char* __obj, char __desr) +{ + __atomic_store(&__obj->__v_, __desr, memory_order_seq_cst); +} + +inline _LIBCPP_INLINE_VISIBILITY +void +atomic_store(atomic_char* __obj, char __desr) +{ + atomic_store(const_cast(__obj), __desr); +} + +inline _LIBCPP_INLINE_VISIBILITY +void +atomic_store_explicit(volatile atomic_char* __obj, char __desr, + memory_order __o) +{ + __atomic_store(&__obj->__v_, __desr, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +void +atomic_store_explicit(atomic_char* __obj, char __desr, memory_order __o) +{ + atomic_store_explicit(const_cast(__obj), __desr, + __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_load(const volatile atomic_char* __obj) +{ + return __atomic_load(&__obj->__v_, memory_order_seq_cst); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_load(const atomic_char* __obj) +{ + return atomic_load(const_cast(__obj)); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_load_explicit(const volatile atomic_char* __obj, memory_order __o) +{ + return __atomic_load(&__obj->__v_, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_load_explicit(const atomic_char* __obj, memory_order __o) +{ + return atomic_load_explicit(const_cast + (__obj), __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_exchange(volatile atomic_char* __obj, char __desr) +{ + return __atomic_exchange(&__obj->__v_, __desr, memory_order_seq_cst); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_exchange(atomic_char* __obj, char __desr) +{ + return atomic_exchange(const_cast(__obj), __desr); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_exchange_explicit(volatile atomic_char* __obj, char __desr, + memory_order __o) +{ + return __atomic_exchange(&__obj->__v_, __desr, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_exchange_explicit(atomic_char* __obj, char __desr, memory_order __o) +{ + return atomic_exchange_explicit(const_cast + (__obj), __desr, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +bool +atomic_compare_exchange_weak(volatile atomic_char* __obj, char* __exp, + char __desr) +{ + return __atomic_compare_exchange_weak(&__obj->__v_, __exp, __desr, + memory_order_seq_cst, memory_order_seq_cst); +} + +inline _LIBCPP_INLINE_VISIBILITY +bool +atomic_compare_exchange_weak(atomic_char* __obj, char* __exp, char __desr) +{ + return atomic_compare_exchange_weak(const_cast + (__obj), __exp, __desr); +} + +inline _LIBCPP_INLINE_VISIBILITY +bool +atomic_compare_exchange_strong(volatile atomic_char* __obj, char* __exp, + char __desr) +{ + return __atomic_compare_exchange_strong(&__obj->__v_, __exp, __desr, + memory_order_seq_cst, memory_order_seq_cst); +} + +inline _LIBCPP_INLINE_VISIBILITY +bool +atomic_compare_exchange_strong(atomic_char* __obj, char* __exp, char __desr) +{ + return atomic_compare_exchange_strong(const_cast + (__obj), __exp, __desr); +} + +inline _LIBCPP_INLINE_VISIBILITY +bool +atomic_compare_exchange_weak_explicit(volatile atomic_char* __obj, char* __exp, + char __desr, memory_order __s, + memory_order __f) +{ + return __atomic_compare_exchange_weak(&__obj->__v_, __exp, __desr, __s, + __f); +} + +inline _LIBCPP_INLINE_VISIBILITY +bool +atomic_compare_exchange_weak_explicit(atomic_char* __obj, char* __exp, + char __desr, memory_order __s, + memory_order __f) +{ + return atomic_compare_exchange_weak_explicit( + const_cast(__obj), __exp, __desr, __s, __f); +} + +inline _LIBCPP_INLINE_VISIBILITY +bool +atomic_compare_exchange_strong_explicit(volatile atomic_char* __obj, + char* __exp, char __desr, + memory_order __s, memory_order __f) +{ + return __atomic_compare_exchange_strong(&__obj->__v_, __exp, __desr, __s, + __f); +} + +inline _LIBCPP_INLINE_VISIBILITY +bool +atomic_compare_exchange_strong_explicit(atomic_char* __obj, char* __exp, + char __desr, memory_order __s, + memory_order __f) +{ + return atomic_compare_exchange_strong_explicit( + const_cast(__obj), __exp, __desr, __s, __f); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_add(volatile atomic_char* __obj, char __v) +{ + return __atomic_fetch_add(&__obj->__v_, __v, memory_order_seq_cst); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_add(atomic_char* __obj, char __v) +{ + return atomic_fetch_add(const_cast(__obj), __v); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_add_explicit(volatile atomic_char* __obj, char __v, + memory_order __o) +{ + return __atomic_fetch_add(&__obj->__v_, __v, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_add_explicit(atomic_char* __obj, char __v, memory_order __o) +{ + return atomic_fetch_add_explicit(const_cast(__obj), + __v, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_sub(volatile atomic_char* __obj, char __v) +{ + return __atomic_fetch_sub(&__obj->__v_, __v, memory_order_seq_cst); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_sub(atomic_char* __obj, char __v) +{ + return atomic_fetch_sub(const_cast(__obj), __v); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_sub_explicit(volatile atomic_char* __obj, char __v, + memory_order __o) +{ + return __atomic_fetch_sub(&__obj->__v_, __v, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_sub_explicit(atomic_char* __obj, char __v, memory_order __o) +{ + return atomic_fetch_sub_explicit(const_cast(__obj), + __v, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_and(volatile atomic_char* __obj, char __v) +{ + return __atomic_fetch_and(&__obj->__v_, __v, memory_order_seq_cst); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_and(atomic_char* __obj, char __v) +{ + return atomic_fetch_and(const_cast(__obj), __v); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_and_explicit(volatile atomic_char* __obj, char __v, + memory_order __o) +{ + return __atomic_fetch_and(&__obj->__v_, __v, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_and_explicit(atomic_char* __obj, char __v, memory_order __o) +{ + return atomic_fetch_and_explicit(const_cast(__obj), + __v, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_or(volatile atomic_char* __obj, char __v) +{ + return __atomic_fetch_or(&__obj->__v_, __v, memory_order_seq_cst); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_or(atomic_char* __obj, char __v) +{ + return atomic_fetch_or(const_cast(__obj), __v); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_or_explicit(volatile atomic_char* __obj, char __v, + memory_order __o) +{ + return __atomic_fetch_or(&__obj->__v_, __v, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_or_explicit(atomic_char* __obj, char __v, memory_order __o) +{ + return atomic_fetch_or_explicit(const_cast(__obj), + __v, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_xor(volatile atomic_char* __obj, char __v) +{ + return __atomic_fetch_xor(&__obj->__v_, __v, memory_order_seq_cst); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_xor(atomic_char* __obj, char __v) +{ + return atomic_fetch_xor(const_cast(__obj), __v); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_xor_explicit(volatile atomic_char* __obj, char __v, + memory_order __o) +{ + return __atomic_fetch_xor(&__obj->__v_, __v, __o); +} + +inline _LIBCPP_INLINE_VISIBILITY +char +atomic_fetch_xor_explicit(atomic_char* __obj, char __v, memory_order __o) +{ + return atomic_fetch_xor_explicit(const_cast(__obj), + __v, __o); +} + _LIBCPP_END_NAMESPACE_STD #endif // _LIBCPP_ATOMIC diff --git a/test/atomics/atomics.types/atomics.types.integral/bool.pass.cpp b/test/atomics/atomics.types/atomics.types.integral/bool.pass.cpp new file mode 100644 index 000000000..8c8b731ff --- /dev/null +++ b/test/atomics/atomics.types/atomics.types.integral/bool.pass.cpp @@ -0,0 +1,239 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +// + +// typedef struct atomic_bool +// { +// bool is_lock_free() const volatile; +// bool is_lock_free() const; +// void store(bool, memory_order = memory_order_seq_cst) volatile; +// void store(bool, memory_order = memory_order_seq_cst); +// bool load(memory_order = memory_order_seq_cst) const volatile; +// bool load(memory_order = memory_order_seq_cst) const; +// operator bool() const volatile; +// operator bool() const; +// bool exchange(bool, memory_order = memory_order_seq_cst) volatile; +// bool exchange(bool, memory_order = memory_order_seq_cst); +// bool compare_exchange_weak(bool&, bool, memory_order, +// memory_order) volatile; +// bool compare_exchange_weak(bool&, bool, memory_order, memory_order); +// bool compare_exchange_strong(bool&, bool, memory_order, +// memory_order) volatile; +// bool compare_exchange_strong(bool&, bool, memory_order, memory_order); +// bool compare_exchange_weak(bool&, bool, +// memory_order = memory_order_seq_cst) volatile; +// bool compare_exchange_weak(bool&, bool, +// memory_order = memory_order_seq_cst); +// bool compare_exchange_strong(bool&, bool, +// memory_order = memory_order_seq_cst) volatile; +// bool compare_exchange_strong(bool&, bool, +// memory_order = memory_order_seq_cst); +// atomic_bool() = default; +// constexpr atomic_bool(bool); +// atomic_bool(const atomic_bool&) = delete; +// atomic_bool& operator=(const atomic_bool&) = delete; +// atomic_bool& operator=(const atomic_bool&) volatile = delete; +// bool operator=(bool) volatile; +// bool operator=(bool); +// } atomic_bool; +// +// bool atomic_is_lock_free(const volatile atomic_bool*); +// bool atomic_is_lock_free(const atomic_bool*); +// void atomic_init(volatile atomic_bool*, bool); +// void atomic_init(atomic_bool*, bool); +// void atomic_store(volatile atomic_bool*, bool); +// void atomic_store(atomic_bool*, bool); +// void atomic_store_explicit(volatile atomic_bool*, bool, memory_order); +// void atomic_store_explicit(atomic_bool*, bool, memory_order); +// bool atomic_load(const volatile atomic_bool*); +// bool atomic_load(const atomic_bool*); +// bool atomic_load_explicit(const volatile atomic_bool*, memory_order); +// bool atomic_load_explicit(const atomic_bool*, memory_order); +// bool atomic_exchange(volatile atomic_bool*, bool); +// bool atomic_exchange(atomic_bool*, bool); +// bool atomic_exchange_explicit(volatile atomic_bool*, bool, memory_order); +// bool atomic_exchange_explicit(atomic_bool*, bool, memory_order); +// bool atomic_compare_exchange_weak(volatile atomic_bool*, bool*, bool); +// bool atomic_compare_exchange_weak(atomic_bool*, bool*, bool); +// bool atomic_compare_exchange_strong(volatile atomic_bool*, bool*, bool); +// bool atomic_compare_exchange_strong(atomic_bool*, bool*, bool); +// bool atomic_compare_exchange_weak_explicit(volatile atomic_bool*, bool*, bool, +// memory_order, memory_order); +// bool atomic_compare_exchange_weak_explicit(atomic_bool*, bool*, bool, +// memory_order, memory_order); +// bool atomic_compare_exchange_strong_explicit(volatile atomic_bool*, bool*, bool, +// memory_order, memory_order); +// bool atomic_compare_exchange_strong_explicit(atomic_bool*, bool*, bool, +// memory_order, memory_order); + +#include +#include + +int main() +{ + { + volatile std::atomic_bool obj(true); + assert(obj == true); + std::atomic_init(&obj, false); + assert(obj == false); + std::atomic_init(&obj, true); + assert(obj == true); + bool b0 = obj.is_lock_free(); + obj.store(false); + assert(obj == false); + obj.store(true, std::memory_order_release); + assert(obj == true); + assert(obj.load() == true); + assert(obj.load(std::memory_order_acquire) == true); + assert(obj.exchange(false) == true); + assert(obj == false); + assert(obj.exchange(true, std::memory_order_relaxed) == false); + assert(obj == true); + bool x = obj; + assert(obj.compare_exchange_weak(x, false) == true); + assert(obj == false); + assert(x == true); + assert(obj.compare_exchange_weak(x, true) == false); + assert(obj == false); + assert(x == false); + assert(obj.compare_exchange_strong(x, true) == true); + assert(obj == true); + assert(x == false); + assert(obj.compare_exchange_strong(x, false) == false); + assert(obj == true); + assert(x == true); + assert((obj = false) == false); + assert(obj == false); + + std::atomic_init(&obj, true); + assert(obj == true); + bool b1 = std::atomic_is_lock_free(&obj); + std::atomic_store(&obj, false); + assert(obj == false); + std::atomic_store_explicit(&obj, true, std::memory_order_release); + assert(obj == true); + assert(std::atomic_load(&obj) == true); + assert(std::atomic_load_explicit(&obj, std::memory_order_acquire) == true); + assert(std::atomic_exchange(&obj, false) == true); + assert(obj == false); + assert(std::atomic_exchange_explicit(&obj, true, std::memory_order_relaxed) == false); + assert(obj == true); + x = obj; + assert(std::atomic_compare_exchange_weak(&obj, &x, false) == true); + assert(obj == false); + assert(x == true); + assert(std::atomic_compare_exchange_weak(&obj, &x, true) == false); + assert(obj == false); + assert(x == false); + assert(std::atomic_compare_exchange_strong(&obj, &x, true) == true); + assert(obj == true); + assert(x == false); + assert(std::atomic_compare_exchange_strong(&obj, &x, false) == false); + assert(obj == true); + assert(x == true); + assert(std::atomic_compare_exchange_weak_explicit(&obj, &x, false, + std::memory_order_relaxed, std::memory_order_relaxed) == true); + assert(obj == false); + assert(x == true); + assert(std::atomic_compare_exchange_weak_explicit(&obj, &x, true, + std::memory_order_relaxed, std::memory_order_relaxed) == false); + assert(obj == false); + assert(x == false); + assert(std::atomic_compare_exchange_strong_explicit(&obj, &x, true, + std::memory_order_relaxed, std::memory_order_relaxed) == true); + assert(obj == true); + assert(x == false); + assert(std::atomic_compare_exchange_strong_explicit(&obj, &x, false, + std::memory_order_relaxed, std::memory_order_relaxed) == false); + assert(obj == true); + assert(x == true); + assert((obj = false) == false); + assert(obj == false); + } + { + std::atomic_bool obj(true); + assert(obj == true); + std::atomic_init(&obj, false); + assert(obj == false); + std::atomic_init(&obj, true); + assert(obj == true); + bool b0 = obj.is_lock_free(); + obj.store(false); + assert(obj == false); + obj.store(true, std::memory_order_release); + assert(obj == true); + assert(obj.load() == true); + assert(obj.load(std::memory_order_acquire) == true); + assert(obj.exchange(false) == true); + assert(obj == false); + assert(obj.exchange(true, std::memory_order_relaxed) == false); + assert(obj == true); + bool x = obj; + assert(obj.compare_exchange_weak(x, false) == true); + assert(obj == false); + assert(x == true); + assert(obj.compare_exchange_weak(x, true) == false); + assert(obj == false); + assert(x == false); + assert(obj.compare_exchange_strong(x, true) == true); + assert(obj == true); + assert(x == false); + assert(obj.compare_exchange_strong(x, false) == false); + assert(obj == true); + assert(x == true); + assert((obj = false) == false); + assert(obj == false); + + std::atomic_init(&obj, true); + assert(obj == true); + bool b1 = std::atomic_is_lock_free(&obj); + std::atomic_store(&obj, false); + assert(obj == false); + std::atomic_store_explicit(&obj, true, std::memory_order_release); + assert(obj == true); + assert(std::atomic_load(&obj) == true); + assert(std::atomic_load_explicit(&obj, std::memory_order_acquire) == true); + assert(std::atomic_exchange(&obj, false) == true); + assert(obj == false); + assert(std::atomic_exchange_explicit(&obj, true, std::memory_order_relaxed) == false); + assert(obj == true); + x = obj; + assert(std::atomic_compare_exchange_weak(&obj, &x, false) == true); + assert(obj == false); + assert(x == true); + assert(std::atomic_compare_exchange_weak(&obj, &x, true) == false); + assert(obj == false); + assert(x == false); + assert(std::atomic_compare_exchange_strong(&obj, &x, true) == true); + assert(obj == true); + assert(x == false); + assert(std::atomic_compare_exchange_strong(&obj, &x, false) == false); + assert(obj == true); + assert(x == true); + assert(std::atomic_compare_exchange_weak_explicit(&obj, &x, false, + std::memory_order_relaxed, std::memory_order_relaxed) == true); + assert(obj == false); + assert(x == true); + assert(std::atomic_compare_exchange_weak_explicit(&obj, &x, true, + std::memory_order_relaxed, std::memory_order_relaxed) == false); + assert(obj == false); + assert(x == false); + assert(std::atomic_compare_exchange_strong_explicit(&obj, &x, true, + std::memory_order_relaxed, std::memory_order_relaxed) == true); + assert(obj == true); + assert(x == false); + assert(std::atomic_compare_exchange_strong_explicit(&obj, &x, false, + std::memory_order_relaxed, std::memory_order_relaxed) == false); + assert(obj == true); + assert(x == true); + assert((obj = false) == false); + assert(obj == false); + } +} diff --git a/test/atomics/atomics.types/atomics.types.integral/integral.pass.cpp b/test/atomics/atomics.types/atomics.types.integral/integral.pass.cpp new file mode 100644 index 000000000..a48ba8b05 --- /dev/null +++ b/test/atomics/atomics.types/atomics.types.integral/integral.pass.cpp @@ -0,0 +1,214 @@ +//===----------------------------------------------------------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +// + +// typedef struct atomic_itype +// { +// bool is_lock_free() const volatile; +// bool is_lock_free() const; +// void store(itype, memory_order = memory_order_seq_cst) volatile; +// void store(itype, memory_order = memory_order_seq_cst); +// itype load(memory_order = memory_order_seq_cst) const volatile; +// itype load(memory_order = memory_order_seq_cst) const; +// operator itype() const volatile; +// operator itype() const; +// itype exchange(itype, memory_order = memory_order_seq_cst) volatile; +// itype exchange(itype, memory_order = memory_order_seq_cst); +// bool compare_exchange_weak(itype&, itype, memory_order, +// memory_order) volatile; +// bool compare_exchange_weak(itype&, itype, memory_order, memory_order); +// bool compare_exchange_strong(itype&, itype, memory_order, +// memory_order) volatile; +// bool compare_exchange_strong(itype&, itype, memory_order, memory_order); +// bool compare_exchange_weak(itype&, itype, +// memory_order = memory_order_seq_cst) volatile; +// bool compare_exchange_weak(itype&, itype, +// memory_order = memory_order_seq_cst); +// bool compare_exchange_strong(itype&, itype, +// memory_order = memory_order_seq_cst) volatile; +// bool compare_exchange_strong(itype&, itype, +// memory_order = memory_order_seq_cst); +// itype fetch_add(itype, memory_order = memory_order_seq_cst) volatile; +// itype fetch_add(itype, memory_order = memory_order_seq_cst); +// itype fetch_sub(itype, memory_order = memory_order_seq_cst) volatile; +// itype fetch_sub(itype, memory_order = memory_order_seq_cst); +// itype fetch_and(itype, memory_order = memory_order_seq_cst) volatile; +// itype fetch_and(itype, memory_order = memory_order_seq_cst); +// itype fetch_or(itype, memory_order = memory_order_seq_cst) volatile; +// itype fetch_or(itype, memory_order = memory_order_seq_cst); +// itype fetch_xor(itype, memory_order = memory_order_seq_cst) volatile; +// itype fetch_xor(itype, memory_order = memory_order_seq_cst); +// atomic_itype() = default; +// constexpr atomic_itype(itype); +// atomic_itype(const atomic_itype&) = delete; +// atomic_itype& operator=(const atomic_itype&) = delete; +// atomic_itype& operator=(const atomic_itype&) volatile = delete; +// itype operator=(itype) volatile; +// itype operator=(itype); +// itype operator++(int) volatile; +// itype operator++(int); +// itype operator--(int) volatile; +// itype operator--(int); +// itype operator++() volatile; +// itype operator++(); +// itype operator--() volatile; +// itype operator--(); +// itype operator+=(itype) volatile; +// itype operator+=(itype); +// itype operator-=(itype) volatile; +// itype operator-=(itype); +// itype operator&=(itype) volatile; +// itype operator&=(itype); +// itype operator|=(itype) volatile; +// itype operator|=(itype); +// itype operator^=(itype) volatile; +// itype operator^=(itype); +// } atomic_itype; +// +// bool atomic_is_lock_free(const volatile atomic_itype*); +// bool atomic_is_lock_free(const atomic_itype*); +// void atomic_init(volatile atomic_itype*, itype); +// void atomic_init(atomic_itype*, itype); +// void atomic_store(volatile atomic_itype*, itype); +// void atomic_store(atomic_itype*, itype); +// void atomic_store_explicit(volatile atomic_itype*, itype, memory_order); +// void atomic_store_explicit(atomic_itype*, itype, memory_order); +// itype atomic_load(const volatile atomic_itype*); +// itype atomic_load(const atomic_itype*); +// itype atomic_load_explicit(const volatile atomic_itype*, memory_order); +// itype atomic_load_explicit(const atomic_itype*, memory_order); +// itype atomic_exchange(volatile atomic_itype*, itype); +// itype atomic_exchange(atomic_itype*, itype); +// itype atomic_exchange_explicit(volatile atomic_itype*, itype, memory_order); +// itype atomic_exchange_explicit(atomic_itype*, itype, memory_order); +// bool atomic_compare_exchange_weak(volatile atomic_itype*, itype*, itype); +// bool atomic_compare_exchange_weak(atomic_itype*, itype*, itype); +// bool atomic_compare_exchange_strong(volatile atomic_itype*, itype*, itype); +// bool atomic_compare_exchange_strong(atomic_itype*, itype*, itype); +// bool atomic_compare_exchange_weak_explicit(volatile atomic_itype*, itype*, itype, +// memory_order, memory_order); +// bool atomic_compare_exchange_weak_explicit(atomic_itype*, itype*, itype, +// memory_order, memory_order); +// bool atomic_compare_exchange_strong_explicit(volatile atomic_itype*, itype*, itype, +// memory_order, memory_order); +// bool atomic_compare_exchange_strong_explicit(atomic_itype*, itype*, itype, +// memory_order, memory_order); +// itype atomic_fetch_add(volatile atomic_itype*, itype); +// itype atomic_fetch_add(atomic_itype*, itype); +// itype atomic_fetch_add_explicit(volatile atomic_itype*, itype, memory_order); +// itype atomic_fetch_add_explicit(atomic_itype*, itype, memory_order); +// itype atomic_fetch_sub(volatile atomic_itype*, itype); +// itype atomic_fetch_sub(atomic_itype*, itype); +// itype atomic_fetch_sub_explicit(volatile atomic_itype*, itype, memory_order); +// itype atomic_fetch_sub_explicit(atomic_itype*, itype, memory_order); +// itype atomic_fetch_and(volatile atomic_itype*, itype); +// itype atomic_fetch_and(atomic_itype*, itype); +// itype atomic_fetch_and_explicit(volatile atomic_itype*, itype, memory_order); +// itype atomic_fetch_and_explicit(atomic_itype*, itype, memory_order); +// itype atomic_fetch_or(volatile atomic_itype*, itype); +// itype atomic_fetch_or(atomic_itype*, itype); +// itype atomic_fetch_or_explicit(volatile atomic_itype*, itype, memory_order); +// itype atomic_fetch_or_explicit(atomic_itype*, itype, memory_order); +// itype atomic_fetch_xor(volatile atomic_itype*, itype); +// itype atomic_fetch_xor(atomic_itype*, itype); +// itype atomic_fetch_xor_explicit(volatile atomic_itype*, itype, memory_order); +// itype atomic_fetch_xor_explicit(atomic_itype*, itype, memory_order); + +#include +#include + +template +void +test() +{ + A obj(T(0)); + assert(obj == T(0)); + std::atomic_init(&obj, T(1)); + assert(obj == T(1)); + std::atomic_init(&obj, T(2)); + assert(obj == T(2)); + bool b0 = obj.is_lock_free(); + obj.store(T(0)); + assert(obj == T(0)); + obj.store(T(1), std::memory_order_release); + assert(obj == T(1)); + assert(obj.load() == T(1)); + assert(obj.load(std::memory_order_acquire) == T(1)); + assert(obj.exchange(T(2)) == T(1)); + assert(obj == T(2)); + assert(obj.exchange(T(3), std::memory_order_relaxed) == T(2)); + assert(obj == T(3)); + T x = obj; + assert(obj.compare_exchange_weak(x, T(2)) == true); + assert(obj == T(2)); + assert(x == T(3)); + assert(obj.compare_exchange_weak(x, T(1)) == false); + assert(obj == T(2)); + assert(x == T(2)); + assert(obj.compare_exchange_strong(x, T(1)) == true); + assert(obj == T(1)); + assert(x == T(2)); + assert(obj.compare_exchange_strong(x, T(0)) == false); + assert(obj == T(1)); + assert(x == T(1)); + assert((obj = T(0)) == T(0)); + assert(obj == T(0)); + + std::atomic_init(&obj, T(1)); + assert(obj == T(1)); + bool b1 = std::atomic_is_lock_free(&obj); + std::atomic_store(&obj, T(0)); + assert(obj == T(0)); + std::atomic_store_explicit(&obj, T(1), std::memory_order_release); + assert(obj == T(1)); + assert(std::atomic_load(&obj) == T(1)); + assert(std::atomic_load_explicit(&obj, std::memory_order_acquire) == T(1)); + assert(std::atomic_exchange(&obj, T(2)) == T(1)); + assert(obj == T(2)); + assert(std::atomic_exchange_explicit(&obj, T(3), std::memory_order_relaxed) == T(2)); + assert(obj == T(3)); + x = obj; + assert(std::atomic_compare_exchange_weak(&obj, &x, T(2)) == true); + assert(obj == T(2)); + assert(x == T(3)); + assert(std::atomic_compare_exchange_weak(&obj, &x, T(1)) == false); + assert(obj == T(2)); + assert(x == T(2)); + assert(std::atomic_compare_exchange_strong(&obj, &x, T(1)) == true); + assert(obj == T(1)); + assert(x == T(2)); + assert(std::atomic_compare_exchange_strong(&obj, &x, T(0)) == false); + assert(obj == T(1)); + assert(x == T(1)); + assert(std::atomic_compare_exchange_weak_explicit(&obj, &x, T(2), + std::memory_order_relaxed, std::memory_order_relaxed) == true); + assert(obj == T(2)); + assert(x == T(1)); + assert(std::atomic_compare_exchange_weak_explicit(&obj, &x, T(3), + std::memory_order_relaxed, std::memory_order_relaxed) == false); + assert(obj == T(2)); + assert(x == T(2)); + assert(std::atomic_compare_exchange_strong_explicit(&obj, &x, T(3), + std::memory_order_relaxed, std::memory_order_relaxed) == true); + assert(obj == T(3)); + assert(x == T(2)); + assert(std::atomic_compare_exchange_strong_explicit(&obj, &x, T(0), + std::memory_order_relaxed, std::memory_order_relaxed) == false); + assert(obj == T(3)); + assert(x == T(3)); + assert((obj = T(1)) == T(1)); + assert(obj == T(1)); +} + +int main() +{ + test(); + test(); +}