summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDamien George <damien@micropython.org>2020-06-16 12:25:41 +1000
committerDamien George <damien@micropython.org>2020-06-17 00:09:42 +1000
commit289be6b352e30e97363c1db98a582eb84c9dd12e (patch)
tree1b7c3b486af076dd097cc5608b4857edd1b7601a
parentda99e0f97911864d1803b804249b38344385de11 (diff)
stm32/usb: Add support for 2xVCP on L0, L432 and WB MCUs.
There are a maximum of 8 USB endpoints and each has 2 buffer slots (in/out). This commit add support for up to 8 endpoints and adds FIFO configuration for USB profiles with 2xVCP on MCUs that have device-only USB peripherals. Tested on NUCLEO_WB55 in 2xVCP, 2xVCP+MSC and 2xVCP+MSC+HID mode. Signed-off-by: Damien George <damien@micropython.org>
-rw-r--r--ports/stm32/usb.c25
-rw-r--r--ports/stm32/usbd_conf.h2
2 files changed, 24 insertions, 3 deletions
diff --git a/ports/stm32/usb.c b/ports/stm32/usb.c
index cd5238172..657d4cb6e 100644
--- a/ports/stm32/usb.c
+++ b/ports/stm32/usb.c
@@ -93,8 +93,29 @@ pyb_usb_storage_medium_t pyb_usb_storage_medium = PYB_USB_STORAGE_MEDIUM_NONE;
// Units of FIFO size arrays below are 4x 16-bit words = 8 bytes
// There are 512x 16-bit words it total to use here (when using PCD_SNG_BUF)
-// EP0(out), EP0(in), MSC/HID(out), MSC/HID(in), unused, CDC_CMD(in), CDC_DATA(out), CDC_DATA(in)
-STATIC const uint8_t usbd_fifo_size_cdc1[] = {16, 16, 16, 16, 0, 16, 16, 16};
+STATIC const uint8_t usbd_fifo_size_cdc1[USBD_PMA_NUM_FIFO] = {
+ 16, 16, 16, 16, // EP0(out), EP0(in), MSC/HID(out), MSC/HID(in)
+ 0, 16, 16, 16, // unused, CDC_CMD(in), CDC_DATA(out), CDC_DATA(in)
+ 0, 0, 0, 0, 0, 0, 0, 0, // 8x unused
+};
+
+#if MICROPY_HW_USB_CDC_NUM >= 2
+STATIC const uint8_t usbd_fifo_size_cdc2[USBD_PMA_NUM_FIFO] = {
+ 8, 8, 16, 16, // EP0(out), EP0(in), MSC/HID(out), MSC/HID(in)
+ 0, 8, 12, 12, // unused, CDC_CMD(in), CDC_DATA(out), CDC_DATA(in)
+ 0, 8, 12, 12, // unused, CDC2_CMD(in), CDC2_DATA(out), CDC2_DATA(in)
+ 0, 0, 0, 0, // 4x unused
+};
+
+// RX; EP0(in), MSC/HID, CDC_CMD, CDC_DATA, CDC2_CMD/HID, CDC2_DATA, HID
+STATIC const uint8_t usbd_fifo_size_cdc2_msc_hid[USBD_PMA_NUM_FIFO] = {
+ 8, 8, 16, 16, // EP0(out), EP0(in), MSC/HID(out), MSC/HID(in)
+ 0, 8, 8, 8, // unused, CDC_CMD(in), CDC_DATA(out), CDC_DATA(in)
+ 0, 8, 8, 8, // unused, CDC2_CMD(in), CDC2_DATA(out), CDC2_DATA(in)
+ 8, 8, // HID(out), HID(in)
+ 0, 0, // 2x unused
+};
+#endif
#else
diff --git a/ports/stm32/usbd_conf.h b/ports/stm32/usbd_conf.h
index 5237ba3a9..83805a6e4 100644
--- a/ports/stm32/usbd_conf.h
+++ b/ports/stm32/usbd_conf.h
@@ -51,7 +51,7 @@
// For MCUs with a device-only USB peripheral
#define USBD_PMA_RESERVE (64)
-#define USBD_PMA_NUM_FIFO (8)
+#define USBD_PMA_NUM_FIFO (16) // Maximum 8 endpoints, 2 FIFOs each
// For MCUs with multiple OTG USB peripherals
#define USBD_FS_NUM_TX_FIFO (6)