pub struct TestClass<'a, B: UsbBus> { /* private fields */ }
Expand description

Test USB class for testing USB driver implementations. Supports various endpoint types and requests for testing USB peripheral drivers on actual hardware.

Implementations§

source§

impl<B: UsbBus> TestClass<'_, B>

source

pub fn new(alloc: &UsbBusAllocator<B>) -> TestClass<'_, B>

Creates a new TestClass.

source

pub fn make_device<'a>( &self, usb_bus: &'a UsbBusAllocator<B> ) -> UsbDevice<'a, B>

Convenience method to create a UsbDevice that is configured correctly for TestClass.

source

pub fn make_device_builder<'a>( &self, usb_bus: &'a UsbBusAllocator<B> ) -> UsbDeviceBuilder<'a, B>

Convenience method to create a UsbDeviceBuilder that is configured correctly for TestClass.

The methods sets

  • manufacturer
  • product
  • serial number
  • max_packet_size_0

on the returned builder. If you change the manufacturer, product, or serial number fields, the test host may misbehave.

source

pub fn poll(&mut self)

Must be called after polling the UsbDevice.

Trait Implementations§

source§

impl<B: UsbBus> UsbClass<B> for TestClass<'_, B>

source§

fn reset(&mut self)

Called after a USB reset after the bus reset sequence is complete.
source§

fn get_configuration_descriptors( &self, writer: &mut DescriptorWriter<'_> ) -> Result<()>

Called when a GET_DESCRIPTOR request is received for a configuration descriptor. When called, the implementation should write its interface, endpoint and any extra class descriptors into writer. The configuration descriptor itself will be written by UsbDevice and shouldn’t be written by classes. Read more
source§

fn get_string(&self, index: StringIndex, lang_id: LangID) -> Option<&str>

Gets a class-specific string descriptor. Read more
source§

fn endpoint_in_complete(&mut self, addr: EndpointAddress)

Called when endpoint with address addr has completed transmitting data (IN packet). Read more
source§

fn endpoint_out(&mut self, addr: EndpointAddress)

Called when endpoint with address addr has received data (OUT packet). Read more
source§

fn control_in(&mut self, xfer: ControlIn<'_, '_, '_, B>)

Called when a control request is received with direction DeviceToHost. Read more
source§

fn control_out(&mut self, xfer: ControlOut<'_, '_, '_, B>)

Called when a control request is received with direction HostToDevice. Read more
source§

fn get_bos_descriptors(&self, writer: &mut BosWriter<'_, '_>) -> Result<()>

Called when a GET_DESCRIPTOR request is received for a BOS descriptor. When called, the implementation should write its blobs such as capability descriptors into writer. The BOS descriptor itself will be written by UsbDevice and shouldn’t be written by classes.
source§

fn poll(&mut self)

Called whenever the UsbDevice is polled.
source§

fn endpoint_setup(&mut self, addr: EndpointAddress)

Called when endpoint with address addr has received a SETUP packet. Implementing this shouldn’t be necessary in most cases, but is provided for completeness’ sake. Read more
source§

fn get_alt_setting(&mut self, interface: InterfaceNumber) -> Option<u8>

Called when the interfaces alternate setting state is requested. Read more
source§

fn set_alt_setting( &mut self, interface: InterfaceNumber, alternative: u8 ) -> bool

Called when the interfaces alternate setting state is altered. Read more

Auto Trait Implementations§

§

impl<'a, B> RefUnwindSafe for TestClass<'a, B>

§

impl<'a, B> Send for TestClass<'a, B>

§

impl<'a, B> Sync for TestClass<'a, B>

§

impl<'a, B> Unpin for TestClass<'a, B>

§

impl<'a, B> UnwindSafe for TestClass<'a, B>

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.