Struct usb_device::endpoint::Endpoint
source · [−]pub struct Endpoint<'a, B: UsbBus, D: EndpointDirection> { /* private fields */ }
Expand description
Handle for a USB endpoint. The endpoint direction is constrained by the D
type argument, which
must be either In
or Out
.
Implementations
sourceimpl<B: UsbBus, D: EndpointDirection> Endpoint<'_, B, D>
impl<B: UsbBus, D: EndpointDirection> Endpoint<'_, B, D>
sourcepub fn address(&self) -> EndpointAddress
pub fn address(&self) -> EndpointAddress
Gets the endpoint address including direction bit.
sourcepub fn ep_type(&self) -> EndpointType
pub fn ep_type(&self) -> EndpointType
Gets the endpoint transfer type.
sourcepub fn max_packet_size(&self) -> u16
pub fn max_packet_size(&self) -> u16
Gets the maximum packet size for the endpoint.
sourceimpl<B: UsbBus> Endpoint<'_, B, In>
impl<B: UsbBus> Endpoint<'_, B, In>
sourcepub fn write(&self, data: &[u8]) -> Result<usize>
pub fn write(&self, data: &[u8]) -> Result<usize>
Writes a single packet of data to the specified endpoint and returns number of bytes
actually written. The buffer must not be longer than the max_packet_size
specified when
allocating the endpoint.
Errors
Note: USB bus implementation errors are directly passed through, so be prepared to handle other errors as well.
WouldBlock
- The transmission buffer of the USB peripheral is full and the packet cannot be sent now. A peripheral may or may not support concurrent transmission of packets.BufferOverflow
- The data is longer than themax_packet_size
specified when allocating the endpoint. This is generally an error in the class implementation.
sourceimpl<B: UsbBus> Endpoint<'_, B, Out>
impl<B: UsbBus> Endpoint<'_, B, Out>
sourcepub fn read(&self, data: &mut [u8]) -> Result<usize>
pub fn read(&self, data: &mut [u8]) -> Result<usize>
Reads a single packet of data from the specified endpoint and returns the actual length of
the packet. The buffer should be large enough to fit at least as many bytes as the
max_packet_size
specified when allocating the endpoint.
Errors
Note: USB bus implementation errors are directly passed through, so be prepared to handle other errors as well.
WouldBlock
- There is no packet to be read. Note that this is different from a received zero-length packet, which is valid and significant in USB. A zero-length packet will returnOk(0)
.BufferOverflow
- The received packet is too long to fit indata
. This is generally an error in the class implementation.