//===----------------------------------------------------------------------===// // // 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. // //===----------------------------------------------------------------------===// // // UNSUPPORTED: libcpp-has-no-threads // ... test crashes clang // // 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 #include "atomic_helpers.h" template struct TestFn { void operator()() const { { 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))); } } int main() { TestEachIntegralType()(); testp(); testp(); }