diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2014-03-03 17:53:30 +0000 |
---|---|---|
committer | Benjamin Kramer <benny.kra@googlemail.com> | 2014-03-03 17:53:30 +0000 |
commit | 4721e55a0c2e749cba4f91aa584508284ff67d2c (patch) | |
tree | 7ee6c143079fc5ad8ae985013a56b8d381a19918 /include/llvm/Support | |
parent | 59a451775954483bc4db825d8f9eb660b7c96a06 (diff) | |
download | llvm-4721e55a0c2e749cba4f91aa584508284ff67d2c.tar.gz llvm-4721e55a0c2e749cba4f91aa584508284ff67d2c.tar.bz2 llvm-4721e55a0c2e749cba4f91aa584508284ff67d2c.tar.xz |
[C++11] Replace LLVM atomics with std::atomic.
With C++11 we finally have a standardized way to specify atomic operations. Use
them to replace the existing custom implemention. Sadly the translation is not
entirely trivial as std::atomic allows more fine-grained control over the
atomicity. I tried to preserve the old semantics as well as possible.
Differential Revision: http://llvm-reviews.chandlerc.com/D2915
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@202730 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/Support')
-rw-r--r-- | include/llvm/Support/ManagedStatic.h | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/include/llvm/Support/ManagedStatic.h b/include/llvm/Support/ManagedStatic.h index 5587618d11..4a12a1ba8e 100644 --- a/include/llvm/Support/ManagedStatic.h +++ b/include/llvm/Support/ManagedStatic.h @@ -14,9 +14,9 @@ #ifndef LLVM_SUPPORT_MANAGED_STATIC_H #define LLVM_SUPPORT_MANAGED_STATIC_H -#include "llvm/Support/Atomic.h" #include "llvm/Support/Threading.h" #include "llvm/Support/Valgrind.h" +#include <atomic> namespace llvm { @@ -64,7 +64,8 @@ public: // Accessors. C &operator*() { void* tmp = Ptr; - if (llvm_is_multithreaded()) sys::MemoryFence(); + if (llvm_is_multithreaded()) + std::atomic_thread_fence(std::memory_order_seq_cst); if (!tmp) RegisterManagedStatic(object_creator<C>, object_deleter<C>::call); TsanHappensAfter(this); @@ -72,7 +73,8 @@ public: } C *operator->() { void* tmp = Ptr; - if (llvm_is_multithreaded()) sys::MemoryFence(); + if (llvm_is_multithreaded()) + std::atomic_thread_fence(std::memory_order_seq_cst); if (!tmp) RegisterManagedStatic(object_creator<C>, object_deleter<C>::call); TsanHappensAfter(this); @@ -80,7 +82,8 @@ public: } const C &operator*() const { void* tmp = Ptr; - if (llvm_is_multithreaded()) sys::MemoryFence(); + if (llvm_is_multithreaded()) + std::atomic_thread_fence(std::memory_order_seq_cst); if (!tmp) RegisterManagedStatic(object_creator<C>, object_deleter<C>::call); TsanHappensAfter(this); @@ -88,7 +91,8 @@ public: } const C *operator->() const { void* tmp = Ptr; - if (llvm_is_multithreaded()) sys::MemoryFence(); + if (llvm_is_multithreaded()) + std::atomic_thread_fence(std::memory_order_seq_cst); if (!tmp) RegisterManagedStatic(object_creator<C>, object_deleter<C>::call); TsanHappensAfter(this); |