2023-07-18 09:02:59 -05:00
|
|
|
include_guard(GLOBAL)
|
2023-04-20 16:55:48 +07:00
|
|
|
|
2023-05-19 16:27:07 +07:00
|
|
|
include(CMakePrintHelpers)
|
2023-04-20 16:55:48 +07:00
|
|
|
|
2023-05-26 14:56:22 +07:00
|
|
|
# TOP is path to root directory
|
|
|
|
set(TOP "${CMAKE_CURRENT_LIST_DIR}/../..")
|
2023-06-07 14:46:14 -05:00
|
|
|
get_filename_component(TOP ${TOP} ABSOLUTE)
|
2023-05-26 14:56:22 +07:00
|
|
|
|
2024-06-06 15:49:20 +07:00
|
|
|
set(UF2CONV_PY ${TOP}/tools/uf2/utils/uf2conv.py)
|
|
|
|
|
2024-04-16 22:17:29 +07:00
|
|
|
#-------------------------------------------------------------
|
|
|
|
# Toolchain
|
|
|
|
# Can be changed via -DTOOLCHAIN=gcc|iar or -DCMAKE_C_COMPILER=
|
|
|
|
#-------------------------------------------------------------
|
2024-04-17 13:00:07 +07:00
|
|
|
# Detect toolchain based on CMAKE_C_COMPILER
|
2024-04-16 22:17:29 +07:00
|
|
|
if (DEFINED CMAKE_C_COMPILER)
|
|
|
|
string(FIND ${CMAKE_C_COMPILER} "iccarm" IS_IAR)
|
2024-04-17 13:00:07 +07:00
|
|
|
string(FIND ${CMAKE_C_COMPILER} "clang" IS_CLANG)
|
|
|
|
string(FIND ${CMAKE_C_COMPILER} "gcc" IS_GCC)
|
|
|
|
|
2024-04-16 22:17:29 +07:00
|
|
|
if (NOT IS_IAR EQUAL -1)
|
|
|
|
set(TOOLCHAIN iar)
|
2024-04-17 13:00:07 +07:00
|
|
|
elseif (NOT IS_CLANG EQUAL -1)
|
|
|
|
set(TOOLCHAIN clang)
|
|
|
|
elseif (NOT IS_GCC EQUAL -1)
|
|
|
|
set(TOOLCHAIN gcc)
|
2024-04-16 22:17:29 +07:00
|
|
|
endif ()
|
|
|
|
endif ()
|
|
|
|
|
2024-04-17 13:00:07 +07:00
|
|
|
# default to gcc
|
2023-05-25 21:27:26 +07:00
|
|
|
if (NOT DEFINED TOOLCHAIN)
|
2023-06-01 12:36:08 +07:00
|
|
|
set(TOOLCHAIN gcc)
|
2023-05-25 21:27:26 +07:00
|
|
|
endif ()
|
2021-06-10 10:11:20 -05:00
|
|
|
|
2024-04-16 22:17:29 +07:00
|
|
|
#-------------------------------------------------------------
|
|
|
|
# FAMILY and BOARD
|
|
|
|
#-------------------------------------------------------------
|
2023-06-26 13:38:24 +07:00
|
|
|
if (NOT DEFINED FAMILY)
|
|
|
|
if (NOT DEFINED BOARD)
|
|
|
|
message(FATAL_ERROR "You must set a FAMILY variable for the build (e.g. rp2040, espressif).
|
|
|
|
You can do this via -DFAMILY=xxx on the cmake command line")
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
# Find path contains BOARD
|
|
|
|
file(GLOB BOARD_PATH LIST_DIRECTORIES true
|
|
|
|
RELATIVE ${TOP}/hw/bsp
|
|
|
|
${TOP}/hw/bsp/*/boards/${BOARD}
|
|
|
|
)
|
|
|
|
if (NOT BOARD_PATH)
|
|
|
|
message(FATAL_ERROR "Could not detect FAMILY from BOARD=${BOARD}")
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
# replace / with ; so that we can get the first element as FAMILY
|
|
|
|
string(REPLACE "/" ";" BOARD_PATH ${BOARD_PATH})
|
|
|
|
list(GET BOARD_PATH 0 FAMILY)
|
2023-05-25 21:27:26 +07:00
|
|
|
endif ()
|
2021-06-10 10:11:20 -05:00
|
|
|
|
2023-05-19 16:27:07 +07:00
|
|
|
if (NOT EXISTS ${CMAKE_CURRENT_LIST_DIR}/${FAMILY}/family.cmake)
|
2023-06-01 12:36:08 +07:00
|
|
|
message(FATAL_ERROR "Family '${FAMILY}' is not known/supported")
|
2023-05-19 16:27:07 +07:00
|
|
|
endif()
|
2022-01-13 13:42:28 +00:00
|
|
|
|
2023-08-02 17:57:28 +07:00
|
|
|
if (NOT FAMILY STREQUAL rp2040)
|
|
|
|
# enable LTO if supported skip rp2040
|
2023-07-18 09:02:59 -05:00
|
|
|
include(CheckIPOSupported)
|
|
|
|
check_ipo_supported(RESULT IPO_SUPPORTED)
|
2023-09-27 16:19:39 +07:00
|
|
|
cmake_print_variables(IPO_SUPPORTED)
|
2023-07-18 09:02:59 -05:00
|
|
|
if (IPO_SUPPORTED)
|
|
|
|
set(CMAKE_INTERPROCEDURAL_OPTIMIZATION TRUE)
|
|
|
|
endif()
|
|
|
|
endif()
|
2023-06-30 16:05:59 +07:00
|
|
|
|
2024-07-17 20:03:27 -05:00
|
|
|
if (NOT NO_WARN_RWX_SEGMENTS_SUPPORTED)
|
|
|
|
set(NO_WARN_RWX_SEGMENTS_SUPPORTED 1)
|
|
|
|
endif()
|
|
|
|
|
2023-06-16 15:29:34 +07:00
|
|
|
set(WARNING_FLAGS_GNU
|
|
|
|
-Wall
|
|
|
|
-Wextra
|
|
|
|
-Werror
|
|
|
|
-Wfatal-errors
|
|
|
|
-Wdouble-promotion
|
|
|
|
-Wstrict-prototypes
|
|
|
|
-Wstrict-overflow
|
|
|
|
-Werror-implicit-function-declaration
|
|
|
|
-Wfloat-equal
|
|
|
|
-Wundef
|
|
|
|
-Wshadow
|
|
|
|
-Wwrite-strings
|
|
|
|
-Wsign-compare
|
|
|
|
-Wmissing-format-attribute
|
|
|
|
-Wunreachable-code
|
|
|
|
-Wcast-align
|
|
|
|
-Wcast-function-type
|
|
|
|
-Wcast-qual
|
|
|
|
-Wnull-dereference
|
|
|
|
-Wuninitialized
|
|
|
|
-Wunused
|
|
|
|
-Wreturn-type
|
|
|
|
-Wredundant-decls
|
|
|
|
)
|
|
|
|
|
2023-12-13 17:19:13 +01:00
|
|
|
set(WARNING_FLAGS_IAR "")
|
2023-06-01 12:36:08 +07:00
|
|
|
|
2024-04-16 22:17:29 +07:00
|
|
|
#-------------------------------------------------------------
|
|
|
|
# Functions
|
|
|
|
#-------------------------------------------------------------
|
2023-06-27 15:45:38 +07:00
|
|
|
|
|
|
|
# Filter example based on only.txt and skip.txt
|
2023-05-19 16:27:07 +07:00
|
|
|
function(family_filter RESULT DIR)
|
2023-06-01 12:36:08 +07:00
|
|
|
get_filename_component(DIR ${DIR} ABSOLUTE BASE_DIR ${CMAKE_CURRENT_SOURCE_DIR})
|
|
|
|
|
2024-04-04 14:10:48 +07:00
|
|
|
if (EXISTS "${DIR}/skip.txt")
|
|
|
|
file(STRINGS "${DIR}/skip.txt" SKIPS_LINES)
|
2023-06-01 12:36:08 +07:00
|
|
|
foreach(MCU IN LISTS FAMILY_MCUS)
|
|
|
|
# For each line in only.txt
|
2024-04-04 14:10:48 +07:00
|
|
|
foreach(_line ${SKIPS_LINES})
|
|
|
|
# If mcu:xxx exists for this mcu then skip
|
|
|
|
if (${_line} STREQUAL "mcu:${MCU}" OR ${_line} STREQUAL "board:${BOARD}" OR ${_line} STREQUAL "family:${FAMILY}")
|
|
|
|
set(${RESULT} 0 PARENT_SCOPE)
|
2023-06-01 12:36:08 +07:00
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
2024-04-04 14:10:48 +07:00
|
|
|
endif ()
|
2023-06-01 12:36:08 +07:00
|
|
|
|
2024-04-04 14:10:48 +07:00
|
|
|
if (EXISTS "${DIR}/only.txt")
|
|
|
|
file(STRINGS "${DIR}/only.txt" ONLYS_LINES)
|
2023-06-01 12:36:08 +07:00
|
|
|
foreach(MCU IN LISTS FAMILY_MCUS)
|
|
|
|
# For each line in only.txt
|
2024-04-04 14:10:48 +07:00
|
|
|
foreach(_line ${ONLYS_LINES})
|
|
|
|
# If mcu:xxx exists for this mcu or board:xxx then include
|
|
|
|
if (${_line} STREQUAL "mcu:${MCU}" OR ${_line} STREQUAL "board:${BOARD}" OR ${_line} STREQUAL "family:${FAMILY}")
|
|
|
|
set(${RESULT} 1 PARENT_SCOPE)
|
2023-06-01 12:36:08 +07:00
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
2022-01-13 13:42:28 +00:00
|
|
|
|
2024-04-04 14:10:48 +07:00
|
|
|
# Didn't find it in only file so don't build
|
|
|
|
set(${RESULT} 0 PARENT_SCOPE)
|
2023-06-01 12:36:08 +07:00
|
|
|
else()
|
2024-04-04 14:10:48 +07:00
|
|
|
# only.txt not exist so build
|
2023-06-01 12:36:08 +07:00
|
|
|
set(${RESULT} 1 PARENT_SCOPE)
|
|
|
|
endif()
|
2023-05-19 16:27:07 +07:00
|
|
|
endfunction()
|
2021-06-10 10:11:20 -05:00
|
|
|
|
2023-05-19 16:27:07 +07:00
|
|
|
function(family_add_subdirectory DIR)
|
2023-06-01 12:36:08 +07:00
|
|
|
family_filter(SHOULD_ADD "${DIR}")
|
|
|
|
if (SHOULD_ADD)
|
|
|
|
add_subdirectory(${DIR})
|
|
|
|
endif()
|
2023-05-19 16:27:07 +07:00
|
|
|
endfunction()
|
|
|
|
|
|
|
|
function(family_get_project_name OUTPUT_NAME DIR)
|
2023-06-01 12:36:08 +07:00
|
|
|
get_filename_component(SHORT_NAME ${DIR} NAME)
|
|
|
|
set(${OUTPUT_NAME} ${TINYUSB_FAMILY_PROJECT_NAME_PREFIX}${SHORT_NAME} PARENT_SCOPE)
|
2023-05-19 16:27:07 +07:00
|
|
|
endfunction()
|
2021-06-10 10:11:20 -05:00
|
|
|
|
2023-05-19 16:27:07 +07:00
|
|
|
function(family_initialize_project PROJECT DIR)
|
2023-06-02 11:42:17 +07:00
|
|
|
# set output suffix to .elf (skip espressif and rp2040)
|
|
|
|
if(NOT FAMILY STREQUAL "espressif" AND NOT FAMILY STREQUAL "rp2040")
|
2023-06-01 12:50:32 +07:00
|
|
|
set(CMAKE_EXECUTABLE_SUFFIX .elf PARENT_SCOPE)
|
|
|
|
endif()
|
2023-06-01 12:36:08 +07:00
|
|
|
|
|
|
|
family_filter(ALLOWED "${DIR}")
|
|
|
|
if (NOT ALLOWED)
|
|
|
|
get_filename_component(SHORT_NAME ${DIR} NAME)
|
|
|
|
message(FATAL_ERROR "${SHORT_NAME} is not supported on FAMILY=${FAMILY}")
|
|
|
|
endif()
|
2023-05-19 16:27:07 +07:00
|
|
|
endfunction()
|
|
|
|
|
2023-06-27 15:45:38 +07:00
|
|
|
#-------------------------------------------------------------
|
|
|
|
# Common Target Configure
|
|
|
|
# Most families use these settings except rp2040 and espressif
|
|
|
|
#-------------------------------------------------------------
|
|
|
|
|
|
|
|
# Add RTOS to example
|
|
|
|
function(family_add_rtos TARGET RTOS)
|
|
|
|
if (RTOS STREQUAL "freertos")
|
|
|
|
# freertos config
|
|
|
|
if (NOT TARGET freertos_config)
|
|
|
|
add_library(freertos_config INTERFACE)
|
|
|
|
target_include_directories(freertos_config INTERFACE ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/${FAMILY}/FreeRTOSConfig)
|
|
|
|
# add board definition to freertos_config mostly for SystemCoreClock
|
|
|
|
target_link_libraries(freertos_config INTERFACE board_${BOARD})
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# freertos kernel
|
|
|
|
if (NOT TARGET freertos_kernel)
|
|
|
|
add_subdirectory(${TOP}/lib/FreeRTOS-Kernel ${CMAKE_BINARY_DIR}/lib/freertos_kernel)
|
|
|
|
endif ()
|
2023-06-06 23:55:33 +07:00
|
|
|
|
2023-06-27 15:45:38 +07:00
|
|
|
target_link_libraries(${TARGET} PUBLIC freertos_kernel)
|
|
|
|
endif ()
|
2023-06-06 23:55:33 +07:00
|
|
|
endfunction()
|
|
|
|
|
2023-06-02 11:42:17 +07:00
|
|
|
# Add common configuration to example
|
2023-06-27 15:45:38 +07:00
|
|
|
function(family_configure_common TARGET RTOS)
|
|
|
|
family_add_rtos(${TARGET} ${RTOS})
|
|
|
|
|
2023-07-31 19:09:40 +07:00
|
|
|
string(TOUPPER ${BOARD} BOARD_UPPER)
|
2023-08-01 11:18:00 +07:00
|
|
|
string(REPLACE "-" "_" BOARD_UPPER ${BOARD_UPPER})
|
2023-07-31 19:09:40 +07:00
|
|
|
target_compile_definitions(${TARGET} PUBLIC
|
|
|
|
BOARD_${BOARD_UPPER}
|
|
|
|
)
|
|
|
|
|
2024-06-18 16:18:58 +07:00
|
|
|
# compile define from command line
|
2024-06-25 11:31:19 +07:00
|
|
|
if(DEFINED CFLAGS_CLI)
|
|
|
|
target_compile_options(${TARGET} PUBLIC ${CFLAGS_CLI})
|
2024-06-18 16:18:58 +07:00
|
|
|
endif()
|
|
|
|
|
2023-06-16 15:29:34 +07:00
|
|
|
target_compile_options(${TARGET} PUBLIC ${WARNING_FLAGS_${CMAKE_C_COMPILER_ID}})
|
|
|
|
|
2023-06-27 15:45:38 +07:00
|
|
|
# Generate linker map file
|
2023-06-02 15:26:16 +07:00
|
|
|
if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
|
2023-06-27 15:45:38 +07:00
|
|
|
target_link_options(${TARGET} PUBLIC "LINKER:-Map=$<TARGET_FILE:${TARGET}>.map")
|
2024-07-17 20:03:27 -05:00
|
|
|
if (CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 12.0 AND NO_WARN_RWX_SEGMENTS_SUPPORTED)
|
2023-11-23 17:53:17 +07:00
|
|
|
target_link_options(${TARGET} PUBLIC "LINKER:--no-warn-rwx-segments")
|
|
|
|
endif ()
|
2024-04-19 13:40:42 +07:00
|
|
|
elseif (CMAKE_C_COMPILER_ID STREQUAL "Clang")
|
|
|
|
target_link_options(${TARGET} PUBLIC "LINKER:-Map=$<TARGET_FILE:${TARGET}>.map")
|
|
|
|
elseif (CMAKE_C_COMPILER_ID STREQUAL "IAR")
|
2023-12-13 17:19:13 +01:00
|
|
|
target_link_options(${TARGET} PUBLIC "LINKER:--map=$<TARGET_FILE:${TARGET}>.map")
|
2023-06-02 13:27:18 +07:00
|
|
|
endif()
|
2023-06-05 15:41:35 +07:00
|
|
|
|
2023-06-27 15:45:38 +07:00
|
|
|
# ETM Trace option
|
2023-06-19 16:33:47 +07:00
|
|
|
if (TRACE_ETM STREQUAL "1")
|
|
|
|
target_compile_definitions(${TARGET} PUBLIC TRACE_ETM)
|
|
|
|
endif ()
|
|
|
|
|
2023-06-27 15:45:38 +07:00
|
|
|
# LOGGER option
|
|
|
|
if (DEFINED LOGGER)
|
|
|
|
target_compile_definitions(${TARGET} PUBLIC LOGGER_${LOGGER})
|
|
|
|
# Add segger rtt to example
|
|
|
|
if(LOGGER STREQUAL "RTT" OR LOGGER STREQUAL "rtt")
|
|
|
|
if (NOT TARGET segger_rtt)
|
|
|
|
add_library(segger_rtt STATIC ${TOP}/lib/SEGGER_RTT/RTT/SEGGER_RTT.c)
|
|
|
|
target_include_directories(segger_rtt PUBLIC ${TOP}/lib/SEGGER_RTT/RTT)
|
2024-04-23 10:57:45 +07:00
|
|
|
# target_compile_definitions(segger_rtt PUBLIC SEGGER_RTT_MODE_DEFAULT=SEGGER_RTT_MODE_BLOCK_IF_FIFO_FULL)
|
2023-06-27 15:45:38 +07:00
|
|
|
endif()
|
|
|
|
target_link_libraries(${TARGET} PUBLIC segger_rtt)
|
|
|
|
endif ()
|
|
|
|
endif ()
|
2023-06-02 11:42:17 +07:00
|
|
|
|
2024-06-18 16:18:58 +07:00
|
|
|
# run size after build
|
|
|
|
find_program(SIZE_EXE ${CMAKE_SIZE})
|
|
|
|
if(NOT ${SIZE_EXE} STREQUAL SIZE_EXE-NOTFOUND)
|
|
|
|
add_custom_command(TARGET ${TARGET} POST_BUILD
|
|
|
|
COMMAND ${SIZE_EXE} $<TARGET_FILE:${TARGET}>
|
|
|
|
)
|
|
|
|
endif ()
|
|
|
|
endfunction()
|
2023-06-02 11:42:17 +07:00
|
|
|
|
|
|
|
# Add tinyusb to example
|
2023-06-27 15:45:38 +07:00
|
|
|
function(family_add_tinyusb TARGET OPT_MCU RTOS)
|
2023-06-02 11:42:17 +07:00
|
|
|
# tinyusb target is built for each example since it depends on example's tusb_config.h
|
|
|
|
set(TINYUSB_TARGET_PREFIX ${TARGET}-)
|
|
|
|
add_library(${TARGET}-tinyusb_config INTERFACE)
|
|
|
|
|
2023-06-27 15:45:38 +07:00
|
|
|
# path to tusb_config.h
|
2023-06-05 15:41:35 +07:00
|
|
|
target_include_directories(${TARGET}-tinyusb_config INTERFACE ${CMAKE_CURRENT_SOURCE_DIR}/src)
|
|
|
|
target_compile_definitions(${TARGET}-tinyusb_config INTERFACE CFG_TUSB_MCU=${OPT_MCU})
|
2023-06-27 15:45:38 +07:00
|
|
|
|
2023-06-05 15:41:35 +07:00
|
|
|
if (DEFINED LOG)
|
|
|
|
target_compile_definitions(${TARGET}-tinyusb_config INTERFACE CFG_TUSB_DEBUG=${LOG})
|
2023-07-07 16:07:11 +07:00
|
|
|
if (LOG STREQUAL "4")
|
|
|
|
# no inline for debug level 4
|
2023-07-04 19:27:37 +07:00
|
|
|
target_compile_definitions(${TARGET}-tinyusb_config INTERFACE TU_ATTR_ALWAYS_INLINE=)
|
|
|
|
endif ()
|
2023-06-05 15:41:35 +07:00
|
|
|
endif()
|
2023-06-02 11:42:17 +07:00
|
|
|
|
2023-06-27 15:45:38 +07:00
|
|
|
if (RTOS STREQUAL "freertos")
|
|
|
|
target_compile_definitions(${TARGET}-tinyusb_config INTERFACE CFG_TUSB_OS=OPT_OS_FREERTOS)
|
|
|
|
endif ()
|
|
|
|
|
2023-06-02 11:42:17 +07:00
|
|
|
# tinyusb's CMakeList.txt
|
|
|
|
add_subdirectory(${TOP}/src ${CMAKE_CURRENT_BINARY_DIR}/tinyusb)
|
2023-06-27 15:45:38 +07:00
|
|
|
|
|
|
|
if (RTOS STREQUAL "freertos")
|
|
|
|
# link tinyusb with freeRTOS kernel
|
|
|
|
target_link_libraries(${TARGET}-tinyusb PUBLIC freertos_kernel)
|
|
|
|
endif ()
|
2023-09-11 11:35:51 +07:00
|
|
|
|
|
|
|
# use max3421 as host controller
|
|
|
|
if (MAX3421_HOST STREQUAL "1")
|
|
|
|
target_compile_definitions(${TARGET}-tinyusb_config INTERFACE CFG_TUH_MAX3421=1)
|
|
|
|
target_sources(${TARGET}-tinyusb PUBLIC
|
|
|
|
${TOP}/src/portable/analog/max3421/hcd_max3421.c
|
|
|
|
)
|
|
|
|
endif ()
|
|
|
|
|
2024-11-18 23:00:16 +07:00
|
|
|
# compile define from command line
|
|
|
|
if(DEFINED CFLAGS_CLI)
|
|
|
|
target_compile_options(${TARGET}-tinyusb PUBLIC ${CFLAGS_CLI})
|
|
|
|
endif()
|
|
|
|
|
2023-06-02 11:42:17 +07:00
|
|
|
endfunction()
|
|
|
|
|
2023-06-27 15:45:38 +07:00
|
|
|
# Add bin/hex output
|
|
|
|
function(family_add_bin_hex TARGET)
|
|
|
|
add_custom_command(TARGET ${TARGET} POST_BUILD
|
|
|
|
COMMAND ${CMAKE_OBJCOPY} -Obinary $<TARGET_FILE:${TARGET}> $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.bin
|
|
|
|
COMMAND ${CMAKE_OBJCOPY} -Oihex $<TARGET_FILE:${TARGET}> $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.hex
|
|
|
|
VERBATIM)
|
|
|
|
endfunction()
|
2023-06-02 11:42:17 +07:00
|
|
|
|
2024-06-06 15:49:20 +07:00
|
|
|
# Add uf2 output
|
|
|
|
function(family_add_uf2 TARGET FAMILY_ID)
|
|
|
|
set(BIN_FILE $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.hex)
|
|
|
|
add_custom_command(TARGET ${TARGET} POST_BUILD
|
|
|
|
COMMAND python ${UF2CONV_PY} -f ${FAMILY_ID} -c -o $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.uf2 ${BIN_FILE}
|
|
|
|
VERBATIM)
|
|
|
|
endfunction()
|
2023-06-02 11:42:17 +07:00
|
|
|
|
2023-06-27 15:45:38 +07:00
|
|
|
#----------------------------------
|
|
|
|
# Example Target Configure (Default rule)
|
|
|
|
# These function can be redefined in FAMILY/family.cmake
|
|
|
|
#----------------------------------
|
|
|
|
|
|
|
|
function(family_configure_example TARGET RTOS)
|
|
|
|
# empty function, should be redefined in FAMILY/family.cmake
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
# Configure device example with RTOS
|
|
|
|
function(family_configure_device_example TARGET RTOS)
|
|
|
|
family_configure_example(${TARGET} ${RTOS})
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
# Configure host example with RTOS
|
|
|
|
function(family_configure_host_example TARGET RTOS)
|
|
|
|
family_configure_example(${TARGET} ${RTOS})
|
2023-06-02 11:42:17 +07:00
|
|
|
endfunction()
|
|
|
|
|
2023-06-27 15:45:38 +07:00
|
|
|
# Configure host + device example with RTOS
|
|
|
|
function(family_configure_dual_usb_example TARGET RTOS)
|
|
|
|
family_configure_example(${TARGET} ${RTOS})
|
|
|
|
endfunction()
|
|
|
|
|
2023-07-18 09:02:59 -05:00
|
|
|
function(family_example_missing_dependency TARGET DEPENDENCY)
|
|
|
|
message(WARNING "${DEPENDENCY} submodule needed by ${TARGET} not found, please run 'python tools/get_deps.py ${DEPENDENCY}' to fetch it")
|
|
|
|
endfunction()
|
|
|
|
|
2023-06-27 15:45:38 +07:00
|
|
|
#----------------------------------
|
|
|
|
# RPI specific: refactor later
|
|
|
|
#----------------------------------
|
2023-06-02 13:27:18 +07:00
|
|
|
function(family_add_default_example_warnings TARGET)
|
|
|
|
target_compile_options(${TARGET} PUBLIC
|
|
|
|
-Wall
|
|
|
|
-Wextra
|
|
|
|
-Werror
|
|
|
|
-Wfatal-errors
|
|
|
|
-Wdouble-promotion
|
|
|
|
-Wfloat-equal
|
2023-08-03 20:42:34 +07:00
|
|
|
# FIXME commented out because of https://github.com/raspberrypi/pico-sdk/issues/1468
|
|
|
|
#-Wshadow
|
2023-06-02 13:27:18 +07:00
|
|
|
-Wwrite-strings
|
|
|
|
-Wsign-compare
|
|
|
|
-Wmissing-format-attribute
|
|
|
|
-Wunreachable-code
|
|
|
|
-Wcast-align
|
|
|
|
-Wcast-qual
|
|
|
|
-Wnull-dereference
|
|
|
|
-Wuninitialized
|
|
|
|
-Wunused
|
|
|
|
-Wredundant-decls
|
|
|
|
#-Wstrict-prototypes
|
|
|
|
#-Werror-implicit-function-declaration
|
|
|
|
#-Wundef
|
|
|
|
)
|
|
|
|
|
|
|
|
if (CMAKE_C_COMPILER_ID STREQUAL "GNU")
|
2024-07-17 20:03:27 -05:00
|
|
|
if (CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 12.0 AND NO_WARN_RWX_SEGMENTS_SUPPORTED)
|
2023-06-02 13:27:18 +07:00
|
|
|
target_link_options(${TARGET} PUBLIC "LINKER:--no-warn-rwx-segments")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# GCC 10
|
|
|
|
if (CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 10.0)
|
|
|
|
target_compile_options(${TARGET} PUBLIC -Wconversion)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# GCC 8
|
|
|
|
if (CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 8.0)
|
|
|
|
target_compile_options(${TARGET} PUBLIC -Wcast-function-type -Wstrict-overflow)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# GCC 6
|
|
|
|
if (CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 6.0)
|
|
|
|
target_compile_options(${TARGET} PUBLIC -Wno-strict-aliasing)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endfunction()
|
|
|
|
|
2023-06-02 11:42:17 +07:00
|
|
|
#----------------------------------
|
|
|
|
# Flashing target
|
|
|
|
#----------------------------------
|
|
|
|
|
2023-05-19 16:27:07 +07:00
|
|
|
# Add flash jlink target
|
|
|
|
function(family_flash_jlink TARGET)
|
2023-05-25 21:27:26 +07:00
|
|
|
if (NOT DEFINED JLINKEXE)
|
|
|
|
set(JLINKEXE JLinkExe)
|
|
|
|
endif ()
|
2023-05-19 16:27:07 +07:00
|
|
|
|
2024-05-09 20:43:46 +07:00
|
|
|
if (NOT DEFINED JLINK_IF)
|
|
|
|
set(JLINK_IF swd)
|
|
|
|
endif ()
|
|
|
|
|
2024-08-02 15:48:39 +07:00
|
|
|
if (NOT DEFINED JLINK_OPTION)
|
|
|
|
set(JLINK_OPTION "")
|
|
|
|
endif ()
|
|
|
|
separate_arguments(OPTION_LIST UNIX_COMMAND ${JLINK_OPTION})
|
|
|
|
|
2023-05-25 21:27:26 +07:00
|
|
|
file(GENERATE
|
2023-12-14 12:19:14 +01:00
|
|
|
OUTPUT $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.jlink
|
2023-05-25 21:27:26 +07:00
|
|
|
CONTENT "halt
|
2023-05-19 16:27:07 +07:00
|
|
|
loadfile $<TARGET_FILE:${TARGET}>
|
|
|
|
r
|
|
|
|
go
|
|
|
|
exit"
|
2023-05-25 21:27:26 +07:00
|
|
|
)
|
2023-05-19 16:27:07 +07:00
|
|
|
|
2023-05-25 21:27:26 +07:00
|
|
|
add_custom_target(${TARGET}-jlink
|
|
|
|
DEPENDS ${TARGET}
|
2024-08-02 15:48:39 +07:00
|
|
|
COMMAND ${JLINKEXE} -device ${JLINK_DEVICE} ${OPTION_LIST} -if ${JLINK_IF} -JTAGConf -1,-1 -speed auto -CommandFile $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.jlink
|
|
|
|
VERBATIM
|
2023-05-25 21:27:26 +07:00
|
|
|
)
|
2024-08-26 12:24:29 +07:00
|
|
|
|
|
|
|
# optional flash post build
|
|
|
|
# add_custom_command(TARGET ${TARGET} POST_BUILD
|
|
|
|
# COMMAND ${JLINKEXE} -device ${JLINK_DEVICE} ${OPTION_LIST} -if ${JLINK_IF} -JTAGConf -1,-1 -speed auto -CommandFile $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.jlink
|
|
|
|
# VERBATIM
|
|
|
|
# )
|
2023-05-19 16:27:07 +07:00
|
|
|
endfunction()
|
|
|
|
|
2023-06-01 12:36:08 +07:00
|
|
|
|
2023-06-01 17:03:04 +07:00
|
|
|
# Add flash stlink target
|
|
|
|
function(family_flash_stlink TARGET)
|
|
|
|
if (NOT DEFINED STM32_PROGRAMMER_CLI)
|
|
|
|
set(STM32_PROGRAMMER_CLI STM32_Programmer_CLI)
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
add_custom_target(${TARGET}-stlink
|
|
|
|
DEPENDS ${TARGET}
|
|
|
|
COMMAND ${STM32_PROGRAMMER_CLI} --connect port=swd --write $<TARGET_FILE:${TARGET}> --go
|
|
|
|
)
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
2024-08-01 14:24:23 +07:00
|
|
|
# Add flash st-flash target
|
|
|
|
function(family_flash_stflash TARGET)
|
|
|
|
if (NOT DEFINED ST_FLASH)
|
|
|
|
set(ST_FLASH st-flash)
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
add_custom_target(${TARGET}-stflash
|
|
|
|
DEPENDS ${TARGET}
|
|
|
|
COMMAND ${ST_FLASH} write $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.bin 0x8000000
|
|
|
|
)
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
2023-11-28 18:27:40 +07:00
|
|
|
# Add flash openocd target
|
2024-05-06 10:52:52 +07:00
|
|
|
function(family_flash_openocd TARGET)
|
2023-11-28 18:27:40 +07:00
|
|
|
if (NOT DEFINED OPENOCD)
|
|
|
|
set(OPENOCD openocd)
|
|
|
|
endif ()
|
|
|
|
|
2024-05-09 20:43:46 +07:00
|
|
|
if (NOT DEFINED OPENOCD_OPTION2)
|
|
|
|
set(OPENOCD_OPTION2 "")
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
separate_arguments(OPTION_LIST UNIX_COMMAND ${OPENOCD_OPTION})
|
|
|
|
separate_arguments(OPTION_LIST2 UNIX_COMMAND ${OPENOCD_OPTION2})
|
2023-11-28 18:27:40 +07:00
|
|
|
|
|
|
|
# note skip verify since it has issue with rp2040
|
|
|
|
add_custom_target(${TARGET}-openocd
|
|
|
|
DEPENDS ${TARGET}
|
2024-08-22 22:25:14 +07:00
|
|
|
COMMAND ${OPENOCD} -c "tcl_port disabled" -c "gdb_port disabled" ${OPTION_LIST} -c init -c halt -c "program $<TARGET_FILE:${TARGET}>" -c reset ${OPTION_LIST2} -c exit
|
2023-11-28 18:27:40 +07:00
|
|
|
VERBATIM
|
|
|
|
)
|
|
|
|
endfunction()
|
|
|
|
|
2024-08-01 14:24:23 +07:00
|
|
|
|
2024-05-09 20:43:46 +07:00
|
|
|
# Add flash openocd-wch target
|
2024-05-15 20:13:00 +07:00
|
|
|
# compiled from https://github.com/hathach/riscv-openocd-wch or https://github.com/dragonlock2/miscboards/blob/main/wch/SDK/riscv-openocd.tar.xz
|
2024-05-09 20:43:46 +07:00
|
|
|
function(family_flash_openocd_wch TARGET)
|
|
|
|
if (NOT DEFINED OPENOCD)
|
|
|
|
set(OPENOCD $ENV{HOME}/app/riscv-openocd-wch/src/openocd)
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
family_flash_openocd(${TARGET})
|
|
|
|
endfunction()
|
|
|
|
|
2024-08-01 14:24:23 +07:00
|
|
|
|
2024-08-18 17:15:07 +07:00
|
|
|
# Add flash openocd adi (Analog Devices) target
|
|
|
|
# included with msdk or compiled from release branch of https://github.com/analogdevicesinc/openocd
|
|
|
|
function(family_flash_openocd_adi TARGET)
|
|
|
|
if (DEFINED $ENV{MAXIM_PATH})
|
|
|
|
# use openocd from msdk
|
|
|
|
set(OPENOCD ENV{MAXIM_PATH}/Tools/OpenOCD/openocd)
|
|
|
|
set(OPENOCD_OPTION2 "-s ENV{MAXIM_PATH}/Tools/OpenOCD/scripts")
|
|
|
|
else()
|
|
|
|
# compiled from source
|
|
|
|
if (NOT DEFINED OPENOCD_ADI_PATH)
|
|
|
|
set(OPENOCD_ADI_PATH $ENV{HOME}/app/openocd_adi)
|
|
|
|
endif ()
|
|
|
|
set(OPENOCD ${OPENOCD_ADI_PATH}/src/openocd)
|
|
|
|
set(OPENOCD_OPTION2 "-s ${OPENOCD_ADI_PATH}/tcl")
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
family_flash_openocd(${TARGET})
|
|
|
|
endfunction()
|
|
|
|
|
2024-07-10 22:48:06 +07:00
|
|
|
# Add flash with https://github.com/ch32-rs/wlink
|
|
|
|
function(family_flash_wlink_rs TARGET)
|
|
|
|
if (NOT DEFINED WLINK_RS)
|
|
|
|
set(WLINK_RS wlink)
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
add_custom_target(${TARGET}-wlink-rs
|
|
|
|
DEPENDS ${TARGET}
|
|
|
|
COMMAND ${WLINK_RS} flash $<TARGET_FILE:${TARGET}>
|
|
|
|
)
|
|
|
|
endfunction()
|
|
|
|
|
2024-08-01 14:24:23 +07:00
|
|
|
|
2023-05-19 16:27:07 +07:00
|
|
|
# Add flash pycod target
|
|
|
|
function(family_flash_pyocd TARGET)
|
2023-06-01 12:36:08 +07:00
|
|
|
if (NOT DEFINED PYOC)
|
|
|
|
set(PYOCD pyocd)
|
|
|
|
endif ()
|
2023-05-19 16:27:07 +07:00
|
|
|
|
2023-06-01 12:36:08 +07:00
|
|
|
add_custom_target(${TARGET}-pyocd
|
|
|
|
DEPENDS ${TARGET}
|
|
|
|
COMMAND ${PYOCD} flash -t ${PYOCD_TARGET} $<TARGET_FILE:${TARGET}>
|
|
|
|
)
|
2023-05-19 16:27:07 +07:00
|
|
|
endfunction()
|
|
|
|
|
2024-08-01 14:24:23 +07:00
|
|
|
|
2024-06-06 15:49:20 +07:00
|
|
|
# Flash with UF2
|
|
|
|
function(family_flash_uf2 TARGET FAMILY_ID)
|
|
|
|
add_custom_target(${TARGET}-uf2
|
|
|
|
DEPENDS ${TARGET}
|
|
|
|
COMMAND python ${UF2CONV_PY} -f ${FAMILY_ID} --deploy $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.uf2
|
|
|
|
)
|
|
|
|
endfunction()
|
2023-06-01 12:36:08 +07:00
|
|
|
|
2024-08-01 14:24:23 +07:00
|
|
|
|
2023-08-28 17:44:29 +07:00
|
|
|
# Add flash teensy_cli target
|
|
|
|
function(family_flash_teensy TARGET)
|
|
|
|
if (NOT DEFINED TEENSY_CLI)
|
|
|
|
set(TEENSY_CLI teensy_loader_cli)
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
add_custom_target(${TARGET}-teensy
|
|
|
|
DEPENDS ${TARGET}
|
2024-11-22 20:22:00 +07:00
|
|
|
COMMAND ${CMAKE_OBJCOPY} -Oihex $<TARGET_FILE:${TARGET}> $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.hex
|
2023-08-28 17:44:29 +07:00
|
|
|
COMMAND ${TEENSY_CLI} --mcu=${TEENSY_MCU} -w -s $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.hex
|
|
|
|
)
|
|
|
|
endfunction()
|
|
|
|
|
2024-08-01 14:24:23 +07:00
|
|
|
|
2023-05-19 16:27:07 +07:00
|
|
|
# Add flash using NXP's LinkServer (redserver)
|
|
|
|
# https://www.nxp.com/design/software/development-software/mcuxpresso-software-and-tools-/linkserver-for-microcontrollers:LINKERSERVER
|
|
|
|
function(family_flash_nxplink TARGET)
|
2023-06-01 12:36:08 +07:00
|
|
|
if (NOT DEFINED LINKSERVER)
|
|
|
|
set(LINKSERVER LinkServer)
|
|
|
|
endif ()
|
2023-05-19 16:27:07 +07:00
|
|
|
|
2023-06-01 12:36:08 +07:00
|
|
|
# LinkServer has a bug that can only execute with full path otherwise it throws:
|
|
|
|
# realpath error: No such file or directory
|
|
|
|
execute_process(COMMAND which ${LINKSERVER} OUTPUT_VARIABLE LINKSERVER_PATH OUTPUT_STRIP_TRAILING_WHITESPACE)
|
2023-05-19 16:27:07 +07:00
|
|
|
|
2023-06-01 12:36:08 +07:00
|
|
|
add_custom_target(${TARGET}-nxplink
|
|
|
|
DEPENDS ${TARGET}
|
|
|
|
COMMAND ${LINKSERVER_PATH} flash ${NXPLINK_DEVICE} load $<TARGET_FILE:${TARGET}>
|
|
|
|
)
|
2023-05-19 16:27:07 +07:00
|
|
|
endfunction()
|
|
|
|
|
2023-06-01 12:36:08 +07:00
|
|
|
|
2023-08-01 13:16:37 +07:00
|
|
|
function(family_flash_dfu_util TARGET OPTION)
|
|
|
|
if (NOT DEFINED DFU_UTIL)
|
|
|
|
set(DFU_UTIL dfu-util)
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
add_custom_target(${TARGET}-dfu-util
|
|
|
|
DEPENDS ${TARGET}
|
|
|
|
COMMAND ${DFU_UTIL} -R -d ${DFU_UTIL_VID_PID} -a 0 -D $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.bin
|
|
|
|
VERBATIM
|
|
|
|
)
|
|
|
|
endfunction()
|
|
|
|
|
2024-04-11 21:49:55 +07:00
|
|
|
function(family_flash_msp430flasher TARGET)
|
|
|
|
if (NOT DEFINED MSP430Flasher)
|
|
|
|
set(MSP430FLASHER MSP430Flasher)
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
# set LD_LIBRARY_PATH to find libmsp430.so (directory containing MSP430Flasher)
|
|
|
|
find_program(MSP430FLASHER_PATH MSP430Flasher)
|
|
|
|
get_filename_component(MSP430FLASHER_PARENT_DIR "${MSP430FLASHER_PATH}" DIRECTORY)
|
|
|
|
add_custom_target(${TARGET}-msp430flasher
|
|
|
|
DEPENDS ${TARGET}
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E env LD_LIBRARY_PATH=${MSP430FLASHER_PARENT_DIR}
|
|
|
|
${MSP430FLASHER} -w $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.hex -z [VCC]
|
|
|
|
)
|
|
|
|
endfunction()
|
|
|
|
|
2024-08-15 14:36:31 +07:00
|
|
|
|
|
|
|
function(family_flash_uniflash TARGET)
|
|
|
|
if (NOT DEFINED DSLITE)
|
|
|
|
set(DSLITE dslite.sh)
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
separate_arguments(OPTION_LIST UNIX_COMMAND ${UNIFLASH_OPTION})
|
|
|
|
|
|
|
|
add_custom_target(${TARGET}-uniflash
|
|
|
|
DEPENDS ${TARGET}
|
|
|
|
COMMAND ${DSLITE} ${UNIFLASH_OPTION} -f $<TARGET_FILE_DIR:${TARGET}>/${TARGET}.hex
|
|
|
|
VERBATIM
|
|
|
|
)
|
|
|
|
endfunction()
|
|
|
|
|
2023-06-27 15:45:38 +07:00
|
|
|
#----------------------------------
|
|
|
|
# Family specific
|
|
|
|
#----------------------------------
|
|
|
|
|
2023-06-02 11:42:17 +07:00
|
|
|
# family specific: can override above functions
|
2023-05-19 16:27:07 +07:00
|
|
|
include(${CMAKE_CURRENT_LIST_DIR}/${FAMILY}/family.cmake)
|
|
|
|
|
|
|
|
if (NOT FAMILY_MCUS)
|
2023-06-01 12:36:08 +07:00
|
|
|
set(FAMILY_MCUS ${FAMILY})
|
2023-03-17 16:12:49 +07:00
|
|
|
endif()
|
2023-05-19 16:27:07 +07:00
|
|
|
|
2023-09-11 11:35:51 +07:00
|
|
|
# if use max3421 as host controller, expand FAMILY_MCUS to include max3421
|
|
|
|
if (MAX3421_HOST STREQUAL "1")
|
|
|
|
set(FAMILY_MCUS ${FAMILY_MCUS} MAX3421)
|
|
|
|
endif ()
|
|
|
|
|
2023-05-19 16:27:07 +07:00
|
|
|
# save it in case of re-inclusion
|
|
|
|
set(FAMILY_MCUS ${FAMILY_MCUS} CACHE INTERNAL "")
|