Skip to content

Commit 6d040eb

Browse files
Merge branch 'main' into ulTaskGetRunTimeCounter
2 parents c7e59d6 + fbaeba3 commit 6d040eb

File tree

2 files changed

+67
-33
lines changed

2 files changed

+67
-33
lines changed

portable/ThirdParty/GCC/RP2040/FreeRTOS_Kernel_import.cmake

Lines changed: 58 additions & 28 deletions
Original file line numberDiff line numberDiff line change
@@ -10,38 +10,68 @@ if (DEFINED ENV{FREERTOS_KERNEL_PATH} AND (NOT FREERTOS_KERNEL_PATH))
1010
message("Using FREERTOS_KERNEL_PATH from environment ('${FREERTOS_KERNEL_PATH}')")
1111
endif ()
1212

13-
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "portable/ThirdParty/GCC/RP2040")
14-
# undo the above
15-
set(FREERTOS_KERNEL_RP2040_BACK_PATH "../../../..")
13+
# first pass we look in old tree; second pass we look in new tree
14+
foreach(SEARCH_PASS RANGE 0 1)
15+
if (SEARCH_PASS)
16+
# ports may be moving to submodule in the future
17+
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "portable/ThirdParty/Community-Supported-Ports/GCC")
18+
set(FREERTOS_KERNEL_RP2040_BACK_PATH "../../../../..")
19+
else()
20+
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "portable/ThirdParty/GCC")
21+
set(FREERTOS_KERNEL_RP2040_BACK_PATH "../../../..")
22+
endif()
1623

17-
if (NOT FREERTOS_KERNEL_PATH)
18-
# check if we are inside the FreeRTOS kernel tree (i.e. this file has been included directly)
19-
get_filename_component(_ACTUAL_PATH ${CMAKE_CURRENT_LIST_DIR} REALPATH)
20-
get_filename_component(_POSSIBLE_PATH ${CMAKE_CURRENT_LIST_DIR}/${FREERTOS_KERNEL_RP2040_BACK_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH} REALPATH)
21-
if (_ACTUAL_PATH STREQUAL _POSSIBLE_PATH)
22-
get_filename_component(FREERTOS_KERNEL_PATH ${CMAKE_CURRENT_LIST_DIR}/${FREERTOS_KERNEL_RP2040_BACK_PATH} REALPATH)
24+
if(PICO_PLATFORM STREQUAL "rp2040")
25+
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/RP2040")
26+
else()
27+
if (PICO_PLATFORM STREQUAL "rp2350-riscv")
28+
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/RP2350_RISC-V")
29+
else()
30+
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/RP2350_ARM_NTZ")
31+
endif()
2332
endif()
24-
if (_ACTUAL_PATH STREQUAL _POSSIBLE_PATH)
25-
get_filename_component(FREERTOS_KERNEL_PATH ${CMAKE_CURRENT_LIST_DIR}/${FREERTOS_KERNEL_RP2040_BACK_PATH} REALPATH)
26-
message("Setting FREERTOS_KERNEL_PATH to ${FREERTOS_KERNEL_PATH} based on location of FreeRTOS-Kernel-import.cmake")
27-
elseif (PICO_SDK_PATH AND EXISTS "${PICO_SDK_PATH}/../FreeRTOS-Kernel")
28-
set(FREERTOS_KERNEL_PATH ${PICO_SDK_PATH}/../FreeRTOS-Kernel)
29-
message("Defaulting FREERTOS_KERNEL_PATH as sibling of PICO_SDK_PATH: ${FREERTOS_KERNEL_PATH}")
33+
34+
if (NOT FREERTOS_KERNEL_PATH)
35+
# check if we are inside the FreeRTOS kernel tree (i.e. this file has been included directly)
36+
get_filename_component(_ACTUAL_PATH ${CMAKE_CURRENT_LIST_DIR} REALPATH)
37+
get_filename_component(_POSSIBLE_PATH ${CMAKE_CURRENT_LIST_DIR}/${FREERTOS_KERNEL_RP2040_BACK_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH} REALPATH)
38+
if (_ACTUAL_PATH STREQUAL _POSSIBLE_PATH)
39+
get_filename_component(FREERTOS_KERNEL_PATH ${CMAKE_CURRENT_LIST_DIR}/${FREERTOS_KERNEL_RP2040_BACK_PATH} REALPATH)
40+
endif()
41+
if (_ACTUAL_PATH STREQUAL _POSSIBLE_PATH)
42+
get_filename_component(FREERTOS_KERNEL_PATH ${CMAKE_CURRENT_LIST_DIR}/${FREERTOS_KERNEL_RP2040_BACK_PATH} REALPATH)
43+
message("Setting FREERTOS_KERNEL_PATH to ${FREERTOS_KERNEL_PATH} based on location of FreeRTOS-Kernel-import.cmake")
44+
break()
45+
elseif (PICO_SDK_PATH AND EXISTS "${PICO_SDK_PATH}/../FreeRTOS-Kernel")
46+
set(FREERTOS_KERNEL_PATH ${PICO_SDK_PATH}/../FreeRTOS-Kernel)
47+
message("Defaulting FREERTOS_KERNEL_PATH as sibling of PICO_SDK_PATH: ${FREERTOS_KERNEL_PATH}")
48+
break()
49+
endif()
50+
endif ()
51+
52+
if (NOT FREERTOS_KERNEL_PATH)
53+
foreach(POSSIBLE_SUFFIX Source FreeRTOS-Kernel FreeRTOS/Source)
54+
# check if FreeRTOS-Kernel exists under directory that included us
55+
set(SEARCH_ROOT ${CMAKE_CURRENT_SOURCE_DIR})
56+
get_filename_component(_POSSIBLE_PATH ${SEARCH_ROOT}/${POSSIBLE_SUFFIX} REALPATH)
57+
if (EXISTS ${_POSSIBLE_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/CMakeLists.txt)
58+
get_filename_component(FREERTOS_KERNEL_PATH ${_POSSIBLE_PATH} REALPATH)
59+
message("Setting FREERTOS_KERNEL_PATH to '${FREERTOS_KERNEL_PATH}' found relative to enclosing project")
60+
break()
61+
endif()
62+
endforeach()
63+
if (FREERTOS_KERNEL_PATH)
64+
break()
65+
endif()
3066
endif()
31-
endif ()
3267

33-
if (NOT FREERTOS_KERNEL_PATH)
34-
foreach(POSSIBLE_SUFFIX Source FreeRTOS-Kernel FreeRTOS/Source)
35-
# check if FreeRTOS-Kernel exists under directory that included us
36-
set(SEARCH_ROOT ${CMAKE_CURRENT_SOURCE_DIR})
37-
get_filename_component(_POSSIBLE_PATH ${SEARCH_ROOT}/${POSSIBLE_SUFFIX} REALPATH)
38-
if (EXISTS ${_POSSIBLE_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/CMakeLists.txt)
39-
get_filename_component(FREERTOS_KERNEL_PATH ${_POSSIBLE_PATH} REALPATH)
40-
message("Setting FREERTOS_KERNEL_PATH to '${FREERTOS_KERNEL_PATH}' found relative to enclosing project")
68+
# user must have specified
69+
if (FREERTOS_KERNEL_PATH)
70+
if (EXISTS "${FREERTOS_KERNEL_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}")
4171
break()
4272
endif()
43-
endforeach()
44-
endif()
73+
endif()
74+
endforeach ()
4575

4676
if (NOT FREERTOS_KERNEL_PATH)
4777
message(FATAL_ERROR "FreeRTOS location was not specified. Please set FREERTOS_KERNEL_PATH.")
@@ -54,8 +84,8 @@ if (NOT EXISTS ${FREERTOS_KERNEL_PATH})
5484
message(FATAL_ERROR "Directory '${FREERTOS_KERNEL_PATH}' not found")
5585
endif()
5686
if (NOT EXISTS ${FREERTOS_KERNEL_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}/CMakeLists.txt)
57-
message(FATAL_ERROR "Directory '${FREERTOS_KERNEL_PATH}' does not contain an RP2040 port here: ${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}")
87+
message(FATAL_ERROR "Directory '${FREERTOS_KERNEL_PATH}' does not contain a '${PICO_PLATFORM}' port here: ${FREERTOS_KERNEL_RP2040_RELATIVE_PATH}")
5888
endif()
5989
set(FREERTOS_KERNEL_PATH ${FREERTOS_KERNEL_PATH} CACHE PATH "Path to the FreeRTOS_KERNEL" FORCE)
6090

61-
add_subdirectory(${FREERTOS_KERNEL_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH} FREERTOS_KERNEL)
91+
add_subdirectory(${FREERTOS_KERNEL_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH} FREERTOS_KERNEL)

tasks.c

Lines changed: 9 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -156,16 +156,15 @@
156156
#define configIDLE_TASK_NAME "IDLE"
157157
#endif
158158

159+
/* Reserve space for Core ID and null termination. */
159160
#if ( configNUMBER_OF_CORES > 1 )
160-
/* Reserve space for Core ID and null termination. */
161+
/* Multi-core systems with up to 9 cores require 1 character for core ID and 1 for null termination. */
161162
#if ( configMAX_TASK_NAME_LEN < 2U )
162163
#error Minimum required task name length is 2. Please increase configMAX_TASK_NAME_LEN.
163164
#endif
164165
#define taskRESERVED_TASK_NAME_LENGTH 2U
165166

166-
#elif ( configNUMBER_OF_CORES > 9 )
167-
#warning Please increase taskRESERVED_TASK_NAME_LENGTH. 1 character is insufficient to store the core ID.
168-
#else
167+
#else /* if ( configNUMBER_OF_CORES > 1 ) */
169168
/* Reserve space for null termination. */
170169
#if ( configMAX_TASK_NAME_LEN < 1U )
171170
#error Minimum required task name length is 1. Please increase configMAX_TASK_NAME_LEN.
@@ -3597,7 +3596,12 @@ static BaseType_t prvCreateIdleTasks( void )
35973596
* only one idle task. */
35983597
#if ( configNUMBER_OF_CORES > 1 )
35993598
{
3600-
/* Append the idle task number to the end of the name. */
3599+
/* Append the idle task number to the end of the name.
3600+
*
3601+
* Note: Idle task name index only supports single-character
3602+
* core IDs (0-9). If the core ID exceeds 9, the idle task
3603+
* name will contain an incorrect ASCII character. This is
3604+
* acceptable as the task name is used mainly for debugging. */
36013605
cIdleName[ xIdleTaskNameIndex ] = ( char ) ( xCoreID + '0' );
36023606
cIdleName[ xIdleTaskNameIndex + 1 ] = '\0';
36033607
}

0 commit comments

Comments
 (0)