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
|