wch usbfs/usbhs need to specify which driver to use. for v307 default to highspeed
This commit is contained in:
		| @@ -38,13 +38,13 @@ | ||||
| // TODO maybe having FS as port0, HS as port1 | ||||
|  | ||||
| __attribute__((interrupt)) void USBHS_IRQHandler(void) { | ||||
|   #if CFG_TUD_MAX_SPEED == OPT_MODE_HIGH_SPEED | ||||
|   #if CFG_TUD_WCH_USBIP_USBHS | ||||
|   tud_int_handler(0); | ||||
|   #endif | ||||
| } | ||||
|  | ||||
| __attribute__((interrupt)) void OTG_FS_IRQHandler(void) { | ||||
|   #if CFG_TUD_MAX_SPEED == OPT_MODE_FULL_SPEED | ||||
|   #if CFG_TUD_WCH_USBIP_USBFS | ||||
|   tud_int_handler(0); | ||||
|   #endif | ||||
| } | ||||
| @@ -74,15 +74,17 @@ void board_init(void) { | ||||
|  | ||||
|   usart_printf_init(CFG_BOARD_UART_BAUDRATE); | ||||
|  | ||||
| #if CFG_TUD_MAX_SPEED == OPT_MODE_HIGH_SPEED | ||||
|   // Use Highspeed USB | ||||
| #ifdef CH32V30x_D8C | ||||
|   // v305/v307: Highspeed USB | ||||
|   RCC_USBCLK48MConfig(RCC_USBCLK48MCLKSource_USBPHY); | ||||
|   RCC_USBHSPLLCLKConfig(RCC_HSBHSPLLCLKSource_HSE); | ||||
|   RCC_USBHSConfig(RCC_USBPLL_Div2); | ||||
|   RCC_USBHSPLLCKREFCLKConfig(RCC_USBHSPLLCKREFCLK_4M); | ||||
|   RCC_USBHSPHYPLLALIVEcmd(ENABLE); | ||||
|   RCC_AHBPeriphClockCmd(RCC_AHBPeriph_USBHS, ENABLE); | ||||
| #else | ||||
| #endif | ||||
|  | ||||
|   // Fullspeed USB | ||||
|   uint8_t otg_div; | ||||
|   switch (SystemCoreClock) { | ||||
|     case 48000000:  otg_div = RCC_OTGFSCLKSource_PLLCLK_Div1; break; | ||||
| @@ -92,7 +94,6 @@ void board_init(void) { | ||||
|   } | ||||
|   RCC_OTGFSCLKConfig(otg_div); | ||||
|   RCC_AHBPeriphClockCmd(RCC_AHBPeriph_OTG_FS, ENABLE); | ||||
| #endif | ||||
|  | ||||
|   GPIO_InitTypeDef GPIO_InitStructure = {0}; | ||||
|  | ||||
|   | ||||
| @@ -14,7 +14,7 @@ set(CMAKE_TOOLCHAIN_FILE ${TOP}/examples/build_system/cmake/toolchain/riscv_${TO | ||||
| set(FAMILY_MCUS CH32V307 CACHE INTERNAL "") | ||||
| set(OPENOCD_OPTION "-f ${CMAKE_CURRENT_LIST_DIR}/wch-riscv.cfg") | ||||
|  | ||||
| # default to highspeed | ||||
| # default to highspeed, used to select USBFS / USBHS driver | ||||
| if (NOT DEFINED SPEED) | ||||
|   set(SPEED high) | ||||
| endif() | ||||
| @@ -52,9 +52,16 @@ function(add_board_target BOARD_TARGET) | ||||
|     ${SDK_SRC_DIR}/Peripheral/inc | ||||
|     ${CMAKE_CURRENT_FUNCTION_LIST_DIR} | ||||
|     ) | ||||
|   target_compile_definitions(${BOARD_TARGET} PUBLIC | ||||
|     BOARD_TUD_MAX_SPEED=$<IF:$<STREQUAL:${SPEED},high>,OPT_MODE_HIGH_SPEED,OPT_MODE_FULL_SPEED> | ||||
|     ) | ||||
|   if (SPEED STREQUAL high) | ||||
|     target_compile_definitions(${BOARD_TARGET} PUBLIC | ||||
|       CFG_TUD_WCH_USBIP_USBHS=1 | ||||
| #      BOARD_TUD_MAX_SPEED=OPT_MODE_HIGH_SPEED | ||||
|       ) | ||||
|   else () | ||||
|     target_compile_definitions(${BOARD_TARGET} PUBLIC | ||||
|       CFG_TUD_WCH_USBIP_USBFS=1 | ||||
|       ) | ||||
|   endif () | ||||
|  | ||||
|   update_board(${BOARD_TARGET}) | ||||
|  | ||||
|   | ||||
| @@ -26,11 +26,11 @@ CFLAGS += \ | ||||
| 	-DCFG_TUSB_MCU=OPT_MCU_CH32V307 \ | ||||
|  | ||||
| ifeq ($(SPEED),high) | ||||
|   CFLAGS += -DBOARD_TUD_MAX_SPEED=OPT_MODE_HIGH_SPEED | ||||
|   $(info "Using USBHS driver for HighSpeed mode") | ||||
|   CFLAGS += -DCFG_TUD_WCH_USBIP_USBHS=1 | ||||
| else | ||||
|   CFLAGS += -DBOARD_TUD_MAX_SPEED=OPT_MODE_FULL_SPEED | ||||
|   $(info "Using USBFS driver for FullSpeed mode") | ||||
|   CFLAGS += -DCFG_TUD_WCH_USBIP_USBFS=1 | ||||
| endif | ||||
|  | ||||
| LDFLAGS_GCC += \ | ||||
|   | ||||
| @@ -402,29 +402,57 @@ | ||||
| #elif TU_CHECK_MCU(OPT_MCU_F1C100S) | ||||
|   #define TUP_DCD_ENDPOINT_MAX    4 | ||||
|  | ||||
| //------------- WCH -------------// | ||||
| #elif TU_CHECK_MCU(OPT_MCU_CH32V307) | ||||
|   // v307 support both FS and HS | ||||
|   #define TUP_USBIP_WCH_USBHS | ||||
|   #define TUP_USBIP_WCH_USBFS | ||||
|  | ||||
|   #define TUP_RHPORT_HIGHSPEED    1 // default to highspeed | ||||
|   #define TUP_DCD_ENDPOINT_MAX    (CFG_TUD_MAX_SPEED == OPT_MODE_HIGH_SPEED ? 16 : 8) | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // WCH | ||||
| //--------------------------------------------------------------------+ | ||||
| #elif TU_CHECK_MCU(OPT_MCU_CH32F20X) | ||||
|   #define TUP_USBIP_WCH_USBHS | ||||
|   #define TUP_USBIP_WCH_USBFS | ||||
|  | ||||
|   #define TUP_RHPORT_HIGHSPEED    1 // default to highspeed | ||||
|   #define TUP_DCD_ENDPOINT_MAX    (CFG_TUD_MAX_SPEED == OPT_MODE_HIGH_SPEED ? 16 : 8) | ||||
|   #if !defined(CFG_TUD_WCH_USBIP_USBFS) | ||||
|   #define CFG_TUD_WCH_USBIP_USBFS 0 | ||||
|   #endif | ||||
|  | ||||
|   #if !defined(CFG_TUD_WCH_USBIP_USBHS) | ||||
|   #define CFG_TUD_WCH_USBIP_USBHS (CFG_TUD_WCH_USBIP_USBFS ? 0 : 1) | ||||
|   #endif | ||||
|  | ||||
|   #define TUP_RHPORT_HIGHSPEED    CFG_TUD_WCH_USBIP_USBHS | ||||
|   #define TUP_DCD_ENDPOINT_MAX    (CFG_TUD_WCH_USBIP_USBHS ? 16 : 8) | ||||
|  | ||||
| #elif TU_CHECK_MCU(OPT_MCU_CH32V20X) | ||||
|   // v20x support both FSDEV (USBD) and USBFS, default to FSDEV | ||||
|   #define TUP_USBIP_WCH_USBFS | ||||
|   #define TUP_DCD_ENDPOINT_MAX    8 | ||||
|   #define TUP_USBIP_FSDEV | ||||
|   #define TUP_USBIP_FSDEV_CH32 | ||||
|  | ||||
|   #if !defined(CFG_TUD_WCH_USBIP_USBFS) | ||||
|   #define CFG_TUD_WCH_USBIP_USBFS 0 | ||||
|   #endif | ||||
|  | ||||
|   #if !defined(CFG_TUD_WCH_FSDEV) | ||||
|   #define CFG_TUD_WCH_USBIP_FSDEV  (CFG_TUD_WCH_USBIP_USBFS ? 0 : 1) | ||||
|   #endif | ||||
|  | ||||
| #elif TU_CHECK_MCU(OPT_MCU_CH32V307) | ||||
|   // v307 support both FS and HS, default to HS | ||||
|   #define TUP_USBIP_WCH_USBHS | ||||
|   #define TUP_USBIP_WCH_USBFS | ||||
|  | ||||
|   #if !defined(CFG_TUD_WCH_USBIP_USBFS) | ||||
|   #define CFG_TUD_WCH_USBIP_USBFS 0 | ||||
|   #endif | ||||
|  | ||||
|   #if !defined(CFG_TUD_WCH_USBIP_USBHS) | ||||
|   #define CFG_TUD_WCH_USBIP_USBHS (CFG_TUD_WCH_USBIP_USBFS ? 0 : 1) | ||||
|   #endif | ||||
|  | ||||
|   #define TUP_RHPORT_HIGHSPEED    CFG_TUD_WCH_USBIP_USBHS | ||||
|   #define TUP_DCD_ENDPOINT_MAX    (CFG_TUD_WCH_USBIP_USBHS ? 16 : 8) | ||||
|  | ||||
| #endif | ||||
|  | ||||
|  | ||||
| //--------------------------------------------------------------------+ | ||||
| // External USB controller | ||||
| //--------------------------------------------------------------------+ | ||||
|   | ||||
| @@ -407,7 +407,7 @@ bool tud_init(uint8_t rhport) { | ||||
|   // skip if already initialized | ||||
|   if (tud_inited()) return true; | ||||
|  | ||||
|   TU_LOG_USBD("USBD init on controller %u\r\n", rhport); | ||||
|   TU_LOG_USBD("USBD init on controller %u, Highspeed = %u\r\n", rhport, TUD_OPT_HIGH_SPEED); | ||||
|   TU_LOG_INT(CFG_TUD_LOG_LEVEL, sizeof(usbd_device_t)); | ||||
|   TU_LOG_INT(CFG_TUD_LOG_LEVEL, sizeof(dcd_event_t)); | ||||
|   TU_LOG_INT(CFG_TUD_LOG_LEVEL, sizeof(tu_fifo_t)); | ||||
|   | ||||
| @@ -1,17 +1,34 @@ | ||||
| /** | ||||
|   * @author  MCD Application Team | ||||
|   *          Ha Thach (tinyusb.org) | ||||
|   * | ||||
|   * @attention | ||||
|   * | ||||
|   * <h2><center>© Copyright (c) 2019 STMicroelectronics. | ||||
| /* | ||||
|  * The MIT License (MIT) | ||||
|  * | ||||
|  * Copyright (c) 2024, hathach (tinyusb.org) | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  */ | ||||
| /** <h2><center>© Copyright (c) 2019 STMicroelectronics. | ||||
|   * All rights reserved.</center></h2> | ||||
|   * | ||||
|   * This software component is licensed by ST under BSD 3-Clause license, | ||||
|   * the "License"; You may not use this file except in compliance with the | ||||
|   * License. You may obtain a copy of the License at: | ||||
|   *                        opensource.org/licenses/BSD-3-Clause | ||||
|   * | ||||
|   */ | ||||
|  | ||||
| #ifndef _TUSB_DWC2_TYPES_H_ | ||||
|   | ||||
| @@ -27,8 +27,7 @@ | ||||
|  | ||||
| #include "tusb_option.h" | ||||
|  | ||||
| // Note: CH32 can have both USB FS and HS, only use this driver if CFG_TUD_MAX_SPEED is full speed | ||||
| #if CFG_TUD_ENABLED && defined(TUP_USBIP_WCH_USBFS) && (CFG_TUD_MAX_SPEED == OPT_MODE_FULL_SPEED) | ||||
| #if CFG_TUD_ENABLED && defined(TUP_USBIP_WCH_USBFS) && CFG_TUD_WCH_USBIP_USBFS | ||||
|  | ||||
| #include "device/dcd.h" | ||||
| #include "ch32_usbfs_reg.h" | ||||
|   | ||||
| @@ -27,8 +27,7 @@ | ||||
|  | ||||
| #include "tusb_option.h" | ||||
|  | ||||
| // Note: CH32 can have both USB FS and HS, only use this driver if CFG_TUD_MAX_SPEED is high speed | ||||
| #if CFG_TUD_ENABLED && defined(TUP_USBIP_WCH_USBHS) && (CFG_TUD_MAX_SPEED == OPT_MODE_HIGH_SPEED) | ||||
| #if CFG_TUD_ENABLED && defined(TUP_USBIP_WCH_USBHS) && CFG_TUD_WCH_USBIP_USBHS | ||||
| #include "ch32_usbhs_reg.h" | ||||
|  | ||||
| #include "device/dcd.h" | ||||
|   | ||||
| @@ -207,19 +207,9 @@ | ||||
| #define OPT_OS_RTTHREAD   6  ///< RT-Thread | ||||
| #define OPT_OS_RTX4       7  ///< Keil RTX 4 | ||||
|  | ||||
| // Allow to use command line to change the config name/location | ||||
| #ifdef CFG_TUSB_CONFIG_FILE | ||||
|   #include CFG_TUSB_CONFIG_FILE | ||||
| #else | ||||
|   #include "tusb_config.h" | ||||
| #endif | ||||
|  | ||||
| #include "common/tusb_mcu.h" | ||||
|  | ||||
| //-------------------------------------------------------------------- | ||||
| // RootHub Mode Configuration | ||||
| // CFG_TUSB_RHPORTx_MODE contains operation mode and speed for that port | ||||
| //-------------------------------------------------------------------- | ||||
| //--------------------------------------------------------------------+ | ||||
| // Mode and Speed | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| // Low byte is operational mode | ||||
| #define OPT_MODE_NONE           0x0000 ///< Disabled | ||||
| @@ -233,7 +223,24 @@ | ||||
| #define OPT_MODE_HIGH_SPEED     0x0400 ///< High Speed | ||||
| #define OPT_MODE_SPEED_MASK     0xff00 | ||||
|  | ||||
| //------------- Roothub as Device -------------// | ||||
| //--------------------------------------------------------------------+ | ||||
| // Include tusb_config.h and tusb_mcu.h | ||||
| //--------------------------------------------------------------------+ | ||||
|  | ||||
| // Allow to use command line to change the config name/location | ||||
| #ifdef CFG_TUSB_CONFIG_FILE | ||||
|   #include CFG_TUSB_CONFIG_FILE | ||||
| #else | ||||
|   #include "tusb_config.h" | ||||
| #endif | ||||
|  | ||||
| #include "common/tusb_mcu.h" | ||||
|  | ||||
| //-------------------------------------------------------------------- | ||||
| // RootHub Mode detection | ||||
| //-------------------------------------------------------------------- | ||||
|  | ||||
| //------------- Root hub as Device -------------// | ||||
|  | ||||
| #if defined(CFG_TUSB_RHPORT0_MODE) && ((CFG_TUSB_RHPORT0_MODE) & OPT_MODE_DEVICE) | ||||
|   #define TUD_RHPORT_MODE     (CFG_TUSB_RHPORT0_MODE) | ||||
| @@ -261,7 +268,7 @@ | ||||
| // highspeed support indicator | ||||
| #define TUD_OPT_HIGH_SPEED    (CFG_TUD_MAX_SPEED ? (CFG_TUD_MAX_SPEED & OPT_MODE_HIGH_SPEED) : TUP_RHPORT_HIGHSPEED) | ||||
|  | ||||
| //------------- Roothub as Host -------------// | ||||
| //------------- Root hub as Host -------------// | ||||
|  | ||||
| #if defined(CFG_TUSB_RHPORT0_MODE) && ((CFG_TUSB_RHPORT0_MODE) & OPT_MODE_HOST) | ||||
|   #define TUH_RHPORT_MODE  (CFG_TUSB_RHPORT0_MODE) | ||||
| @@ -467,26 +474,26 @@ | ||||
|   #define CFG_TUH_CDC    0 | ||||
| #endif | ||||
|  | ||||
| // FTDI is not part of CDC class, only to re-use CDC driver API | ||||
| #ifndef CFG_TUH_CDC_FTDI | ||||
|   // FTDI is not part of CDC class, only to re-use CDC driver API | ||||
|   #define CFG_TUH_CDC_FTDI 0 | ||||
| #endif | ||||
|  | ||||
| // List of product IDs that can use the FTDI CDC driver. 0x0403 is FTDI's VID | ||||
| #ifndef CFG_TUH_CDC_FTDI_VID_PID_LIST | ||||
|   // List of product IDs that can use the FTDI CDC driver. 0x0403 is FTDI's VID | ||||
|   #define CFG_TUH_CDC_FTDI_VID_PID_LIST \ | ||||
|     {0x0403, 0x6001}, {0x0403, 0x6006}, {0x0403, 0x6010}, {0x0403, 0x6011}, \ | ||||
|     {0x0403, 0x6014}, {0x0403, 0x6015}, {0x0403, 0x8372}, {0x0403, 0xFBFA}, \ | ||||
|     {0x0403, 0xCD18} | ||||
| #endif | ||||
|  | ||||
| // CP210X is not part of CDC class, only to re-use CDC driver API | ||||
| #ifndef CFG_TUH_CDC_CP210X | ||||
|   // CP210X is not part of CDC class, only to re-use CDC driver API | ||||
|   #define CFG_TUH_CDC_CP210X 0 | ||||
| #endif | ||||
|  | ||||
| // List of product IDs that can use the CP210X CDC driver. 0x10C4 is Silicon Labs' VID | ||||
| #ifndef CFG_TUH_CDC_CP210X_VID_PID_LIST | ||||
|   // List of product IDs that can use the CP210X CDC driver. 0x10C4 is Silicon Labs' VID | ||||
|   #define CFG_TUH_CDC_CP210X_VID_PID_LIST \ | ||||
|     {0x10C4, 0xEA60}, {0x10C4, 0xEA70} | ||||
| #endif | ||||
| @@ -496,8 +503,8 @@ | ||||
|   #define CFG_TUH_CDC_CH34X 0 | ||||
| #endif | ||||
|  | ||||
| // List of product IDs that can use the CH34X CDC driver | ||||
| #ifndef CFG_TUH_CDC_CH34X_VID_PID_LIST | ||||
|   // List of product IDs that can use the CH34X CDC driver | ||||
|   #define CFG_TUH_CDC_CH34X_VID_PID_LIST \ | ||||
|     { 0x1a86, 0x5523 }, /* ch341 chip */ \ | ||||
|     { 0x1a86, 0x7522 }, /* ch340k chip */ \ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 hathach
					hathach