//===----------------------------------------------------------------------===// // // 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_add(volatile atomic* obj, Integral op); // // template // Integral // atomic_fetch_add(atomic* obj, Integral op); // // template // T* // atomic_fetch_add(volatile atomic* obj, ptrdiff_t op); // // template // T* // atomic_fetch_add(atomic* obj, ptrdiff_t op); #include #include #include template void test() { { typedef std::atomic A; A t; std::atomic_init(&t, T(1)); assert(std::atomic_fetch_add(&t, T(2)) == T(1)); assert(t == T(3)); } { typedef std::atomic A; volatile A t; std::atomic_init(&t, T(1)); assert(std::atomic_fetch_add(&t, T(2)) == T(1)); assert(t == T(3)); } } template void testp() { { typedef std::atomic A; typedef typename std::remove_pointer::type X; A t; std::atomic_init(&t, T(1*sizeof(X))); assert(std::atomic_fetch_add(&t, 2) == T(1*sizeof(X))); assert(t == T(3*sizeof(X))); } { typedef std::atomic A; typedef typename std::remove_pointer::type X; volatile A t; std::atomic_init(&t, T(1*sizeof(X))); assert(std::atomic_fetch_add(&t, 2) == T(1*sizeof(X))); assert(t == T(3*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(); }