change hcd_int_handler(rhport, in_isr) signature: add in_isr
change tuh_int_handler() to take in_isr as optional parameter (default = true)
This commit is contained in:
@@ -1,3 +1,4 @@
|
|||||||
|
mcu:KINETIS_KL
|
||||||
mcu:LPC175X_6X
|
mcu:LPC175X_6X
|
||||||
mcu:LPC177X_8X
|
mcu:LPC177X_8X
|
||||||
mcu:LPC18XX
|
mcu:LPC18XX
|
||||||
|
@@ -1,3 +1,4 @@
|
|||||||
|
mcu:KINETIS_KL
|
||||||
mcu:LPC175X_6X
|
mcu:LPC175X_6X
|
||||||
mcu:LPC177X_8X
|
mcu:LPC177X_8X
|
||||||
mcu:LPC18XX
|
mcu:LPC18XX
|
||||||
|
@@ -1,3 +1,4 @@
|
|||||||
|
mcu:KINETIS_KL
|
||||||
mcu:LPC175X_6X
|
mcu:LPC175X_6X
|
||||||
mcu:LPC177X_8X
|
mcu:LPC177X_8X
|
||||||
mcu:LPC18XX
|
mcu:LPC18XX
|
||||||
|
@@ -1,3 +1,4 @@
|
|||||||
|
mcu:KINETIS_KL
|
||||||
mcu:LPC175X_6X
|
mcu:LPC175X_6X
|
||||||
mcu:LPC177X_8X
|
mcu:LPC177X_8X
|
||||||
mcu:LPC18XX
|
mcu:LPC18XX
|
||||||
|
@@ -188,7 +188,7 @@ void USB_OTG1_IRQHandler(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PORT_SUPPORT_HOST(0)
|
#if PORT_SUPPORT_HOST(0)
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -199,7 +199,7 @@ void USB_OTG2_IRQHandler(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PORT_SUPPORT_HOST(1)
|
#if PORT_SUPPORT_HOST(1)
|
||||||
tuh_int_handler(1);
|
tuh_int_handler(1, true);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -39,7 +39,7 @@
|
|||||||
void USB0_IRQHandler(void)
|
void USB0_IRQHandler(void)
|
||||||
{
|
{
|
||||||
#if CFG_TUH_ENABLED
|
#if CFG_TUH_ENABLED
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
#if CFG_TUD_ENABLED
|
#if CFG_TUD_ENABLED
|
||||||
tud_int_handler(0);
|
tud_int_handler(0);
|
||||||
|
@@ -22,7 +22,10 @@ set(FAMILY_MCUS KINETIS_KL CACHE INTERNAL "")
|
|||||||
#------------------------------------
|
#------------------------------------
|
||||||
# only need to be built ONCE for all examples
|
# only need to be built ONCE for all examples
|
||||||
function(add_board_target BOARD_TARGET)
|
function(add_board_target BOARD_TARGET)
|
||||||
if (NOT TARGET ${BOARD_TARGET})
|
if (TARGET ${BOARD_TARGET})
|
||||||
|
return()
|
||||||
|
endif ()
|
||||||
|
|
||||||
add_library(${BOARD_TARGET} STATIC
|
add_library(${BOARD_TARGET} STATIC
|
||||||
${SDK_DIR}/drivers/gpio/fsl_gpio.c
|
${SDK_DIR}/drivers/gpio/fsl_gpio.c
|
||||||
${SDK_DIR}/drivers/lpsci/fsl_lpsci.c
|
${SDK_DIR}/drivers/lpsci/fsl_lpsci.c
|
||||||
@@ -43,11 +46,9 @@ function(add_board_target BOARD_TARGET)
|
|||||||
${SDK_DIR}/drivers/smc
|
${SDK_DIR}/drivers/smc
|
||||||
${SDK_DIR}/drivers/uart
|
${SDK_DIR}/drivers/uart
|
||||||
)
|
)
|
||||||
|
|
||||||
update_board(${BOARD_TARGET})
|
update_board(${BOARD_TARGET})
|
||||||
|
|
||||||
# LD_FILE and STARTUP_FILE can be defined in board.cmake
|
# LD_FILE and STARTUP_FILE can be defined in board.cmake
|
||||||
|
|
||||||
target_sources(${BOARD_TARGET} PUBLIC
|
target_sources(${BOARD_TARGET} PUBLIC
|
||||||
${STARTUP_FILE_${CMAKE_C_COMPILER_ID}}
|
${STARTUP_FILE_${CMAKE_C_COMPILER_ID}}
|
||||||
)
|
)
|
||||||
@@ -56,15 +57,13 @@ function(add_board_target BOARD_TARGET)
|
|||||||
target_link_options(${BOARD_TARGET} PUBLIC
|
target_link_options(${BOARD_TARGET} PUBLIC
|
||||||
"LINKER:--script=${LD_FILE_GNU}"
|
"LINKER:--script=${LD_FILE_GNU}"
|
||||||
# nanolib
|
# nanolib
|
||||||
--specs=nosys.specs
|
--specs=nosys.specs --specs=nano.specs
|
||||||
--specs=nano.specs
|
|
||||||
)
|
)
|
||||||
elseif (CMAKE_C_COMPILER_ID STREQUAL "IAR")
|
elseif (CMAKE_C_COMPILER_ID STREQUAL "IAR")
|
||||||
target_link_options(${BOARD_TARGET} PUBLIC
|
target_link_options(${BOARD_TARGET} PUBLIC
|
||||||
"LINKER:--config=${LD_FILE_IAR}"
|
"LINKER:--config=${LD_FILE_IAR}"
|
||||||
)
|
)
|
||||||
endif ()
|
endif ()
|
||||||
endif ()
|
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
|
|
||||||
|
@@ -37,7 +37,7 @@ void USB_IRQHandler(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CFG_TUH_ENABLED
|
#if CFG_TUH_ENABLED
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -151,7 +151,7 @@ void USB_IRQHandler(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CFG_TUH_ENABLED
|
#if CFG_TUH_ENABLED
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -43,25 +43,23 @@
|
|||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
// USB Interrupt Handler
|
// USB Interrupt Handler
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
void USB0_IRQHandler(void)
|
void USB0_IRQHandler(void) {
|
||||||
{
|
|
||||||
#if PORT_SUPPORT_DEVICE(0)
|
#if PORT_SUPPORT_DEVICE(0)
|
||||||
tud_int_handler(0);
|
tud_int_handler(0);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PORT_SUPPORT_HOST(0)
|
#if PORT_SUPPORT_HOST(0)
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void USB1_IRQHandler(void)
|
void USB1_IRQHandler(void) {
|
||||||
{
|
|
||||||
#if PORT_SUPPORT_DEVICE(1)
|
#if PORT_SUPPORT_DEVICE(1)
|
||||||
tud_int_handler(1);
|
tud_int_handler(1);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PORT_SUPPORT_HOST(1)
|
#if PORT_SUPPORT_HOST(1)
|
||||||
tuh_int_handler(1);
|
tuh_int_handler(1, true);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -74,28 +72,26 @@ const uint32_t OscRateIn = 12000000;
|
|||||||
const uint32_t ExtRateIn = 0;
|
const uint32_t ExtRateIn = 0;
|
||||||
|
|
||||||
// Invoked by startup code
|
// Invoked by startup code
|
||||||
void SystemInit(void)
|
void SystemInit(void) {
|
||||||
{
|
|
||||||
#ifdef __USE_LPCOPEN
|
#ifdef __USE_LPCOPEN
|
||||||
extern void (* const g_pfnVectors[])(void);
|
extern void (*const g_pfnVectors[])(void);
|
||||||
unsigned int *pSCB_VTOR = (unsigned int *) 0xE000ED08;
|
unsigned int *pSCB_VTOR = (unsigned int *) 0xE000ED08;
|
||||||
*pSCB_VTOR = (unsigned int) g_pfnVectors;
|
*pSCB_VTOR = (unsigned int) g_pfnVectors;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
board_lpc18_pinmux();
|
board_lpc18_pinmux();
|
||||||
|
|
||||||
#ifdef TRACE_ETM
|
#ifdef TRACE_ETM
|
||||||
// Trace clock is limited to 60MHz, limit CPU clock to 120MHz
|
// Trace clock is limited to 60MHz, limit CPU clock to 120MHz
|
||||||
Chip_SetupCoreClock(CLKIN_CRYSTAL, 120000000UL, true);
|
Chip_SetupCoreClock(CLKIN_CRYSTAL, 120000000UL, true);
|
||||||
#else
|
#else
|
||||||
// CPU clock max to 180 Mhz
|
// CPU clock max to 180 Mhz
|
||||||
Chip_SetupCoreClock(CLKIN_CRYSTAL, MAX_CLOCK_FREQ, true);
|
Chip_SetupCoreClock(CLKIN_CRYSTAL, MAX_CLOCK_FREQ, true);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void board_init(void)
|
void board_init(void) {
|
||||||
{
|
|
||||||
SystemCoreClockUpdate();
|
SystemCoreClockUpdate();
|
||||||
|
|
||||||
#if CFG_TUSB_OS == OPT_OS_NONE
|
#if CFG_TUSB_OS == OPT_OS_NONE
|
||||||
@@ -135,27 +131,22 @@ void board_init(void)
|
|||||||
// Board porting API
|
// Board porting API
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
|
|
||||||
void board_led_write(bool state)
|
void board_led_write(bool state) {
|
||||||
{
|
|
||||||
Chip_GPIO_SetPinState(LPC_GPIO_PORT, LED_PORT, LED_PIN, state);
|
Chip_GPIO_SetPinState(LPC_GPIO_PORT, LED_PORT, LED_PIN, state);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t board_button_read(void)
|
uint32_t board_button_read(void) {
|
||||||
{
|
|
||||||
// active low
|
// active low
|
||||||
return Chip_GPIO_GetPinState(LPC_GPIO_PORT, BUTTON_PORT, BUTTON_PIN) ? 0 : 1;
|
return Chip_GPIO_GetPinState(LPC_GPIO_PORT, BUTTON_PORT, BUTTON_PIN) ? 0 : 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int board_uart_read(uint8_t* buf, int len)
|
int board_uart_read(uint8_t *buf, int len) {
|
||||||
{
|
|
||||||
return Chip_UART_Read(UART_DEV, buf, len);
|
return Chip_UART_Read(UART_DEV, buf, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
int board_uart_write(void const * buf, int len)
|
int board_uart_write(void const *buf, int len) {
|
||||||
{
|
uint8_t const *buf8 = (uint8_t const *) buf;
|
||||||
uint8_t const* buf8 = (uint8_t const*) buf;
|
for (int i = 0; i < len; i++) {
|
||||||
for(int i=0; i<len; i++)
|
|
||||||
{
|
|
||||||
while ((Chip_UART_ReadLineStatus(UART_DEV) & UART_LSR_THRE) == 0) {}
|
while ((Chip_UART_ReadLineStatus(UART_DEV) & UART_LSR_THRE) == 0) {}
|
||||||
Chip_UART_SendByte(UART_DEV, buf8[i]);
|
Chip_UART_SendByte(UART_DEV, buf8[i]);
|
||||||
}
|
}
|
||||||
@@ -165,13 +156,13 @@ int board_uart_write(void const * buf, int len)
|
|||||||
|
|
||||||
#if CFG_TUSB_OS == OPT_OS_NONE
|
#if CFG_TUSB_OS == OPT_OS_NONE
|
||||||
volatile uint32_t system_ticks = 0;
|
volatile uint32_t system_ticks = 0;
|
||||||
void SysTick_Handler (void)
|
|
||||||
{
|
void SysTick_Handler(void) {
|
||||||
system_ticks++;
|
system_ticks++;
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t board_millis(void)
|
uint32_t board_millis(void) {
|
||||||
{
|
|
||||||
return system_ticks;
|
return system_ticks;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -37,7 +37,7 @@ void USB_IRQHandler(void) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CFG_TUH_ENABLED
|
#if CFG_TUH_ENABLED
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -213,7 +213,7 @@ void USB0_IRQHandler(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PORT_SUPPORT_HOST(0)
|
#if PORT_SUPPORT_HOST(0)
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -224,7 +224,7 @@ void USB1_IRQHandler(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PORT_SUPPORT_HOST(1)
|
#if PORT_SUPPORT_HOST(1)
|
||||||
tuh_int_handler(1);
|
tuh_int_handler(1, true);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -34,7 +34,7 @@
|
|||||||
void USB0_IRQHandler(void)
|
void USB0_IRQHandler(void)
|
||||||
{
|
{
|
||||||
#if CFG_TUH_ENABLED
|
#if CFG_TUH_ENABLED
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
#if CFG_TUD_ENABLED
|
#if CFG_TUD_ENABLED
|
||||||
tud_int_handler(0);
|
tud_int_handler(0);
|
||||||
|
@@ -214,7 +214,7 @@ void USB0_IRQHandler(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PORT_SUPPORT_HOST(0)
|
#if PORT_SUPPORT_HOST(0)
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -225,7 +225,7 @@ void USB1_IRQHandler(void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PORT_SUPPORT_HOST(1)
|
#if PORT_SUPPORT_HOST(1)
|
||||||
tuh_int_handler(1);
|
tuh_int_handler(1, true);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -100,7 +100,7 @@ static nrfx_spim_t _spi = NRFX_SPIM_INSTANCE(1);
|
|||||||
void max3421_int_handler(nrfx_gpiote_pin_t pin, nrf_gpiote_polarity_t action) {
|
void max3421_int_handler(nrfx_gpiote_pin_t pin, nrf_gpiote_polarity_t action) {
|
||||||
if (!(pin == MAX3421_INTR_PIN && action == NRF_GPIOTE_POLARITY_HITOLO)) return;
|
if (!(pin == MAX3421_INTR_PIN && action == NRF_GPIOTE_POLARITY_HITOLO)) return;
|
||||||
|
|
||||||
tuh_int_handler(1);
|
tuh_int_handler(1, true);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@@ -188,7 +188,7 @@ void usbfs_interrupt_handler(void) {
|
|||||||
R_BSP_IrqStatusClear(irq);
|
R_BSP_IrqStatusClear(irq);
|
||||||
|
|
||||||
#if PORT_SUPPORT_HOST(0)
|
#if PORT_SUPPORT_HOST(0)
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PORT_SUPPORT_DEVICE(0)
|
#if PORT_SUPPORT_DEVICE(0)
|
||||||
@@ -201,7 +201,7 @@ void usbfs_resume_handler(void) {
|
|||||||
R_BSP_IrqStatusClear(irq);
|
R_BSP_IrqStatusClear(irq);
|
||||||
|
|
||||||
#if PORT_SUPPORT_HOST(0)
|
#if PORT_SUPPORT_HOST(0)
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PORT_SUPPORT_DEVICE(0)
|
#if PORT_SUPPORT_DEVICE(0)
|
||||||
@@ -229,7 +229,7 @@ void usbhs_interrupt_handler(void) {
|
|||||||
R_BSP_IrqStatusClear(irq);
|
R_BSP_IrqStatusClear(irq);
|
||||||
|
|
||||||
#if PORT_SUPPORT_HOST(1)
|
#if PORT_SUPPORT_HOST(1)
|
||||||
tuh_int_handler(1);
|
tuh_int_handler(1, true);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if PORT_SUPPORT_DEVICE(1)
|
#if PORT_SUPPORT_DEVICE(1)
|
||||||
|
@@ -177,7 +177,7 @@ void INT_Excep_SCI5_RXI5(void)
|
|||||||
void INT_Excep_USB0_USBI0(void)
|
void INT_Excep_USB0_USBI0(void)
|
||||||
{
|
{
|
||||||
#if CFG_TUH_ENABLED
|
#if CFG_TUH_ENABLED
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
#if CFG_TUD_ENABLED
|
#if CFG_TUD_ENABLED
|
||||||
tud_int_handler(0);
|
tud_int_handler(0);
|
||||||
|
@@ -356,7 +356,7 @@ void EIC_Handler(void) {
|
|||||||
EIC->INTFLAG.reg = EIC_INTFLAG_EXTINT(1 << MAX3421_INTR_EIC_ID);
|
EIC->INTFLAG.reg = EIC_INTFLAG_EXTINT(1 << MAX3421_INTR_EIC_ID);
|
||||||
|
|
||||||
// Call the TinyUSB interrupt handler
|
// Call the TinyUSB interrupt handler
|
||||||
tuh_int_handler(1);
|
tuh_int_handler(1, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void tuh_max3421_int_api(uint8_t rhport, bool enabled) {
|
void tuh_max3421_int_api(uint8_t rhport, bool enabled) {
|
||||||
|
@@ -296,7 +296,7 @@ void MAX3421_EIC_Handler(void) {
|
|||||||
EIC->INTFLAG.reg = EIC_INTFLAG_EXTINT(1 << MAX3421_INTR_EIC_ID);
|
EIC->INTFLAG.reg = EIC_INTFLAG_EXTINT(1 << MAX3421_INTR_EIC_ID);
|
||||||
|
|
||||||
// Call the TinyUSB interrupt handler
|
// Call the TinyUSB interrupt handler
|
||||||
tuh_int_handler(1);
|
tuh_int_handler(1, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void tuh_max3421_int_api(uint8_t rhport, bool enabled) {
|
void tuh_max3421_int_api(uint8_t rhport, bool enabled) {
|
||||||
|
@@ -26,7 +26,10 @@ set(FAMILY_MCUS STM32G4 CACHE INTERNAL "")
|
|||||||
#------------------------------------
|
#------------------------------------
|
||||||
# only need to be built ONCE for all examples
|
# only need to be built ONCE for all examples
|
||||||
function(add_board_target BOARD_TARGET)
|
function(add_board_target BOARD_TARGET)
|
||||||
if (NOT TARGET ${BOARD_TARGET})
|
if (TARGET ${BOARD_TARGET})
|
||||||
|
return()
|
||||||
|
endif ()
|
||||||
|
|
||||||
# Startup & Linker script
|
# Startup & Linker script
|
||||||
set(STARTUP_FILE_GNU ${ST_CMSIS}/Source/Templates/gcc/startup_${MCU_VARIANT}.s)
|
set(STARTUP_FILE_GNU ${ST_CMSIS}/Source/Templates/gcc/startup_${MCU_VARIANT}.s)
|
||||||
set(STARTUP_FILE_IAR ${ST_CMSIS}/Source/Templates/iar/startup_${MCU_VARIANT}.s)
|
set(STARTUP_FILE_IAR ${ST_CMSIS}/Source/Templates/iar/startup_${MCU_VARIANT}.s)
|
||||||
@@ -50,11 +53,6 @@ function(add_board_target BOARD_TARGET)
|
|||||||
${ST_CMSIS}/Include
|
${ST_CMSIS}/Include
|
||||||
${ST_HAL_DRIVER}/Inc
|
${ST_HAL_DRIVER}/Inc
|
||||||
)
|
)
|
||||||
target_compile_options(${BOARD_TARGET} PUBLIC
|
|
||||||
)
|
|
||||||
target_compile_definitions(${BOARD_TARGET} PUBLIC
|
|
||||||
)
|
|
||||||
|
|
||||||
update_board(${BOARD_TARGET})
|
update_board(${BOARD_TARGET})
|
||||||
|
|
||||||
if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
|
if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
|
||||||
@@ -70,7 +68,6 @@ function(add_board_target BOARD_TARGET)
|
|||||||
"LINKER:--config=${LD_FILE_IAR}"
|
"LINKER:--config=${LD_FILE_IAR}"
|
||||||
)
|
)
|
||||||
endif ()
|
endif ()
|
||||||
endif ()
|
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
|
|
||||||
|
@@ -8,7 +8,7 @@
|
|||||||
void USB0_Handler(void)
|
void USB0_Handler(void)
|
||||||
{
|
{
|
||||||
#if CFG_TUH_ENABLED
|
#if CFG_TUH_ENABLED
|
||||||
tuh_int_handler(0);
|
tuh_int_handler(0, true);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CFG_TUD_ENABLED
|
#if CFG_TUD_ENABLED
|
||||||
|
@@ -75,8 +75,6 @@
|
|||||||
#include "tusb_types.h"
|
#include "tusb_types.h"
|
||||||
#include "tusb_debug.h"
|
#include "tusb_debug.h"
|
||||||
|
|
||||||
#include "tusb_timeout.h" // TODO remove
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
// Optional API implemented by application if needed
|
// Optional API implemented by application if needed
|
||||||
// TODO move to a more ovious place/file
|
// TODO move to a more ovious place/file
|
||||||
|
@@ -1,80 +0,0 @@
|
|||||||
/*
|
|
||||||
* The MIT License (MIT)
|
|
||||||
*
|
|
||||||
* Copyright (c) 2019 Ha Thach (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.
|
|
||||||
*
|
|
||||||
* This file is part of the TinyUSB stack.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/** \ingroup Group_Common Common Files
|
|
||||||
* \defgroup Group_TimeoutTimer timeout timer
|
|
||||||
* @{ */
|
|
||||||
|
|
||||||
#ifndef _TUSB_TIMEOUT_H_
|
|
||||||
#define _TUSB_TIMEOUT_H_
|
|
||||||
|
|
||||||
#include <stdbool.h>
|
|
||||||
#include <stdint.h>
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
uint32_t start;
|
|
||||||
uint32_t interval;
|
|
||||||
}tu_timeout_t;
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
|
|
||||||
extern uint32_t tusb_hal_millis(void);
|
|
||||||
|
|
||||||
static inline void tu_timeout_set(tu_timeout_t* tt, uint32_t msec)
|
|
||||||
{
|
|
||||||
tt->interval = msec;
|
|
||||||
tt->start = tusb_hal_millis();
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline bool tu_timeout_expired(tu_timeout_t* tt)
|
|
||||||
{
|
|
||||||
return ( tusb_hal_millis() - tt->start ) >= tt->interval;
|
|
||||||
}
|
|
||||||
|
|
||||||
// For used with periodic event to prevent drift
|
|
||||||
static inline void tu_timeout_reset(tu_timeout_t* tt)
|
|
||||||
{
|
|
||||||
tt->start += tt->interval;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void tu_timeout_restart(tu_timeout_t* tt)
|
|
||||||
{
|
|
||||||
tt->start = tusb_hal_millis();
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* _TUSB_TIMEOUT_H_ */
|
|
||||||
|
|
||||||
/** @} */
|
|
@@ -56,12 +56,8 @@
|
|||||||
* #define TU_VERIFY(cond) if(cond) return false;
|
* #define TU_VERIFY(cond) if(cond) return false;
|
||||||
* #define TU_VERIFY(cond,ret) if(cond) return ret;
|
* #define TU_VERIFY(cond,ret) if(cond) return ret;
|
||||||
*
|
*
|
||||||
* #define TU_VERIFY_HDLR(cond,handler) if(cond) {handler; return false;}
|
|
||||||
* #define TU_VERIFY_HDLR(cond,ret,handler) if(cond) {handler; return ret;}
|
|
||||||
*
|
|
||||||
* #define TU_ASSERT(cond) if(cond) {_MESS_FAILED(); TU_BREAKPOINT(), return false;}
|
* #define TU_ASSERT(cond) if(cond) {_MESS_FAILED(); TU_BREAKPOINT(), return false;}
|
||||||
* #define TU_ASSERT(cond,ret) if(cond) {_MESS_FAILED(); TU_BREAKPOINT(), return ret;}
|
* #define TU_ASSERT(cond,ret) if(cond) {_MESS_FAILED(); TU_BREAKPOINT(), return ret;}
|
||||||
*
|
|
||||||
*------------------------------------------------------------------*/
|
*------------------------------------------------------------------*/
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
@@ -97,40 +93,23 @@
|
|||||||
#define TU_BREAKPOINT() do {} while (0)
|
#define TU_BREAKPOINT() do {} while (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*------------------------------------------------------------------*/
|
|
||||||
/* Macro Generator
|
|
||||||
*------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
// Helper to implement optional parameter for TU_VERIFY Macro family
|
// Helper to implement optional parameter for TU_VERIFY Macro family
|
||||||
#define _GET_3RD_ARG(arg1, arg2, arg3, ...) arg3
|
#define _GET_3RD_ARG(arg1, arg2, arg3, ...) arg3
|
||||||
#define _GET_4TH_ARG(arg1, arg2, arg3, arg4, ...) arg4
|
|
||||||
|
|
||||||
/*------------- Generator for TU_VERIFY and TU_VERIFY_HDLR -------------*/
|
|
||||||
#define TU_VERIFY_DEFINE(_cond, _handler, _ret) do \
|
|
||||||
{ \
|
|
||||||
if ( !(_cond) ) { _handler; return _ret; } \
|
|
||||||
} while(0)
|
|
||||||
|
|
||||||
/*------------------------------------------------------------------*/
|
/*------------------------------------------------------------------*/
|
||||||
/* TU_VERIFY
|
/* TU_VERIFY
|
||||||
* - TU_VERIFY_1ARGS : return false if failed
|
* - TU_VERIFY_1ARGS : return false if failed
|
||||||
* - TU_VERIFY_2ARGS : return provided value if failed
|
* - TU_VERIFY_2ARGS : return provided value if failed
|
||||||
*------------------------------------------------------------------*/
|
*------------------------------------------------------------------*/
|
||||||
#define TU_VERIFY_1ARGS(_cond) TU_VERIFY_DEFINE(_cond, , false)
|
#define TU_VERIFY_DEFINE(_cond, _ret) \
|
||||||
#define TU_VERIFY_2ARGS(_cond, _ret) TU_VERIFY_DEFINE(_cond, , _ret)
|
do { \
|
||||||
|
if ( !(_cond) ) { return _ret; } \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
#define TU_VERIFY(...) _GET_3RD_ARG(__VA_ARGS__, TU_VERIFY_2ARGS, TU_VERIFY_1ARGS, UNUSED)(__VA_ARGS__)
|
#define TU_VERIFY_1ARGS(_cond) TU_VERIFY_DEFINE(_cond, false)
|
||||||
|
#define TU_VERIFY_2ARGS(_cond, _ret) TU_VERIFY_DEFINE(_cond, _ret)
|
||||||
|
|
||||||
|
#define TU_VERIFY(...) _GET_3RD_ARG(__VA_ARGS__, TU_VERIFY_2ARGS, TU_VERIFY_1ARGS, _dummy)(__VA_ARGS__)
|
||||||
/*------------------------------------------------------------------*/
|
|
||||||
/* TU_VERIFY WITH HANDLER
|
|
||||||
* - TU_VERIFY_HDLR_2ARGS : execute handler, return false if failed
|
|
||||||
* - TU_VERIFY_HDLR_3ARGS : execute handler, return provided error if failed
|
|
||||||
*------------------------------------------------------------------*/
|
|
||||||
#define TU_VERIFY_HDLR_2ARGS(_cond, _handler) TU_VERIFY_DEFINE(_cond, _handler, false)
|
|
||||||
#define TU_VERIFY_HDLR_3ARGS(_cond, _handler, _ret) TU_VERIFY_DEFINE(_cond, _handler, _ret)
|
|
||||||
|
|
||||||
#define TU_VERIFY_HDLR(...) _GET_4TH_ARG(__VA_ARGS__, TU_VERIFY_HDLR_3ARGS, TU_VERIFY_HDLR_2ARGS,UNUSED)(__VA_ARGS__)
|
|
||||||
|
|
||||||
/*------------------------------------------------------------------*/
|
/*------------------------------------------------------------------*/
|
||||||
/* ASSERT
|
/* ASSERT
|
||||||
@@ -138,19 +117,20 @@
|
|||||||
* - 1 arg : return false if failed
|
* - 1 arg : return false if failed
|
||||||
* - 2 arg : return error if failed
|
* - 2 arg : return error if failed
|
||||||
*------------------------------------------------------------------*/
|
*------------------------------------------------------------------*/
|
||||||
#define ASSERT_1ARGS(_cond) TU_VERIFY_DEFINE(_cond, _MESS_FAILED(); TU_BREAKPOINT(), false)
|
#define TU_ASSERT_DEFINE(_cond, _ret) \
|
||||||
#define ASSERT_2ARGS(_cond, _ret) TU_VERIFY_DEFINE(_cond, _MESS_FAILED(); TU_BREAKPOINT(), _ret)
|
do { \
|
||||||
|
if ( !(_cond) ) { _MESS_FAILED(); TU_BREAKPOINT(); return _ret; } \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
#define TU_ASSERT_1ARGS(_cond) TU_ASSERT_DEFINE(_cond, false)
|
||||||
|
#define TU_ASSERT_2ARGS(_cond, _ret) TU_ASSERT_DEFINE(_cond, _ret)
|
||||||
|
|
||||||
#ifndef TU_ASSERT
|
#ifndef TU_ASSERT
|
||||||
#define TU_ASSERT(...) _GET_3RD_ARG(__VA_ARGS__, ASSERT_2ARGS, ASSERT_1ARGS,UNUSED)(__VA_ARGS__)
|
#define TU_ASSERT(...) _GET_3RD_ARG(__VA_ARGS__, TU_ASSERT_2ARGS, TU_ASSERT_1ARGS, _dummy)(__VA_ARGS__)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*------------------------------------------------------------------*/
|
|
||||||
/* ASSERT HDLR
|
|
||||||
*------------------------------------------------------------------*/
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* TUSB_VERIFY_H_ */
|
#endif
|
||||||
|
@@ -131,7 +131,7 @@ bool hcd_configure(uint8_t rhport, uint32_t cfg_id, const void* cfg_param) TU_AT
|
|||||||
bool hcd_init(uint8_t rhport);
|
bool hcd_init(uint8_t rhport);
|
||||||
|
|
||||||
// Interrupt Handler
|
// Interrupt Handler
|
||||||
void hcd_int_handler(uint8_t rhport);
|
void hcd_int_handler(uint8_t rhport, bool in_isr);
|
||||||
|
|
||||||
// Enable USB interrupt
|
// Enable USB interrupt
|
||||||
void hcd_int_enable (uint8_t rhport);
|
void hcd_int_enable (uint8_t rhport);
|
||||||
|
@@ -124,11 +124,16 @@ void tuh_task(void) {
|
|||||||
bool tuh_task_event_ready(void);
|
bool tuh_task_event_ready(void);
|
||||||
|
|
||||||
#ifndef _TUSB_HCD_H_
|
#ifndef _TUSB_HCD_H_
|
||||||
extern void hcd_int_handler(uint8_t rhport);
|
extern void hcd_int_handler(uint8_t rhport, bool in_isr);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Interrupt handler, name alias to HCD
|
// Interrupt handler alias to HCD with in_isr as optional parameter
|
||||||
#define tuh_int_handler hcd_int_handler
|
// - tuh_int_handler(rhport) --> hcd_int_handler(rhport, true)
|
||||||
|
// - tuh_int_handler(rhport, in_isr) --> hcd_int_handler(rhport, in_isr)
|
||||||
|
// Note: this is similar to TU_VERIFY(), _GET_3RD_ARG() is defined in tusb_verify.h
|
||||||
|
#define _tuh_int_handler_1arg(_rhport) hcd_int_handler(_rhport, true)
|
||||||
|
#define _tuh_int_hanlder_2arg(_rhport, _in_isr) hcd_int_handler(_rhport, _in_isr)
|
||||||
|
#define tuh_int_handler(...) _GET_3RD_ARG(__VA_ARGS__, _tuh_int_hanlder_2arg, _tuh_int_handler_1arg, _dummy)(__VA_ARGS__)
|
||||||
|
|
||||||
// Check if roothub port is initialized and active as a host
|
// Check if roothub port is initialized and active as a host
|
||||||
bool tuh_rhport_is_active(uint8_t rhport);
|
bool tuh_rhport_is_active(uint8_t rhport);
|
||||||
|
@@ -863,7 +863,8 @@ void print_hirq(uint8_t hirq) {
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Interrupt Handler
|
// Interrupt Handler
|
||||||
void hcd_int_handler(uint8_t rhport) {
|
void hcd_int_handler(uint8_t rhport, bool in_isr) {
|
||||||
|
(void) in_isr;
|
||||||
uint8_t hirq = reg_read(rhport, HIRQ_ADDR, true) & _hcd_data.hien;
|
uint8_t hirq = reg_read(rhport, HIRQ_ADDR, true) & _hcd_data.hien;
|
||||||
if (!hirq) return;
|
if (!hirq) return;
|
||||||
// print_hirq(hirq);
|
// print_hirq(hirq);
|
||||||
|
@@ -656,8 +656,8 @@ void process_period_xfer_isr(uint8_t rhport, uint32_t interval_ms)
|
|||||||
}
|
}
|
||||||
|
|
||||||
//------------- Host Controller Driver's Interrupt Handler -------------//
|
//------------- Host Controller Driver's Interrupt Handler -------------//
|
||||||
void hcd_int_handler(uint8_t rhport)
|
void hcd_int_handler(uint8_t rhport, bool in_isr) {
|
||||||
{
|
(void) in_isr;
|
||||||
ehci_registers_t* regs = ehci_data.regs;
|
ehci_registers_t* regs = ehci_data.regs;
|
||||||
uint32_t const int_status = regs->status;
|
uint32_t const int_status = regs->status;
|
||||||
|
|
||||||
|
@@ -847,8 +847,10 @@ bool hcd_edpt_clear_stall(uint8_t rhport, uint8_t dev_addr, uint8_t ep_addr) {
|
|||||||
/*-------------------------------------------------------------------
|
/*-------------------------------------------------------------------
|
||||||
* ISR
|
* ISR
|
||||||
*-------------------------------------------------------------------*/
|
*-------------------------------------------------------------------*/
|
||||||
void hcd_int_handler(uint8_t rhport)
|
void hcd_int_handler(uint8_t rhport, bool in_isr)
|
||||||
{
|
{
|
||||||
|
(void) in_isr;
|
||||||
|
|
||||||
uint_fast8_t is, txis, rxis;
|
uint_fast8_t is, txis, rxis;
|
||||||
|
|
||||||
is = USB0->IS; /* read and clear interrupt status */
|
is = USB0->IS; /* read and clear interrupt status */
|
||||||
|
@@ -447,6 +447,10 @@ void hcd_port_reset(uint8_t rhport)
|
|||||||
_hcd.need_reset = false;
|
_hcd.need_reset = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void hcd_port_reset_end(uint8_t rhport) {
|
||||||
|
(void) rhport;
|
||||||
|
}
|
||||||
|
|
||||||
tusb_speed_t hcd_port_speed_get(uint8_t rhport)
|
tusb_speed_t hcd_port_speed_get(uint8_t rhport)
|
||||||
{
|
{
|
||||||
(void)rhport;
|
(void)rhport;
|
||||||
@@ -583,8 +587,9 @@ bool hcd_edpt_clear_stall(uint8_t rhport, uint8_t dev_addr, uint8_t ep_addr) {
|
|||||||
/*--------------------------------------------------------------------+
|
/*--------------------------------------------------------------------+
|
||||||
* ISR
|
* ISR
|
||||||
*--------------------------------------------------------------------+*/
|
*--------------------------------------------------------------------+*/
|
||||||
void hcd_int_handler(uint8_t rhport)
|
void hcd_int_handler(uint8_t rhport, bool in_isr)
|
||||||
{
|
{
|
||||||
|
(void) in_isr;
|
||||||
uint32_t is = KHCI->ISTAT;
|
uint32_t is = KHCI->ISTAT;
|
||||||
uint32_t msk = KHCI->INTEN;
|
uint32_t msk = KHCI->INTEN;
|
||||||
|
|
||||||
|
@@ -667,8 +667,9 @@ static void done_queue_isr(uint8_t hostid)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void hcd_int_handler(uint8_t hostid)
|
void hcd_int_handler(uint8_t hostid, bool in_isr) {
|
||||||
{
|
(void) in_isr;
|
||||||
|
|
||||||
uint32_t const int_en = OHCI_REG->interrupt_enable;
|
uint32_t const int_en = OHCI_REG->interrupt_enable;
|
||||||
uint32_t const int_status = OHCI_REG->interrupt_status & int_en;
|
uint32_t const int_status = OHCI_REG->interrupt_status & int_en;
|
||||||
|
|
||||||
|
@@ -252,9 +252,9 @@ static void __tusb_irq_path_func(hcd_rp2040_irq)(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void __tusb_irq_path_func(hcd_int_handler)(uint8_t rhport)
|
void __tusb_irq_path_func(hcd_int_handler)(uint8_t rhport, bool in_isr) {
|
||||||
{
|
|
||||||
(void) rhport;
|
(void) rhport;
|
||||||
|
(void) in_isr;
|
||||||
hcd_rp2040_irq();
|
hcd_rp2040_irq();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -771,8 +771,9 @@ bool hcd_edpt_clear_stall(uint8_t rhport, uint8_t dev_addr, uint8_t ep_addr) {
|
|||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
// ISR
|
// ISR
|
||||||
//--------------------------------------------------------------------+
|
//--------------------------------------------------------------------+
|
||||||
void hcd_int_handler(uint8_t rhport)
|
void hcd_int_handler(uint8_t rhport, bool in_isr) {
|
||||||
{
|
(void) in_isr;
|
||||||
|
|
||||||
rusb2_reg_t* rusb = RUSB2_REG(rhport);
|
rusb2_reg_t* rusb = RUSB2_REG(rhport);
|
||||||
unsigned is0 = rusb->INTSTS0;
|
unsigned is0 = rusb->INTSTS0;
|
||||||
unsigned is1 = rusb->INTSTS1;
|
unsigned is1 = rusb->INTSTS1;
|
||||||
|
@@ -51,8 +51,9 @@ bool hcd_init(uint8_t rhport) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Interrupt Handler
|
// Interrupt Handler
|
||||||
void hcd_int_handler(uint8_t rhport) {
|
void hcd_int_handler(uint8_t rhport, bool in_isr) {
|
||||||
(void) rhport;
|
(void) rhport;
|
||||||
|
(void) in_isr;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Enable USB interrupt
|
// Enable USB interrupt
|
||||||
|
@@ -66,7 +66,7 @@
|
|||||||
#endif
|
#endif
|
||||||
#else
|
#else
|
||||||
#ifndef tuh_int_handler
|
#ifndef tuh_int_handler
|
||||||
#define tuh_int_handler(_x)
|
#define tuh_int_handler(...)
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -123,7 +123,7 @@
|
|||||||
#endif
|
#endif
|
||||||
#else
|
#else
|
||||||
#ifndef tud_int_handler
|
#ifndef tud_int_handler
|
||||||
#define tud_int_handler(_x)
|
#define tud_int_handler(...)
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user