Struct parking_lot::raw_rwlock::RawRwLock

source ·
pub struct RawRwLock {
    state: AtomicUsize,
}
Expand description

Raw reader-writer lock type backed by the parking lot.

Fields§

§state: AtomicUsize

Implementations§

source§

impl RawRwLock

source

fn try_lock_shared_fast(&self, recursive: bool) -> bool

source

fn try_lock_shared_slow(&self, recursive: bool) -> bool

source

fn try_lock_upgradable_fast(&self) -> bool

source

fn try_lock_upgradable_slow(&self) -> bool

source

fn lock_exclusive_slow(&self, timeout: Option<Instant>) -> bool

source

fn unlock_exclusive_slow(&self, force_fair: bool)

source

fn lock_shared_slow(&self, recursive: bool, timeout: Option<Instant>) -> bool

source

fn unlock_shared_slow(&self)

source

fn lock_upgradable_slow(&self, timeout: Option<Instant>) -> bool

source

fn unlock_upgradable_slow(&self, force_fair: bool)

source

fn try_upgrade_slow(&self) -> bool

source

fn upgrade_slow(&self, timeout: Option<Instant>) -> bool

source

fn downgrade_slow(&self)

source

fn downgrade_to_upgradable_slow(&self)

source

unsafe fn bump_shared_slow(&self)

source

fn bump_exclusive_slow(&self)

source

fn bump_upgradable_slow(&self)

source

unsafe fn wake_parked_threads( &self, new_state: usize, callback: impl FnOnce(usize, UnparkResult) -> UnparkToken, )

Common code for waking up parked threads after releasing WRITER_BIT or UPGRADABLE_BIT.

§Safety

callback must uphold the requirements of the callback parameter to parking_lot_core::unpark_filter. Meaning no panics or calls into any function in parking_lot.

source

fn wait_for_readers(&self, timeout: Option<Instant>, prev_value: usize) -> bool

source

fn lock_common( &self, timeout: Option<Instant>, token: ParkToken, try_lock: impl FnMut(&mut usize) -> bool, validate_flags: usize, ) -> bool

Common code for acquiring a lock

source

fn deadlock_acquire(&self)

source

fn deadlock_release(&self)

Trait Implementations§

source§

impl RawRwLock for RawRwLock

source§

const INIT: RawRwLock = _

Initial value for an unlocked RwLock.
source§

type GuardMarker = GuardNoSend

Marker type which determines whether a lock guard should be Send. Use one of the GuardSend or GuardNoSend helper types here.
source§

fn lock_exclusive(&self)

Acquires an exclusive lock, blocking the current thread until it is able to do so.
source§

fn try_lock_exclusive(&self) -> bool

Attempts to acquire an exclusive lock without blocking.
source§

unsafe fn unlock_exclusive(&self)

Releases an exclusive lock. Read more
source§

fn lock_shared(&self)

Acquires a shared lock, blocking the current thread until it is able to do so.
source§

fn try_lock_shared(&self) -> bool

Attempts to acquire a shared lock without blocking.
source§

unsafe fn unlock_shared(&self)

Releases a shared lock. Read more
source§

fn is_locked(&self) -> bool

Checks if this RwLock is currently locked in any way.
source§

fn is_locked_exclusive(&self) -> bool

Check if this RwLock is currently exclusively locked.
source§

impl RawRwLockDowngrade for RawRwLock

source§

unsafe fn downgrade(&self)

Atomically downgrades an exclusive lock into a shared lock without allowing any thread to take an exclusive lock in the meantime. Read more
source§

impl RawRwLockFair for RawRwLock

source§

unsafe fn unlock_shared_fair(&self)

Releases a shared lock using a fair unlock protocol. Read more
source§

unsafe fn unlock_exclusive_fair(&self)

Releases an exclusive lock using a fair unlock protocol. Read more
source§

unsafe fn bump_shared(&self)

Temporarily yields a shared lock to a waiting thread if there is one. Read more
source§

unsafe fn bump_exclusive(&self)

Temporarily yields an exclusive lock to a waiting thread if there is one. Read more
source§

impl RawRwLockRecursive for RawRwLock

source§

fn lock_shared_recursive(&self)

Acquires a shared lock without deadlocking in case of a recursive lock.
source§

fn try_lock_shared_recursive(&self) -> bool

Attempts to acquire a shared lock without deadlocking in case of a recursive lock.
source§

impl RawRwLockRecursiveTimed for RawRwLock

source§

fn try_lock_shared_recursive_for(&self, timeout: Self::Duration) -> bool

Attempts to acquire a shared lock until a timeout is reached, without deadlocking in case of a recursive lock.
source§

fn try_lock_shared_recursive_until(&self, timeout: Self::Instant) -> bool

Attempts to acquire a shared lock until a timeout is reached, without deadlocking in case of a recursive lock.
source§

impl RawRwLockTimed for RawRwLock

source§

type Duration = Duration

Duration type used for try_lock_for.
source§

type Instant = Instant

Instant type used for try_lock_until.
source§

fn try_lock_shared_for(&self, timeout: Self::Duration) -> bool

Attempts to acquire a shared lock until a timeout is reached.
source§

fn try_lock_shared_until(&self, timeout: Self::Instant) -> bool

Attempts to acquire a shared lock until a timeout is reached.
source§

fn try_lock_exclusive_for(&self, timeout: Duration) -> bool

Attempts to acquire an exclusive lock until a timeout is reached.
source§

fn try_lock_exclusive_until(&self, timeout: Instant) -> bool

Attempts to acquire an exclusive lock until a timeout is reached.
source§

impl RawRwLockUpgrade for RawRwLock

source§

fn lock_upgradable(&self)

Acquires an upgradable lock, blocking the current thread until it is able to do so.
source§

fn try_lock_upgradable(&self) -> bool

Attempts to acquire an upgradable lock without blocking.
source§

unsafe fn unlock_upgradable(&self)

Releases an upgradable lock. Read more
source§

unsafe fn upgrade(&self)

Upgrades an upgradable lock to an exclusive lock. Read more
source§

unsafe fn try_upgrade(&self) -> bool

Attempts to upgrade an upgradable lock to an exclusive lock without blocking. Read more
source§

impl RawRwLockUpgradeDowngrade for RawRwLock

source§

unsafe fn downgrade_upgradable(&self)

Downgrades an upgradable lock to a shared lock. Read more
source§

unsafe fn downgrade_to_upgradable(&self)

Downgrades an exclusive lock to an upgradable lock. Read more
source§

impl RawRwLockUpgradeFair for RawRwLock

source§

unsafe fn unlock_upgradable_fair(&self)

Releases an upgradable lock using a fair unlock protocol. Read more
source§

unsafe fn bump_upgradable(&self)

Temporarily yields an upgradable lock to a waiting thread if there is one. Read more
source§

impl RawRwLockUpgradeTimed for RawRwLock

source§

fn try_lock_upgradable_until(&self, timeout: Instant) -> bool

Attempts to acquire an upgradable lock until a timeout is reached.
source§

fn try_lock_upgradable_for(&self, timeout: Duration) -> bool

Attempts to acquire an upgradable lock until a timeout is reached.
source§

unsafe fn try_upgrade_until(&self, timeout: Instant) -> bool

Attempts to upgrade an upgradable lock to an exclusive lock until a timeout is reached. Read more
source§

unsafe fn try_upgrade_for(&self, timeout: Duration) -> bool

Attempts to upgrade an upgradable lock to an exclusive lock until a timeout is reached. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.