mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-02 07:11:49 +00:00
Simplify.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@73723 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3c8031df6d
commit
b2c0fe4d93
@ -233,37 +233,30 @@ void Function::removeAttribute(unsigned i, Attributes attr) {
|
||||
// use GC.
|
||||
static DenseMap<const Function*,PooledStringPtr> *GCNames;
|
||||
static StringPool *GCNamePool;
|
||||
static ManagedStatic<sys::RWMutex> GCLock;
|
||||
static ManagedStatic<sys::SmartRWMutex<true> > GCLock;
|
||||
|
||||
bool Function::hasGC() const {
|
||||
if (llvm_is_multithreaded()) {
|
||||
sys::ScopedReader Reader(&*GCLock);
|
||||
return GCNames && GCNames->count(this);
|
||||
} else
|
||||
return GCNames && GCNames->count(this);
|
||||
sys::SmartScopedReader<true> Reader(&*GCLock);
|
||||
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];
|
||||
} else
|
||||
return *(*GCNames)[this];
|
||||
sys::SmartScopedReader<true> Reader(&*GCLock);
|
||||
return *(*GCNames)[this];
|
||||
}
|
||||
|
||||
void Function::setGC(const char *Str) {
|
||||
if (llvm_is_multithreaded()) GCLock->writer_acquire();
|
||||
sys::SmartScopedWriter<true> Writer(&*GCLock);
|
||||
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()) GCLock->writer_acquire();
|
||||
sys::SmartScopedWriter<true> Writer(&*GCLock);
|
||||
if (GCNames) {
|
||||
GCNames->erase(this);
|
||||
if (GCNames->empty()) {
|
||||
@ -275,7 +268,6 @@ void Function::clearGC() {
|
||||
}
|
||||
}
|
||||
}
|
||||
if (llvm_is_multithreaded()) GCLock->writer_release();
|
||||
}
|
||||
|
||||
/// copyAttributesFrom - copy all additional attributes (those not needed to
|
||||
|
Loading…
Reference in New Issue
Block a user