Merge pull request #2269 from hathach/add-in_isr-to-hcd_int_hanlder
Add in isr to hcd int hanlder
This commit is contained in:
2
.github/workflows/build_arm.yml
vendored
2
.github/workflows/build_arm.yml
vendored
@@ -36,7 +36,7 @@ jobs:
|
|||||||
- 'broadcom_32bit'
|
- 'broadcom_32bit'
|
||||||
- 'kinetis_k32l2'
|
- 'kinetis_k32l2'
|
||||||
- 'lpc11 lpc13 lpc15 lpc17'
|
- 'lpc11 lpc13 lpc15 lpc17'
|
||||||
- 'lpc51 lpc54'
|
- 'lpc51'
|
||||||
- 'mm32 msp432e4'
|
- 'mm32 msp432e4'
|
||||||
- 'samd11 same5x saml2x'
|
- 'samd11 same5x saml2x'
|
||||||
- 'stm32f2 stm32f3'
|
- 'stm32f2 stm32f3'
|
||||||
|
2
.github/workflows/cmake_arm.yml
vendored
2
.github/workflows/cmake_arm.yml
vendored
@@ -36,7 +36,7 @@ jobs:
|
|||||||
- 'imxrt'
|
- 'imxrt'
|
||||||
- 'kinetis_kl'
|
- 'kinetis_kl'
|
||||||
- 'lpc18 lpc40 lpc43'
|
- 'lpc18 lpc40 lpc43'
|
||||||
- 'lpc55'
|
- 'lpc54 lpc55'
|
||||||
- 'mcx'
|
- 'mcx'
|
||||||
- 'nrf'
|
- 'nrf'
|
||||||
- 'ra'
|
- 'ra'
|
||||||
|
@@ -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
|
||||||
|
@@ -40,6 +40,7 @@ if (NOT FAMILY STREQUAL rp2040)
|
|||||||
# enable LTO if supported skip rp2040
|
# enable LTO if supported skip rp2040
|
||||||
include(CheckIPOSupported)
|
include(CheckIPOSupported)
|
||||||
check_ipo_supported(RESULT IPO_SUPPORTED)
|
check_ipo_supported(RESULT IPO_SUPPORTED)
|
||||||
|
cmake_print_variables(IPO_SUPPORTED)
|
||||||
if (IPO_SUPPORTED)
|
if (IPO_SUPPORTED)
|
||||||
set(CMAKE_INTERPROCEDURAL_OPTIMIZATION TRUE)
|
set(CMAKE_INTERPROCEDURAL_OPTIMIZATION TRUE)
|
||||||
endif()
|
endif()
|
||||||
|
@@ -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,48 +22,47 @@ 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})
|
||||||
add_library(${BOARD_TARGET} STATIC
|
return()
|
||||||
${SDK_DIR}/drivers/gpio/fsl_gpio.c
|
endif ()
|
||||||
${SDK_DIR}/drivers/lpsci/fsl_lpsci.c
|
|
||||||
${SDK_DIR}/drivers/uart/fsl_uart.c
|
|
||||||
${SDK_DIR}/devices/${MCU_VARIANT}/drivers/fsl_clock.c
|
|
||||||
${SDK_DIR}/devices/${MCU_VARIANT}/system_${MCU_VARIANT}.c
|
|
||||||
)
|
|
||||||
target_compile_definitions(${BOARD_TARGET} PUBLIC
|
|
||||||
)
|
|
||||||
target_include_directories(${BOARD_TARGET} PUBLIC
|
|
||||||
${CMSIS_DIR}/CMSIS/Core/Include
|
|
||||||
${SDK_DIR}/devices/${MCU_VARIANT}
|
|
||||||
${SDK_DIR}/devices/${MCU_VARIANT}/drivers
|
|
||||||
${SDK_DIR}/drivers/common
|
|
||||||
${SDK_DIR}/drivers/gpio
|
|
||||||
${SDK_DIR}/drivers/lpsci
|
|
||||||
${SDK_DIR}/drivers/port
|
|
||||||
${SDK_DIR}/drivers/smc
|
|
||||||
${SDK_DIR}/drivers/uart
|
|
||||||
)
|
|
||||||
|
|
||||||
update_board(${BOARD_TARGET})
|
add_library(${BOARD_TARGET} STATIC
|
||||||
|
${SDK_DIR}/drivers/gpio/fsl_gpio.c
|
||||||
|
${SDK_DIR}/drivers/lpsci/fsl_lpsci.c
|
||||||
|
${SDK_DIR}/drivers/uart/fsl_uart.c
|
||||||
|
${SDK_DIR}/devices/${MCU_VARIANT}/drivers/fsl_clock.c
|
||||||
|
${SDK_DIR}/devices/${MCU_VARIANT}/system_${MCU_VARIANT}.c
|
||||||
|
)
|
||||||
|
target_compile_definitions(${BOARD_TARGET} PUBLIC
|
||||||
|
)
|
||||||
|
target_include_directories(${BOARD_TARGET} PUBLIC
|
||||||
|
${CMSIS_DIR}/CMSIS/Core/Include
|
||||||
|
${SDK_DIR}/devices/${MCU_VARIANT}
|
||||||
|
${SDK_DIR}/devices/${MCU_VARIANT}/drivers
|
||||||
|
${SDK_DIR}/drivers/common
|
||||||
|
${SDK_DIR}/drivers/gpio
|
||||||
|
${SDK_DIR}/drivers/lpsci
|
||||||
|
${SDK_DIR}/drivers/port
|
||||||
|
${SDK_DIR}/drivers/smc
|
||||||
|
${SDK_DIR}/drivers/uart
|
||||||
|
)
|
||||||
|
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
|
||||||
|
${STARTUP_FILE_${CMAKE_C_COMPILER_ID}}
|
||||||
|
)
|
||||||
|
|
||||||
target_sources(${BOARD_TARGET} PUBLIC
|
if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
|
||||||
${STARTUP_FILE_${CMAKE_C_COMPILER_ID}}
|
target_link_options(${BOARD_TARGET} PUBLIC
|
||||||
|
"LINKER:--script=${LD_FILE_GNU}"
|
||||||
|
# nanolib
|
||||||
|
--specs=nosys.specs --specs=nano.specs
|
||||||
|
)
|
||||||
|
elseif (CMAKE_C_COMPILER_ID STREQUAL "IAR")
|
||||||
|
target_link_options(${BOARD_TARGET} PUBLIC
|
||||||
|
"LINKER:--config=${LD_FILE_IAR}"
|
||||||
)
|
)
|
||||||
|
|
||||||
if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
|
|
||||||
target_link_options(${BOARD_TARGET} PUBLIC
|
|
||||||
"LINKER:--script=${LD_FILE_GNU}"
|
|
||||||
# nanolib
|
|
||||||
--specs=nosys.specs
|
|
||||||
--specs=nano.specs
|
|
||||||
)
|
|
||||||
elseif (CMAKE_C_COMPILER_ID STREQUAL "IAR")
|
|
||||||
target_link_options(${BOARD_TARGET} PUBLIC
|
|
||||||
"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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
165
hw/bsp/lpc54/FreeRTOSConfig/FreeRTOSConfig.h
Normal file
165
hw/bsp/lpc54/FreeRTOSConfig/FreeRTOSConfig.h
Normal file
@@ -0,0 +1,165 @@
|
|||||||
|
/*
|
||||||
|
* FreeRTOS Kernel V10.0.0
|
||||||
|
* Copyright (C) 2017 Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
||||||
|
*
|
||||||
|
* 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. If you wish to use our Amazon
|
||||||
|
* FreeRTOS name, please do so in a fair use way that does not cause confusion.
|
||||||
|
*
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
* http://www.FreeRTOS.org
|
||||||
|
* http://aws.amazon.com/freertos
|
||||||
|
*
|
||||||
|
* 1 tab == 4 spaces!
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef FREERTOS_CONFIG_H
|
||||||
|
#define FREERTOS_CONFIG_H
|
||||||
|
|
||||||
|
/*-----------------------------------------------------------
|
||||||
|
* Application specific definitions.
|
||||||
|
*
|
||||||
|
* These definitions should be adjusted for your particular hardware and
|
||||||
|
* application requirements.
|
||||||
|
*
|
||||||
|
* THESE PARAMETERS ARE DESCRIBED WITHIN THE 'CONFIGURATION' SECTION OF THE
|
||||||
|
* FreeRTOS API DOCUMENTATION AVAILABLE ON THE FreeRTOS.org WEB SITE.
|
||||||
|
*
|
||||||
|
* See http://www.freertos.org/a00110.html.
|
||||||
|
*----------------------------------------------------------*/
|
||||||
|
|
||||||
|
// skip if included from IAR assembler
|
||||||
|
#ifndef __IASMARM__
|
||||||
|
#include "fsl_device_registers.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Cortex M23/M33 port configuration. */
|
||||||
|
#define configENABLE_MPU 0
|
||||||
|
#define configENABLE_FPU 1
|
||||||
|
#define configENABLE_TRUSTZONE 0
|
||||||
|
#define configMINIMAL_SECURE_STACK_SIZE (1024)
|
||||||
|
|
||||||
|
#define configUSE_PREEMPTION 1
|
||||||
|
#define configUSE_PORT_OPTIMISED_TASK_SELECTION 0
|
||||||
|
#define configCPU_CLOCK_HZ SystemCoreClock
|
||||||
|
#define configTICK_RATE_HZ ( 1000 )
|
||||||
|
#define configMAX_PRIORITIES ( 5 )
|
||||||
|
#define configMINIMAL_STACK_SIZE ( 128 )
|
||||||
|
#define configTOTAL_HEAP_SIZE ( configSUPPORT_DYNAMIC_ALLOCATION*4*1024 )
|
||||||
|
#define configMAX_TASK_NAME_LEN 16
|
||||||
|
#define configUSE_16_BIT_TICKS 0
|
||||||
|
#define configIDLE_SHOULD_YIELD 1
|
||||||
|
#define configUSE_MUTEXES 1
|
||||||
|
#define configUSE_RECURSIVE_MUTEXES 1
|
||||||
|
#define configUSE_COUNTING_SEMAPHORES 1
|
||||||
|
#define configQUEUE_REGISTRY_SIZE 4
|
||||||
|
#define configUSE_QUEUE_SETS 0
|
||||||
|
#define configUSE_TIME_SLICING 0
|
||||||
|
#define configUSE_NEWLIB_REENTRANT 0
|
||||||
|
#define configENABLE_BACKWARD_COMPATIBILITY 1
|
||||||
|
#define configSTACK_ALLOCATION_FROM_SEPARATE_HEAP 0
|
||||||
|
|
||||||
|
#define configSUPPORT_STATIC_ALLOCATION 0
|
||||||
|
#define configSUPPORT_DYNAMIC_ALLOCATION 1
|
||||||
|
|
||||||
|
/* Hook function related definitions. */
|
||||||
|
#define configUSE_IDLE_HOOK 0
|
||||||
|
#define configUSE_TICK_HOOK 0
|
||||||
|
#define configUSE_MALLOC_FAILED_HOOK 0 // cause nested extern warning
|
||||||
|
#define configCHECK_FOR_STACK_OVERFLOW 2
|
||||||
|
|
||||||
|
/* Run time and task stats gathering related definitions. */
|
||||||
|
#define configGENERATE_RUN_TIME_STATS 0
|
||||||
|
#define configRECORD_STACK_HIGH_ADDRESS 1
|
||||||
|
#define configUSE_TRACE_FACILITY 1 // legacy trace
|
||||||
|
#define configUSE_STATS_FORMATTING_FUNCTIONS 0
|
||||||
|
|
||||||
|
/* Co-routine definitions. */
|
||||||
|
#define configUSE_CO_ROUTINES 0
|
||||||
|
#define configMAX_CO_ROUTINE_PRIORITIES 2
|
||||||
|
|
||||||
|
/* Software timer related definitions. */
|
||||||
|
#define configUSE_TIMERS 1
|
||||||
|
#define configTIMER_TASK_PRIORITY (configMAX_PRIORITIES-2)
|
||||||
|
#define configTIMER_QUEUE_LENGTH 32
|
||||||
|
#define configTIMER_TASK_STACK_DEPTH configMINIMAL_STACK_SIZE
|
||||||
|
|
||||||
|
/* Optional functions - most linkers will remove unused functions anyway. */
|
||||||
|
#define INCLUDE_vTaskPrioritySet 0
|
||||||
|
#define INCLUDE_uxTaskPriorityGet 0
|
||||||
|
#define INCLUDE_vTaskDelete 0
|
||||||
|
#define INCLUDE_vTaskSuspend 1 // required for queue, semaphore, mutex to be blocked indefinitely with portMAX_DELAY
|
||||||
|
#define INCLUDE_xResumeFromISR 0
|
||||||
|
#define INCLUDE_vTaskDelayUntil 1
|
||||||
|
#define INCLUDE_vTaskDelay 1
|
||||||
|
#define INCLUDE_xTaskGetSchedulerState 0
|
||||||
|
#define INCLUDE_xTaskGetCurrentTaskHandle 1
|
||||||
|
#define INCLUDE_uxTaskGetStackHighWaterMark 0
|
||||||
|
#define INCLUDE_xTaskGetIdleTaskHandle 0
|
||||||
|
#define INCLUDE_xTimerGetTimerDaemonTaskHandle 0
|
||||||
|
#define INCLUDE_pcTaskGetTaskName 0
|
||||||
|
#define INCLUDE_eTaskGetState 0
|
||||||
|
#define INCLUDE_xEventGroupSetBitFromISR 0
|
||||||
|
#define INCLUDE_xTimerPendFunctionCall 0
|
||||||
|
|
||||||
|
/* Define to trap errors during development. */
|
||||||
|
// Halt CPU (breakpoint) when hitting error, only apply for Cortex M3, M4, M7
|
||||||
|
#if defined(__ARM_ARCH_7M__) || defined (__ARM_ARCH_7EM__)
|
||||||
|
#define configASSERT(_exp) \
|
||||||
|
do {\
|
||||||
|
if ( !(_exp) ) { \
|
||||||
|
volatile uint32_t* ARM_CM_DHCSR = ((volatile uint32_t*) 0xE000EDF0UL); /* Cortex M CoreDebug->DHCSR */ \
|
||||||
|
if ( (*ARM_CM_DHCSR) & 1UL ) { /* Only halt mcu if debugger is attached */ \
|
||||||
|
taskDISABLE_INTERRUPTS(); \
|
||||||
|
__asm("BKPT #0\n"); \
|
||||||
|
}\
|
||||||
|
}\
|
||||||
|
} while(0)
|
||||||
|
#else
|
||||||
|
#define configASSERT( x )
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* FreeRTOS hooks to NVIC vectors */
|
||||||
|
#define xPortPendSVHandler PendSV_Handler
|
||||||
|
#define xPortSysTickHandler SysTick_Handler
|
||||||
|
#define vPortSVCHandler SVC_Handler
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------+
|
||||||
|
// Interrupt nesting behavior configuration.
|
||||||
|
//--------------------------------------------------------------------+
|
||||||
|
|
||||||
|
// For Cortex-M specific: __NVIC_PRIO_BITS is defined in mcu header
|
||||||
|
#define configPRIO_BITS 3
|
||||||
|
|
||||||
|
/* The lowest interrupt priority that can be used in a call to a "set priority" function. */
|
||||||
|
#define configLIBRARY_LOWEST_INTERRUPT_PRIORITY ((1<<configPRIO_BITS) - 1)
|
||||||
|
|
||||||
|
/* The highest interrupt priority that can be used by any interrupt service
|
||||||
|
routine that makes calls to interrupt safe FreeRTOS API functions. DO NOT CALL
|
||||||
|
INTERRUPT SAFE FREERTOS API FUNCTIONS FROM ANY INTERRUPT THAT HAS A HIGHER
|
||||||
|
PRIORITY THAN THIS! (higher priorities are lower numeric values. */
|
||||||
|
#define configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY 2
|
||||||
|
|
||||||
|
/* Interrupt priorities used by the kernel port layer itself. These are generic
|
||||||
|
to all Cortex-M ports, and do not rely on any particular library functions. */
|
||||||
|
#define configKERNEL_INTERRUPT_PRIORITY ( configLIBRARY_LOWEST_INTERRUPT_PRIORITY << (8 - configPRIO_BITS) )
|
||||||
|
|
||||||
|
/* !!!! configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to zero !!!!
|
||||||
|
See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html. */
|
||||||
|
#define configMAX_SYSCALL_INTERRUPT_PRIORITY ( configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY << (8 - configPRIO_BITS) )
|
||||||
|
|
||||||
|
#endif
|
21
hw/bsp/lpc54/boards/lpcxpresso54114/board.cmake
Normal file
21
hw/bsp/lpc54/boards/lpcxpresso54114/board.cmake
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
set(MCU_VARIANT LPC54114)
|
||||||
|
set(MCU_CORE LPC54114_cm4)
|
||||||
|
|
||||||
|
set(JLINK_DEVICE LPC54114J256_M4)
|
||||||
|
set(PYOCD_TARGET LPC54114)
|
||||||
|
|
||||||
|
set(LD_FILE_GNU ${SDK_DIR}/devices/${MCU_VARIANT}/gcc/LPC54114J256_cm4_flash.ld)
|
||||||
|
|
||||||
|
# Device port default to PORT1 Highspeed
|
||||||
|
if (NOT DEFINED PORT)
|
||||||
|
set(PORT 1)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
function(update_board TARGET)
|
||||||
|
target_compile_definitions(${TARGET} PUBLIC
|
||||||
|
CPU_LPC54114J256BD64_cm4
|
||||||
|
)
|
||||||
|
target_link_libraries(${TARGET} PUBLIC
|
||||||
|
${SDK_DIR}/devices/${MCU_VARIANT}/gcc/libpower_cm4_hardabi.a
|
||||||
|
)
|
||||||
|
endfunction()
|
22
hw/bsp/lpc54/boards/lpcxpresso54608/board.cmake
Normal file
22
hw/bsp/lpc54/boards/lpcxpresso54608/board.cmake
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
set(MCU_VARIANT LPC54608)
|
||||||
|
set(MCU_CORE LPC54608)
|
||||||
|
|
||||||
|
set(JLINK_DEVICE LPC54608J512)
|
||||||
|
set(PYOCD_TARGET LPC54608)
|
||||||
|
set(NXPLINK_DEVICE LPC54608:LPCXpresso54608)
|
||||||
|
|
||||||
|
set(LD_FILE_GNU ${SDK_DIR}/devices/${MCU_VARIANT}/gcc/LPC54608J512_flash.ld)
|
||||||
|
|
||||||
|
# Device port default to PORT1 Highspeed
|
||||||
|
if (NOT DEFINED PORT)
|
||||||
|
set(PORT 1)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
function(update_board TARGET)
|
||||||
|
target_compile_definitions(${TARGET} PUBLIC
|
||||||
|
CPU_LPC54608J512ET180
|
||||||
|
)
|
||||||
|
target_link_libraries(${TARGET} PUBLIC
|
||||||
|
${SDK_DIR}/devices/${MCU_VARIANT}/gcc/libpower_hardabi.a
|
||||||
|
)
|
||||||
|
endfunction()
|
@@ -28,83 +28,85 @@ set(HOST_PORT $<NOT:${PORT}>)
|
|||||||
#------------------------------------
|
#------------------------------------
|
||||||
# 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})
|
||||||
add_library(${BOARD_TARGET} STATIC
|
return()
|
||||||
# driver
|
endif()
|
||||||
${SDK_DIR}/drivers/lpc_gpio/fsl_gpio.c
|
|
||||||
${SDK_DIR}/drivers/common/fsl_common_arm.c
|
|
||||||
${SDK_DIR}/drivers/flexcomm/fsl_flexcomm.c
|
|
||||||
${SDK_DIR}/drivers/flexcomm/fsl_usart.c
|
|
||||||
# mcu
|
|
||||||
${SDK_DIR}/devices/${MCU_VARIANT}/system_${MCU_CORE}.c
|
|
||||||
${SDK_DIR}/devices/${MCU_VARIANT}/drivers/fsl_clock.c
|
|
||||||
${SDK_DIR}/devices/${MCU_VARIANT}/drivers/fsl_power.c
|
|
||||||
${SDK_DIR}/devices/${MCU_VARIANT}/drivers/fsl_reset.c
|
|
||||||
)
|
|
||||||
|
|
||||||
|
add_library(${BOARD_TARGET} STATIC
|
||||||
|
# driver
|
||||||
|
${SDK_DIR}/drivers/lpc_gpio/fsl_gpio.c
|
||||||
|
${SDK_DIR}/drivers/common/fsl_common_arm.c
|
||||||
|
${SDK_DIR}/drivers/flexcomm/fsl_flexcomm.c
|
||||||
|
${SDK_DIR}/drivers/flexcomm/fsl_usart.c
|
||||||
|
# mcu
|
||||||
|
${SDK_DIR}/devices/${MCU_VARIANT}/system_${MCU_CORE}.c
|
||||||
|
${SDK_DIR}/devices/${MCU_VARIANT}/drivers/fsl_clock.c
|
||||||
|
${SDK_DIR}/devices/${MCU_VARIANT}/drivers/fsl_power.c
|
||||||
|
${SDK_DIR}/devices/${MCU_VARIANT}/drivers/fsl_reset.c
|
||||||
|
)
|
||||||
|
|
||||||
|
target_compile_definitions(${BOARD_TARGET} PUBLIC
|
||||||
|
CFG_TUSB_MEM_ALIGN=TU_ATTR_ALIGNED\(64\)
|
||||||
|
BOARD_TUD_RHPORT=${PORT}
|
||||||
|
BOARD_TUH_RHPORT=${HOST_PORT}
|
||||||
|
)
|
||||||
|
# Port 0 is Fullspeed, Port 1 is Highspeed. Port1 controller can only access USB_SRAM
|
||||||
|
if (PORT EQUAL 1)
|
||||||
target_compile_definitions(${BOARD_TARGET} PUBLIC
|
target_compile_definitions(${BOARD_TARGET} PUBLIC
|
||||||
CFG_TUSB_MEM_ALIGN=TU_ATTR_ALIGNED\(64\)
|
BOARD_TUD_MAX_SPEED=OPT_MODE_HIGH_SPEED
|
||||||
BOARD_TUD_RHPORT=${PORT}
|
BOARD_TUH_MAX_SPEED=OPT_MODE_FULL_SPEED
|
||||||
BOARD_TUH_RHPORT=${HOST_PORT}
|
CFG_TUD_MEM_SECTION=__attribute__\(\(section\(\"m_usb_global\"\)\)\)
|
||||||
)
|
)
|
||||||
# Port 0 is Fullspeed, Port 1 is Highspeed. Port1 controller can only access USB_SRAM
|
else ()
|
||||||
if (PORT EQUAL 1)
|
target_compile_definitions(${BOARD_TARGET} PUBLIC
|
||||||
target_compile_definitions(${BOARD_TARGET} PUBLIC
|
BOARD_TUD_MAX_SPEED=OPT_MODE_FULL_SPEED
|
||||||
BOARD_TUD_MAX_SPEED=OPT_MODE_HIGH_SPEED
|
BOARD_TUH_MAX_SPEED=OPT_MODE_HIGH_SPEED
|
||||||
BOARD_TUH_MAX_SPEED=OPT_MODE_FULL_SPEED
|
CFG_TUH_MEM_SECTION=__attribute__\(\(section\(\"m_usb_global\"\)\)\)
|
||||||
CFG_TUD_MEM_SECTION=__attribute__\(\(section\(\"m_usb_global\"\)\)\)
|
#CFG_TUD_MEM_SECTION=__attribute__\(\(section\(\"m_usb_global\"\)\)\)
|
||||||
)
|
|
||||||
else ()
|
|
||||||
target_compile_definitions(${BOARD_TARGET} PUBLIC
|
|
||||||
BOARD_TUD_MAX_SPEED=OPT_MODE_FULL_SPEED
|
|
||||||
BOARD_TUH_MAX_SPEED=OPT_MODE_HIGH_SPEED
|
|
||||||
CFG_TUH_MEM_SECTION=__attribute__\(\(section\(\"m_usb_global\"\)\)\)
|
|
||||||
#CFG_TUD_MEM_SECTION=__attribute__\(\(section\(\"m_usb_global\"\)\)\)
|
|
||||||
)
|
|
||||||
endif ()
|
|
||||||
|
|
||||||
target_include_directories(${BOARD_TARGET} PUBLIC
|
|
||||||
${TOP}/lib/sct_neopixel
|
|
||||||
# driver
|
|
||||||
${SDK_DIR}/drivers/common
|
|
||||||
${SDK_DIR}/drivers/flexcomm
|
|
||||||
${SDK_DIR}/drivers/lpc_iocon
|
|
||||||
${SDK_DIR}/drivers/lpc_gpio
|
|
||||||
${SDK_DIR}/drivers/lpuart
|
|
||||||
${SDK_DIR}/drivers/sctimer
|
|
||||||
# mcu
|
|
||||||
${CMSIS_DIR}/CMSIS/Core/Include
|
|
||||||
${SDK_DIR}/devices/${MCU_VARIANT}
|
|
||||||
${SDK_DIR}/devices/${MCU_VARIANT}/drivers
|
|
||||||
)
|
)
|
||||||
|
endif ()
|
||||||
|
|
||||||
update_board(${BOARD_TARGET})
|
target_include_directories(${BOARD_TARGET} PUBLIC
|
||||||
|
${TOP}/lib/sct_neopixel
|
||||||
|
# driver
|
||||||
|
${SDK_DIR}/drivers/common
|
||||||
|
${SDK_DIR}/drivers/flexcomm
|
||||||
|
${SDK_DIR}/drivers/lpc_iocon
|
||||||
|
${SDK_DIR}/drivers/lpc_gpio
|
||||||
|
${SDK_DIR}/drivers/lpuart
|
||||||
|
${SDK_DIR}/drivers/sctimer
|
||||||
|
# mcu
|
||||||
|
${CMSIS_DIR}/CMSIS/Core/Include
|
||||||
|
${SDK_DIR}/devices/${MCU_VARIANT}
|
||||||
|
${SDK_DIR}/devices/${MCU_VARIANT}/drivers
|
||||||
|
)
|
||||||
|
|
||||||
if (NOT DEFINED LD_FILE_${CMAKE_C_COMPILER_ID})
|
update_board(${BOARD_TARGET})
|
||||||
set(LD_FILE_GNU ${SDK_DIR}/devices/${MCU_VARIANT}/gcc/${MCU_CORE}_flash.ld)
|
|
||||||
endif ()
|
|
||||||
|
|
||||||
if (NOT DEFINED STARTUP_FILE_${CMAKE_C_COMPILER_ID})
|
if (NOT DEFINED LD_FILE_${CMAKE_C_COMPILER_ID})
|
||||||
set(STARTUP_FILE_GNU ${SDK_DIR}/devices/${MCU_VARIANT}/gcc/startup_${MCU_CORE}.S)
|
set(LD_FILE_GNU ${SDK_DIR}/devices/${MCU_VARIANT}/gcc/${MCU_CORE}_flash.ld)
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
target_sources(${BOARD_TARGET} PUBLIC
|
if (NOT DEFINED STARTUP_FILE_${CMAKE_C_COMPILER_ID})
|
||||||
${STARTUP_FILE_${CMAKE_C_COMPILER_ID}}
|
set(STARTUP_FILE_GNU ${SDK_DIR}/devices/${MCU_VARIANT}/gcc/startup_${MCU_CORE}.S)
|
||||||
|
endif ()
|
||||||
|
|
||||||
|
target_sources(${BOARD_TARGET} PUBLIC
|
||||||
|
${STARTUP_FILE_${CMAKE_C_COMPILER_ID}}
|
||||||
|
)
|
||||||
|
|
||||||
|
if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
|
||||||
|
target_link_options(${BOARD_TARGET} PUBLIC
|
||||||
|
# linker file
|
||||||
|
"LINKER:--script=${LD_FILE_GNU}"
|
||||||
|
# nanolib
|
||||||
|
--specs=nosys.specs
|
||||||
|
--specs=nano.specs
|
||||||
|
)
|
||||||
|
elseif (CMAKE_C_COMPILER_ID STREQUAL "IAR")
|
||||||
|
target_link_options(${BOARD_TARGET} PUBLIC
|
||||||
|
"LINKER:--config=${LD_FILE_IAR}"
|
||||||
)
|
)
|
||||||
|
|
||||||
if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
|
|
||||||
target_link_options(${BOARD_TARGET} PUBLIC
|
|
||||||
# linker file
|
|
||||||
"LINKER:--script=${LD_FILE_GNU}"
|
|
||||||
# nanolib
|
|
||||||
--specs=nosys.specs
|
|
||||||
--specs=nano.specs
|
|
||||||
)
|
|
||||||
elseif (CMAKE_C_COMPILER_ID STREQUAL "IAR")
|
|
||||||
target_link_options(${BOARD_TARGET} PUBLIC
|
|
||||||
"LINKER:--config=${LD_FILE_IAR}"
|
|
||||||
)
|
|
||||||
endif ()
|
|
||||||
endif ()
|
endif ()
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
@@ -124,8 +126,6 @@ function(family_configure_example TARGET RTOS)
|
|||||||
# BSP
|
# BSP
|
||||||
${CMAKE_CURRENT_FUNCTION_LIST_DIR}/family.c
|
${CMAKE_CURRENT_FUNCTION_LIST_DIR}/family.c
|
||||||
${CMAKE_CURRENT_FUNCTION_LIST_DIR}/../board.c
|
${CMAKE_CURRENT_FUNCTION_LIST_DIR}/../board.c
|
||||||
# external driver
|
|
||||||
${TOP}/lib/sct_neopixel/sct_neopixel.c
|
|
||||||
)
|
)
|
||||||
|
|
||||||
# https://github.com/gsteiert/sct_neopixel/pull/1
|
# https://github.com/gsteiert/sct_neopixel/pull/1
|
||||||
|
@@ -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,44 +26,46 @@ 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})
|
||||||
# Startup & Linker script
|
return()
|
||||||
set(STARTUP_FILE_GNU ${ST_CMSIS}/Source/Templates/gcc/startup_${MCU_VARIANT}.s)
|
endif ()
|
||||||
set(STARTUP_FILE_IAR ${ST_CMSIS}/Source/Templates/iar/startup_${MCU_VARIANT}.s)
|
|
||||||
set(LD_FILE_IAR ${ST_CMSIS}/Source/Templates/iar/linker/${MCU_VARIANT}_flash.icf)
|
|
||||||
|
|
||||||
add_library(${BOARD_TARGET} STATIC
|
# Startup & Linker script
|
||||||
${ST_CMSIS}/Source/Templates/system_${ST_PREFIX}.c
|
set(STARTUP_FILE_GNU ${ST_CMSIS}/Source/Templates/gcc/startup_${MCU_VARIANT}.s)
|
||||||
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal.c
|
set(STARTUP_FILE_IAR ${ST_CMSIS}/Source/Templates/iar/startup_${MCU_VARIANT}.s)
|
||||||
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_cortex.c
|
set(LD_FILE_IAR ${ST_CMSIS}/Source/Templates/iar/linker/${MCU_VARIANT}_flash.icf)
|
||||||
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_gpio.c
|
|
||||||
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_pwr_ex.c
|
|
||||||
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_rcc.c
|
|
||||||
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_rcc_ex.c
|
|
||||||
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_uart.c
|
|
||||||
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_uart_ex.c
|
|
||||||
${STARTUP_FILE_${CMAKE_C_COMPILER_ID}}
|
|
||||||
)
|
|
||||||
target_include_directories(${BOARD_TARGET} PUBLIC
|
|
||||||
${CMAKE_CURRENT_FUNCTION_LIST_DIR}
|
|
||||||
${CMSIS_5}/CMSIS/Core/Include
|
|
||||||
${ST_CMSIS}/Include
|
|
||||||
${ST_HAL_DRIVER}/Inc
|
|
||||||
)
|
|
||||||
update_board(${BOARD_TARGET})
|
|
||||||
|
|
||||||
if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
|
add_library(${BOARD_TARGET} STATIC
|
||||||
target_link_options(${BOARD_TARGET} PUBLIC
|
${ST_CMSIS}/Source/Templates/system_${ST_PREFIX}.c
|
||||||
"LINKER:--script=${LD_FILE_GNU}"
|
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal.c
|
||||||
-nostartfiles
|
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_cortex.c
|
||||||
# nanolib
|
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_gpio.c
|
||||||
--specs=nosys.specs --specs=nano.specs
|
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_pwr_ex.c
|
||||||
)
|
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_rcc.c
|
||||||
elseif (CMAKE_C_COMPILER_ID STREQUAL "IAR")
|
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_rcc_ex.c
|
||||||
target_link_options(${BOARD_TARGET} PUBLIC
|
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_uart.c
|
||||||
"LINKER:--config=${LD_FILE_IAR}"
|
${ST_HAL_DRIVER}/Src/${ST_PREFIX}_hal_uart_ex.c
|
||||||
)
|
${STARTUP_FILE_${CMAKE_C_COMPILER_ID}}
|
||||||
endif ()
|
)
|
||||||
|
target_include_directories(${BOARD_TARGET} PUBLIC
|
||||||
|
${CMAKE_CURRENT_FUNCTION_LIST_DIR}
|
||||||
|
${CMSIS_5}/CMSIS/Core/Include
|
||||||
|
${ST_CMSIS}/Include
|
||||||
|
${ST_HAL_DRIVER}/Inc
|
||||||
|
)
|
||||||
|
update_board(${BOARD_TARGET})
|
||||||
|
|
||||||
|
if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
|
||||||
|
target_link_options(${BOARD_TARGET} PUBLIC
|
||||||
|
"LINKER:--script=${LD_FILE_GNU}"
|
||||||
|
-nostartfiles
|
||||||
|
# nanolib
|
||||||
|
--specs=nosys.specs --specs=nano.specs
|
||||||
|
)
|
||||||
|
elseif (CMAKE_C_COMPILER_ID STREQUAL "IAR")
|
||||||
|
target_link_options(${BOARD_TARGET} PUBLIC
|
||||||
|
"LINKER:--config=${LD_FILE_IAR}"
|
||||||
|
)
|
||||||
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