// Support for atomic operations -*- C++ -*- // Copyright (C) 2004-2013 Free Software Foundation, Inc. // // This file is part of the GNU ISO C++ Library. This library is free // software; you can redistribute it and/or modify it under the // terms of the GNU General Public License as published by the // Free Software Foundation; either version 3, or (at your option) // any later version. // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // Under Section 7 of GPL version 3, you are granted additional // permissions described in the GCC Runtime Library Exception, version // 3.1, as published by the Free Software Foundation. // You should have received a copy of the GNU General Public License and // a copy of the GCC Runtime Library Exception along with this program; // see the files COPYING3 and COPYING.RUNTIME respectively. If not, see // <http://www.gnu.org/licenses/>. /** @file ext/atomicity.h * This file is a GNU extension to the Standard C++ Library. */ #ifndef _GLIBCXX_ATOMICITY_H #define _GLIBCXX_ATOMICITY_H 1 #pragma GCC system_header #include <bits/c++config.h> #include <bits/gthr.h> #include <bits/atomic_word.h> namespace __gnu_cxx _GLIBCXX_VISIBILITY(default) { _GLIBCXX_BEGIN_NAMESPACE_VERSION // Functions for portable atomic access. // To abstract locking primitives across all thread policies, use: // __exchange_and_add_dispatch // __atomic_add_dispatch #ifdef _GLIBCXX_ATOMIC_BUILTINS static inline _Atomic_word __exchange_and_add(volatile _Atomic_word* __mem, int __val) { return __atomic_fetch_add(__mem, __val, __ATOMIC_ACQ_REL); } static inline void __atomic_add(volatile _Atomic_word* __mem, int __val) { __atomic_fetch_add(__mem, __val, __ATOMIC_ACQ_REL); } #else _Atomic_word __attribute__ ((__unused__)) __exchange_and_add(volatile _Atomic_word*, int) throw (); void __attribute__ ((__unused__)) __atomic_add(volatile _Atomic_word*, int) throw (); #endif static inline _Atomic_word __exchange_and_add_single(_Atomic_word* __mem, int __val) { _Atomic_word __result = *__mem; *__mem += __val; return __result; } static inline void __atomic_add_single(_Atomic_word* __mem, int __val) { *__mem += __val; } static inline _Atomic_word __attribute__ ((__unused__)) __exchange_and_add_dispatch(_Atomic_word* __mem, int __val) { #ifdef __GTHREADS if (__gthread_active_p()) return __exchange_and_add(__mem, __val); else return __exchange_and_add_single(__mem, __val); #else return __exchange_and_add_single(__mem, __val); #endif } static inline void __attribute__ ((__unused__)) __atomic_add_dispatch(_Atomic_word* __mem, int __val) { #ifdef __GTHREADS if (__gthread_active_p()) __atomic_add(__mem, __val); else __atomic_add_single(__mem, __val); #else __atomic_add_single(__mem, __val); #endif } _GLIBCXX_END_NAMESPACE_VERSION } // namespace // Even if the CPU doesn't need a memory barrier, we need to ensure // that the compiler doesn't reorder memory accesses across the // barriers. #ifndef _GLIBCXX_READ_MEM_BARRIER #define _GLIBCXX_READ_MEM_BARRIER __asm __volatile ("":::"memory") #endif #ifndef _GLIBCXX_WRITE_MEM_BARRIER #define _GLIBCXX_WRITE_MEM_BARRIER __asm __volatile ("":::"memory") #endif #endif
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
pb_ds | Folder | 0755 |
|
|
algorithm | File | 18.84 KB | 0644 |
|
alloc_traits.h | File | 7.98 KB | 0644 |
|
array_allocator.h | File | 4.98 KB | 0644 |
|
atomicity.h | File | 3.41 KB | 0644 |
|
bitmap_allocator.h | File | 30.59 KB | 0644 |
|
cast.h | File | 4.34 KB | 0644 |
|
cmath | File | 6.41 KB | 0644 |
|
codecvt_specializations.h | File | 15.91 KB | 0644 |
|
concurrence.h | File | 7.43 KB | 0644 |
|
debug_allocator.h | File | 3.93 KB | 0644 |
|
enc_filebuf.h | File | 2.19 KB | 0644 |
|
extptr_allocator.h | File | 6.04 KB | 0644 |
|
functional | File | 13.96 KB | 0644 |
|
hash_map | File | 17.36 KB | 0644 |
|
hash_set | File | 16.79 KB | 0644 |
|
iterator | File | 3.94 KB | 0644 |
|
malloc_allocator.h | File | 4.36 KB | 0644 |
|
memory | File | 6.99 KB | 0644 |
|
mt_allocator.h | File | 22.43 KB | 0644 |
|
new_allocator.h | File | 4.33 KB | 0644 |
|
numeric | File | 4.62 KB | 0644 |
|
numeric_traits.h | File | 4.47 KB | 0644 |
|
pod_char_traits.h | File | 5.11 KB | 0644 |
|
pointer.h | File | 19.2 KB | 0644 |
|
pool_allocator.h | File | 8.23 KB | 0644 |
|
random | File | 82.75 KB | 0644 |
|
random.tcc | File | 42.78 KB | 0644 |
|
rb_tree | File | 3.23 KB | 0644 |
|
rc_string_base.h | File | 23.16 KB | 0644 |
|
rope | File | 85.59 KB | 0644 |
|
ropeimpl.h | File | 47.29 KB | 0644 |
|
slist | File | 28.91 KB | 0644 |
|
sso_string_base.h | File | 15.93 KB | 0644 |
|
stdio_filebuf.h | File | 5.3 KB | 0644 |
|
stdio_sync_filebuf.h | File | 7.77 KB | 0644 |
|
string_conversions.h | File | 3.14 KB | 0644 |
|
throw_allocator.h | File | 20.5 KB | 0644 |
|
type_traits.h | File | 5.64 KB | 0644 |
|
typelist.h | File | 16.44 KB | 0644 |
|
vstring.h | File | 103.94 KB | 0644 |
|
vstring.tcc | File | 23.04 KB | 0644 |
|
vstring_fwd.h | File | 3.15 KB | 0644 |
|
vstring_util.h | File | 5.63 KB | 0644 |
|