Skip to content

Commit

Permalink
feat(maitake): add maitake::sync::RwLock (#307)
Browse files Browse the repository at this point in the history
This branch adds an async read-write lock implementation in
`maitake::sync`. This lock is implemented using the `Semaphore` type
added in #301. The rwlock is modeled using a `Semaphore` with
`Semaphore::MAX_PERMITS` permits in it; a reader must acquire a single
permit to gain read access, while a writer must acquire all the permits.
  • Loading branch information
hawkw authored Sep 1, 2022
1 parent 6ef500f commit 1b8c7a4
Show file tree
Hide file tree
Showing 8 changed files with 701 additions and 15 deletions.
23 changes: 23 additions & 0 deletions maitake/src/loom.rs
Original file line number Diff line number Diff line change
Expand Up @@ -141,12 +141,35 @@ mod inner {
f(self.0.get())
}

#[inline(always)]
pub(crate) fn get(&self) -> ConstPtr<T> {
ConstPtr(self.0.get())
}

#[inline(always)]
pub(crate) fn get_mut(&self) -> MutPtr<T> {
MutPtr(self.0.get())
}
}

#[derive(Debug)]
pub(crate) struct ConstPtr<T: ?Sized>(*const T);

impl<T: ?Sized> ConstPtr<T> {
#[inline(always)]
pub(crate) unsafe fn deref(&self) -> &T {
&*self.0
}

#[inline(always)]
pub fn with<F, R>(&self, f: F) -> R
where
F: FnOnce(*const T) -> R,
{
f(self.0)
}
}

#[derive(Debug)]
pub(crate) struct MutPtr<T: ?Sized>(*mut T);

Expand Down
9 changes: 8 additions & 1 deletion maitake/src/sync.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@
//!
//! - [`Mutex`]: a fairly queued, asynchronous [mutual exclusion lock], for
//! protecting shared data
//! - [`RwLock`]: a fairly queued, asynchronous [readers-writer lock], which
//! allows concurrent read access to shared data while ensuring write
//! access is exclusive
//! - [`Semaphore`]: an asynchronous [counting semaphore], for limiting the
//! number of tasks which may run concurrently
//! - [`WaitCell`], a cell that stores a *single* waiting task's [`Waker`], so
Expand All @@ -13,11 +16,13 @@
//! - [`WaitMap`], a set of waiting tasks associated with keys, in which a task
//! can be woken by its key
//!
//! [mutual exclusion lock]:https://en.wikipedia.org/wiki/Mutual_exclusion
//! [mutual exclusion lock]: https://en.wikipedia.org/wiki/Mutual_exclusion
//! [readers-writer lock]: https://en.wikipedia.org/wiki/Readers%E2%80%93writer_lock
//! [counting semaphore]: https://en.wikipedia.org/wiki/Semaphore_(programming)
//! [`Waker`]: core::task::Waker
#![warn(missing_docs, missing_debug_implementations)]
pub mod mutex;
pub mod rwlock;
pub mod semaphore;
pub mod wait_cell;
pub mod wait_map;
Expand All @@ -29,6 +34,8 @@ pub use self::mutex::OwnedMutexGuard;
#[doc(inline)]
pub use self::mutex::{Mutex, MutexGuard};
#[doc(inline)]
pub use self::rwlock::{RwLock, RwLockReadGuard, RwLockWriteGuard};
#[doc(inline)]
pub use self::semaphore::Semaphore;
#[doc(inline)]
pub use self::wait_cell::WaitCell;
Expand Down
4 changes: 3 additions & 1 deletion maitake/src/sync/mutex.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
//! An asynchronous mutual exclusion lock.
//! An asynchronous [mutual exclusion lock].
//!
//! See the documentation on the [`Mutex`] type for details.
//!
//! [mutual exclusion lock]: https://en.wikipedia.org/wiki/Mutual_exclusion
use crate::{
loom::cell::{MutPtr, UnsafeCell},
sync::wait_queue::{self, WaitQueue},
Expand Down
Loading

0 comments on commit 1b8c7a4

Please sign in to comment.