//===----------------------------------------------------------------------===// // // The LLVM Compiler Infrastructure // // This file is dual licensed under the MIT and the University of Illinois Open // Source Licenses. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // template // Integral // atomic_fetch_sub_explicit(volatile atomic* obj, Integral op, // memory_order m); // template // Integral // atomic_fetch_sub_explicit(atomic* obj, Integral op, // memory_order m); // // template // T* // atomic_fetch_sub_explicit(volatile atomic* obj, ptrdiff_t op, // memory_order m); // template // T* // atomic_fetch_sub_explicit(atomic* obj, ptrdiff_t op, memory_order m); #include #include #include template void test() { { typedef std::atomic A; A t; std::atomic_init(&t, T(3)); assert(std::atomic_fetch_sub_explicit(&t, T(2), std::memory_order_seq_cst) == T(3)); assert(t == T(1)); } { typedef std::atomic A; volatile A t; std::atomic_init(&t, T(3)); assert(std::atomic_fetch_sub_explicit(&t, T(2), std::memory_order_seq_cst) == T(3)); assert(t == T(1)); } } template void testp() { { typedef std::atomic A; typedef typename std::remove_pointer::type X; A t; std::atomic_init(&t, T(3*sizeof(X))); assert(std::atomic_fetch_sub_explicit(&t, 2, std::memory_order_seq_cst) == T(3*sizeof(X))); assert(t == T(1*sizeof(X))); } { typedef std::atomic A; typedef typename std::remove_pointer::type X; volatile A t; std::atomic_init(&t, T(3*sizeof(X))); assert(std::atomic_fetch_sub_explicit(&t, 2, std::memory_order_seq_cst) == T(3*sizeof(X))); assert(t == T(1*sizeof(X))); } } struct A { int i; explicit A(int d = 0) : i(d) {} A(const A& a) : i(a.i) {} A(const volatile A& a) : i(a.i) {} void operator=(const volatile A& a) volatile {i = a.i;} friend bool operator==(const A& x, const A& y) {return x.i == y.i;} }; int main() { test(); test(); test(); test(); test(); test(); test(); test(); test(); test(); test(); test(); #ifndef _LIBCPP_HAS_NO_UNICODE_CHARS test(); test(); #endif // _LIBCPP_HAS_NO_UNICODE_CHARS testp(); testp(); }