Crates.io | priomutex |
lib.rs | priomutex |
version | 0.3.1 |
source | src |
created_at | 2018-01-25 06:39:02.370026 |
updated_at | 2018-04-10 06:22:38.031186 |
description | A mutex where waiting threads specify a priority |
homepage | |
repository | https://github.com/asayers/priomutex |
max_upload_size | |
id | 48233 |
size | 41,380 |
The API is very similar to std::sync::Mutex. The key difference, of course, is that lock() takes a priority. If multiple threads are waiting for the mutex when it's freed, the one which gave the highest priorty will recieve it.
impl<T> Mutex<T> {
fn new(data: T) -> Mutex<T>;
fn lock(&self, prio: usize) -> LockResult<MutexGuard<T>>;
fn try_lock(&self) -> TryLockResult<MutexGuard<T>>;
}
impl<T> Drop for MutexGuard<T>; // Releases the lock
impl<T> Deref for MutexGuard<T>; // For accessing your data
impl<T> DerefMut for MutexGuard<T>; // For accessing your data
This crate also includes a high-performance variant in the spin_one module, which spins the highest-priority waiting thread. This makes releasing the mutex very fast, because it never needs to do any syscalls.
There is no unsafe code used in either variant, so there's no possibility of two threads holding the mutex at the same time. Bugs may lead to deadlocks or non-priority-order locking, however. I'm not currently aware of any such bugs.
Benchmarking locking time is difficult. Release time, however, can be reliably measured:
simple: 2887 ns
spin_one: 248 ns
(Intel Core i7-4790K CPU @ 4.00GHz, max_cstate = 0)
Licensed under either of the following, at your option:
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.