Embassy
embassy-net

Crates

git

Versions

default

Flavors

Struct embassy_net::udp::UdpSocket

source ·
pub struct UdpSocket<'a> { /* private fields */ }
Expand description

An UDP socket.

Implementations§

source§

impl<'a> UdpSocket<'a>

source

pub fn new<D: Driver>( stack: &'a Stack<D>, rx_meta: &'a mut [PacketMetadata], rx_buffer: &'a mut [u8], tx_meta: &'a mut [PacketMetadata], tx_buffer: &'a mut [u8] ) -> Self

Create a new UDP socket using the provided stack and buffers.

source

pub fn bind<T>(&mut self, endpoint: T) -> Result<(), BindError>

Bind the socket to a local endpoint.

source

pub async fn recv_from( &self, buf: &mut [u8] ) -> Result<(usize, UdpMetadata), RecvError>

Receive a datagram.

This method will wait until a datagram is received.

Returns the number of bytes received and the remote endpoint.

source

pub fn poll_recv_from( &self, buf: &mut [u8], cx: &mut Context<'_> ) -> Poll<Result<(usize, UdpMetadata), RecvError>>

Receive a datagram.

When no datagram is available, this method will return Poll::Pending and register the current task to be notified when a datagram is received.

When a datagram is received, this method will return Poll::Ready with the number of bytes received and the remote endpoint.

source

pub async fn send_to<T>( &self, buf: &[u8], remote_endpoint: T ) -> Result<(), SendError>
where T: Into<UdpMetadata>,

Send a datagram to the specified remote endpoint.

This method will wait until the datagram has been sent.

When the remote endpoint is not reachable, this method will return Err(SendError::NoRoute)

source

pub fn poll_send_to<T>( &self, buf: &[u8], remote_endpoint: T, cx: &mut Context<'_> ) -> Poll<Result<(), SendError>>
where T: Into<UdpMetadata>,

Send a datagram to the specified remote endpoint.

When the datagram has been sent, this method will return Poll::Ready(Ok()).

When the socket’s send buffer is full, this method will return Poll::Pending and register the current task to be notified when the buffer has space available.

When the remote endpoint is not reachable, this method will return Poll::Ready(Err(Error::NoRoute)).

source

pub fn endpoint(&self) -> IpListenEndpoint

Returns the local endpoint of the socket.

source

pub fn is_open(&self) -> bool

Returns whether the socket is open.

source

pub fn close(&mut self)

Close the socket.

source

pub fn may_send(&self) -> bool

Returns whether the socket is ready to send data, i.e. it has enough buffer space to hold a packet.

source

pub fn may_recv(&self) -> bool

Returns whether the socket is ready to receive data, i.e. it has received a packet that’s now in the buffer.

source

pub fn packet_recv_capacity(&self) -> usize

Return the maximum number packets the socket can receive.

source

pub fn packet_send_capacity(&self) -> usize

Return the maximum number packets the socket can receive.

source

pub fn payload_recv_capacity(&self) -> usize

Return the maximum number of bytes inside the recv buffer.

source

pub fn payload_send_capacity(&self) -> usize

Return the maximum number of bytes inside the transmit buffer.

source

pub fn set_hop_limit(&mut self, hop_limit: Option<u8>)

Set the hop limit field in the IP header of sent packets.

Trait Implementations§

source§

impl Drop for UdpSocket<'_>

source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl<'a> Freeze for UdpSocket<'a>

§

impl<'a> !RefUnwindSafe for UdpSocket<'a>

§

impl<'a> !Send for UdpSocket<'a>

§

impl<'a> !Sync for UdpSocket<'a>

§

impl<'a> Unpin for UdpSocket<'a>

§

impl<'a> !UnwindSafe for UdpSocket<'a>

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>,

§

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>,

§

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.