X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=include%2Fllvm%2FSupport%2FManagedStatic.h;h=4171d1bec8dcee1272aec10dbc5a89a096b171d4;hb=a5bf44b0b396e8b9ae0db5c62c05ac6618aab5d3;hp=28b25dbb623b0b9b90b216f50c9af81185a53858;hpb=7ed47a13356daed2a34cd2209a31f92552e3bdd8;p=oota-llvm.git diff --git a/include/llvm/Support/ManagedStatic.h b/include/llvm/Support/ManagedStatic.h index 28b25dbb623..4171d1bec8d 100644 --- a/include/llvm/Support/ManagedStatic.h +++ b/include/llvm/Support/ManagedStatic.h @@ -14,15 +14,27 @@ #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" + namespace llvm { -/// object_deleter - Helper method for ManagedStatic. -/// +/// object_creator - Helper method for ManagedStatic. template -void object_deleter(void *Ptr) { - delete (C*)Ptr; +void* object_creator() { + return new C(); } +/// object_deleter - Helper method for ManagedStatic. +/// +template struct object_deleter { + static void call(void * Ptr) { delete (T*)Ptr; } +}; +template struct object_deleter { + static void call(void * Ptr) { delete[] (T*)Ptr; } +}; + /// ManagedStaticBase - Common base class for ManagedStatic instances. class ManagedStaticBase { protected: @@ -31,12 +43,12 @@ protected: mutable void *Ptr; mutable void (*DeleterFn)(void*); mutable const ManagedStaticBase *Next; - - void RegisterManagedStatic(void *ObjPtr, void (*deleter)(void*)) const; + + void RegisterManagedStatic(void *(*creator)(), void (*deleter)(void*)) const; public: - /// isConstructed - Return true if this object has not been created yet. + /// isConstructed - Return true if this object has not been created yet. bool isConstructed() const { return Ptr != 0; } - + void destroy() const; }; @@ -48,49 +60,56 @@ public: template class ManagedStatic : public ManagedStaticBase { public: - + // Accessors. C &operator*() { - if (!Ptr) LazyInit(); + void* tmp = Ptr; + if (llvm_is_multithreaded()) sys::MemoryFence(); + if (!tmp) RegisterManagedStatic(object_creator, object_deleter::call); + TsanHappensAfter(this); + return *static_cast(Ptr); } C *operator->() { - if (!Ptr) LazyInit(); + void* tmp = Ptr; + if (llvm_is_multithreaded()) sys::MemoryFence(); + if (!tmp) RegisterManagedStatic(object_creator, object_deleter::call); + TsanHappensAfter(this); + return static_cast(Ptr); } const C &operator*() const { - if (!Ptr) LazyInit(); + void* tmp = Ptr; + if (llvm_is_multithreaded()) sys::MemoryFence(); + if (!tmp) RegisterManagedStatic(object_creator, object_deleter::call); + TsanHappensAfter(this); + return *static_cast(Ptr); } const C *operator->() const { - if (!Ptr) LazyInit(); + void* tmp = Ptr; + if (llvm_is_multithreaded()) sys::MemoryFence(); + if (!tmp) RegisterManagedStatic(object_creator, object_deleter::call); + TsanHappensAfter(this); + return static_cast(Ptr); } - -public: - void LazyInit() const { - RegisterManagedStatic(new C(), object_deleter); - } -}; - -template -class ManagedCleanup : public ManagedStaticBase { -public: - void Register() { RegisterManagedStatic(0, CleanupFn); } }; - /// llvm_shutdown - Deallocate and destroy all ManagedStatic variables. void llvm_shutdown(); - + /// llvm_shutdown_obj - This is a simple helper class that calls /// llvm_shutdown() when it is destroyed. struct llvm_shutdown_obj { - llvm_shutdown_obj() {} + llvm_shutdown_obj() { } + explicit llvm_shutdown_obj(bool multithreaded) { + if (multithreaded) llvm_start_multithreaded(); + } ~llvm_shutdown_obj() { llvm_shutdown(); } }; - + } #endif