X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=include%2Fllvm%2FSupport%2FManagedStatic.h;h=4171d1bec8dcee1272aec10dbc5a89a096b171d4;hb=536a88ad5bf160232205192a7ce72e50bfadbded;hp=619cc2055250a9b46f95ecdb0b177e1a5c1343ae;hpb=6afe2fa28816b5b208a0140372900325709271c4;p=oota-llvm.git diff --git a/include/llvm/Support/ManagedStatic.h b/include/llvm/Support/ManagedStatic.h index 619cc205525..4171d1bec8d 100644 --- a/include/llvm/Support/ManagedStatic.h +++ b/include/llvm/Support/ManagedStatic.h @@ -14,7 +14,9 @@ #ifndef LLVM_SUPPORT_MANAGED_STATIC_H #define LLVM_SUPPORT_MANAGED_STATIC_H -#include "llvm/System/Atomic.h" +#include "llvm/Support/Atomic.h" +#include "llvm/Support/Threading.h" +#include "llvm/Support/Valgrind.h" namespace llvm { @@ -26,10 +28,12 @@ void* object_creator() { /// object_deleter - Helper method for ManagedStatic. /// -template -void object_deleter(void *Ptr) { - delete (C*)Ptr; -} +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 { @@ -60,47 +64,38 @@ public: // Accessors. C &operator*() { void* tmp = Ptr; - sys::MemoryFence(); - if (!tmp) RegisterManagedStatic(object_creator, object_deleter); + if (llvm_is_multithreaded()) sys::MemoryFence(); + if (!tmp) RegisterManagedStatic(object_creator, object_deleter::call); + TsanHappensAfter(this); return *static_cast(Ptr); } C *operator->() { void* tmp = Ptr; - sys::MemoryFence(); - if (!tmp) RegisterManagedStatic(object_creator, object_deleter); + if (llvm_is_multithreaded()) sys::MemoryFence(); + if (!tmp) RegisterManagedStatic(object_creator, object_deleter::call); + TsanHappensAfter(this); return static_cast(Ptr); } const C &operator*() const { void* tmp = Ptr; - sys::MemoryFence(); - if (!tmp) RegisterManagedStatic(object_creator, object_deleter); + if (llvm_is_multithreaded()) sys::MemoryFence(); + if (!tmp) RegisterManagedStatic(object_creator, object_deleter::call); + TsanHappensAfter(this); return *static_cast(Ptr); } const C *operator->() const { void* tmp = Ptr; - sys::MemoryFence(); - if (!tmp) RegisterManagedStatic(object_creator, object_deleter); + if (llvm_is_multithreaded()) sys::MemoryFence(); + if (!tmp) RegisterManagedStatic(object_creator, object_deleter::call); + TsanHappensAfter(this); return static_cast(Ptr); } }; -template -class ManagedCleanup : public ManagedStaticBase { -public: - void Register() { RegisterManagedStatic(0, CleanupFn); } -}; - - -/// llvm_start_multithreaded - Allocate and initialize structures needed to -/// make LLVM safe for multithreading. The return value indicates whether -/// multithreaded initialization succeeded. LLVM will still be operational -/// on "failed" return, but will not be safe to run multithreaded. -bool llvm_start_multithreaded(); - /// llvm_shutdown - Deallocate and destroy all ManagedStatic variables. void llvm_shutdown();