*/
#pragma once
+#include <mutex>
+
namespace folly {
namespace fibers {
template <typename BatonType>
void TimedRWMutex<BatonType>::read_lock() {
- lock_.lock();
+ std::unique_lock<folly::SpinLock> lock{lock_};
if (state_ == State::WRITE_LOCKED) {
MutexWaiter waiter;
read_waiters_.push_back(waiter);
- lock_.unlock();
+ lock.unlock();
waiter.baton.wait();
assert(state_ == State::READ_LOCKED);
return;
assert(read_waiters_.empty());
state_ = State::READ_LOCKED;
readers_ += 1;
- lock_.unlock();
}
template <typename BatonType>
template <typename Rep, typename Period>
bool TimedRWMutex<BatonType>::timed_read_lock(
const std::chrono::duration<Rep, Period>& duration) {
- lock_.lock();
+ std::unique_lock<folly::SpinLock> lock{lock_};
if (state_ == State::WRITE_LOCKED) {
MutexWaiter waiter;
read_waiters_.push_back(waiter);
- lock_.unlock();
+ lock.unlock();
if (!waiter.baton.timed_wait(duration)) {
// We timed out. Two cases:
// 2. We're not in the waiter list anymore. This could happen if the baton
// times out but the mutex is unlocked before we reach this code. In
// this case we'll pretend we got the lock on time.
- lock_.lock();
+ std::lock_guard<SpinLock> guard{lock_};
if (waiter.hook.is_linked()) {
read_waiters_.erase(read_waiters_.iterator_to(waiter));
- lock_.unlock();
return false;
}
- lock_.unlock();
}
return true;
}
assert(read_waiters_.empty());
state_ = State::READ_LOCKED;
readers_ += 1;
- lock_.unlock();
return true;
}
template <typename BatonType>
bool TimedRWMutex<BatonType>::try_read_lock() {
- lock_.lock();
+ std::lock_guard<SpinLock> guard{lock_};
if (state_ != State::WRITE_LOCKED) {
assert(
(state_ == State::UNLOCKED && readers_ == 0) ||
assert(read_waiters_.empty());
state_ = State::READ_LOCKED;
readers_ += 1;
- lock_.unlock();
return true;
}
- lock_.unlock();
return false;
}
template <typename BatonType>
void TimedRWMutex<BatonType>::write_lock() {
- lock_.lock();
+ std::unique_lock<folly::SpinLock> lock{lock_};
if (state_ == State::UNLOCKED) {
verify_unlocked_properties();
state_ = State::WRITE_LOCKED;
- lock_.unlock();
return;
}
MutexWaiter waiter;
write_waiters_.push_back(waiter);
- lock_.unlock();
+ lock.unlock();
waiter.baton.wait();
}
template <typename Rep, typename Period>
bool TimedRWMutex<BatonType>::timed_write_lock(
const std::chrono::duration<Rep, Period>& duration) {
- lock_.lock();
+ std::unique_lock<folly::SpinLock> lock{lock_};
if (state_ == State::UNLOCKED) {
verify_unlocked_properties();
state_ = State::WRITE_LOCKED;
- lock_.unlock();
return true;
}
MutexWaiter waiter;
write_waiters_.push_back(waiter);
- lock_.unlock();
+ lock.unlock();
if (!waiter.baton.timed_wait(duration)) {
// We timed out. Two cases:
// 2. We're not in the waiter list anymore. This could happen if the baton
// times out but the mutex is unlocked before we reach this code. In
// this case we'll pretend we got the lock on time.
- lock_.lock();
+ std::lock_guard<SpinLock> guard{lock_};
if (waiter.hook.is_linked()) {
write_waiters_.erase(write_waiters_.iterator_to(waiter));
- lock_.unlock();
return false;
}
- lock_.unlock();
}
assert(state_ == State::WRITE_LOCKED);
return true;
template <typename BatonType>
bool TimedRWMutex<BatonType>::try_write_lock() {
- lock_.lock();
+ std::lock_guard<SpinLock> guard{lock_};
if (state_ == State::UNLOCKED) {
verify_unlocked_properties();
state_ = State::WRITE_LOCKED;
- lock_.unlock();
return true;
}
- lock_.unlock();
return false;
}
template <typename BatonType>
void TimedRWMutex<BatonType>::unlock() {
- lock_.lock();
+ std::lock_guard<SpinLock> guard{lock_};
assert(state_ != State::UNLOCKED);
assert(
(state_ == State::READ_LOCKED && readers_ > 0) ||
} else {
assert(state_ == State::READ_LOCKED);
}
- lock_.unlock();
}
template <typename BatonType>
void TimedRWMutex<BatonType>::downgrade() {
- lock_.lock();
+ std::lock_guard<SpinLock> guard{lock_};
assert(state_ == State::WRITE_LOCKED && readers_ == 0);
state_ = State::READ_LOCKED;
readers_ += 1;
to_wake.baton.post();
}
}
- lock_.unlock();
}
}
}