12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- #ifndef BOOST_SMART_PTR_DETAIL_SPINLOCK_STD_ATOMIC_HPP_INCLUDED
- #define BOOST_SMART_PTR_DETAIL_SPINLOCK_STD_ATOMIC_HPP_INCLUDED
- // MS compatible compilers support #pragma once
- #if defined(_MSC_VER) && (_MSC_VER >= 1020)
- # pragma once
- #endif
- //
- // Copyright (c) 2014 Peter Dimov
- //
- // 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/smart_ptr/detail/yield_k.hpp>
- #include <boost/config.hpp>
- #include <atomic>
- #if defined(BOOST_SP_REPORT_IMPLEMENTATION)
- #include <boost/config/pragma_message.hpp>
- BOOST_PRAGMA_MESSAGE("Using std::atomic spinlock")
- #endif
- namespace boost
- {
- namespace detail
- {
- class spinlock
- {
- public:
- std::atomic_flag v_;
- public:
- bool try_lock() BOOST_NOEXCEPT
- {
- return !v_.test_and_set( std::memory_order_acquire );
- }
- void lock() BOOST_NOEXCEPT
- {
- for( unsigned k = 0; !try_lock(); ++k )
- {
- boost::detail::yield( k );
- }
- }
- void unlock() BOOST_NOEXCEPT
- {
- v_ .clear( std::memory_order_release );
- }
- public:
- class scoped_lock
- {
- private:
- spinlock & sp_;
- scoped_lock( scoped_lock const & );
- scoped_lock & operator=( scoped_lock const & );
- public:
- explicit scoped_lock( spinlock & sp ) BOOST_NOEXCEPT: sp_( sp )
- {
- sp.lock();
- }
- ~scoped_lock() /*BOOST_NOEXCEPT*/
- {
- sp_.unlock();
- }
- };
- };
- } // namespace detail
- } // namespace boost
- #define BOOST_DETAIL_SPINLOCK_INIT { ATOMIC_FLAG_INIT }
- #endif // #ifndef BOOST_SMART_PTR_DETAIL_SPINLOCK_STD_ATOMIC_HPP_INCLUDED
|