struct Waiter {
    state: AtomicUsize,
    waker: UnsafeCell<Option<Waker>>,
    pointers: Pointers<Waiter>,
    _p: PhantomPinned,
}
Expand description

An entry in the wait queue.

Fields§

§state: AtomicUsize

The current state of the waiter.

This is either the number of remaining permits required by the waiter, or a flag indicating that the waiter is not yet queued.

§waker: UnsafeCell<Option<Waker>>

The waker to notify the task awaiting permits.

Safety

This may only be accessed while the wait queue is locked.

§pointers: Pointers<Waiter>

Intrusive linked-list pointers.

Safety

This may only be accessed while the wait queue is locked.

TODO: Ideally, we would be able to use loom to enforce that this isn’t accessed concurrently. However, it is difficult to use a UnsafeCell here, since the Link trait requires returning references to Pointers, and UnsafeCell requires that checked access take place inside a closure. We should consider changing Pointers to use UnsafeCell internally.

§_p: PhantomPinned

Should not be Unpin.

Implementations§

source§

impl Waiter

source§

impl Waiter

source

fn new(num_permits: usize) -> Self

source

fn assign_permits(&self, n: &mut usize) -> bool

Assign permits to the waiter.

Returns true if the waiter should be removed from the queue

Trait Implementations§

Safety

Waiter is forced to be !Unpin.

§

type Handle = NonNull<Waiter>

Handle to the list entry. Read more
§

type Target = Waiter

Node type.
source§

fn as_raw(handle: &Self::Handle) -> NonNull<Waiter>

Convert the handle to a raw pointer without consuming the handle.
source§

unsafe fn from_raw(ptr: NonNull<Waiter>) -> NonNull<Waiter>

Convert the raw pointer to a handle
source§

unsafe fn pointers(target: NonNull<Waiter>) -> NonNull<Pointers<Waiter>>

Return the pointers for a node Read more

Auto Trait Implementations§

§

impl !RefUnwindSafe for Waiter

§

impl Send for Waiter

§

impl !Sync for Waiter

§

impl !Unpin for Waiter

§

impl !UnwindSafe for Waiter

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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 Twhere 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 Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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.