Add logging and interface for debugging buffer usage
This commit is contained in:
		| @@ -201,6 +201,20 @@ impl<'d, D: Driver<'d>> Builder<'d, D> { | |||||||
|         self.config_descriptor.end_configuration(); |         self.config_descriptor.end_configuration(); | ||||||
|         self.bos_descriptor.end_bos(); |         self.bos_descriptor.end_bos(); | ||||||
|  |  | ||||||
|  |         info!("USB: device_descriptor used: {}", self.device_descriptor.position()); | ||||||
|  |         info!("USB: config_descriptor used: {}", self.config_descriptor.position()); | ||||||
|  |         info!("USB: bos_descriptor_buf used: {}", self.bos_descriptor.writer.position()); | ||||||
|  |         #[cfg(feature = "msos-descriptor")] | ||||||
|  |         info!("USB: device_descriptor used: {}", msos_descriptor.len()); | ||||||
|  |         if self.control_buf.len() != self.config.max_packet_size_0.into() { | ||||||
|  |             warn!( | ||||||
|  |                 "Mismatch in control buf and max packet size! buf len: {}, max ep0 size: {}", | ||||||
|  |                 self.control_buf.len(), | ||||||
|  |                 self.config.max_packet_size_0, | ||||||
|  |             ); | ||||||
|  |         } | ||||||
|  |         info!("USB: device_descriptor used: {}", self.config_descriptor.position()); | ||||||
|  |  | ||||||
|         UsbDevice::build( |         UsbDevice::build( | ||||||
|             self.driver, |             self.driver, | ||||||
|             self.config, |             self.config, | ||||||
|   | |||||||
| @@ -458,6 +458,9 @@ impl<'d> Handler for Control<'d> { | |||||||
|             return None; |             return None; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         // TODO(AJM): This uses a defmt-specific formatter that causes use of the `log` | ||||||
|  |         // feature to fail to build | ||||||
|  |         #[cfg(feature = "defmt")] | ||||||
|         trace!("HID control_out {:?} {=[u8]:x}", req, data); |         trace!("HID control_out {:?} {=[u8]:x}", req, data); | ||||||
|         match req.request { |         match req.request { | ||||||
|             HID_REQ_SET_IDLE => { |             HID_REQ_SET_IDLE => { | ||||||
|   | |||||||
| @@ -165,6 +165,25 @@ struct Interface { | |||||||
|     num_alt_settings: u8, |     num_alt_settings: u8, | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /// A report of the used size of the runtime allocated buffers | ||||||
|  | #[derive(PartialEq, Eq, Copy, Clone, Debug)] | ||||||
|  | #[cfg_attr(feature = "defmt", derive(defmt::Format))] | ||||||
|  | pub struct UsbBufferReport { | ||||||
|  |     /// Number of device descriptor bytes used | ||||||
|  |     pub device_descriptor_used: usize, | ||||||
|  |     /// Number of config descriptor bytes used | ||||||
|  |     pub config_descriptor_used: usize, | ||||||
|  |     /// Number of bos descriptor bytes used | ||||||
|  |     pub bos_descriptor_used: usize, | ||||||
|  |     /// Number of msos descriptor bytes used | ||||||
|  |     /// | ||||||
|  |     /// Will be `None` if the "msos-descriptor" feature is not active. | ||||||
|  |     /// Otherwise will return Some(bytes). | ||||||
|  |     pub msos_descriptor_used: Option<usize>, | ||||||
|  |     /// Size of the control buffer | ||||||
|  |     pub control_buffer_size: usize, | ||||||
|  | } | ||||||
|  |  | ||||||
| /// Main struct for the USB device stack. | /// Main struct for the USB device stack. | ||||||
| pub struct UsbDevice<'d, D: Driver<'d>> { | pub struct UsbDevice<'d, D: Driver<'d>> { | ||||||
|     control_buf: &'d mut [u8], |     control_buf: &'d mut [u8], | ||||||
| @@ -239,6 +258,24 @@ impl<'d, D: Driver<'d>> UsbDevice<'d, D> { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /// Returns a report of the consumed buffers | ||||||
|  |     /// | ||||||
|  |     /// Useful for tuning buffer sizes for actual usage | ||||||
|  |     pub fn buffer_usage(&self) -> UsbBufferReport { | ||||||
|  |         #[cfg(not(feature = "msos-descriptor"))] | ||||||
|  |         let mdu = None; | ||||||
|  |         #[cfg(feature = "msos-descriptor")] | ||||||
|  |         let mdu = Some(self.inner.msos_descriptor.len()); | ||||||
|  |  | ||||||
|  |         UsbBufferReport { | ||||||
|  |             device_descriptor_used: self.inner.device_descriptor.len(), | ||||||
|  |             config_descriptor_used: self.inner.config_descriptor.len(), | ||||||
|  |             bos_descriptor_used: self.inner.bos_descriptor.len(), | ||||||
|  |             msos_descriptor_used: mdu, | ||||||
|  |             control_buffer_size: self.control_buf.len(), | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /// Runs the `UsbDevice` forever. |     /// Runs the `UsbDevice` forever. | ||||||
|     /// |     /// | ||||||
|     /// This future may leave the bus in an invalid state if it is dropped. |     /// This future may leave the bus in an invalid state if it is dropped. | ||||||
|   | |||||||
| @@ -32,6 +32,11 @@ impl<'d> MsOsDescriptorSet<'d> { | |||||||
|     pub fn is_empty(&self) -> bool { |     pub fn is_empty(&self) -> bool { | ||||||
|         self.descriptor.is_empty() |         self.descriptor.is_empty() | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /// Returns the length of the descriptor field | ||||||
|  |     pub fn len(&self) -> usize { | ||||||
|  |         self.descriptor.len() | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| /// Writes a Microsoft OS 2.0 Descriptor set into a buffer. | /// Writes a Microsoft OS 2.0 Descriptor set into a buffer. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user