smoltcp::wire

Struct Ipv4Packet

Source
pub struct Ipv4Packet<T: AsRef<[u8]>> { /* private fields */ }
Expand description

A read/write wrapper around an Internet Protocol version 4 packet buffer.

Implementations§

Source§

impl<T: AsRef<[u8]>> Packet<T>

Source

pub const fn new_unchecked(buffer: T) -> Packet<T>

Imbue a raw octet buffer with IPv4 packet structure.

Source

pub fn new_checked(buffer: T) -> Result<Packet<T>>

Shorthand for a combination of new_unchecked and check_len.

Source

pub fn check_len(&self) -> Result<()>

Ensure that no accessor method will panic if called. Returns Err(Error) if the buffer is too short. Returns Err(Error) if the header length is greater than total length.

The result of this check is invalidated by calling set_header_len and set_total_len.

Source

pub fn into_inner(self) -> T

Consume the packet, returning the underlying buffer.

Source

pub fn version(&self) -> u8

Return the version field.

Source

pub fn header_len(&self) -> u8

Return the header length, in octets.

Source

pub fn dscp(&self) -> u8

Return the Differential Services Code Point field.

Source

pub fn ecn(&self) -> u8

Return the Explicit Congestion Notification field.

Source

pub fn total_len(&self) -> u16

Return the total length field.

Source

pub fn ident(&self) -> u16

Return the fragment identification field.

Source

pub fn dont_frag(&self) -> bool

Return the “don’t fragment” flag.

Source

pub fn more_frags(&self) -> bool

Return the “more fragments” flag.

Source

pub fn frag_offset(&self) -> u16

Return the fragment offset, in octets.

Source

pub fn hop_limit(&self) -> u8

Return the time to live field.

Source

pub fn next_header(&self) -> Protocol

Return the next_header (protocol) field.

Source

pub fn checksum(&self) -> u16

Return the header checksum field.

Source

pub fn src_addr(&self) -> Address

Return the source address field.

Source

pub fn dst_addr(&self) -> Address

Return the destination address field.

Source

pub fn verify_checksum(&self) -> bool

Validate the header checksum.

§Fuzzing

This function always returns true when fuzzing.

Source

pub fn get_key(&self) -> Key

Returns the key for identifying the packet.

Source§

impl<'a, T: AsRef<[u8]> + ?Sized> Packet<&'a T>

Source

pub fn payload(&self) -> &'a [u8]

Return a pointer to the payload.

Source§

impl<T: AsRef<[u8]> + AsMut<[u8]>> Packet<T>

Source

pub fn set_version(&mut self, value: u8)

Set the version field.

Source

pub fn set_header_len(&mut self, value: u8)

Set the header length, in octets.

Source

pub fn set_dscp(&mut self, value: u8)

Set the Differential Services Code Point field.

Source

pub fn set_ecn(&mut self, value: u8)

Set the Explicit Congestion Notification field.

Source

pub fn set_total_len(&mut self, value: u16)

Set the total length field.

Source

pub fn set_ident(&mut self, value: u16)

Set the fragment identification field.

Source

pub fn clear_flags(&mut self)

Clear the entire flags field.

Source

pub fn set_dont_frag(&mut self, value: bool)

Set the “don’t fragment” flag.

Source

pub fn set_more_frags(&mut self, value: bool)

Set the “more fragments” flag.

Source

pub fn set_frag_offset(&mut self, value: u16)

Set the fragment offset, in octets.

Source

pub fn set_hop_limit(&mut self, value: u8)

Set the time to live field.

Source

pub fn set_next_header(&mut self, value: Protocol)

Set the next header (protocol) field.

Source

pub fn set_checksum(&mut self, value: u16)

Set the header checksum field.

Source

pub fn set_src_addr(&mut self, value: Address)

Set the source address field.

Source

pub fn set_dst_addr(&mut self, value: Address)

Set the destination address field.

Source

pub fn fill_checksum(&mut self)

Compute and fill in the header checksum.

Source

pub fn payload_mut(&mut self) -> &mut [u8]

Return a mutable pointer to the payload.

Trait Implementations§

Source§

impl<T: AsRef<[u8]>> AsRef<[u8]> for Packet<T>

Source§

fn as_ref(&self) -> &[u8]

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<T: Clone + AsRef<[u8]>> Clone for Packet<T>

Source§

fn clone(&self) -> Packet<T>

Returns a copy of the value. Read more
1.0.0§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<T: Debug + AsRef<[u8]>> Debug for Packet<T>

Source§

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

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

impl<'a, T: AsRef<[u8]> + ?Sized> Display for Packet<&'a T>

Source§

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

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

impl<T: PartialEq + AsRef<[u8]>> PartialEq for Packet<T>

Source§

fn eq(&self, other: &Packet<T>) -> bool

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

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<T: AsRef<[u8]>> PrettyPrint for Packet<T>

Source§

fn pretty_print( buffer: &dyn AsRef<[u8]>, f: &mut Formatter<'_>, indent: &mut PrettyIndent, ) -> Result

Write a concise, formatted representation of a packet contained in the provided buffer, and any nested packets it may contain. Read more
Source§

impl<T: Eq + AsRef<[u8]>> Eq for Packet<T>

Source§

impl<T: AsRef<[u8]>> StructuralPartialEq for Packet<T>

Auto Trait Implementations§

§

impl<T> Freeze for Packet<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for Packet<T>
where T: RefUnwindSafe,

§

impl<T> Send for Packet<T>
where T: Send,

§

impl<T> Sync for Packet<T>
where T: Sync,

§

impl<T> Unpin for Packet<T>
where T: Unpin,

§

impl<T> UnwindSafe for Packet<T>
where T: UnwindSafe,

Blanket Implementations§

§

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

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

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

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

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

§

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

Mutably borrows from an owned value. Read more
§

impl<T> CloneToUninit for T
where T: Clone,

§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

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

§

fn into(self) -> U

Calls U::from(self).

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

§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

impl<T> ToString for T
where T: Display + ?Sized,

§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
§

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

§

type Error = Infallible

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

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

Performs the conversion.
§

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

§

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

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

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

Performs the conversion.