summaryrefslogtreecommitdiff
path: root/include/llvm/Support
diff options
context:
space:
mode:
authorBenjamin Kramer <benny.kra@googlemail.com>2014-03-03 17:53:30 +0000
committerBenjamin Kramer <benny.kra@googlemail.com>2014-03-03 17:53:30 +0000
commit4721e55a0c2e749cba4f91aa584508284ff67d2c (patch)
tree7ee6c143079fc5ad8ae985013a56b8d381a19918 /include/llvm/Support
parent59a451775954483bc4db825d8f9eb660b7c96a06 (diff)
downloadllvm-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.h14
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);