OSDN Git Service

2006-05-29 Paolo Carlini <pcarlini@suse.de>
[pf3gnuchains/gcc-fork.git] / libstdc++-v3 / include / bits / atomicity.h
1 // Low-level functions for atomic operations -*- C++ -*-
2
3 // Copyright (C) 2004, 2005, 2006 Free Software Foundation, Inc.
4 //
5 // This file is part of the GNU ISO C++ Library.  This library is free
6 // software; you can redistribute it and/or modify it under the
7 // terms of the GNU General Public License as published by the
8 // Free Software Foundation; either version 2, or (at your option)
9 // any later version.
10
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 // GNU General Public License for more details.
15
16 // You should have received a copy of the GNU General Public License along
17 // with this library; see the file COPYING.  If not, write to the Free
18 // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
19 // USA.
20
21 // As a special exception, you may use this file as part of a free software
22 // library without restriction.  Specifically, if other files instantiate
23 // templates or use macros or inline functions from this file, or you compile
24 // this file and link it with other files to produce an executable, this
25 // file does not by itself cause the resulting executable to be covered by
26 // the GNU General Public License.  This exception does not however
27 // invalidate any other reasons why the executable file might be covered by
28 // the GNU General Public License.
29
30 /** @file atomicity.h
31  *  This is an internal header file, included by other library headers.
32  *  You should not attempt to use it directly.
33  */
34
35 #ifndef _GLIBCXX_ATOMICITY_H
36 #define _GLIBCXX_ATOMICITY_H    1
37
38 #include <bits/c++config.h>
39 #include <bits/gthr.h>
40 #include <bits/atomic_word.h>
41
42 _GLIBCXX_BEGIN_NAMESPACE(__gnu_cxx)
43
44   _Atomic_word
45   __attribute__ ((__unused__))
46   __exchange_and_add(volatile _Atomic_word* __mem, int __val);
47
48   void
49   __attribute__ ((__unused__))
50   __atomic_add(volatile _Atomic_word* __mem, int __val);
51
52   static inline _Atomic_word
53   __exchange_and_add_multi(volatile _Atomic_word* __mem, int __val)
54   {
55 #ifdef _GLIBCXX_ATOMIC_BUILTINS
56
57     return __sync_fetch_and_add(__mem, __val);
58
59 #else
60
61     return __exchange_and_add(__mem, __val);
62
63 #endif
64   }
65
66   static inline void
67   __atomic_add_multi(volatile _Atomic_word* __mem, int __val)
68   { 
69 #ifdef _GLIBCXX_ATOMIC_BUILTINS
70
71     __sync_fetch_and_add(__mem, __val);
72
73 #else
74
75     __atomic_add(__mem, __val);
76
77 #endif
78   }
79
80   static inline _Atomic_word
81   __exchange_and_add_single(volatile _Atomic_word* __mem, int __val)
82   {
83     _Atomic_word __result = *__mem;
84     *__mem += __val;
85     return __result;
86   }
87
88   static inline void
89   __atomic_add_single(volatile _Atomic_word* __mem, int __val)
90   { *__mem += __val; }
91
92   static inline _Atomic_word
93   __attribute__ ((__unused__))
94   __exchange_and_add_dispatch(volatile _Atomic_word* __mem, int __val)
95   {
96 #ifdef __GTHREADS
97
98     if (__gthread_active_p())
99       return __exchange_and_add_multi(__mem, __val);
100     else
101       return __exchange_and_add_single(__mem, __val);
102
103 #else
104
105     return __exchange_and_add_single(__mem, __val);
106
107 #endif
108   }
109
110   static inline void
111   __attribute__ ((__unused__))
112   __atomic_add_dispatch(volatile _Atomic_word* __mem, int __val)
113   {
114 #ifdef __GTHREADS
115
116     if (__gthread_active_p())
117       __atomic_add_multi(__mem, __val);
118     else
119       __atomic_add_single(__mem, __val);
120
121 #else
122
123     __atomic_add_single(__mem, __val);
124
125 #endif
126   }
127
128 _GLIBCXX_END_NAMESPACE
129
130 /* Even if the CPU doesn't need a memory barrier, we need to ensure that
131    the compiler doesn't reorder memory accesses across the barriers.  */
132 #ifndef _GLIBCXX_READ_MEM_BARRIER
133 #define _GLIBCXX_READ_MEM_BARRIER __asm __volatile ("":::"memory")
134 #endif
135 #ifndef _GLIBCXX_WRITE_MEM_BARRIER
136 #define _GLIBCXX_WRITE_MEM_BARRIER __asm __volatile ("":::"memory")
137 #endif
138
139 #endif