DadState

Enum DadState 

Source
pub enum DadState<I: DadIpExt, BT: DadBindingsTypes> {
    Assigned {
        ran_dad: bool,
    },
    Announcing {
        timer: BT::Timer,
        ip_specific_state: I::AnnouncingState,
    },
    Tentative {
        dad_transmits_remaining: Option<NonZeroU16>,
        timer: BT::Timer,
        ip_specific_state: I::TentativeState,
        probe_wait: Option<Duration>,
    },
    Uninitialized,
}
Expand description

The various states DAD may be in for an address.

Variants§

§

Assigned

The address is assigned to an interface and can be considered bound to it (all packets destined to the address will be accepted).

Fields

§ran_dad: bool

Indicates whether the address is assigned because DAD completed successfully, or because DAD was disabled and skipped.

§

Announcing

Like Self::Assigned, but the DAD engine is announcing to the network that we are using this address.

This state corresponds to the announcing described in RFC 5227 section 2.3 and as such only applies to IPv4 addresses. The IPv6 DAD specification (RFC 4862 section 5.4) does not define an announcement period.

Fields

§timer: BT::Timer

The timer used to schedule DAD operations in the future.

§ip_specific_state: I::AnnouncingState

Announcing state specific to the given IP version.

§

Tentative

The address is considered unassigned to an interface for normal operations, but has the intention of being assigned in the future (e.g. once Duplicate Address Detection is completed).

Fields

§dad_transmits_remaining: Option<NonZeroU16>

The number of probes that still need to be sent. When None, there are no more probes to send and DAD may resolve.

§timer: BT::Timer

The timer used to schedule DAD operations in the future.

§ip_specific_state: I::TentativeState

Probing state specific to the given IP version.

§probe_wait: Option<Duration>

The (optional) delay to wait before starting to send DAD probes.

§

Uninitialized

The address has not yet been initialized.

Trait Implementations§

Source§

impl<I: DadIpExt, BT: DadBindingsTypes> Debug for DadState<I, BT>

Source§

fn fmt(&self, __f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<I: IpDeviceStateIpExt, BT: IpDeviceStateBindingsTypes> OrderedLockAccess<DadState<I, BT>> for IpAddressEntry<I, BT>

Source§

type Lock = Mutex<DadState<I, BT>>

The lock type that observes ordering. Read more
Source§

fn ordered_lock_access(&self) -> OrderedLockRef<'_, Self::Lock>

Returns a borrow to the order-aware lock. Read more

Auto Trait Implementations§

§

impl<I, BT> Freeze for DadState<I, BT>
where <BT as TimerBindingsTypes>::Timer: Freeze, <I as DadIpExt>::AnnouncingState: Freeze, <I as DadIpExt>::TentativeState: Freeze,

§

impl<I, BT> RefUnwindSafe for DadState<I, BT>
where <BT as TimerBindingsTypes>::Timer: RefUnwindSafe, <I as DadIpExt>::AnnouncingState: RefUnwindSafe, <I as DadIpExt>::TentativeState: RefUnwindSafe,

§

impl<I, BT> Send for DadState<I, BT>

§

impl<I, BT> Sync for DadState<I, BT>

§

impl<I, BT> Unpin for DadState<I, BT>
where <BT as TimerBindingsTypes>::Timer: Unpin, <I as DadIpExt>::AnnouncingState: Unpin, <I as DadIpExt>::TentativeState: Unpin,

§

impl<I, BT> UnwindSafe for DadState<I, BT>
where <BT as TimerBindingsTypes>::Timer: UnwindSafe, <I as DadIpExt>::AnnouncingState: UnwindSafe, <I as DadIpExt>::TentativeState: UnwindSafe,

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
§

impl<T, D> Encode<Ambiguous1, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
§

impl<T, D> Encode<Ambiguous2, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. 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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<CC, BC, Meta> RecvFrameContext<Meta, BC> for CC
where Meta: ReceivableFrameMeta<CC, BC>,

Source§

fn receive_frame<B>(&mut self, bindings_ctx: &mut BC, metadata: Meta, frame: B)
where B: BufferMut + Debug,

Receive a frame. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<CC, BC, Meta> SendFrameContext<BC, Meta> for CC
where Meta: SendableFrameMeta<CC, BC>,

Source§

fn send_frame<S>( &mut self, bindings_ctx: &mut BC, metadata: Meta, frame: S, ) -> Result<(), ErrorAndSerializer<SendFrameErrorReason, S>>

Send a frame. Read more
Source§

impl<BC, S, Meta, DeviceId> SendableFrameMeta<FakeCoreCtx<S, Meta, DeviceId>, BC> for Meta

Source§

fn send_meta<SS>( self, core_ctx: &mut FakeCoreCtx<S, Meta, DeviceId>, bindings_ctx: &mut BC, frame: SS, ) -> Result<(), ErrorAndSerializer<SendFrameErrorReason, SS>>
where SS: Serializer, <SS as Serializer>::Buffer: BufferMut,

Sends this frame metadata to the provided contexts.
Source§

impl<Meta, BC> SendableFrameMeta<FakeFrameCtx<Meta>, BC> for Meta

Source§

fn send_meta<S>( self, core_ctx: &mut FakeFrameCtx<Meta>, _bindings_ctx: &mut BC, frame: S, ) -> Result<(), ErrorAndSerializer<SendFrameErrorReason, S>>

Sends this frame metadata to the provided contexts.
Source§

impl<Id, CC, BC> TimerHandler<BC, Id> for CC
where BC: TimerBindingsTypes, Id: HandleableTimer<CC, BC>,

Source§

fn handle_timer( &mut self, bindings_ctx: &mut BC, dispatch: Id, timer: <BC as TimerBindingsTypes>::UniqueTimerId, )

Handle a timer firing. Read more
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.
Source§

impl<L, T> UnlockedAccess<L> for T

Source§

type Data = <L as UnlockedAccessMarkerFor<T>>::Data

The type of state being accessed.
Source§

type Guard<'l> = &'l <L as UnlockedAccessMarkerFor<T>>::Data where T: 'l

A guard providing read access to the data.
Source§

fn access(&self) -> <T as UnlockedAccess<L>>::Guard<'_>

How to access the state.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

Source§

impl<B, A> LockBefore<B> for A
where B: LockAfter<A>,