mirror of
https://github.com/FreeRTOS/FreeRTOS-Kernel.git
synced 2025-04-19 21:11:57 -04:00
Merge branch 'main' into stack_overflow_check
This commit is contained in:
commit
19661e559d
46
portable/ThirdParty/GCC/Posix/port.c
vendored
46
portable/ThirdParty/GCC/Posix/port.c
vendored
|
@ -48,6 +48,11 @@
|
||||||
* stdio (printf() and friends) should be called from a single task
|
* stdio (printf() and friends) should be called from a single task
|
||||||
* only or serialized with a FreeRTOS primitive such as a binary
|
* only or serialized with a FreeRTOS primitive such as a binary
|
||||||
* semaphore or mutex.
|
* semaphore or mutex.
|
||||||
|
*
|
||||||
|
* Note: When using LLDB (the default debugger on macOS) with this port,
|
||||||
|
* suppress SIGUSR1 to prevent debugger interference. This can be
|
||||||
|
* done by adding the following line to ~/.lldbinit:
|
||||||
|
* `process handle SIGUSR1 -n true -p true -s false`
|
||||||
*----------------------------------------------------------*/
|
*----------------------------------------------------------*/
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
#define _GNU_SOURCE
|
#define _GNU_SOURCE
|
||||||
|
@ -97,6 +102,7 @@ static inline Thread_t * prvGetThreadFromTask( TaskHandle_t xTask )
|
||||||
/*-----------------------------------------------------------*/
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
static pthread_once_t hSigSetupThread = PTHREAD_ONCE_INIT;
|
static pthread_once_t hSigSetupThread = PTHREAD_ONCE_INIT;
|
||||||
|
static pthread_once_t hThreadKeyOnce = PTHREAD_ONCE_INIT;
|
||||||
static sigset_t xAllSignals;
|
static sigset_t xAllSignals;
|
||||||
static sigset_t xSchedulerOriginalSignalMask;
|
static sigset_t xSchedulerOriginalSignalMask;
|
||||||
static pthread_t hMainThread = ( pthread_t ) NULL;
|
static pthread_t hMainThread = ( pthread_t ) NULL;
|
||||||
|
@ -105,7 +111,6 @@ static BaseType_t xSchedulerEnd = pdFALSE;
|
||||||
static pthread_t hTimerTickThread;
|
static pthread_t hTimerTickThread;
|
||||||
static bool xTimerTickThreadShouldRun;
|
static bool xTimerTickThreadShouldRun;
|
||||||
static uint64_t prvStartTimeNs;
|
static uint64_t prvStartTimeNs;
|
||||||
static pthread_mutex_t xThreadMutex = PTHREAD_MUTEX_INITIALIZER;
|
|
||||||
static pthread_key_t xThreadKey = 0;
|
static pthread_key_t xThreadKey = 0;
|
||||||
/*-----------------------------------------------------------*/
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
@ -134,14 +139,7 @@ static void prvThreadKeyDestructor( void * pvData )
|
||||||
|
|
||||||
static void prvInitThreadKey( void )
|
static void prvInitThreadKey( void )
|
||||||
{
|
{
|
||||||
pthread_mutex_lock( &xThreadMutex );
|
pthread_key_create( &xThreadKey, prvThreadKeyDestructor );
|
||||||
|
|
||||||
if( xThreadKey == 0 )
|
|
||||||
{
|
|
||||||
pthread_key_create( &xThreadKey, prvThreadKeyDestructor );
|
|
||||||
}
|
|
||||||
|
|
||||||
pthread_mutex_unlock( &xThreadMutex );
|
|
||||||
}
|
}
|
||||||
/*-----------------------------------------------------------*/
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
@ -149,7 +147,7 @@ static void prvMarkAsFreeRTOSThread( void )
|
||||||
{
|
{
|
||||||
uint8_t * pucThreadData = NULL;
|
uint8_t * pucThreadData = NULL;
|
||||||
|
|
||||||
prvInitThreadKey();
|
( void ) pthread_once( &hThreadKeyOnce, prvInitThreadKey );
|
||||||
|
|
||||||
pucThreadData = malloc( 1 );
|
pucThreadData = malloc( 1 );
|
||||||
configASSERT( pucThreadData != NULL );
|
configASSERT( pucThreadData != NULL );
|
||||||
|
@ -165,7 +163,10 @@ static BaseType_t prvIsFreeRTOSThread( void )
|
||||||
uint8_t * pucThreadData = NULL;
|
uint8_t * pucThreadData = NULL;
|
||||||
BaseType_t xRet = pdFALSE;
|
BaseType_t xRet = pdFALSE;
|
||||||
|
|
||||||
|
( void ) pthread_once( &hThreadKeyOnce, prvInitThreadKey );
|
||||||
|
|
||||||
pucThreadData = ( uint8_t * ) pthread_getspecific( xThreadKey );
|
pucThreadData = ( uint8_t * ) pthread_getspecific( xThreadKey );
|
||||||
|
|
||||||
if( ( pucThreadData != NULL ) && ( *pucThreadData == 1 ) )
|
if( ( pucThreadData != NULL ) && ( *pucThreadData == 1 ) )
|
||||||
{
|
{
|
||||||
xRet = pdTRUE;
|
xRet = pdTRUE;
|
||||||
|
@ -192,13 +193,13 @@ void prvFatalError( const char * pcCall,
|
||||||
}
|
}
|
||||||
/*-----------------------------------------------------------*/
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
static void prvPortSetCurrentThreadName(char * pxThreadName)
|
static void prvPortSetCurrentThreadName( char * pxThreadName )
|
||||||
{
|
{
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
pthread_setname_np(pxThreadName);
|
pthread_setname_np( pxThreadName );
|
||||||
#else
|
#else
|
||||||
pthread_setname_np(pthread_self(), pxThreadName);
|
pthread_setname_np( pthread_self(), pxThreadName );
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
/*-----------------------------------------------------------*/
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
@ -269,7 +270,7 @@ BaseType_t xPortStartScheduler( void )
|
||||||
sigset_t xSignals;
|
sigset_t xSignals;
|
||||||
|
|
||||||
hMainThread = pthread_self();
|
hMainThread = pthread_self();
|
||||||
prvPortSetCurrentThreadName("Scheduler");
|
prvPortSetCurrentThreadName( "Scheduler" );
|
||||||
|
|
||||||
/* Start the timer that generates the tick ISR(SIGALRM).
|
/* Start the timer that generates the tick ISR(SIGALRM).
|
||||||
* Interrupts are disabled here already. */
|
* Interrupts are disabled here already. */
|
||||||
|
@ -303,9 +304,12 @@ BaseType_t xPortStartScheduler( void )
|
||||||
* memset the internal struct members for MacOS/Linux Compatibility */
|
* memset the internal struct members for MacOS/Linux Compatibility */
|
||||||
#if __APPLE__
|
#if __APPLE__
|
||||||
hSigSetupThread.__sig = _PTHREAD_ONCE_SIG_init;
|
hSigSetupThread.__sig = _PTHREAD_ONCE_SIG_init;
|
||||||
memset( ( void * ) &hSigSetupThread.__opaque, 0, sizeof(hSigSetupThread.__opaque));
|
hThreadKeyOnce.__sig = _PTHREAD_ONCE_SIG_init;
|
||||||
|
memset( ( void * ) &hSigSetupThread.__opaque, 0, sizeof( hSigSetupThread.__opaque ) );
|
||||||
|
memset( ( void * ) &hThreadKeyOnce.__opaque, 0, sizeof( hThreadKeyOnce.__opaque ) );
|
||||||
#else /* Linux PTHREAD library*/
|
#else /* Linux PTHREAD library*/
|
||||||
hSigSetupThread = PTHREAD_ONCE_INIT;
|
hSigSetupThread = ( pthread_once_t ) PTHREAD_ONCE_INIT;
|
||||||
|
hThreadKeyOnce = ( pthread_once_t ) PTHREAD_ONCE_INIT;
|
||||||
#endif /* __APPLE__*/
|
#endif /* __APPLE__*/
|
||||||
|
|
||||||
/* Restore original signal mask. */
|
/* Restore original signal mask. */
|
||||||
|
@ -392,7 +396,7 @@ void vPortDisableInterrupts( void )
|
||||||
{
|
{
|
||||||
if( prvIsFreeRTOSThread() == pdTRUE )
|
if( prvIsFreeRTOSThread() == pdTRUE )
|
||||||
{
|
{
|
||||||
pthread_sigmask(SIG_BLOCK, &xAllSignals, NULL);
|
pthread_sigmask( SIG_BLOCK, &xAllSignals, NULL );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*-----------------------------------------------------------*/
|
/*-----------------------------------------------------------*/
|
||||||
|
@ -540,7 +544,7 @@ static void * prvWaitForStart( void * pvParams )
|
||||||
vPortEnableInterrupts();
|
vPortEnableInterrupts();
|
||||||
|
|
||||||
/* Set thread name */
|
/* Set thread name */
|
||||||
prvPortSetCurrentThreadName(pcTaskGetName(xTaskGetCurrentTaskHandle()));
|
prvPortSetCurrentThreadName( pcTaskGetName( xTaskGetCurrentTaskHandle() ) );
|
||||||
|
|
||||||
/* Call the task's entry point. */
|
/* Call the task's entry point. */
|
||||||
pxThread->pxCode( pxThread->pvParams );
|
pxThread->pxCode( pxThread->pvParams );
|
||||||
|
|
|
@ -10,38 +10,68 @@ if (DEFINED ENV{FREERTOS_KERNEL_PATH} AND (NOT FREERTOS_KERNEL_PATH))
|
||||||
message("Using FREERTOS_KERNEL_PATH from environment ('${FREERTOS_KERNEL_PATH}')")
|
message("Using FREERTOS_KERNEL_PATH from environment ('${FREERTOS_KERNEL_PATH}')")
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "portable/ThirdParty/GCC/RP2040")
|
# first pass we look in old tree; second pass we look in new tree
|
||||||
# undo the above
|
foreach(SEARCH_PASS RANGE 0 1)
|
||||||
set(FREERTOS_KERNEL_RP2040_BACK_PATH "../../../..")
|
if (SEARCH_PASS)
|
||||||
|
# ports may be moving to submodule in the future
|
||||||
if (NOT FREERTOS_KERNEL_PATH)
|
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "portable/ThirdParty/Community-Supported-Ports/GCC")
|
||||||
# check if we are inside the FreeRTOS kernel tree (i.e. this file has been included directly)
|
set(FREERTOS_KERNEL_RP2040_BACK_PATH "../../../../..")
|
||||||
get_filename_component(_ACTUAL_PATH ${CMAKE_CURRENT_LIST_DIR} REALPATH)
|
else()
|
||||||
get_filename_component(_POSSIBLE_PATH ${CMAKE_CURRENT_LIST_DIR}/${FREERTOS_KERNEL_RP2040_BACK_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH} REALPATH)
|
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "portable/ThirdParty/GCC")
|
||||||
if (_ACTUAL_PATH STREQUAL _POSSIBLE_PATH)
|
set(FREERTOS_KERNEL_RP2040_BACK_PATH "../../../..")
|
||||||
get_filename_component(FREERTOS_KERNEL_PATH ${CMAKE_CURRENT_LIST_DIR}/${FREERTOS_KERNEL_RP2040_BACK_PATH} REALPATH)
|
|
||||||
endif()
|
endif()
|
||||||
if (_ACTUAL_PATH STREQUAL _POSSIBLE_PATH)
|
|
||||||
get_filename_component(FREERTOS_KERNEL_PATH ${CMAKE_CURRENT_LIST_DIR}/${FREERTOS_KERNEL_RP2040_BACK_PATH} REALPATH)
|
|
||||||
message("Setting FREERTOS_KERNEL_PATH to ${FREERTOS_KERNEL_PATH} based on location of FreeRTOS-Kernel-import.cmake")
|
|
||||||
elseif (PICO_SDK_PATH AND EXISTS "${PICO_SDK_PATH}/../FreeRTOS-Kernel")
|
|
||||||
set(FREERTOS_KERNEL_PATH ${PICO_SDK_PATH}/../FreeRTOS-Kernel)
|
|
||||||
message("Defaulting FREERTOS_KERNEL_PATH as sibling of PICO_SDK_PATH: ${FREERTOS_KERNEL_PATH}")
|
|
||||||
endif()
|
|
||||||
endif ()
|
|
||||||
|
|
||||||
if (NOT FREERTOS_KERNEL_PATH)
|
if(PICO_PLATFORM STREQUAL "rp2040")
|
||||||
foreach(POSSIBLE_SUFFIX Source FreeRTOS-Kernel FreeRTOS/Source)
|
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/RP2040")
|
||||||
# check if FreeRTOS-Kernel exists under directory that included us
|
else()
|
||||||
set(SEARCH_ROOT ${CMAKE_CURRENT_SOURCE_DIR})
|
if (PICO_PLATFORM STREQUAL "rp2350-riscv")
|
||||||
get_filename_component(_POSSIBLE_PATH ${SEARCH_ROOT}/${POSSIBLE_SUFFIX} REALPATH)
|
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/RP2350_RISC-V")
|
||||||
if (EXISTS ${_POSSIBLE_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/CMakeLists.txt)
|
else()
|
||||||
get_filename_component(FREERTOS_KERNEL_PATH ${_POSSIBLE_PATH} REALPATH)
|
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/RP2350_ARM_NTZ")
|
||||||
message("Setting FREERTOS_KERNEL_PATH to '${FREERTOS_KERNEL_PATH}' found relative to enclosing project")
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (NOT FREERTOS_KERNEL_PATH)
|
||||||
|
# check if we are inside the FreeRTOS kernel tree (i.e. this file has been included directly)
|
||||||
|
get_filename_component(_ACTUAL_PATH ${CMAKE_CURRENT_LIST_DIR} REALPATH)
|
||||||
|
get_filename_component(_POSSIBLE_PATH ${CMAKE_CURRENT_LIST_DIR}/${FREERTOS_KERNEL_RP2040_BACK_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH} REALPATH)
|
||||||
|
if (_ACTUAL_PATH STREQUAL _POSSIBLE_PATH)
|
||||||
|
get_filename_component(FREERTOS_KERNEL_PATH ${CMAKE_CURRENT_LIST_DIR}/${FREERTOS_KERNEL_RP2040_BACK_PATH} REALPATH)
|
||||||
|
endif()
|
||||||
|
if (_ACTUAL_PATH STREQUAL _POSSIBLE_PATH)
|
||||||
|
get_filename_component(FREERTOS_KERNEL_PATH ${CMAKE_CURRENT_LIST_DIR}/${FREERTOS_KERNEL_RP2040_BACK_PATH} REALPATH)
|
||||||
|
message("Setting FREERTOS_KERNEL_PATH to ${FREERTOS_KERNEL_PATH} based on location of FreeRTOS-Kernel-import.cmake")
|
||||||
|
break()
|
||||||
|
elseif (PICO_SDK_PATH AND EXISTS "${PICO_SDK_PATH}/../FreeRTOS-Kernel")
|
||||||
|
set(FREERTOS_KERNEL_PATH ${PICO_SDK_PATH}/../FreeRTOS-Kernel)
|
||||||
|
message("Defaulting FREERTOS_KERNEL_PATH as sibling of PICO_SDK_PATH: ${FREERTOS_KERNEL_PATH}")
|
||||||
break()
|
break()
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endif ()
|
||||||
endif()
|
|
||||||
|
if (NOT FREERTOS_KERNEL_PATH)
|
||||||
|
foreach(POSSIBLE_SUFFIX Source FreeRTOS-Kernel FreeRTOS/Source)
|
||||||
|
# check if FreeRTOS-Kernel exists under directory that included us
|
||||||
|
set(SEARCH_ROOT ${CMAKE_CURRENT_SOURCE_DIR})
|
||||||
|
get_filename_component(_POSSIBLE_PATH ${SEARCH_ROOT}/${POSSIBLE_SUFFIX} REALPATH)
|
||||||
|
if (EXISTS ${_POSSIBLE_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/CMakeLists.txt)
|
||||||
|
get_filename_component(FREERTOS_KERNEL_PATH ${_POSSIBLE_PATH} REALPATH)
|
||||||
|
message("Setting FREERTOS_KERNEL_PATH to '${FREERTOS_KERNEL_PATH}' found relative to enclosing project")
|
||||||
|
break()
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
if (FREERTOS_KERNEL_PATH)
|
||||||
|
break()
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# user must have specified
|
||||||
|
if (FREERTOS_KERNEL_PATH)
|
||||||
|
if (EXISTS "${FREERTOS_KERNEL_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}")
|
||||||
|
break()
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
endforeach ()
|
||||||
|
|
||||||
if (NOT FREERTOS_KERNEL_PATH)
|
if (NOT FREERTOS_KERNEL_PATH)
|
||||||
message(FATAL_ERROR "FreeRTOS location was not specified. Please set FREERTOS_KERNEL_PATH.")
|
message(FATAL_ERROR "FreeRTOS location was not specified. Please set FREERTOS_KERNEL_PATH.")
|
||||||
|
@ -54,7 +84,7 @@ if (NOT EXISTS ${FREERTOS_KERNEL_PATH})
|
||||||
message(FATAL_ERROR "Directory '${FREERTOS_KERNEL_PATH}' not found")
|
message(FATAL_ERROR "Directory '${FREERTOS_KERNEL_PATH}' not found")
|
||||||
endif()
|
endif()
|
||||||
if (NOT EXISTS ${FREERTOS_KERNEL_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/CMakeLists.txt)
|
if (NOT EXISTS ${FREERTOS_KERNEL_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/CMakeLists.txt)
|
||||||
message(FATAL_ERROR "Directory '${FREERTOS_KERNEL_PATH}' does not contain an RP2040 port here: ${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}")
|
message(FATAL_ERROR "Directory '${FREERTOS_KERNEL_PATH}' does not contain a '${PICO_PLATFORM}' port here: ${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}")
|
||||||
endif()
|
endif()
|
||||||
set(FREERTOS_KERNEL_PATH ${FREERTOS_KERNEL_PATH} CACHE PATH "Path to the FreeRTOS_KERNEL" FORCE)
|
set(FREERTOS_KERNEL_PATH ${FREERTOS_KERNEL_PATH} CACHE PATH "Path to the FreeRTOS_KERNEL" FORCE)
|
||||||
|
|
||||||
|
|
14
tasks.c
14
tasks.c
|
@ -156,16 +156,15 @@
|
||||||
#define configIDLE_TASK_NAME "IDLE"
|
#define configIDLE_TASK_NAME "IDLE"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* Reserve space for Core ID and null termination. */
|
||||||
#if ( configNUMBER_OF_CORES > 1 )
|
#if ( configNUMBER_OF_CORES > 1 )
|
||||||
/* Reserve space for Core ID and null termination. */
|
/* Multi-core systems with up to 9 cores require 1 character for core ID and 1 for null termination. */
|
||||||
#if ( configMAX_TASK_NAME_LEN < 2U )
|
#if ( configMAX_TASK_NAME_LEN < 2U )
|
||||||
#error Minimum required task name length is 2. Please increase configMAX_TASK_NAME_LEN.
|
#error Minimum required task name length is 2. Please increase configMAX_TASK_NAME_LEN.
|
||||||
#endif
|
#endif
|
||||||
#define taskRESERVED_TASK_NAME_LENGTH 2U
|
#define taskRESERVED_TASK_NAME_LENGTH 2U
|
||||||
|
|
||||||
#elif ( configNUMBER_OF_CORES > 9 )
|
#else /* if ( configNUMBER_OF_CORES > 1 ) */
|
||||||
#warning Please increase taskRESERVED_TASK_NAME_LENGTH. 1 character is insufficient to store the core ID.
|
|
||||||
#else
|
|
||||||
/* Reserve space for null termination. */
|
/* Reserve space for null termination. */
|
||||||
#if ( configMAX_TASK_NAME_LEN < 1U )
|
#if ( configMAX_TASK_NAME_LEN < 1U )
|
||||||
#error Minimum required task name length is 1. Please increase configMAX_TASK_NAME_LEN.
|
#error Minimum required task name length is 1. Please increase configMAX_TASK_NAME_LEN.
|
||||||
|
@ -3597,7 +3596,12 @@ static BaseType_t prvCreateIdleTasks( void )
|
||||||
* only one idle task. */
|
* only one idle task. */
|
||||||
#if ( configNUMBER_OF_CORES > 1 )
|
#if ( configNUMBER_OF_CORES > 1 )
|
||||||
{
|
{
|
||||||
/* Append the idle task number to the end of the name. */
|
/* Append the idle task number to the end of the name.
|
||||||
|
*
|
||||||
|
* Note: Idle task name index only supports single-character
|
||||||
|
* core IDs (0-9). If the core ID exceeds 9, the idle task
|
||||||
|
* name will contain an incorrect ASCII character. This is
|
||||||
|
* acceptable as the task name is used mainly for debugging. */
|
||||||
cIdleName[ xIdleTaskNameIndex ] = ( char ) ( xCoreID + '0' );
|
cIdleName[ xIdleTaskNameIndex ] = ( char ) ( xCoreID + '0' );
|
||||||
cIdleName[ xIdleTaskNameIndex + 1 ] = '\0';
|
cIdleName[ xIdleTaskNameIndex + 1 ] = '\0';
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue