mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-22 02:33:06 +01:00
Fix RWMutex to be thread-safe when pthread_rwlock is not available
lib/Support/RWMutex.cpp contains an implementation of RWMutex that uses pthread_rwlock, but when pthread_rwlock is not available (such as under NaCl, when using newlib), it silently falls back to using the no-op definition in lib/Support/Unix/RWMutex.inc, which is not thread-safe. Fix this case to be thread-safe by using a normal mutex. Differential Revision: http://llvm-reviews.chandlerc.com/D2892 llvm-svn: 202570
This commit is contained in:
parent
0369d0e738
commit
83fd697a96
@ -16,28 +16,36 @@
|
||||
//=== is guaranteed to work on *all* UNIX variants.
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "llvm/Support/Mutex.h"
|
||||
|
||||
namespace llvm {
|
||||
|
||||
using namespace sys;
|
||||
|
||||
RWMutexImpl::RWMutexImpl() { }
|
||||
// This naive implementation treats readers the same as writers. This
|
||||
// will therefore deadlock if a thread tries to acquire a read lock
|
||||
// multiple times.
|
||||
|
||||
RWMutexImpl::~RWMutexImpl() { }
|
||||
RWMutexImpl::RWMutexImpl() : data_(new Mutex(false)) { }
|
||||
|
||||
RWMutexImpl::~RWMutexImpl() {
|
||||
delete static_cast<Mutex *>(data_);
|
||||
}
|
||||
|
||||
bool RWMutexImpl::reader_acquire() {
|
||||
return true;
|
||||
return static_cast<Mutex *>(data_)->acquire();
|
||||
}
|
||||
|
||||
bool RWMutexImpl::reader_release() {
|
||||
return true;
|
||||
return static_cast<Mutex *>(data_)->release();
|
||||
}
|
||||
|
||||
bool RWMutexImpl::writer_acquire() {
|
||||
return true;
|
||||
return static_cast<Mutex *>(data_)->acquire();
|
||||
}
|
||||
|
||||
bool RWMutexImpl::writer_release() {
|
||||
return true;
|
||||
return static_cast<Mutex *>(data_)->release();
|
||||
}
|
||||
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user