annotate DEPENDENCIES/generic/include/boost/asio/detail/gcc_arm_fenced_block.hpp @ 133:4acb5d8d80b6 tip

Don't fail environmental check if README.md exists (but .txt and no-suffix don't)
author Chris Cannam
date Tue, 30 Jul 2019 12:25:44 +0100
parents c530137014c0
children
rev   line source
Chris@16 1 //
Chris@16 2 // detail/gcc_arm_fenced_block.hpp
Chris@16 3 // ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Chris@16 4 //
Chris@101 5 // Copyright (c) 2003-2015 Christopher M. Kohlhoff (chris at kohlhoff dot com)
Chris@16 6 //
Chris@16 7 // Distributed under the Boost Software License, Version 1.0. (See accompanying
Chris@16 8 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
Chris@16 9 //
Chris@16 10
Chris@16 11 #ifndef BOOST_ASIO_DETAIL_GCC_ARM_FENCED_BLOCK_HPP
Chris@16 12 #define BOOST_ASIO_DETAIL_GCC_ARM_FENCED_BLOCK_HPP
Chris@16 13
Chris@16 14 #if defined(_MSC_VER) && (_MSC_VER >= 1200)
Chris@16 15 # pragma once
Chris@16 16 #endif // defined(_MSC_VER) && (_MSC_VER >= 1200)
Chris@16 17
Chris@16 18 #include <boost/asio/detail/config.hpp>
Chris@16 19
Chris@16 20 #if defined(__GNUC__) && defined(__arm__)
Chris@16 21
Chris@16 22 #include <boost/asio/detail/push_options.hpp>
Chris@16 23
Chris@16 24 namespace boost {
Chris@16 25 namespace asio {
Chris@16 26 namespace detail {
Chris@16 27
Chris@16 28 class gcc_arm_fenced_block
Chris@16 29 : private noncopyable
Chris@16 30 {
Chris@16 31 public:
Chris@16 32 enum half_t { half };
Chris@16 33 enum full_t { full };
Chris@16 34
Chris@16 35 // Constructor for a half fenced block.
Chris@16 36 explicit gcc_arm_fenced_block(half_t)
Chris@16 37 {
Chris@16 38 }
Chris@16 39
Chris@16 40 // Constructor for a full fenced block.
Chris@16 41 explicit gcc_arm_fenced_block(full_t)
Chris@16 42 {
Chris@16 43 barrier();
Chris@16 44 }
Chris@16 45
Chris@16 46 // Destructor.
Chris@16 47 ~gcc_arm_fenced_block()
Chris@16 48 {
Chris@16 49 barrier();
Chris@16 50 }
Chris@16 51
Chris@16 52 private:
Chris@16 53 static void barrier()
Chris@16 54 {
Chris@16 55 #if defined(__ARM_ARCH_4__) \
Chris@16 56 || defined(__ARM_ARCH_4T__) \
Chris@16 57 || defined(__ARM_ARCH_5__) \
Chris@16 58 || defined(__ARM_ARCH_5E__) \
Chris@16 59 || defined(__ARM_ARCH_5T__) \
Chris@16 60 || defined(__ARM_ARCH_5TE__) \
Chris@16 61 || defined(__ARM_ARCH_5TEJ__) \
Chris@16 62 || defined(__ARM_ARCH_6__) \
Chris@16 63 || defined(__ARM_ARCH_6J__) \
Chris@16 64 || defined(__ARM_ARCH_6K__) \
Chris@16 65 || defined(__ARM_ARCH_6Z__) \
Chris@16 66 || defined(__ARM_ARCH_6ZK__) \
Chris@16 67 || defined(__ARM_ARCH_6T2__)
Chris@16 68 # if defined(__thumb__)
Chris@16 69 // This is just a placeholder and almost certainly not sufficient.
Chris@16 70 __asm__ __volatile__ ("" : : : "memory");
Chris@16 71 # else // defined(__thumb__)
Chris@16 72 int a = 0, b = 0;
Chris@16 73 __asm__ __volatile__ ("swp %0, %1, [%2]"
Chris@16 74 : "=&r"(a) : "r"(1), "r"(&b) : "memory", "cc");
Chris@16 75 # endif // defined(__thumb__)
Chris@16 76 #else
Chris@16 77 // ARMv7 and later.
Chris@16 78 __asm__ __volatile__ ("dmb" : : : "memory");
Chris@16 79 #endif
Chris@16 80 }
Chris@16 81 };
Chris@16 82
Chris@16 83 } // namespace detail
Chris@16 84 } // namespace asio
Chris@16 85 } // namespace boost
Chris@16 86
Chris@16 87 #include <boost/asio/detail/pop_options.hpp>
Chris@16 88
Chris@16 89 #endif // defined(__GNUC__) && defined(__arm__)
Chris@16 90
Chris@16 91 #endif // BOOST_ASIO_DETAIL_GCC_ARM_FENCED_BLOCK_HPP