cooptex provides deadlock-free Mutexes. The [CoopMutex::lock
] method wraps the
[std::sync::Mutex
] return value with a Result
that will request the caller to drop other held
locks so another thread could make progress. This behavior is easily accomplished by using the
[retry_loop
] function.
```rust use cooptex::*; let a = CoopMutex::new(42); let b = CoopMutex::new(43);
retryloop(|| { let alock = a.lock()?.unwrap(); let block = b.lock()?.unwrap(); asserteq!(*alock + *block, 85); Ok(()) }); ```
This crate aims to guarantee that multiple threads cannot possibly deadlock by acquiring locks.
The crate is still in early development, so there may be cases that aren't covered. Please open an issue if you can reproduce a deadlock.
This crate allows the following potentially undesired behavior:
CoopMutex::lock
] may return [Retry
] when it could wait and acquire the lock without
a deadlock.CoopMutex::lock
] may wait arbitrarily long before returning [Retry
].MutexGuard
] is not [Send
], as we haven't fully evaluated the implications of sending
MutexGuard
s.retry_loop
] will spin-lock the calling thread until it can make progress.License: MIT