atomic/test/atomic_api.cpp
Andrey Semashev 80cfbfd0de Added implementation of inter-process atomics.
The inter-process atomics have ipc_ prefixes: ipc_atomic, ipc_atomic_ref
and ipc_atomic_flag. These types are similar to their unprefixed counterparts
with the following distinctions:

- The operations are provided with an added precondition that is_lock_free()
  returns true.
- All operations, including waiting/notifying operations, are address-free,
  so the types are suitable for inter-process communication.
- The new has_native_wait_notify() operation and always_has_native_wait_notify
  static constant allow to test if the target platform has native support for
  address-free waiting/notifying operations. If it does not, a generic
  implementation is used based on a busy wait.
- The new set of capability macros added. The macros are named
  BOOST_ATOMIC_HAS_NATIVE_<T>_IPC_WAIT_NOTIFY and indicate whether address-free
  waiting/notifying operations are supported natively for a given type.

Additionally, to unify interface and implementation of different components,
the has_native_wait_notify() operation and always_has_native_wait_notify
static constant were added to non-IPC atomic types as well. Added
BOOST_ATOMIC_HAS_NATIVE_<T>_WAIT_NOTIFY capability macros to indicate
native support for inter-thread waiting/notifying operations.

Also, added is_lock_free() and is_always_lock_free to atomic_flag.

This commit adds implementation, docs and tests.
2020-06-11 13:07:16 +03:00

84 lines
3.3 KiB
C++

// Copyright (c) 2011 Helge Bahmann
// Copyright (c) 2020 Andrey Semashev
//
// Distributed under the Boost Software License, Version 1.0.
// See accompanying file LICENSE_1_0.txt or copy at
// http://www.boost.org/LICENSE_1_0.txt)
#include <boost/atomic.hpp>
#include <boost/config.hpp>
#include <boost/cstdint.hpp>
#include "api_test_helpers.hpp"
int main(int, char *[])
{
test_flag_api< boost::atomic_flag >();
test_integral_api< atomic_wrapper, char >();
test_integral_api< atomic_wrapper, signed char >();
test_integral_api< atomic_wrapper, unsigned char >();
test_integral_api< atomic_wrapper, boost::uint8_t >();
test_integral_api< atomic_wrapper, boost::int8_t >();
test_integral_api< atomic_wrapper, short >();
test_integral_api< atomic_wrapper, unsigned short >();
test_integral_api< atomic_wrapper, boost::uint16_t >();
test_integral_api< atomic_wrapper, boost::int16_t >();
test_integral_api< atomic_wrapper, int >();
test_integral_api< atomic_wrapper, unsigned int >();
test_integral_api< atomic_wrapper, boost::uint32_t >();
test_integral_api< atomic_wrapper, boost::int32_t >();
test_integral_api< atomic_wrapper, long >();
test_integral_api< atomic_wrapper, unsigned long >();
test_integral_api< atomic_wrapper, boost::uint64_t >();
test_integral_api< atomic_wrapper, boost::int64_t >();
test_integral_api< atomic_wrapper, long long >();
test_integral_api< atomic_wrapper, unsigned long long >();
#if defined(BOOST_HAS_INT128) && !defined(BOOST_ATOMIC_TESTS_NO_INT128)
test_integral_api< atomic_wrapper, boost::int128_type >();
test_integral_api< atomic_wrapper, boost::uint128_type >();
#endif
test_constexpr_ctor< char >();
test_constexpr_ctor< short >();
test_constexpr_ctor< int >();
test_constexpr_ctor< long >();
// test_constexpr_ctor< int* >(); // for pointers we're not offering a constexpr constructor because of bitwise_cast
#if !defined(BOOST_ATOMIC_NO_FLOATING_POINT)
test_floating_point_api< atomic_wrapper, float >();
test_floating_point_api< atomic_wrapper, double >();
test_floating_point_api< atomic_wrapper, long double >();
#if defined(BOOST_HAS_FLOAT128) && !defined(BOOST_ATOMIC_TESTS_NO_FLOAT128)
test_floating_point_api< atomic_wrapper, boost::float128_type >();
#endif
#endif
test_pointer_api< atomic_wrapper, int >();
test_enum_api< atomic_wrapper >();
test_struct_api< atomic_wrapper, test_struct< boost::uint8_t > >();
test_struct_api< atomic_wrapper, test_struct< boost::uint16_t > >();
test_struct_api< atomic_wrapper, test_struct< boost::uint32_t > >();
test_struct_api< atomic_wrapper, test_struct< boost::uint64_t > >();
#if defined(BOOST_HAS_INT128)
test_struct_api< atomic_wrapper, test_struct< boost::uint128_type > >();
#endif
// https://svn.boost.org/trac/boost/ticket/10994
test_struct_x2_api< atomic_wrapper, test_struct_x2< boost::uint64_t > >();
// https://svn.boost.org/trac/boost/ticket/9985
test_struct_api< atomic_wrapper, test_struct< double > >();
test_large_struct_api< atomic_wrapper >();
// Test that boost::atomic<T> only requires T to be trivially copyable.
// Other non-trivial constructors are allowed.
test_struct_with_ctor_api< atomic_wrapper >();
return boost::report_errors();
}