mirror of
https://github.com/hathach/tinyusb.git
synced 2025-01-17 05:32:55 +08:00
move core init code to dwc2 common. update/correct build for esppressif
This commit is contained in:
parent
10a3aa3cc8
commit
4012e15075
@ -48,7 +48,7 @@
|
|||||||
// Include MCU header
|
// Include MCU header
|
||||||
#include "bsp/board_mcu.h"
|
#include "bsp/board_mcu.h"
|
||||||
|
|
||||||
#if CFG_TUSB_MCU == OPT_MCU_ESP32S2 || CFG_TUSB_MCU == OPT_MCU_ESP32S3
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#error "ESP32-Sx should use IDF's FreeRTOSConfig.h"
|
#error "ESP32-Sx should use IDF's FreeRTOSConfig.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@
|
|||||||
#include "bsp/board_api.h"
|
#include "bsp/board_api.h"
|
||||||
#include "tusb.h"
|
#include "tusb.h"
|
||||||
|
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
// ESP-IDF need "freertos/" prefix in include path.
|
// ESP-IDF need "freertos/" prefix in include path.
|
||||||
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
||||||
#include "freertos/FreeRTOS.h"
|
#include "freertos/FreeRTOS.h"
|
||||||
@ -186,14 +186,14 @@ int main(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
||||||
#if !TU_CHECK_MCU(OPT_MCU_ESP32S2, OPT_MCU_ESP32S3)
|
#if !TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
vTaskStartScheduler();
|
vTaskStartScheduler();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if TU_CHECK_MCU(OPT_MCU_ESP32S2, OPT_MCU_ESP32S3)
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
void app_main(void)
|
void app_main(void)
|
||||||
{
|
{
|
||||||
main();
|
main();
|
||||||
|
@ -59,7 +59,7 @@ extern "C" {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Espressif IDF requires "freertos/" prefix in include path
|
// Espressif IDF requires "freertos/" prefix in include path
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#define CFG_TUSB_OS_INC_PATH freertos/
|
#define CFG_TUSB_OS_INC_PATH freertos/
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@
|
|||||||
// Include MCU header
|
// Include MCU header
|
||||||
#include "bsp/board_mcu.h"
|
#include "bsp/board_mcu.h"
|
||||||
|
|
||||||
#if CFG_TUSB_MCU == OPT_MCU_ESP32S2 || CFG_TUSB_MCU == OPT_MCU_ESP32S3
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#error "ESP32-Sx should use IDF's FreeRTOSConfig.h"
|
#error "ESP32-Sx should use IDF's FreeRTOSConfig.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@
|
|||||||
#include "bsp/board_api.h"
|
#include "bsp/board_api.h"
|
||||||
#include "tusb.h"
|
#include "tusb.h"
|
||||||
|
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
// ESP-IDF need "freertos/" prefix in include path.
|
// ESP-IDF need "freertos/" prefix in include path.
|
||||||
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
||||||
#include "freertos/FreeRTOS.h"
|
#include "freertos/FreeRTOS.h"
|
||||||
@ -133,16 +133,15 @@ int main(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
||||||
#if !TU_CHECK_MCU(OPT_MCU_ESP32S2, OPT_MCU_ESP32S3)
|
#if !TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
vTaskStartScheduler();
|
vTaskStartScheduler();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if TU_CHECK_MCU(OPT_MCU_ESP32S2, OPT_MCU_ESP32S3)
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
void app_main(void)
|
void app_main(void) {
|
||||||
{
|
|
||||||
main();
|
main();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -59,7 +59,7 @@ extern "C" {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Espressif IDF requires "freertos/" prefix in include path
|
// Espressif IDF requires "freertos/" prefix in include path
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#define CFG_TUSB_OS_INC_PATH freertos/
|
#define CFG_TUSB_OS_INC_PATH freertos/
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -67,7 +67,7 @@ int main(void) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if CFG_TUSB_MCU == OPT_MCU_ESP32S2 || CFG_TUSB_MCU == OPT_MCU_ESP32S3
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
void app_main(void) {
|
void app_main(void) {
|
||||||
main();
|
main();
|
||||||
}
|
}
|
||||||
|
@ -44,7 +44,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Espressif IDF requires "freertos/" prefix in include path
|
// Espressif IDF requires "freertos/" prefix in include path
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#define CFG_TUSB_OS_INC_PATH freertos/
|
#define CFG_TUSB_OS_INC_PATH freertos/
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@
|
|||||||
// Include MCU header
|
// Include MCU header
|
||||||
#include "bsp/board_mcu.h"
|
#include "bsp/board_mcu.h"
|
||||||
|
|
||||||
#if CFG_TUSB_MCU == OPT_MCU_ESP32S2 || CFG_TUSB_MCU == OPT_MCU_ESP32S3
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#error "ESP32-Sx should use IDF's FreeRTOSConfig.h"
|
#error "ESP32-Sx should use IDF's FreeRTOSConfig.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
#include "bsp/board_api.h"
|
#include "bsp/board_api.h"
|
||||||
#include "tusb.h"
|
#include "tusb.h"
|
||||||
|
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
// ESP-IDF need "freertos/" prefix in include path.
|
// ESP-IDF need "freertos/" prefix in include path.
|
||||||
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
||||||
#include "freertos/FreeRTOS.h"
|
#include "freertos/FreeRTOS.h"
|
||||||
@ -111,14 +111,14 @@ int main(void) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
||||||
#if !TUP_MCU_ESPRESSIF
|
#if !TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
vTaskStartScheduler();
|
vTaskStartScheduler();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
void app_main(void) {
|
void app_main(void) {
|
||||||
main();
|
main();
|
||||||
}
|
}
|
||||||
|
@ -59,7 +59,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Espressif IDF requires "freertos/" prefix in include path
|
// Espressif IDF requires "freertos/" prefix in include path
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#define CFG_TUSB_OS_INC_PATH freertos/
|
#define CFG_TUSB_OS_INC_PATH freertos/
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@
|
|||||||
// Include MCU header
|
// Include MCU header
|
||||||
#include "bsp/board_mcu.h"
|
#include "bsp/board_mcu.h"
|
||||||
|
|
||||||
#if CFG_TUSB_MCU == OPT_MCU_ESP32S2 || CFG_TUSB_MCU == OPT_MCU_ESP32S3
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#error "ESP32-Sx should use IDF's FreeRTOSConfig.h"
|
#error "ESP32-Sx should use IDF's FreeRTOSConfig.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
#include "tusb.h"
|
#include "tusb.h"
|
||||||
#include "usb_descriptors.h"
|
#include "usb_descriptors.h"
|
||||||
|
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
// ESP-IDF need "freertos/" prefix in include path.
|
// ESP-IDF need "freertos/" prefix in include path.
|
||||||
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
||||||
#include "freertos/FreeRTOS.h"
|
#include "freertos/FreeRTOS.h"
|
||||||
@ -113,14 +113,14 @@ int main(void)
|
|||||||
xTimerStart(blinky_tm, 0);
|
xTimerStart(blinky_tm, 0);
|
||||||
|
|
||||||
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
||||||
#if !TUP_MCU_ESPRESSIF
|
#if !TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
vTaskStartScheduler();
|
vTaskStartScheduler();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
void app_main(void)
|
void app_main(void)
|
||||||
{
|
{
|
||||||
main();
|
main();
|
||||||
|
@ -59,7 +59,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Espressif IDF requires "freertos/" prefix in include path
|
// Espressif IDF requires "freertos/" prefix in include path
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#define CFG_TUSB_OS_INC_PATH freertos/
|
#define CFG_TUSB_OS_INC_PATH freertos/
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -292,7 +292,7 @@ void led_blinking_task(void* param) {
|
|||||||
#define BLINKY_STACK_SIZE configMINIMAL_STACK_SIZE
|
#define BLINKY_STACK_SIZE configMINIMAL_STACK_SIZE
|
||||||
#define VIDEO_STACK_SIZE (configMINIMAL_STACK_SIZE*4)
|
#define VIDEO_STACK_SIZE (configMINIMAL_STACK_SIZE*4)
|
||||||
|
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#define USBD_STACK_SIZE 4096
|
#define USBD_STACK_SIZE 4096
|
||||||
int main(void);
|
int main(void);
|
||||||
void app_main(void) {
|
void app_main(void) {
|
||||||
@ -352,7 +352,7 @@ void freertos_init_task(void) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
||||||
#if !TUP_MCU_ESPRESSIF
|
#if !TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
vTaskStartScheduler();
|
vTaskStartScheduler();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -58,7 +58,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Espressif IDF requires "freertos/" prefix in include path
|
// Espressif IDF requires "freertos/" prefix in include path
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#define CFG_TUSB_OS_INC_PATH freertos/
|
#define CFG_TUSB_OS_INC_PATH freertos/
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -300,7 +300,7 @@ void led_blinking_task(void* param) {
|
|||||||
#define BLINKY_STACK_SIZE configMINIMAL_STACK_SIZE
|
#define BLINKY_STACK_SIZE configMINIMAL_STACK_SIZE
|
||||||
#define VIDEO_STACK_SIZE (configMINIMAL_STACK_SIZE*4)
|
#define VIDEO_STACK_SIZE (configMINIMAL_STACK_SIZE*4)
|
||||||
|
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#define USBD_STACK_SIZE 4096
|
#define USBD_STACK_SIZE 4096
|
||||||
int main(void);
|
int main(void);
|
||||||
void app_main(void) {
|
void app_main(void) {
|
||||||
@ -360,7 +360,7 @@ void freertos_init_task(void) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
||||||
#if !TUP_MCU_ESPRESSIF
|
#if !TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
vTaskStartScheduler();
|
vTaskStartScheduler();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -58,7 +58,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Espressif IDF requires "freertos/" prefix in include path
|
// Espressif IDF requires "freertos/" prefix in include path
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#define CFG_TUSB_OS_INC_PATH freertos/
|
#define CFG_TUSB_OS_INC_PATH freertos/
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -48,7 +48,7 @@
|
|||||||
// Include MCU header
|
// Include MCU header
|
||||||
#include "bsp/board_mcu.h"
|
#include "bsp/board_mcu.h"
|
||||||
|
|
||||||
#if CFG_TUSB_MCU == OPT_MCU_ESP32S2 || CFG_TUSB_MCU == OPT_MCU_ESP32S3
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#error "ESP32-Sx should use IDF's FreeRTOSConfig.h"
|
#error "ESP32-Sx should use IDF's FreeRTOSConfig.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@
|
|||||||
#include "tusb.h"
|
#include "tusb.h"
|
||||||
#include "bsp/board_api.h"
|
#include "bsp/board_api.h"
|
||||||
|
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
// ESP-IDF need "freertos/" prefix in include path.
|
// ESP-IDF need "freertos/" prefix in include path.
|
||||||
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
||||||
#include "freertos/FreeRTOS.h"
|
#include "freertos/FreeRTOS.h"
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
#include "bsp/board_api.h"
|
#include "bsp/board_api.h"
|
||||||
#include "tusb.h"
|
#include "tusb.h"
|
||||||
|
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
// ESP-IDF need "freertos/" prefix in include path.
|
// ESP-IDF need "freertos/" prefix in include path.
|
||||||
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
||||||
#include "freertos/FreeRTOS.h"
|
#include "freertos/FreeRTOS.h"
|
||||||
@ -107,14 +107,14 @@ int main(void) {
|
|||||||
xTimerStart(blinky_tm, 0);
|
xTimerStart(blinky_tm, 0);
|
||||||
|
|
||||||
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
// skip starting scheduler (and return) for ESP32-S2 or ESP32-S3
|
||||||
#if !TUP_MCU_ESPRESSIF
|
#if !TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
vTaskStartScheduler();
|
vTaskStartScheduler();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
void app_main(void) {
|
void app_main(void) {
|
||||||
main();
|
main();
|
||||||
}
|
}
|
||||||
|
@ -44,7 +44,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Espressif IDF requires "freertos/" prefix in include path
|
// Espressif IDF requires "freertos/" prefix in include path
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#define CFG_TUSB_OS_INC_PATH freertos/
|
#define CFG_TUSB_OS_INC_PATH freertos/
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -71,7 +71,7 @@ int main(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#if CFG_TUSB_MCU == OPT_MCU_ESP32S2 || CFG_TUSB_MCU == OPT_MCU_ESP32S3
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
void app_main(void)
|
void app_main(void)
|
||||||
{
|
{
|
||||||
main();
|
main();
|
||||||
|
@ -39,7 +39,7 @@ extern "C" {
|
|||||||
#include "tusb.h"
|
#include "tusb.h"
|
||||||
|
|
||||||
#if CFG_TUSB_OS == OPT_OS_FREERTOS
|
#if CFG_TUSB_OS == OPT_OS_FREERTOS
|
||||||
#if TUP_MCU_ESPRESSIF
|
#if TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
// ESP-IDF need "freertos/" prefix in include path.
|
// ESP-IDF need "freertos/" prefix in include path.
|
||||||
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
// CFG_TUSB_OS_INC_PATH should be defined accordingly.
|
||||||
#include "freertos/FreeRTOS.h"
|
#include "freertos/FreeRTOS.h"
|
||||||
|
@ -97,6 +97,8 @@ function(family_configure_example TARGET RTOS)
|
|||||||
family_add_tinyusb(${TARGET} OPT_MCU_BCM2835 ${RTOS})
|
family_add_tinyusb(${TARGET} OPT_MCU_BCM2835 ${RTOS})
|
||||||
target_sources(${TARGET}-tinyusb PUBLIC
|
target_sources(${TARGET}-tinyusb PUBLIC
|
||||||
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/hcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/dwc2_common.c
|
||||||
)
|
)
|
||||||
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
||||||
|
|
||||||
|
@ -104,6 +104,8 @@ function(family_configure_example TARGET RTOS)
|
|||||||
family_add_tinyusb(${TARGET} OPT_MCU_BCM${BCM_VERSION} ${RTOS})
|
family_add_tinyusb(${TARGET} OPT_MCU_BCM${BCM_VERSION} ${RTOS})
|
||||||
target_sources(${TARGET}-tinyusb PUBLIC
|
target_sources(${TARGET}-tinyusb PUBLIC
|
||||||
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/hcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/dwc2_common.c
|
||||||
)
|
)
|
||||||
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
||||||
|
|
||||||
|
@ -34,6 +34,8 @@ list(APPEND srcs
|
|||||||
${tusb_src}/class/vendor/vendor_device.c
|
${tusb_src}/class/vendor/vendor_device.c
|
||||||
${tusb_src}/class/video/video_device.c
|
${tusb_src}/class/video/video_device.c
|
||||||
${tusb_src}/portable/synopsys/dwc2/dcd_dwc2.c
|
${tusb_src}/portable/synopsys/dwc2/dcd_dwc2.c
|
||||||
|
${tusb_src}/portable/synopsys/dwc2/hcd_dwc2.c
|
||||||
|
${tusb_src}/portable/synopsys/dwc2/dwc2_common.c
|
||||||
# host
|
# host
|
||||||
${tusb_src}/host/usbh.c
|
${tusb_src}/host/usbh.c
|
||||||
${tusb_src}/host/hub.c
|
${tusb_src}/host/hub.c
|
||||||
|
@ -108,6 +108,8 @@ function(family_configure_example TARGET RTOS)
|
|||||||
family_add_tinyusb(${TARGET} OPT_MCU_GD32VF103 ${RTOS})
|
family_add_tinyusb(${TARGET} OPT_MCU_GD32VF103 ${RTOS})
|
||||||
target_sources(${TARGET}-tinyusb PUBLIC
|
target_sources(${TARGET}-tinyusb PUBLIC
|
||||||
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/hcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/dwc2_common.c
|
||||||
)
|
)
|
||||||
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
||||||
|
|
||||||
|
@ -102,6 +102,8 @@ function(family_configure_example TARGET RTOS)
|
|||||||
family_add_tinyusb(${TARGET} OPT_MCU_STM32F2 ${RTOS})
|
family_add_tinyusb(${TARGET} OPT_MCU_STM32F2 ${RTOS})
|
||||||
target_sources(${TARGET}-tinyusb PUBLIC
|
target_sources(${TARGET}-tinyusb PUBLIC
|
||||||
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/hcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/dwc2_common.c
|
||||||
)
|
)
|
||||||
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
||||||
|
|
||||||
|
@ -102,6 +102,8 @@ function(family_configure_example TARGET RTOS)
|
|||||||
family_add_tinyusb(${TARGET} OPT_MCU_STM32F4 ${RTOS})
|
family_add_tinyusb(${TARGET} OPT_MCU_STM32F4 ${RTOS})
|
||||||
target_sources(${TARGET}-tinyusb PUBLIC
|
target_sources(${TARGET}-tinyusb PUBLIC
|
||||||
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/hcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/dwc2_common.c
|
||||||
)
|
)
|
||||||
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
||||||
|
|
||||||
|
@ -104,6 +104,8 @@ function(family_configure_example TARGET RTOS)
|
|||||||
family_add_tinyusb(${TARGET} OPT_MCU_STM32F7 ${RTOS})
|
family_add_tinyusb(${TARGET} OPT_MCU_STM32F7 ${RTOS})
|
||||||
target_sources(${TARGET}-tinyusb PUBLIC
|
target_sources(${TARGET}-tinyusb PUBLIC
|
||||||
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/hcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/dwc2_common.c
|
||||||
)
|
)
|
||||||
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
set(MCU_VARIANT stm32h743xx)
|
set(MCU_VARIANT stm32h743xx)
|
||||||
set(JLINK_DEVICE stm32h743xi)
|
set(JLINK_DEVICE stm32h743xi)
|
||||||
# set(JLINK_OPTION "-USB jtrace")
|
set(JLINK_OPTION "-USB jtrace")
|
||||||
|
|
||||||
set(LD_FILE_GNU ${CMAKE_CURRENT_LIST_DIR}/../../linker/${MCU_VARIANT}_flash.ld)
|
set(LD_FILE_GNU ${CMAKE_CURRENT_LIST_DIR}/../../linker/${MCU_VARIANT}_flash.ld)
|
||||||
|
|
||||||
|
@ -102,16 +102,13 @@ function(family_configure_example TARGET RTOS)
|
|||||||
|
|
||||||
# Add TinyUSB target and port source
|
# Add TinyUSB target and port source
|
||||||
family_add_tinyusb(${TARGET} OPT_MCU_STM32U5 ${RTOS})
|
family_add_tinyusb(${TARGET} OPT_MCU_STM32U5 ${RTOS})
|
||||||
if ((${MCU_VARIANT} STREQUAL "stm32u535xx") OR (${MCU_VARIANT} STREQUAL "stm32u545xx"))
|
target_sources(${TARGET}-tinyusb PUBLIC
|
||||||
target_sources(${TARGET}-tinyusb PUBLIC
|
${TOP}/src/portable/st/stm32_fsdev/dcd_stm32_fsdev.c
|
||||||
${TOP}/src/portable/st/stm32_fsdev/dcd_stm32_fsdev.c
|
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
||||||
)
|
${TOP}/src/portable/synopsys/dwc2/hcd_dwc2.c
|
||||||
else ()
|
${TOP}/src/portable/synopsys/dwc2/dwc2_common.c
|
||||||
target_sources(${TARGET}-tinyusb PUBLIC
|
#${TOP}/src/portable/st/typec/typec_stm32.c
|
||||||
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
)
|
||||||
#${TOP}/src/portable/st/typec/typec_stm32.c
|
|
||||||
)
|
|
||||||
endif ()
|
|
||||||
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
||||||
|
|
||||||
# Link dependencies
|
# Link dependencies
|
||||||
|
@ -86,6 +86,8 @@ function(family_configure_example TARGET RTOS)
|
|||||||
family_add_tinyusb(${TARGET} OPT_MCU_XMC4000 ${RTOS})
|
family_add_tinyusb(${TARGET} OPT_MCU_XMC4000 ${RTOS})
|
||||||
target_sources(${TARGET}-tinyusb PUBLIC
|
target_sources(${TARGET}-tinyusb PUBLIC
|
||||||
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
${TOP}/src/portable/synopsys/dwc2/dcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/hcd_dwc2.c
|
||||||
|
${TOP}/src/portable/synopsys/dwc2/dwc2_common.c
|
||||||
)
|
)
|
||||||
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
target_link_libraries(${TARGET}-tinyusb PUBLIC board_${BOARD})
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@
|
|||||||
if ( (*ARM_CM_DHCSR) & 1UL ) __asm("BKPT #0\n"); /* Only halt mcu if debugger is attached */ \
|
if ( (*ARM_CM_DHCSR) & 1UL ) __asm("BKPT #0\n"); /* Only halt mcu if debugger is attached */ \
|
||||||
} while(0)
|
} while(0)
|
||||||
|
|
||||||
#elif defined(__riscv) && !TUP_MCU_ESPRESSIF
|
#elif defined(__riscv) && !TUSB_MCU_VENDOR_ESPRESSIF
|
||||||
#define TU_BREAKPOINT() do { __asm("ebreak\n"); } while(0)
|
#define TU_BREAKPOINT() do { __asm("ebreak\n"); } while(0)
|
||||||
|
|
||||||
#elif defined(_mips)
|
#elif defined(_mips)
|
||||||
|
@ -480,21 +480,28 @@ bool dcd_init(uint8_t rhport, const tusb_rhport_init_t* rh_init) {
|
|||||||
(void) rh_init;
|
(void) rh_init;
|
||||||
dwc2_regs_t* dwc2 = DWC2_REG(rhport);
|
dwc2_regs_t* dwc2 = DWC2_REG(rhport);
|
||||||
|
|
||||||
TU_ASSERT(dwc2_controller_init(rhport, rh_init));
|
TU_ASSERT(dwc2_core_init(rhport, rh_init));
|
||||||
|
|
||||||
|
// Device Initialization
|
||||||
dcd_disconnect(rhport);
|
dcd_disconnect(rhport);
|
||||||
|
|
||||||
// Restart PHY clock
|
// Set device max speed
|
||||||
dwc2->pcgctl &= ~(PCGCTL_STOPPCLK | PCGCTL_GATEHCLK | PCGCTL_PWRCLMP | PCGCTL_RSTPDWNMODULE);
|
uint32_t dcfg = dwc2->dcfg & ~DCFG_DSPD_Msk;
|
||||||
|
if (dwc2_core_is_highspeed(dwc2, rh_init)) {
|
||||||
|
dcfg |= DCFG_DSPD_HS << DCFG_DSPD_Pos;
|
||||||
|
|
||||||
/* Set HS/FS Timeout Calibration to 7 (max available value).
|
// XCVRDLY: transceiver delay between xcvr_sel and txvalid during device chirp is required
|
||||||
* The number of PHY clocks that the application programs in
|
// when using with some PHYs such as USB334x (USB3341, USB3343, USB3346, USB3347)
|
||||||
* this field is added to the high/full speed interpacket timeout
|
if (dwc2->ghwcfg2_bm.hs_phy_type == GHWCFG2_HSPHY_ULPI) {
|
||||||
* duration in the core to account for any additional delays
|
dcfg |= DCFG_XCVRDLY;
|
||||||
* introduced by the PHY. This can be required, because the delay
|
}
|
||||||
* introduced by the PHY in generating the linestate condition
|
}else {
|
||||||
* can vary from one PHY to another.
|
dcfg |= DCFG_DSPD_FS << DCFG_DSPD_Pos;
|
||||||
*/
|
}
|
||||||
dwc2->gusbcfg |= (7ul << GUSBCFG_TOCAL_Pos);
|
dwc2->dcfg = dcfg;
|
||||||
|
|
||||||
|
// Enable PHY clock TODO stop/gate clock when suspended mode
|
||||||
|
dwc2->pcgcctl &= ~(PCGCCTL_STOPPCLK | PCGCCTL_GATEHCLK | PCGCCTL_PWRCLMP | PCGCCTL_RSTPDWNMODULE);
|
||||||
|
|
||||||
// Force device mode
|
// Force device mode
|
||||||
dwc2->gusbcfg = (dwc2->gusbcfg & ~GUSBCFG_FHMOD) | GUSBCFG_FDMOD;
|
dwc2->gusbcfg = (dwc2->gusbcfg & ~GUSBCFG_FHMOD) | GUSBCFG_FDMOD;
|
||||||
@ -502,8 +509,7 @@ bool dcd_init(uint8_t rhport, const tusb_rhport_init_t* rh_init) {
|
|||||||
// Clear A override, force B Valid
|
// Clear A override, force B Valid
|
||||||
dwc2->gotgctl = (dwc2->gotgctl & ~GOTGCTL_AVALOEN) | GOTGCTL_BVALOEN | GOTGCTL_BVALOVAL;
|
dwc2->gotgctl = (dwc2->gotgctl & ~GOTGCTL_AVALOEN) | GOTGCTL_BVALOEN | GOTGCTL_BVALOVAL;
|
||||||
|
|
||||||
// If USB host misbehaves during status portion of control xfer
|
// If USB host misbehaves during status portion of control xfer (non zero-length packet), send STALL back and discard
|
||||||
// (non zero-length packet), send STALL back and discard.
|
|
||||||
dwc2->dcfg |= DCFG_NZLSOHSK;
|
dwc2->dcfg |= DCFG_NZLSOHSK;
|
||||||
|
|
||||||
dfifo_flush_tx(dwc2, 0x10); // all tx fifo
|
dfifo_flush_tx(dwc2, 0x10); // all tx fifo
|
||||||
|
@ -30,7 +30,14 @@
|
|||||||
|
|
||||||
#if defined(TUP_USBIP_DWC2) && (CFG_TUH_ENABLED || CFG_TUD_ENABLED)
|
#if defined(TUP_USBIP_DWC2) && (CFG_TUH_ENABLED || CFG_TUD_ENABLED)
|
||||||
|
|
||||||
#include "common/tusb_common.h"
|
#if CFG_TUD_ENABLED
|
||||||
|
#include "device/dcd.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CFG_TUH_ENABLED
|
||||||
|
#include "host/hcd.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "dwc2_common.h"
|
#include "dwc2_common.h"
|
||||||
|
|
||||||
static void reset_core(dwc2_regs_t* dwc2) {
|
static void reset_core(dwc2_regs_t* dwc2) {
|
||||||
@ -47,18 +54,24 @@ static void reset_core(dwc2_regs_t* dwc2) {
|
|||||||
// wait for device mode ?
|
// wait for device mode ?
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool phy_hs_supported(dwc2_regs_t* dwc2, const tusb_rhport_init_t* rh_init) {
|
bool dwc2_core_is_highspeed(dwc2_regs_t* dwc2, const tusb_rhport_init_t* rh_init) {
|
||||||
(void) dwc2;
|
(void) dwc2;
|
||||||
|
|
||||||
|
#if CFG_TUD_ENABLED
|
||||||
#if !TUD_OPT_HIGH_SPEED
|
if (rh_init->role == TUSB_ROLE_DEVICE && !TUD_OPT_HIGH_SPEED) {
|
||||||
return false;
|
return false;
|
||||||
#else
|
}
|
||||||
return dwc2->ghwcfg2_bm.hs_phy_type != GHWCFG2_HSPHY_NOT_SUPPORTED;
|
|
||||||
#endif
|
#endif
|
||||||
|
#if CFG_TUH_ENABLED
|
||||||
|
if (rh_init->role == TUSB_ROLE_DEVICE && !TUH_OPT_HIGH_SPEED) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return dwc2->ghwcfg2_bm.hs_phy_type != GHWCFG2_HSPHY_NOT_SUPPORTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void phy_fs_init(dwc2_regs_t* dwc2, const tusb_rhport_init_t* rh_init) {
|
static void phy_fs_init(dwc2_regs_t* dwc2) {
|
||||||
TU_LOG(DWC2_COMMON_DEBUG, "Fullspeed PHY init\r\n");
|
TU_LOG(DWC2_COMMON_DEBUG, "Fullspeed PHY init\r\n");
|
||||||
|
|
||||||
// Select FS PHY
|
// Select FS PHY
|
||||||
@ -77,12 +90,9 @@ static void phy_fs_init(dwc2_regs_t* dwc2, const tusb_rhport_init_t* rh_init) {
|
|||||||
|
|
||||||
// MCU specific PHY update post reset
|
// MCU specific PHY update post reset
|
||||||
dwc2_phy_update(dwc2, GHWCFG2_HSPHY_NOT_SUPPORTED);
|
dwc2_phy_update(dwc2, GHWCFG2_HSPHY_NOT_SUPPORTED);
|
||||||
|
|
||||||
// set max speed
|
|
||||||
dwc2->dcfg = (dwc2->dcfg & ~DCFG_DSPD_Msk) | (DCFG_DSPD_FS << DCFG_DSPD_Pos);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void phy_hs_init(dwc2_regs_t* dwc2, const tusb_rhport_init_t* rh_init) {
|
static void phy_hs_init(dwc2_regs_t* dwc2) {
|
||||||
uint32_t gusbcfg = dwc2->gusbcfg;
|
uint32_t gusbcfg = dwc2->gusbcfg;
|
||||||
|
|
||||||
// De-select FS PHY
|
// De-select FS PHY
|
||||||
@ -137,19 +147,6 @@ static void phy_hs_init(dwc2_regs_t* dwc2, const tusb_rhport_init_t* rh_init) {
|
|||||||
|
|
||||||
// MCU specific PHY update post reset
|
// MCU specific PHY update post reset
|
||||||
dwc2_phy_update(dwc2, dwc2->ghwcfg2_bm.hs_phy_type);
|
dwc2_phy_update(dwc2, dwc2->ghwcfg2_bm.hs_phy_type);
|
||||||
|
|
||||||
// Set max speed
|
|
||||||
uint32_t dcfg = dwc2->dcfg;
|
|
||||||
dcfg &= ~DCFG_DSPD_Msk;
|
|
||||||
dcfg |= DCFG_DSPD_HS << DCFG_DSPD_Pos;
|
|
||||||
|
|
||||||
// XCVRDLY: transceiver delay between xcvr_sel and txvalid during device chirp is required
|
|
||||||
// when using with some PHYs such as USB334x (USB3341, USB3343, USB3346, USB3347)
|
|
||||||
if (dwc2->ghwcfg2_bm.hs_phy_type == GHWCFG2_HSPHY_ULPI) {
|
|
||||||
dcfg |= DCFG_XCVRDLY;
|
|
||||||
}
|
|
||||||
|
|
||||||
dwc2->dcfg = dcfg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool check_dwc2(dwc2_regs_t* dwc2) {
|
static bool check_dwc2(dwc2_regs_t* dwc2) {
|
||||||
@ -177,19 +174,29 @@ static bool check_dwc2(dwc2_regs_t* dwc2) {
|
|||||||
//--------------------------------------------------------------------
|
//--------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
//--------------------------------------------------------------------
|
//--------------------------------------------------------------------
|
||||||
bool dwc2_controller_init(uint8_t rhport, const tusb_rhport_init_t* rh_init) {
|
bool dwc2_core_init(uint8_t rhport, const tusb_rhport_init_t* rh_init) {
|
||||||
(void) rh_init;
|
(void) rh_init;
|
||||||
dwc2_regs_t* dwc2 = DWC2_REG(rhport);
|
dwc2_regs_t* dwc2 = DWC2_REG(rhport);
|
||||||
|
|
||||||
// Check Synopsys ID register, failed if controller clock/power is not enabled
|
// Check Synopsys ID register, failed if controller clock/power is not enabled
|
||||||
TU_ASSERT(check_dwc2(dwc2));
|
TU_ASSERT(check_dwc2(dwc2));
|
||||||
|
|
||||||
if (phy_hs_supported(dwc2, rh_init)) {
|
if (dwc2_core_is_highspeed(dwc2, rh_init)) {
|
||||||
phy_hs_init(dwc2, rh_init); // Highspeed
|
phy_hs_init(dwc2); // Highspeed
|
||||||
} else {
|
} else {
|
||||||
phy_fs_init(dwc2, rh_init); // core does not support highspeed or hs phy is not present
|
phy_fs_init(dwc2); // core does not support highspeed or hs phy is not present
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Set HS/FS Timeout Calibration to 7 (max available value).
|
||||||
|
* The number of PHY clocks that the application programs in
|
||||||
|
* this field is added to the high/full speed interpacket timeout
|
||||||
|
* duration in the core to account for any additional delays
|
||||||
|
* introduced by the PHY. This can be required, because the delay
|
||||||
|
* introduced by the PHY in generating the linestate condition
|
||||||
|
* can vary from one PHY to another.
|
||||||
|
*/
|
||||||
|
dwc2->gusbcfg |= (7ul << GUSBCFG_TOCAL_Pos);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
#ifndef TUSB_DWC2_COMMON_H
|
#ifndef TUSB_DWC2_COMMON_H
|
||||||
#define TUSB_DWC2_COMMON_H
|
#define TUSB_DWC2_COMMON_H
|
||||||
|
|
||||||
|
#include "common/tusb_common.h"
|
||||||
#include "dwc2_type.h"
|
#include "dwc2_type.h"
|
||||||
|
|
||||||
// Following symbols must be defined by port header
|
// Following symbols must be defined by port header
|
||||||
@ -64,7 +65,7 @@ TU_ATTR_ALWAYS_INLINE static inline dwc2_regs_t* DWC2_REG(uint8_t rhport) {
|
|||||||
return (dwc2_regs_t*)_dwc2_controller[rhport].reg_base;
|
return (dwc2_regs_t*)_dwc2_controller[rhport].reg_base;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool dwc2_core_is_highspeed(dwc2_regs_t* dwc2, const tusb_rhport_init_t* rh_init);
|
||||||
bool dwc2_controller_init(uint8_t rhport, const tusb_rhport_init_t* rh_init);
|
bool dwc2_core_init(uint8_t rhport, const tusb_rhport_init_t* rh_init);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -25,13 +25,14 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
#ifndef _DWC2_ESP32_H_
|
#ifndef TUSB_DWC2_ESP32_H_
|
||||||
#define _DWC2_ESP32_H_
|
#define TUSB_DWC2_ESP32_H_
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include "freertos/FreeRTOS.h"
|
||||||
#include "freertos/task.h"
|
#include "freertos/task.h"
|
||||||
|
|
||||||
#include "esp_intr_alloc.h"
|
#include "esp_intr_alloc.h"
|
||||||
|
@ -464,8 +464,8 @@ typedef struct {
|
|||||||
uint32_t reservedd00[64]; // D00..DFF
|
uint32_t reservedd00[64]; // D00..DFF
|
||||||
|
|
||||||
//------------- Power Clock -------------//
|
//------------- Power Clock -------------//
|
||||||
volatile uint32_t pcgctl; // E00 Power and Clock Gating Control
|
volatile uint32_t pcgcctl; // E00 Power and Clock Gating Characteristic Control
|
||||||
volatile uint32_t pcgctl1; // E04
|
volatile uint32_t pcgcctl1; // E04 Power and Clock Gating Characteristic Control 1
|
||||||
uint32_t reservede08[126]; // E08..FFF
|
uint32_t reservede08[126]; // E08..FFF
|
||||||
|
|
||||||
//------------- FIFOs -------------//
|
//------------- FIFOs -------------//
|
||||||
@ -478,7 +478,7 @@ TU_VERIFY_STATIC(offsetof(dwc2_regs_t, channel) == 0x0500, "incorrect size");
|
|||||||
TU_VERIFY_STATIC(offsetof(dwc2_regs_t, dcfg ) == 0x0800, "incorrect size");
|
TU_VERIFY_STATIC(offsetof(dwc2_regs_t, dcfg ) == 0x0800, "incorrect size");
|
||||||
TU_VERIFY_STATIC(offsetof(dwc2_regs_t, epin ) == 0x0900, "incorrect size");
|
TU_VERIFY_STATIC(offsetof(dwc2_regs_t, epin ) == 0x0900, "incorrect size");
|
||||||
TU_VERIFY_STATIC(offsetof(dwc2_regs_t, epout ) == 0x0B00, "incorrect size");
|
TU_VERIFY_STATIC(offsetof(dwc2_regs_t, epout ) == 0x0B00, "incorrect size");
|
||||||
TU_VERIFY_STATIC(offsetof(dwc2_regs_t, pcgctl ) == 0x0E00, "incorrect size");
|
TU_VERIFY_STATIC(offsetof(dwc2_regs_t, pcgcctl) == 0x0E00, "incorrect size");
|
||||||
TU_VERIFY_STATIC(offsetof(dwc2_regs_t, fifo ) == 0x1000, "incorrect size");
|
TU_VERIFY_STATIC(offsetof(dwc2_regs_t, fifo ) == 0x1000, "incorrect size");
|
||||||
|
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
@ -720,7 +720,7 @@ TU_VERIFY_STATIC(offsetof(dwc2_regs_t, fifo ) == 0x1000, "incorrect size");
|
|||||||
/******************** Bit definition for GUSBCFG register ********************/
|
/******************** Bit definition for GUSBCFG register ********************/
|
||||||
#define GUSBCFG_TOCAL_Pos (0U)
|
#define GUSBCFG_TOCAL_Pos (0U)
|
||||||
#define GUSBCFG_TOCAL_Msk (0x7UL << GUSBCFG_TOCAL_Pos) // 0x00000007
|
#define GUSBCFG_TOCAL_Msk (0x7UL << GUSBCFG_TOCAL_Pos) // 0x00000007
|
||||||
#define GUSBCFG_TOCAL GUSBCFG_TOCAL_Msk // FS timeout calibration
|
#define GUSBCFG_TOCAL GUSBCFG_TOCAL_Msk // HS/FS timeout calibration
|
||||||
#define GUSBCFG_PHYIF16_Pos (3U)
|
#define GUSBCFG_PHYIF16_Pos (3U)
|
||||||
#define GUSBCFG_PHYIF16_Msk (0x1UL << GUSBCFG_PHYIF16_Pos) // 0x00000008
|
#define GUSBCFG_PHYIF16_Msk (0x1UL << GUSBCFG_PHYIF16_Pos) // 0x00000008
|
||||||
#define GUSBCFG_PHYIF16 GUSBCFG_PHYIF16_Msk // PHY Interface (PHYIf)
|
#define GUSBCFG_PHYIF16 GUSBCFG_PHYIF16_Msk // PHY Interface (PHYIf)
|
||||||
@ -1973,32 +1973,32 @@ TU_VERIFY_STATIC(offsetof(dwc2_regs_t, fifo ) == 0x1000, "incorrect size");
|
|||||||
#define DOEPTSIZ_STUPCNT_1 (0x2UL << DOEPTSIZ_STUPCNT_Pos) // 0x40000000
|
#define DOEPTSIZ_STUPCNT_1 (0x2UL << DOEPTSIZ_STUPCNT_Pos) // 0x40000000
|
||||||
|
|
||||||
/******************** Bit definition for PCGCTL register ********************/
|
/******************** Bit definition for PCGCTL register ********************/
|
||||||
#define PCGCTL_IF_DEV_MODE TU_BIT(31)
|
#define PCGCCTL_IF_DEV_MODE TU_BIT(31)
|
||||||
#define PCGCTL_P2HD_PRT_SPD_MASK (0x3ul << 29)
|
#define PCGCCTL_P2HD_PRT_SPD_MASK (0x3ul << 29)
|
||||||
#define PCGCTL_P2HD_PRT_SPD_SHIFT 29
|
#define PCGCCTL_P2HD_PRT_SPD_SHIFT 29
|
||||||
#define PCGCTL_P2HD_DEV_ENUM_SPD_MASK (0x3ul << 27)
|
#define PCGCCTL_P2HD_DEV_ENUM_SPD_MASK (0x3ul << 27)
|
||||||
#define PCGCTL_P2HD_DEV_ENUM_SPD_SHIFT 27
|
#define PCGCCTL_P2HD_DEV_ENUM_SPD_SHIFT 27
|
||||||
#define PCGCTL_MAC_DEV_ADDR_MASK (0x7ful << 20)
|
#define PCGCCTL_MAC_DEV_ADDR_MASK (0x7ful << 20)
|
||||||
#define PCGCTL_MAC_DEV_ADDR_SHIFT 20
|
#define PCGCCTL_MAC_DEV_ADDR_SHIFT 20
|
||||||
#define PCGCTL_MAX_TERMSEL TU_BIT(19)
|
#define PCGCCTL_MAX_TERMSEL TU_BIT(19)
|
||||||
#define PCGCTL_MAX_XCVRSELECT_MASK (0x3ul << 17)
|
#define PCGCCTL_MAX_XCVRSELECT_MASK (0x3ul << 17)
|
||||||
#define PCGCTL_MAX_XCVRSELECT_SHIFT 17
|
#define PCGCCTL_MAX_XCVRSELECT_SHIFT 17
|
||||||
#define PCGCTL_PORT_POWER TU_BIT(16)
|
#define PCGCCTL_PORT_POWER TU_BIT(16)
|
||||||
#define PCGCTL_PRT_CLK_SEL_MASK (0x3ul << 14)
|
#define PCGCCTL_PRT_CLK_SEL_MASK (0x3ul << 14)
|
||||||
#define PCGCTL_PRT_CLK_SEL_SHIFT 14
|
#define PCGCCTL_PRT_CLK_SEL_SHIFT 14
|
||||||
#define PCGCTL_ESS_REG_RESTORED TU_BIT(13)
|
#define PCGCCTL_ESS_REG_RESTORED TU_BIT(13)
|
||||||
#define PCGCTL_EXTND_HIBER_SWITCH TU_BIT(12)
|
#define PCGCCTL_EXTND_HIBER_SWITCH TU_BIT(12)
|
||||||
#define PCGCTL_EXTND_HIBER_PWRCLMP TU_BIT(11)
|
#define PCGCCTL_EXTND_HIBER_PWRCLMP TU_BIT(11)
|
||||||
#define PCGCTL_ENBL_EXTND_HIBER TU_BIT(10)
|
#define PCGCCTL_ENBL_EXTND_HIBER TU_BIT(10)
|
||||||
#define PCGCTL_RESTOREMODE TU_BIT(9)
|
#define PCGCCTL_RESTOREMODE TU_BIT(9)
|
||||||
#define PCGCTL_RESETAFTSUSP TU_BIT(8)
|
#define PCGCCTL_RESETAFTSUSP TU_BIT(8)
|
||||||
#define PCGCTL_DEEP_SLEEP TU_BIT(7)
|
#define PCGCCTL_DEEP_SLEEP TU_BIT(7)
|
||||||
#define PCGCTL_PHY_IN_SLEEP TU_BIT(6)
|
#define PCGCCTL_PHY_IN_SLEEP TU_BIT(6)
|
||||||
#define PCGCTL_ENBL_SLEEP_GATING TU_BIT(5)
|
#define PCGCCTL_ENBL_SLEEP_GATING TU_BIT(5)
|
||||||
#define PCGCTL_RSTPDWNMODULE TU_BIT(3)
|
#define PCGCCTL_RSTPDWNMODULE TU_BIT(3)
|
||||||
#define PCGCTL_PWRCLMP TU_BIT(2)
|
#define PCGCCTL_PWRCLMP TU_BIT(2)
|
||||||
#define PCGCTL_GATEHCLK TU_BIT(1)
|
#define PCGCCTL_GATEHCLK TU_BIT(1)
|
||||||
#define PCGCTL_STOPPCLK TU_BIT(0)
|
#define PCGCCTL_STOPPCLK TU_BIT(0)
|
||||||
|
|
||||||
#define PCGCTL1_TIMER (0x3ul << 1)
|
#define PCGCTL1_TIMER (0x3ul << 1)
|
||||||
#define PCGCTL1_GATEEN TU_BIT(0)
|
#define PCGCTL1_GATEEN TU_BIT(0)
|
||||||
|
@ -125,7 +125,8 @@
|
|||||||
#define OPT_MCU_ESP32C2 905 ///< Espressif ESP32-C2
|
#define OPT_MCU_ESP32C2 905 ///< Espressif ESP32-C2
|
||||||
#define OPT_MCU_ESP32H2 906 ///< Espressif ESP32-H2
|
#define OPT_MCU_ESP32H2 906 ///< Espressif ESP32-H2
|
||||||
#define OPT_MCU_ESP32P4 907 ///< Espressif ESP32-P4
|
#define OPT_MCU_ESP32P4 907 ///< Espressif ESP32-P4
|
||||||
#define TUP_MCU_ESPRESSIF (CFG_TUSB_MCU >= 900 && CFG_TUSB_MCU < 1000) // check if Espressif MCU
|
#define TUSB_MCU_VENDOR_ESPRESSIF (CFG_TUSB_MCU >= 900 && CFG_TUSB_MCU < 1000) // check if Espressif MCU
|
||||||
|
#define TUP_MCU_ESPRESSIF TUSB_MCU_VENDOR_ESPRESSIF // for backward compatibility
|
||||||
|
|
||||||
// Dialog
|
// Dialog
|
||||||
#define OPT_MCU_DA1469X 1000 ///< Dialog Semiconductor DA1469x
|
#define OPT_MCU_DA1469X 1000 ///< Dialog Semiconductor DA1469x
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#!/usr/bin/env python3
|
#!/usr/bin/env python3
|
||||||
import subprocess
|
import subprocess
|
||||||
import pathlib
|
import pathlib
|
||||||
import time
|
import re
|
||||||
|
|
||||||
build_format = '| {:29} | {:30} | {:18} | {:7} | {:6} | {:6} |'
|
build_format = '| {:29} | {:30} | {:18} | {:7} | {:6} | {:6} |'
|
||||||
|
|
||||||
@ -36,18 +36,21 @@ def skip_example(example, board):
|
|||||||
mk_contents = board_mk.read_text()
|
mk_contents = board_mk.read_text()
|
||||||
|
|
||||||
mcu = "NONE"
|
mcu = "NONE"
|
||||||
for token in mk_contents.split():
|
if family == "espressif":
|
||||||
if "CFG_TUSB_MCU=OPT_MCU_" in token:
|
for line in mk_contents.splitlines():
|
||||||
# Strip " because cmake files has them.
|
match = re.search(r'set\(IDF_TARGET\s+"([^"]+)"\)', line)
|
||||||
token = token.strip("\"")
|
if match:
|
||||||
_, opt_mcu = token.split("=")
|
mcu = match.group(1)
|
||||||
mcu = opt_mcu[len("OPT_MCU_"):]
|
break
|
||||||
if "esp32s2" in token:
|
else:
|
||||||
mcu = "ESP32S2"
|
for token in mk_contents.split():
|
||||||
if "esp32s3" in token:
|
if "CFG_TUSB_MCU=OPT_MCU_" in token:
|
||||||
mcu = "ESP32S3"
|
# Strip " because cmake files has them.
|
||||||
if mcu != "NONE":
|
token = token.strip("\"")
|
||||||
break
|
_, opt_mcu = token.split("=")
|
||||||
|
mcu = opt_mcu[len("OPT_MCU_"):]
|
||||||
|
if mcu != "NONE":
|
||||||
|
break
|
||||||
|
|
||||||
# Skip all OPT_MCU_NONE these are WIP port
|
# Skip all OPT_MCU_NONE these are WIP port
|
||||||
if mcu == "NONE":
|
if mcu == "NONE":
|
||||||
|
Loading…
x
Reference in New Issue
Block a user