aboutsummaryrefslogtreecommitdiffstats
path: root/include/llvm/Support
diff options
context:
space:
mode:
authorOwen Anderson <resistor@mac.com>2009-05-15 08:22:07 +0000
committerOwen Anderson <resistor@mac.com>2009-05-15 08:22:07 +0000
commitcdc943532d8f81843e18995f317f1e906c55e370 (patch)
treee71620cf5e568961ece1d17394115be2c3e22c59 /include/llvm/Support
parent31456024dada134c5ef96a7a17e7cc5e8e73955a (diff)
downloadexternal_llvm-cdc943532d8f81843e18995f317f1e906c55e370.zip
external_llvm-cdc943532d8f81843e18995f317f1e906c55e370.tar.gz
external_llvm-cdc943532d8f81843e18995f317f1e906c55e370.tar.bz2
Factor out some common code, fix more typoes, and add a memory fence that might be needed.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@71853 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'include/llvm/Support')
-rw-r--r--include/llvm/Support/ManagedStatic.h46
1 files changed, 15 insertions, 31 deletions
diff --git a/include/llvm/Support/ManagedStatic.h b/include/llvm/Support/ManagedStatic.h
index c1ff0fe..a504be3 100644
--- a/include/llvm/Support/ManagedStatic.h
+++ b/include/llvm/Support/ManagedStatic.h
@@ -51,51 +51,35 @@ public:
///
template<class C>
class ManagedStatic : public ManagedStaticBase {
-public:
-
- // Accessors.
- C &operator*() {
+private:
+ void checkInit() {
sys::cas_flag OldFlag = sys::CompareAndSwap(&InitFlag, 1, 0);
if (OldFlag == 0) {
LazyInit();
sys::MemoryFence();
InitFlag = 2;
- } else if (OldFlag == 1)
- while (OldFlag == 1) ;
-
+ } else if (OldFlag == 1) {
+ while (InitFlag == 1) ;
+ sys::MemoryFence();
+ }
+ }
+public:
+
+ // Accessors.
+ C &operator*() {
+ checkInit();
return *static_cast<C*>(Ptr);
}
C *operator->() {
- sys::cas_flag OldFlag = sys::CompareAndSwap(&InitFlag, 1, 0);
- if (OldFlag == 0) {
- LazyInit();
- sys::MemoryFence();
- InitFlag = 2;
- } else if (OldFlag == 1)
- while (OldFlag == 1) ;
-
+ checkInit();
return static_cast<C*>(Ptr);
}
const C &operator*() const {
- sys::cas_flag OldFlag = sys::CompareAndSwap(&InitFlag, 1, 0);
- if (OldFlag == 0) {
- LazyInit();
- sys::MemoryFence();
- InitFlag = 2;
- } else if (OldFlag == 1)
- while (InitFlag == 1) ;
-
+ checkInit();
return *static_cast<C*>(Ptr);
}
const C *operator->() const {
- sys::cas_flag OldFlag = sys::CompareAndSwap(&InitFlag, 1, 0);
- if (OldFlag == 0) {
- LazyInit();
- sys::MemoryFence();
- InitFlag = 2;
- } else if (OldFlag == 1)
- while (OldFlag == 1) ;
-
+ checkInit();
return static_cast<C*>(Ptr);
}