usb_cdc: Add a usb_fill_serial() helper function
Add a helper function to fill the usb serial string descriptor. Use it in the lpc176x code. Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
@@ -284,10 +284,27 @@ static const struct descriptor_s {
|
||||
&cdc_string_manufacturer, SIZE_cdc_string_manufacturer },
|
||||
{ (USB_DT_STRING<<8) | USB_STR_ID_PRODUCT, USB_LANGID_ENGLISH_US,
|
||||
&cdc_string_product, SIZE_cdc_string_product },
|
||||
#if !CONFIG_USB_SERIAL_NUMBER_CHIPID
|
||||
{ (USB_DT_STRING<<8) | USB_STR_ID_SERIAL, USB_LANGID_ENGLISH_US,
|
||||
&cdc_string_serial, SIZE_cdc_string_serial },
|
||||
#endif
|
||||
};
|
||||
|
||||
// Fill in a USB serial string descriptor from a chip id
|
||||
void
|
||||
usb_fill_serial(struct usb_string_descriptor *desc, int strlen, void *id)
|
||||
{
|
||||
desc->bLength = sizeof(*desc) + strlen * sizeof(desc->data[0]);
|
||||
desc->bDescriptorType = USB_DT_STRING;
|
||||
|
||||
uint8_t *src = id;
|
||||
int i;
|
||||
for (i = 0; i < strlen; i++) {
|
||||
uint8_t c = i & 1 ? src[i/2] & 0x0f : src[i/2] >> 4;
|
||||
desc->data[i] = c < 10 ? c + '0' : c - 10 + 'A';
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/****************************************************************
|
||||
* USB endpoint 0 control message handling
|
||||
|
||||
@@ -25,6 +25,7 @@ void usb_request_bootloader(void);
|
||||
struct usb_string_descriptor *usbserial_get_serialid(void);
|
||||
|
||||
// usb_cdc.c
|
||||
void usb_fill_serial(struct usb_string_descriptor *desc, int strlen, void *id);
|
||||
void usb_notify_bulk_in(void);
|
||||
void usb_notify_bulk_out(void);
|
||||
void usb_notify_ep0(void);
|
||||
|
||||
Reference in New Issue
Block a user