mirror of
https://github.com/boostorg/atomic.git
synced 2026-02-01 20:12:09 +00:00
The generic implementation is based on the lock pool. A list of condition variables (or waiting futexes) is added per lock. Basically, the lock pool serves as a global hash table, where each lock represents a bucket and each wait state is an element. Every wait operation allocates a wait state keyed on the pointer to the atomic object. Notify operations look up the wait state by the atomic pointer and notify the condition variable/futex. The corresponding lock needs to be acquired to protect the wait state list during all wait/notify operations. Backends not involving the lock pool are going to be added later. The implementation of wait operation extends the C++20 definition in that it returns the newly loaded value instead of void. This allows the caller to avoid loading the value himself. The waiting/notifying operations are not address-free. Address-free variants will be added later. Added tests for the new operations and refactored existing tests for atomic operations. Added docs for the new operations.
75 lines
3.1 KiB
C++
75 lines
3.1 KiB
C++
// 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/atomic_ref.hpp>
|
|
|
|
#include <boost/config.hpp>
|
|
#include <boost/cstdint.hpp>
|
|
|
|
#include "api_test_helpers.hpp"
|
|
|
|
int main(int, char *[])
|
|
{
|
|
test_integral_api< atomic_ref_wrapper, char >();
|
|
test_integral_api< atomic_ref_wrapper, signed char >();
|
|
test_integral_api< atomic_ref_wrapper, unsigned char >();
|
|
test_integral_api< atomic_ref_wrapper, boost::uint8_t >();
|
|
test_integral_api< atomic_ref_wrapper, boost::int8_t >();
|
|
test_integral_api< atomic_ref_wrapper, short >();
|
|
test_integral_api< atomic_ref_wrapper, unsigned short >();
|
|
test_integral_api< atomic_ref_wrapper, boost::uint16_t >();
|
|
test_integral_api< atomic_ref_wrapper, boost::int16_t >();
|
|
test_integral_api< atomic_ref_wrapper, int >();
|
|
test_integral_api< atomic_ref_wrapper, unsigned int >();
|
|
test_integral_api< atomic_ref_wrapper, boost::uint32_t >();
|
|
test_integral_api< atomic_ref_wrapper, boost::int32_t >();
|
|
test_integral_api< atomic_ref_wrapper, long >();
|
|
test_integral_api< atomic_ref_wrapper, unsigned long >();
|
|
test_integral_api< atomic_ref_wrapper, boost::uint64_t >();
|
|
test_integral_api< atomic_ref_wrapper, boost::int64_t >();
|
|
test_integral_api< atomic_ref_wrapper, long long >();
|
|
test_integral_api< atomic_ref_wrapper, unsigned long long >();
|
|
#if defined(BOOST_HAS_INT128) && !defined(BOOST_ATOMIC_TESTS_NO_INT128)
|
|
test_integral_api< atomic_ref_wrapper, boost::int128_type >();
|
|
test_integral_api< atomic_ref_wrapper, boost::uint128_type >();
|
|
#endif
|
|
|
|
#if !defined(BOOST_ATOMIC_NO_FLOATING_POINT)
|
|
test_floating_point_api< atomic_ref_wrapper, float >();
|
|
test_floating_point_api< atomic_ref_wrapper, double >();
|
|
test_floating_point_api< atomic_ref_wrapper, long double >();
|
|
#if defined(BOOST_HAS_FLOAT128) && !defined(BOOST_ATOMIC_TESTS_NO_FLOAT128)
|
|
test_floating_point_api< atomic_ref_wrapper, boost::float128_type >();
|
|
#endif
|
|
#endif
|
|
|
|
test_pointer_api< atomic_ref_wrapper, int >();
|
|
|
|
test_enum_api< atomic_ref_wrapper >();
|
|
|
|
test_struct_api< atomic_ref_wrapper, test_struct< boost::uint8_t > >();
|
|
test_struct_api< atomic_ref_wrapper, test_struct< boost::uint16_t > >();
|
|
test_struct_api< atomic_ref_wrapper, test_struct< boost::uint32_t > >();
|
|
test_struct_api< atomic_ref_wrapper, test_struct< boost::uint64_t > >();
|
|
#if defined(BOOST_HAS_INT128)
|
|
test_struct_api< atomic_ref_wrapper, test_struct< boost::uint128_type > >();
|
|
#endif
|
|
|
|
// https://svn.boost.org/trac/boost/ticket/10994
|
|
test_struct_x2_api< atomic_ref_wrapper, test_struct_x2< boost::uint64_t > >();
|
|
|
|
// https://svn.boost.org/trac/boost/ticket/9985
|
|
test_struct_api< atomic_ref_wrapper, test_struct< double > >();
|
|
|
|
test_large_struct_api< atomic_ref_wrapper >();
|
|
|
|
// Test that boost::atomic_ref<T> only requires T to be trivially copyable.
|
|
// Other non-trivial constructors are allowed.
|
|
test_struct_with_ctor_api< atomic_ref_wrapper >();
|
|
|
|
return boost::report_errors();
|
|
}
|