Struct ForwardedPacket

Source
pub struct ForwardedPacket<I: IpExt, B> { /* private fields */ }
Expand description

An incoming IP packet that is being forwarded.

Implementations§

Source§

impl<I: IpExt, B: BufferMut> ForwardedPacket<I, B>

Source

pub fn new( src_addr: I::Addr, dst_addr: I::Addr, protocol: I::Proto, meta: ParseMetadata, buffer: B, ) -> Self

Create a new ForwardedPacket from its IP header fields and payload.

meta is used to revert buffer back to the IP header for further serialization, and to mark where the transport header starts in buffer. It must have originated from a previously parsed IP packet on buffer.

Source

pub fn into_buffer(self) -> B

Discard the metadata carried by the ForwardedPacket and return the inner buffer.

The returned buffer is guaranteed to contain a valid IP frame, the start of the buffer points at the start of the IP header.

Source

pub fn buffer(&self) -> &B

Returns a reference to the forwarded buffer.

The returned reference is guaranteed to contain a valid IP frame, the start of the buffer points at the start of the IP header.

Trait Implementations§

Source§

impl<I: Debug + IpExt, B: Debug> Debug for ForwardedPacket<I, B>
where I::Addr: Debug, I::Proto: Debug,

Source§

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

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

impl<I: IpExt, B, IpType> GenericOverIp<IpType> for ForwardedPacket<I, B>
where IpType: IpExt + Ip,

Source§

type Type = ForwardedPacket<IpType, B>

The type of Self when its IP-generic parameter is replaced with the type NewIp.
Source§

impl<I: IpExt, B: BufferMut> IpPacket<I> for ForwardedPacket<I, B>

Source§

type TransportPacket<'a> = &'a ForwardedPacket<I, B> where Self: 'a

The type that provides access to transport-layer header inspection, if a transport header is contained in the body of the IP packet.
Source§

type TransportPacketMut<'a> = Option<ParsedTransportHeaderMut<'a, I>> where Self: 'a

The type that provides access to transport-layer header modification, if a transport header is contained in the body of the IP packet.
Source§

fn src_addr(&self) -> I::Addr

The source IP address of the packet.
Source§

fn set_src_addr(&mut self, addr: I::Addr)

Sets the source IP address of the packet.
Source§

fn dst_addr(&self) -> I::Addr

The destination IP address of the packet.
Source§

fn set_dst_addr(&mut self, addr: I::Addr)

Sets the destination IP address of the packet.
Source§

fn protocol(&self) -> I::Proto

The IP protocol of the packet.
Source§

fn maybe_transport_packet(&self) -> Self::TransportPacket<'_>

Returns a type that provides access to the transport-layer packet contained in the body of the IP packet, if one exists. Read more
Source§

fn transport_packet_mut(&mut self) -> Self::TransportPacketMut<'_>

Returns a type that provides the ability to modify the transport-layer packet contained in the body of the IP packet, if one exists. Read more
Source§

impl<I: IpExt, B: BufferMut> MaybeTransportPacket for ForwardedPacket<I, B>

Source§

fn transport_packet_data(&self) -> Option<TransportPacketData>

Optionally returns a type that provides access to this transport-layer packet.
Source§

impl<I: PartialEq + IpExt, B: PartialEq> PartialEq for ForwardedPacket<I, B>
where I::Addr: PartialEq, I::Proto: PartialEq,

Source§

fn eq(&self, other: &ForwardedPacket<I, B>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<I: IpExt, B: BufferMut> Serializer for ForwardedPacket<I, B>

Source§

type Buffer = <B as Serializer>::Buffer

The type of buffers returned from serialization methods on this trait.
Source§

fn serialize<G: GrowBufferMut, P: BufferProvider<Self::Buffer, G>>( self, outer: PacketConstraints, provider: P, ) -> Result<G, (SerializeError<P::Error>, Self)>

Serializes this Serializer, producing a buffer. Read more
Source§

fn serialize_new_buf<BB: ReusableBuffer, A: BufferAlloc<BB>>( &self, outer: PacketConstraints, alloc: A, ) -> Result<BB, SerializeError<A::Error>>

Serializes the data into a new buffer without consuming self. Read more
§

fn serialize_vec( self, outer: PacketConstraints, ) -> Result<Either<Self::Buffer, Buf<Vec<u8>>>, (SerializeError<Infallible>, Self)>
where Self::Buffer: ReusableBuffer,

Serializes this Serializer, allocating a Buf<Vec<u8>> if the contained buffer isn’t large enough. Read more
§

fn serialize_no_alloc( self, outer: PacketConstraints, ) -> Result<Self::Buffer, (SerializeError<BufferTooShortError>, Self)>
where Self::Buffer: ReusableBuffer,

Serializes this Serializer, failing if the existing buffer is not large enough. Read more
§

fn serialize_outer<B, P>( self, provider: P, ) -> Result<B, (SerializeError<<P as BufferProvider<Self::Buffer, B>>::Error>, Self)>
where B: GrowBufferMut, P: BufferProvider<Self::Buffer, B>,

Serializes this Serializer as the outermost packet. Read more
§

fn serialize_vec_outer( self, ) -> Result<Either<Self::Buffer, Buf<Vec<u8>>>, (SerializeError<Infallible>, Self)>
where Self::Buffer: ReusableBuffer,

Serializes this Serializer as the outermost packet, allocating a Buf<Vec<u8>> if the contained buffer isn’t large enough. Read more
§

fn serialize_no_alloc_outer( self, ) -> Result<Self::Buffer, (SerializeError<BufferTooShortError>, Self)>
where Self::Buffer: ReusableBuffer,

Serializes this Serializer as the outermost packet, failing if the existing buffer is not large enough. Read more
§

fn encapsulate<B>(self, outer: B) -> Nested<Self, B>

Encapsulates this Serializer in another packet, producing a new Serializer. Read more
§

fn with_size_limit(self, limit: usize) -> Nested<Self, LimitedSizePacketBuilder>

Creates a new Serializer which will enforce a size limit. Read more
Source§

impl<I: IpExt, B> StructuralPartialEq for ForwardedPacket<I, B>

Auto Trait Implementations§

§

impl<I, B> Freeze for ForwardedPacket<I, B>
where <I as Ip>::Addr: Freeze, <I as IpProtoExt>::Proto: Freeze, B: Freeze,

§

impl<I, B> RefUnwindSafe for ForwardedPacket<I, B>

§

impl<I, B> Send for ForwardedPacket<I, B>
where B: Send,

§

impl<I, B> Sync for ForwardedPacket<I, B>
where B: Sync,

§

impl<I, B> Unpin for ForwardedPacket<I, B>
where <I as Ip>::Addr: Unpin, <I as IpProtoExt>::Proto: Unpin, B: Unpin,

§

impl<I, B> UnwindSafe for ForwardedPacket<I, B>
where <I as Ip>::Addr: UnwindSafe, <I as IpProtoExt>::Proto: UnwindSafe, B: 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<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>>
where S: Serializer, <S as Serializer>::Buffer: BufferMut,

Send a frame. Read more
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.
§

impl<L, T> UnlockedAccess<L> for T
where L: UnlockedAccessMarkerFor<T>,

§

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

The type of state being accessed.
§

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

A guard providing read access to the data.
§

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

§

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