Skip to content

Commit 13f18e2

Browse files
authored
Merge pull request #31 from P33M/picodebug
Add a CMSIS compatible implementation for picoprobe
2 parents fcb1fab + f4fe468 commit 13f18e2

17 files changed

+1406
-56
lines changed

.gitmodules

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,6 @@
1+
[submodule "CMSIS_5"]
2+
path = CMSIS_5
3+
url = https://github.com/ARM-software/CMSIS_5
4+
[submodule "freertos"]
5+
path = freertos
6+
url = https://github.com/FreeRTOS/FreeRTOS-Kernel

CMSIS_5

Submodule CMSIS_5 added at a65b7c9

CMakeLists.txt

Lines changed: 32 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,9 @@ cmake_minimum_required(VERSION 3.12)
22

33
include(pico_sdk_import.cmake)
44

5+
set(FREERTOS_KERNEL_PATH ${CMAKE_CURRENT_LIST_DIR}/freertos)
6+
include(FreeRTOS_Kernel_import.cmake)
7+
58
project(picoprobe)
69

710
pico_sdk_init()
@@ -13,8 +16,25 @@ add_executable(picoprobe
1316
src/probe.c
1417
src/cdc_uart.c
1518
src/get_serial.c
19+
src/sw_dp_pio.c
1620
)
1721

22+
target_sources(picoprobe PRIVATE
23+
CMSIS_5/CMSIS/DAP/Firmware/Source/DAP.c
24+
CMSIS_5/CMSIS/DAP/Firmware/Source/JTAG_DP.c
25+
CMSIS_5/CMSIS/DAP/Firmware/Source/DAP_vendor.c
26+
CMSIS_5/CMSIS/DAP/Firmware/Source/SWO.c
27+
#CMSIS_5/CMSIS/DAP/Firmware/Source/SW_DP.c
28+
)
29+
30+
target_include_directories(picoprobe PRIVATE
31+
CMSIS_5/CMSIS/DAP/Firmware/Include/
32+
CMSIS_5/CMSIS/Core/Include/
33+
include/
34+
)
35+
36+
target_compile_options(picoprobe PRIVATE -Wall)
37+
1838
if (DEFINED ENV{PICOPROBE_LED})
1939
message("PICOPROBE_LED is defined as " $ENV{PICOPROBE_LED})
2040
target_compile_definitions(picoprobe PRIVATE PICOPROBE_LED=$ENV{PICOPROBE_LED})
@@ -30,6 +50,17 @@ target_compile_definitions (picoprobe PRIVATE
3050
PICO_RP2040_USB_DEVICE_ENUMERATION_FIX=1
3151
)
3252

33-
target_link_libraries(picoprobe PRIVATE pico_stdlib pico_unique_id tinyusb_device tinyusb_board hardware_pio)
53+
target_link_libraries(picoprobe PRIVATE
54+
pico_multicore
55+
pico_stdlib
56+
pico_unique_id
57+
tinyusb_device
58+
tinyusb_board
59+
hardware_pio
60+
FreeRTOS-Kernel
61+
FreeRTOS-Kernel-Heap1
62+
)
63+
64+
pico_set_binary_type(picoprobe copy_to_ram)
3465

3566
pico_add_extra_outputs(picoprobe)

FreeRTOS_Kernel_import.cmake

Lines changed: 61 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,61 @@
1+
# This is a copy of <FREERTOS_KERNEL_PATH>/portable/ThirdParty/GCC/RP2040/FREERTOS_KERNEL_import.cmake
2+
3+
# This can be dropped into an external project to help locate the FreeRTOS kernel
4+
# It should be include()ed prior to project(). Alternatively this file may
5+
# or the CMakeLists.txt in this directory may be included or added via add_subdirectory
6+
# respectively.
7+
8+
if (DEFINED ENV{FREERTOS_KERNEL_PATH} AND (NOT FREERTOS_KERNEL_PATH))
9+
set(FREERTOS_KERNEL_PATH $ENV{FREERTOS_KERNEL_PATH})
10+
message("Using FREERTOS_KERNEL_PATH from environment ('${FREERTOS_KERNEL_PATH}')")
11+
endif ()
12+
13+
set(FREERTOS_KERNEL_RP2040_RELATIVE_PATH "portable/ThirdParty/GCC/RP2040")
14+
# undo the above
15+
set(FREERTOS_KERNEL_RP2040_BACK_PATH "../../../..")
16+
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)
23+
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}")
30+
endif()
31+
endif ()
32+
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")
41+
break()
42+
endif()
43+
endforeach()
44+
endif()
45+
46+
if (NOT FREERTOS_KERNEL_PATH)
47+
message(FATAL_ERROR "FreeRTOS location was not specified. Please set FREERTOS_KERNEL_PATH.")
48+
endif()
49+
50+
set(FREERTOS_KERNEL_PATH "${FREERTOS_KERNEL_PATH}" CACHE PATH "Path to the FreeRTOS Kernel")
51+
52+
get_filename_component(FREERTOS_KERNEL_PATH "${FREERTOS_KERNEL_PATH}" REALPATH BASE_DIR "${CMAKE_BINARY_DIR}")
53+
if (NOT EXISTS ${FREERTOS_KERNEL_PATH})
54+
message(FATAL_ERROR "Directory '${FREERTOS_KERNEL_PATH}' not found")
55+
endif()
56+
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}")
58+
endif()
59+
set(FREERTOS_KERNEL_PATH ${FREERTOS_KERNEL_PATH} CACHE PATH "Path to the FreeRTOS_KERNEL" FORCE)
60+
61+
add_subdirectory(${FREERTOS_KERNEL_PATH}/${FREERTOS_KERNEL_RP2040_RELATIVE_PATH} FREERTOS_KERNEL)

freertos

Submodule freertos added at 2dfdfc4

0 commit comments

Comments
 (0)