adapting cmakelists

This commit is contained in:
2021-06-11 13:42:16 +02:00
parent 3a3a3f476c
commit 5405359ff6
4 changed files with 208 additions and 232 deletions

View File

@ -1,54 +1,4 @@
function(post_source_hw_os_config)
if(${TGT_BSP} MATCHES "arm/stm32h743zi-nucleo")
if(${OS_FSFW} MATCHES "freertos")
if(ADD_LWIP_STACK)
message(STATUS "Linking against ${LIB_LWIP_NAME} lwIP library")
if(LIB_LWIP_NAME)
target_link_libraries(${TARGET_NAME} PUBLIC
${LIB_LWIP_NAME}
)
else()
message(WARNING "lwIP library name not set!")
endif()
endif()
if(LINK_HAL)
message(STATUS "Linking against ${LIB_HAL_NAME} HAL library")
if(LIB_HAL_NAME)
target_link_libraries(${TARGET_NAME} PUBLIC
${LIB_HAL_NAME}
)
else()
message(WARNING "HAL library name not set!")
endif()
endif()
elseif(${OS_FSFW} MATCHES "rtems")
if(ADD_LWIP_STACK)
message(STATUS "Linking against ${LIB_LWIP_NAME} lwIP library")
if(LIB_LWIP_NAME)
target_link_libraries(${TARGET_NAME} PUBLIC
${LIB_LWIP_NAME}
)
else()
message(WARNING "lwIP library name not set!")
endif()
endif()
include("${RTEMS_CONFIG_DIR}/RTEMSPostProjectConfig.cmake")
rtems_post_project_config(${TARGET_NAME})
endif()
endif()
if(LINKER_SCRIPT)
target_link_options(${TARGET_NAME} PRIVATE
-T${LINKER_SCRIPT}
)
endif()
set(C_FLAGS "" CACHE INTERNAL "C flags")

View File

@ -1,24 +1,11 @@
function(pre_source_hw_os_config)
# FreeRTOS
if(${OS_FSFW} MATCHES freertos)
add_definitions(-DFREERTOS)
# RTEMS
elseif(${OS_FSFW} STREQUAL rtems)
add_definitions(-DRTEMS)
elseif(${OS_FSFW} STREQUAL linux)
add_definitions(-DUNIX -DLINUX)
if(${OS_FSFW} STREQUAL linux)
find_package(Threads REQUIRED)
set(BSP_PATH "bsp_linux")
# Hosted
else()
set(BSP_PATH "bsp_hosted")
if(WIN32)
add_definitions(-DWIN32)
elseif(UNIX)
find_package(Threads REQUIRED)
add_definitions(-DUNIX -DLINUX)
endif()
message(FATAL_ERROR "OS_FSFW not valid, only Linux is allowed!")
endif()
# Cross-compile information
@ -51,119 +38,11 @@ if(CMAKE_CROSSCOMPILING)
)
endif()
if(${TGT_BSP} MATCHES "arm/stm32h743zi-nucleo")
add_definitions(-DSTM32H743ZI_NUCLEO)
if(${OS_FSFW} MATCHES freertos)
option(ADD_LWIP_STACK "Add LwIP stack for application" ON)
set(LIB_OS_NAME "freertos" CACHE STRING "OS FSFW library name")
set(BSP_PATH "bsp_stm32_freertos")
set(BOARD_CONFIG_PATH
"${BSP_PATH}/STM32CubeH7/Boards/NUCLEO-H743ZI/Inc"
CACHE STRING
"Board configuration include path."
)
set(MIDDLEWARES_PATH
"${BSP_PATH}/STM32CubeH7/Middlewares"
)
set(CMSIS_INC_PATH
"${BSP_PATH}/STM32CubeH7/Drivers/CMSIS/Include"
CACHE STRING
"CMSIS include path"
)
set(FREERTOS_GENERIC_PORT_PATH
"${MIDDLEWARES_PATH}/Third_Party/FreeRTOS"
)
set(FREERTOS_PORT_PATH
"${FREERTOS_GENERIC_PORT_PATH}/portable/GCC/ARM_CM7/r0p1"
)
set(FREERTOS_CONFIG_AND_PORT_PATHS
"${FREERTOS_PORT_PATH}"
"${BOARD_CONFIG_PATH}"
"${CMSIS_INC_PATH}"
CACHE STRING
"FreeRTOS configuration and port paths."
)
set(FREERTOS_PORT_SOURCES
${FREERTOS_PORT_PATH}/port.c
CACHE INTERNAL
"FreeRTOS port sources"
)
set(LIB_STM_HAL_NAME "stm_hal" CACHE STRING "STM32 HAL library name")
set(LIB_HAL_NAME ${LIB_STM_HAL_NAME} PARENT_SCOPE)
set(LINK_HAL TRUE PARENT_SCOPE)
set(STM_HAL_CONFIG_PATH
"${BOARD_CONFIG_PATH}"
CACHE INTERNAL
"STM HAL config path."
)
set(STM_HAL_DEFINES
"USE_HAL_DRIVER"
"STM32H743xx"
CACHE INTERNAL
"HAL defines for target machine"
)
set(FSFW_HAL_DEFINES
${STM_HAL_DEFINES}
CACHE INTERNAL
"Defines for FSFW HAL"
)
set(FSFW_HAL_LINK_LIBS
${LIB_OS_NAME}
${LIB_STM_HAL_NAME}
CACHE INTERNAL
"Link FSFW HAL against OS"
)
set(LINKER_SCRIPT_PATH "${BSP_PATH}/STM32CubeH7/Boards/NUCLEO-H743ZI")
set(LINKER_SCRIPT_NAME "STM32H743ZITx_FLASH.ld")
get_filename_component(LINKER_SCRIPT
${LINKER_SCRIPT_PATH}/${LINKER_SCRIPT_NAME}
REALPATH BASE_DIR ${CMAKE_SOURCE_DIR}
)
set(LINKER_SCRIPT ${LINKER_SCRIPT} CACHE STRING "Custom linker script")
if(ADD_LWIP_STACK)
set(LWIP_CONFIG_PATH
"${BOARD_CONFIG_PATH}"
CACHE INTERNAL
"lwIP configuration include path"
)
set(LIB_LWIP_NAME "lwip" CACHE STRING "lwIP library name")
endif()
elseif(${OS_FSFW} MATCHES rtems)
option(ADD_LWIP_STACK "Add LwIP stack for application" ON)
set(BSP_PATH "bsp_stm32_rtems")
set(BOARD_CONFIG_PATH "${BSP_PATH}/boardconfig")
if(ADD_LWIP_STACK)
set(LWIP_CONFIG_PATH
"${BOARD_CONFIG_PATH}"
CACHE INTERNAL
"lwIP configuration include path"
)
set(LIB_LWIP_NAME "lwip" CACHE STRING "lwIP library name")
endif()
endif() # ${OS_FSFW} MATCHES XYZ
elseif(${TGT_BSP} MATCHES "arm/raspberrypi")
if(${TGT_BSP} MATCHES "arm/raspberrypi")
add_definitions(-DRASPBERRY_PI)
elseif(${TGT_BSP} MATCHES "arm/beagleboneblack")
add_definitions(-DBEAGLE_BONE_BLACK)
elseif(${TGT_BSP} MATCHES "host/none")
option(ADD_LWIP_STACK "Add LwIP stack for application" OFF)
else()
option(ADD_LWIP_STACK "Add LwIP stack for application" OFF)

View File

@ -16,67 +16,10 @@ if(DEFINED TGT_BSP)
endif()
endif()
endif()
endif()
# Disable compiler checks for cross-compiling.
if(${OS_FSFW} MATCHES freertos)
set(CMAKE_TOOLCHAIN_FILE
"${CMAKE_SCRIPT_PATH}/STM32FreeRTOSConfig.cmake"
PARENT_SCOPE
)
elseif(${OS_FSFW} MATCHES rtems)
set(RTEMS_CONFIG_DIR
"${CMAKE_CURRENT_SOURCE_DIR}/cmake/rtems-cmake"
CACHE FILEPATH
"Directory containing the RTEMS *.cmake files"
)
include(${RTEMS_CONFIG_DIR}/RTEMSPreProjectConfig.cmake)
if(NOT DEFINED RTEMS_PREFIX)
if(NOT DEFINED ENV{RTEMS_PREFIX})
message(FATAL_ERROR
"RTEMS_PREFIX must be set either manually or as an environment "
"variable!"
)
else()
message(STATUS
"Using environment variable RTEMS_PREFIX $ENV{RTEMS_PREFIX} "
"as RTEMS prefix"
)
set(RTEMS_PREFIX $ENV{RTEMS_PREFIX})
endif()
endif()
if(${TGT_BSP} MATCHES "arm/stm32h743zi-nucleo")
set(RTEMS_BSP "arm/nucleo-h743zi")
else()
if(NOT DEFINED RTEMS_BSP)
if(NOT DEFINED ENV{RTEMS_BSP})
message(FATAL_ERROR
"RTEMS_BSP must be set either manually or as an environment"
"variable!"
)
else()
set(RTEMS_BSP $ENV{RTEMS_BSP})
endif()
endif()
endif()
rtems_pre_project_config(${RTEMS_PREFIX} ${RTEMS_BSP})
set(CMAKE_TOOLCHAIN_FILE
${RTEMS_CONFIG_DIR}/RTEMSToolchain.cmake
PARENT_SCOPE
)
elseif(${OS_FSFW} STREQUAL linux AND TGT_BSP)
if(${OS_FSFW} STREQUAL linux AND TGT_BSP)
if(${TGT_BSP} MATCHES "host/none")
elseif(${TGT_BSP} MATCHES "arm/raspberrypi")
if(NOT DEFINED ENV{RASPBIAN_ROOTFS})
if(NOT RASPBIAN_ROOTFS)
@ -110,6 +53,7 @@ elseif(${OS_FSFW} STREQUAL linux AND TGT_BSP)
"$ENV{RASPBERRY_VERSION}"
)
endif()
if(LINUX_CROSS_COMPILE)
set(CMAKE_TOOLCHAIN_FILE
"${CMAKE_SCRIPT_PATH}/RPiCrossCompileConfig.cmake"