Expand description
Synchronization objects used by Starnix
Re-exports§
pub use crate::LockBefore;
pub use crate::LockEqualOrBefore;
pub use crate::LockFor;
pub use crate::RwLockFor;
Macros§
- lock_
level - lock_
ordering - This macro takes a definition of the lock ordering graph in the form of lock_ordering!{ Unlocked -> A, A -> B, Unlocked -> C, }
Structs§
- Atomic
Monotonic Instant - An atomic wrapper around
zx::MonotonicInstant
. - Event
Wait Guard - A guard object to enforce that clients call
begin_wait
beforeblock_until
. - Interruptible
Event - A blocking object that can either be notified normally or interrupted
- Locked
- Enforcement mechanism for lock ordering.
- Ordered
Mutex - A wrapper for mutex that requires a
Locked
context to acquire. This context must be of a level that precedesL
in the lock ordering graph whereL
is a level associated with this mutex. - Ordered
RwLock - A wrapper for an RwLock that requires a
Locked
context to acquire. This context must be of a level that precedesL
in the lock ordering graph whereL
is a level associated with this RwLock. - Port
Event - A wrapper around a
zx::Port
that optimizes for the case where events are signaled within a process.
Enums§
- Before
FsNode Append - BpfPrograms
- Device
Open - File
OpsCore - FsNode
Append - Kernel
IpTables - Kernel
Swap Files - Memory
Pressure Monitor - Memory
Pressure Monitor Client State - MmDumpable
- Notify
Kind - The kind of notification.
- Port
Wait Result - The result of a call to [
PortEvent.wait
]. - Process
Group State - Resource
Accessor AddFile - Task
Release - Uninterruptible
Lock - Unlocked
- “Highest” lock level
- User
Fault Inner - Wake
Reason - A description of why a
block_until
returned without the event being notified.
Traits§
- Lock
After - Marker trait that indicates that
Self
can be locked afterA
. - Lock
Before - Marker trait that indicates that
Self
is an ancestor ofX
. - Lock
Equal OrBefore - Marker trait that indicates that
Self
isX
or an ancestor ofX
. - LockFor
- Describes how to apply a lock type to the implementing type.
- RwLock
For - Describes how to acquire reader and writer locks to the implementing type.
Functions§
- lock_
both - Lock two OrderedMutex of the same level in the consistent order. Returns both guards and a new locked context.
- ordered_
lock - Lock
m1
andm2
in a consistent order (using the memory address of m1 and m2 and returns the associated guard. This ensure thatordered_lock(m1, m2)
andordered_lock(m2, m1)
will not deadlock.