diff options
author | Owen Anderson <resistor@mac.com> | 2009-06-17 23:49:06 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2009-06-17 23:49:06 +0000 |
commit | 90a218cfd6802885f1c42ff59d95bcdd9fcc7ae1 (patch) | |
tree | 4c9fee6bb9d60fc7352ec34daa000c1abf744cec /lib/VMCore/Function.cpp | |
parent | 8b20dabd9924809997e2e10d9acfbffcf8c9c62c (diff) | |
download | external_llvm-90a218cfd6802885f1c42ff59d95bcdd9fcc7ae1.zip external_llvm-90a218cfd6802885f1c42ff59d95bcdd9fcc7ae1.tar.gz external_llvm-90a218cfd6802885f1c42ff59d95bcdd9fcc7ae1.tar.bz2 |
Reapply r73647 in a non-broken form.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@73662 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/VMCore/Function.cpp')
-rw-r--r-- | lib/VMCore/Function.cpp | 40 |
1 files changed, 25 insertions, 15 deletions
diff --git a/lib/VMCore/Function.cpp b/lib/VMCore/Function.cpp index 96c6792..00f9fa3 100644 --- a/lib/VMCore/Function.cpp +++ b/lib/VMCore/Function.cpp @@ -18,6 +18,7 @@ #include "llvm/Support/LeakDetector.h" #include "llvm/Support/ManagedStatic.h" #include "llvm/Support/StringPool.h" +#include "llvm/Support/Threading.h" #include "llvm/System/RWMutex.h" #include "SymbolTableListTraitsImpl.h" #include "llvm/ADT/DenseMap.h" @@ -230,21 +231,20 @@ void Function::removeAttribute(unsigned i, Attributes attr) { // allocating an additional word in Function for programs which do not use GC // (i.e., most programs) at the cost of increased overhead for clients which do // use GC. -static ManagedStatic<DenseMap<const Function*,PooledStringPtr> > GCNames; -static ManagedStatic<StringPool> GCNamePool; +static DenseMap<const Function*,PooledStringPtr> *GCNames; +static StringPool *GCNamePool; static ManagedStatic<sys::RWMutex> GCLock; bool Function::hasGC() const { if (llvm_is_multithreaded()) { sys::ScopedReader Reader(&*GCLock); - return GCNames->count(this); - } else - return GCNames->count(this); + return GCNames && GCNames->count(this); + } else + return GCNames && GCNames->count(this); } const char *Function::getGC() const { assert(hasGC() && "Function has no collector"); - if (llvm_is_multithreaded()) { sys::ScopedReader Reader(&*GCLock); return *(*GCNames)[this]; @@ -253,19 +253,29 @@ const char *Function::getGC() const { } void Function::setGC(const char *Str) { - if (llvm_is_multithreaded()) { - sys::ScopedWriter Writer(&*GCLock); - (*GCNames)[this] = GCNamePool->intern(Str); - } else - (*GCNames)[this] = GCNamePool->intern(Str); + if (llvm_is_multithreaded()) GCLock->writer_acquire(); + if (!GCNamePool) + GCNamePool = new StringPool(); + if (!GCNames) + GCNames = new DenseMap<const Function*,PooledStringPtr>(); + (*GCNames)[this] = GCNamePool->intern(Str); + if (llvm_is_multithreaded()) GCLock->writer_release(); } void Function::clearGC() { - if (llvm_is_multithreaded()) { - sys::ScopedWriter Writer(&*GCLock); - GCNames->erase(this); - } else + if (llvm_is_multithreaded()) GCLock->writer_acquire(); + if (GCNames) { GCNames->erase(this); + if (GCNames->empty()) { + delete GCNames; + GCNames = 0; + if (GCNamePool->empty()) { + delete GCNamePool; + GCNamePool = 0; + } + } + } + if (llvm_is_multithreaded()) GCLock->writer_release(); } /// copyAttributesFrom - copy all additional attributes (those not needed to |