12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- #ifndef BOOST_SMART_PTR_DETAIL_ATOMIC_COUNT_GCC_X86_HPP_INCLUDED
- #define BOOST_SMART_PTR_DETAIL_ATOMIC_COUNT_GCC_X86_HPP_INCLUDED
- //
- // boost/detail/atomic_count_gcc_x86.hpp
- //
- // atomic_count for g++ on 486+/AMD64
- //
- // Copyright 2007 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/sp_obsolete.hpp>
- #if defined(BOOST_SP_REPORT_IMPLEMENTATION)
- #include <boost/config/pragma_message.hpp>
- BOOST_PRAGMA_MESSAGE("Using g++/x86 atomic_count")
- #endif
- BOOST_SP_OBSOLETE()
- namespace boost
- {
- namespace detail
- {
- class atomic_count
- {
- public:
- explicit atomic_count( long v ) : value_( static_cast< int >( v ) ) {}
- long operator++()
- {
- return atomic_exchange_and_add( &value_, +1 ) + 1;
- }
- long operator--()
- {
- return atomic_exchange_and_add( &value_, -1 ) - 1;
- }
- operator long() const
- {
- return atomic_exchange_and_add( &value_, 0 );
- }
- private:
- atomic_count(atomic_count const &);
- atomic_count & operator=(atomic_count const &);
- mutable int value_;
- private:
- static int atomic_exchange_and_add( int * pw, int dv )
- {
- // int r = *pw;
- // *pw += dv;
- // return r;
- int r;
- __asm__ __volatile__
- (
- "lock\n\t"
- "xadd %1, %0":
- "+m"( *pw ), "=r"( r ): // outputs (%0, %1)
- "1"( dv ): // inputs (%2 == %1)
- "memory", "cc" // clobbers
- );
- return r;
- }
- };
- } // namespace detail
- } // namespace boost
- #endif // #ifndef BOOST_SMART_PTR_DETAIL_ATOMIC_COUNT_GCC_X86_HPP_INCLUDED
|