X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=include%2Fllvm%2FSupport%2FManagedStatic.h;h=b8e223587fbd34d305704e2d701d7c8840689bf1;hb=41b5adf20208f46e4b1104d6d473710fbfa61eb9;hp=412e474ffba6f85694ebf85d293fe7fd845610f3;hpb=4c7ac18fc9e9af51ea6362871589c13263526d7a;p=oota-llvm.git diff --git a/include/llvm/Support/ManagedStatic.h b/include/llvm/Support/ManagedStatic.h index 412e474ffba..b8e223587fb 100644 --- a/include/llvm/Support/ManagedStatic.h +++ b/include/llvm/Support/ManagedStatic.h @@ -15,7 +15,7 @@ #define LLVM_SUPPORT_MANAGED_STATIC_H #include "llvm/System/Atomic.h" -#include "llvm/Support/Threading.h" +#include "llvm/System/Threading.h" namespace llvm { @@ -27,10 +27,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 { @@ -61,29 +63,29 @@ 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); 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); 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); 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); return static_cast(Ptr); }