--refactor

This commit is contained in:
Mysteo
2023-07-28 07:22:49 +03:00
parent bfa9d67eb9
commit 4835d6a3a5
12 changed files with 95 additions and 98 deletions

View File

@@ -29,12 +29,12 @@ list(FILTER SOURCES EXCLUDE REGEX "IAR\\/.*.[c|h]$")
list(FILTER SOURCES EXCLUDE REGEX "Keil\\/.*.[c|h]$") list(FILTER SOURCES EXCLUDE REGEX "Keil\\/.*.[c|h]$")
set(LINKER_SCRIPT ${CMAKE_SOURCE_DIR}/Boot/STM32G070CBTX_FLASH.ld) set(LINKER_SCRIPT ${CMAKE_SOURCE_DIR}/Boot/STM32G070CBTX_FLASH.ld)
add_executable(${PROJECT_NAME}.elf ${SOURCES} ) add_executable(${PROJECT_NAME}.elf ${SOURCES} )
target_compile_options(${PROJECT_NAME}.elf PUBLIC $ENV{COMPILE_OPTIONS}) target_compile_options(${PROJECT_NAME}.elf PUBLIC ${COMPILE_OPTIONS})
target_link_options(${PROJECT_NAME}.elf PUBLIC $ENV{LINK_OPTIONS}) target_link_options(${PROJECT_NAME}.elf PUBLIC ${LINK_OPTIONS})
set(HEX_FILE ${PROJECT_BINARY_DIR}/${PROJECT_NAME}.hex) set(HEX_FILE ${PROJECT_BINARY_DIR}/${PROJECT_NAME}.hex)
set(BIN_FILE ${PROJECT_BINARY_DIR}/${PROJECT_NAME}.bin) set(BIN_FILE ${PROJECT_BINARY_DIR}/${PROJECT_NAME}.bin)
target_include_directories(${PROJECT_NAME}.elf PRIVATE ${INCLUDE_DIR} ) target_include_directories(${PROJECT_NAME}.elf PRIVATE ${INCLUDE_DIR} )
target_link_libraries(${PROJECT_NAME}.elf PUBLIC $ENV{MCU_SERIES}_HAL_DRIVER CMSIS) target_link_libraries(${PROJECT_NAME}.elf PUBLIC ${MCU_SERIES}_HAL_DRIVER CMSIS)
add_custom_command(TARGET ${PROJECT_NAME}.elf PRE_BUILD add_custom_command(TARGET ${PROJECT_NAME}.elf PRE_BUILD
COMMAND ${CMAKE_COMMAND} -E copy "${CMAKE_SOURCE_DIR}/${MEM_MAP_FILE}" ${PROJECT_BINARY_DIR}/../${MEM_MAP_FILE} COMMAND ${CMAKE_COMMAND} -E copy "${CMAKE_SOURCE_DIR}/${MEM_MAP_FILE}" ${PROJECT_BINARY_DIR}/../${MEM_MAP_FILE}
) )

View File

@@ -3,37 +3,37 @@ cmake_minimum_required(VERSION 3.23)
#/////////////////////////////////////////////PLEASE CHOOSE THIS OPTIONS BY YOURSELF #/////////////////////////////////////////////PLEASE CHOOSE THIS OPTIONS BY YOURSELF
set (ENV{HAL_DRIVER_CONFIG} ${CMAKE_CURRENT_SOURCE_DIR}/main_prog/Core/Inc/stm32g0xx_hal_conf.h) set (HAL_DRIVER_CONFIG ${CMAKE_CURRENT_SOURCE_DIR}/main_prog/Core/Inc/stm32g0xx_hal_conf.h)
set(ENV{MCU} "STM32G070xx") set(MCU "STM32G070xx")
if(BOOT) if(BOOT)
set (LINKER_SCRIPT ${CMAKE_SOURCE_DIR}/Boot/STM32G070CBTX_FLASH.ld) set (LINKER_SCRIPT ${CMAKE_SOURCE_DIR}/Boot/STM32G070CBTX_FLASH.ld)
else() else()
set(LINKER_SCRIPT ${CMAKE_SOURCE_DIR}/main_prog/STM32G070CBTX_FLASH.ld ) set(LINKER_SCRIPT ${CMAKE_SOURCE_DIR}/main_prog/STM32G070CBTX_FLASH.ld )
endif() endif()
set(ENV{FREERTOS_CONFIG} "${CMAKE_CURRENT_SOURCE_DIR}/main_prog/Core/Inc/FreeRTOSConfig.h") set(FREERTOS_CONFIG "${CMAKE_CURRENT_SOURCE_DIR}/main_prog/Core/Inc/FreeRTOSConfig.h")
#///////////////////////////////////////////// #/////////////////////////////////////////////
string (SUBSTRING "$ENV{MCU}" 0 7 MCU_SERIES) string (SUBSTRING "${MCU}" 0 7 MCU_SERIES)
string(APPEND MCU_SERIES "XX") string(APPEND MCU_SERIES "XX")
if(${MCU_SERIES} MATCHES "STM32F4|STM32F3|STM32WB|STM32WL|STM32L4|STM32WB|STM32WL|STM32G4") if(${MCU_SERIES} MATCHES "STM32F4|STM32F3|STM32WB|STM32WL|STM32L4|STM32WB|STM32WL|STM32G4")
set(ENV{CORTEX-M} "4") set(CORTEX-M "4")
set(ENV{HARDWARE_FLOAT} 1) set(HARDWARE_FLOAT 1)
elseif(${MCU_SERIES} MATCHES "STM32F2|STM32F1") elseif(${MCU_SERIES} MATCHES "STM32F2|STM32F1")
set(ENV{CORTEX-M} "3") set(CORTEX-M "3")
set(ENV{HARDWARE_FLOAT} 0) set(HARDWARE_FLOAT 0)
elseif(${MCU_SERIES} MATCHES "STM32F0|STM32C0|STM32G0|STM32L0" ) elseif(${MCU_SERIES} MATCHES "STM32F0|STM32C0|STM32G0|STM32L0" )
set(ENV{CORTEX-M} "0") set(CORTEX-M "0")
set(ENV{HARDWARE_FLOAT} 0) set(HARDWARE_FLOAT 0)
else() else()
message(FATAL_ERROR "${MCU_SERIES} is not supported") message(FATAL_ERROR "${MCU_SERIES} is not supported")
endif() endif()
set(ENV{MCU_SERIES} ${MCU_SERIES}) set(MCU_SERIES ${MCU_SERIES})
add_subdirectory(Cmake_templates) add_subdirectory(Cmake_templates)
if(GTEST) if(GTEST)
add_subdirectory(libs/Drivers/CMSIS) add_subdirectory(libs/Drivers/CMSIS)
add_subdirectory(libs/Drivers/$ENV{MCU_SERIES}_HAL_Driver) add_subdirectory(libs/Drivers/${MCU_SERIES}_HAL_Driver)
add_subdirectory(gtests) add_subdirectory(gtests)
else() else()
set(CMAKE_SYSTEM_NAME Generic) set(CMAKE_SYSTEM_NAME Generic)
@@ -78,7 +78,7 @@ else()
set(COMPILE_OPTIONS set(COMPILE_OPTIONS
-mcpu=cortex-m$ENV{CORTEX-M} -mcpu=cortex-m${CORTEX-M}
-mthumb -mthumb-interwork -mthumb -mthumb-interwork
-ffunction-sections -ffunction-sections
-fdata-sections -fdata-sections
@@ -90,7 +90,7 @@ else()
) )
set(LINK_OPTIONS set(LINK_OPTIONS
-Wl,-gc-sections,--print-memory-usage,-Map=${PROJECT_BINARY_DIR}/${PROJECT_NAME}.map -Wl,-gc-sections,--print-memory-usage,-Map=${PROJECT_BINARY_DIR}/${PROJECT_NAME}.map
-mcpu=cortex-m$ENV{CORTEX-M} -mcpu=cortex-m${CORTEX-M}
-mthumb -mthumb
-mthumb-interwork -mthumb-interwork
-T ${LINKER_SCRIPT} -T ${LINKER_SCRIPT}
@@ -106,21 +106,21 @@ else()
FW_VERSION="${FW_VERSION}" FW_VERSION="${FW_VERSION}"
) )
set(ENV{LINK_OPTIONS} "${LINK_OPTIONS}") set(LINK_OPTIONS "${LINK_OPTIONS}")
add_link_options($ENV{LINK_OPTIONS}) add_link_options(${LINK_OPTIONS})
if ($ENV{CORTEX-M} EQUAL 4) if (${CORTEX-M} EQUAL 4)
if ($ENV{HARDWARE_FLOAT} EQUAL 1) if (${HARDWARE_FLOAT} EQUAL 1)
add_compile_options(-mfloat-abi=hard -mfpu=fpv4-sp-d16) add_compile_options(-mfloat-abi=hard -mfpu=fpv4-sp-d16)
add_link_options(-mfloat-abi=hard -mfpu=fpv4-sp-d16) add_link_options(-mfloat-abi=hard -mfpu=fpv4-sp-d16)
add_compile_definitions(ARM_MATH_CM4 ARM_MATH_MATRIX_CHECK ARM_MATH_ROUNDING) add_compile_definitions(ARM_MATH_CM4 ARM_MATH_MATRIX_CHECK ARM_MATH_ROUNDING)
elseif($ENV{HARDWARE_FLOAT} EQUAL 0 AND $ENV}) elseif(${HARDWARE_FLOAT} EQUAL 0 AND $})
string(PREPEND COMPILE_OPTIONS " -mfloat-abi=soft") string(PREPEND COMPILE_OPTIONS " -mfloat-abi=soft")
endif () endif ()
endif() endif()
set(ENV{COMPILE_OPTIONS} "${COMPILE_OPTIONS}") set(COMPILE_OPTIONS "${COMPILE_OPTIONS}")
set(ENV{COMPILE_DEF} "${COMPILE_DEF}") set(COMPILE_DEF "${COMPILE_DEF}")
if ("${CMAKE_BUILD_TYPE}" STREQUAL "Release") if ("${CMAKE_BUILD_TYPE}" STREQUAL "Release")
message(STATUS "Maximum optimization for speed") message(STATUS "Maximum optimization for speed")
@@ -145,7 +145,7 @@ else()
endif () endif ()
if (BOOT) if (BOOT)
set (ENV{HAL_DRIVER_CONFIG} ${CMAKE_CURRENT_SOURCE_DIR}/Boot/Core/Inc/stm32g0xx_hal_conf.h) set (HAL_DRIVER_CONFIG ${CMAKE_CURRENT_SOURCE_DIR}/Boot/Core/Inc/stm32g0xx_hal_conf.h)
FUNC_CREATE_MEMORY_MAP("${MEM_MAP_FILE}" "128" "8" "4" ) FUNC_CREATE_MEMORY_MAP("${MEM_MAP_FILE}" "128" "8" "4" )
add_compile_definitions("BOOT_FLASH_VECTOR_TABLE_CS_OFFSET=${LEN_OFFSET}" "LEN_ADDRESS=${LEN_ADDRESS}") add_compile_definitions("BOOT_FLASH_VECTOR_TABLE_CS_OFFSET=${LEN_OFFSET}" "LEN_ADDRESS=${LEN_ADDRESS}")
add_compile_definitions("PAGE_SIZE=0x0800") add_compile_definitions("PAGE_SIZE=0x0800")

View File

@@ -1,4 +1,4 @@
if (NOT DEFINED ENV{MCU_SERIES}) if (NOT DEFINED MCU_SERIES)
message(FATAL_ERROR "Please Define MCU Series Like STM32F4xx") message(FATAL_ERROR "Please Define MCU Series Like STM32F4xx")
endif() endif()
set(MAIN_PROG_DIR ${CMAKE_SOURCE_DIR}/main_prog) set(MAIN_PROG_DIR ${CMAKE_SOURCE_DIR}/main_prog)
@@ -6,8 +6,8 @@ set(DRIVERS_DEST ${CMAKE_SOURCE_DIR}/libs/Drivers)
set(CMSIS_SOURCE_DIR ${CMAKE_SOURCE_DIR}/Drivers/CMSIS) set(CMSIS_SOURCE_DIR ${CMAKE_SOURCE_DIR}/Drivers/CMSIS)
set(CMSIS_SOURCE_DEST_DIR ${CMAKE_SOURCE_DIR}/libs/Drivers/CMSIS) set(CMSIS_SOURCE_DEST_DIR ${CMAKE_SOURCE_DIR}/libs/Drivers/CMSIS)
set(HAL_DRIVER_SOURCE_DIR ${CMAKE_SOURCE_DIR}/Drivers/$ENV{MCU_SERIES}_HAL_Driver) set(HAL_DRIVER_SOURCE_DIR ${CMAKE_SOURCE_DIR}/Drivers/${MCU_SERIES}_HAL_Driver)
set(HAL_DRIVER_DEST_DIR ${CMAKE_SOURCE_DIR}/libs/Drivers/$ENV{MCU_SERIES}_HAL_Driver) set(HAL_DRIVER_DEST_DIR ${CMAKE_SOURCE_DIR}/libs/Drivers/${MCU_SERIES}_HAL_Driver)
if (NOT EXISTS ${CMAKE_SOURCE_DIR}/libs) if (NOT EXISTS ${CMAKE_SOURCE_DIR}/libs)
file(MAKE_DIRECTORY ${CMAKE_SOURCE_DIR}/libs) file(MAKE_DIRECTORY ${CMAKE_SOURCE_DIR}/libs)

View File

@@ -1,34 +1,34 @@
set(LIB_NAME CMSIS) set(LIB_NAME CMSIS)
if(NOT DEFINED ENV{MCU_SERIES}) if(NOT DEFINED MCU_SERIES)
message(FATAL_ERROR "MCU_SERIES NOT DEFINED. Please define it like stm32fxx") message(FATAL_ERROR "MCU_SERIES NOT DEFINED. Please define it like stm32fxx")
else() else()
string(TOUPPER $ENV{MCU_SERIES} MCU_SERIES_UPPERCASE) string(TOUPPER ${MCU_SERIES} MCU_SERIES_UPPERCASE)
endif() endif()
project(${LIB_NAME} project(${LIB_NAME}
LANGUAGES C ASM LANGUAGES C ASM
) )
if (NOT DEFINED ENV{MCU}) if (NOT DEFINED MCU)
message(FATAL_ERROR "PLEASE DEFINE ENV{MCU} i.e STM32F427xx") message(FATAL_ERROR "PLEASE DEFINE MCU i.e STM32F427xx")
endif () endif ()
if (NOT GTEST) if (NOT GTEST)
if (NOT $ENV{CORTEX-M} STREQUAL "3" AND NOT $ENV{CORTEX-M} STREQUAL "1" AND NOT $ENV{CORTEX-M} STREQUAL "0" AND NOT $ENV{CORTEX-M} STREQUAL "4" AND NOT $ENV{CORTEX-M} STREQUAL "3" AND NOT $ENV{CORTEX-M} STREQUAL "55") if (NOT ${CORTEX-M} STREQUAL "3" AND NOT ${CORTEX-M} STREQUAL "1" AND NOT ${CORTEX-M} STREQUAL "0" AND NOT ${CORTEX-M} STREQUAL "4" AND NOT ${CORTEX-M} STREQUAL "3" AND NOT ${CORTEX-M} STREQUAL "55")
message(FATAL_ERROR "Error: please set CORTEX-M") message(FATAL_ERROR "Error: please set CORTEX-M")
endif () endif ()
if (NOT DEFINED ENV{COMPILE_OPTIONS}) if (NOT DEFINED COMPILE_OPTIONS)
set(COMPILE_OPTIONS -ffunction-sections -fdata-sections -fno-common -fmessage-length=0 $<$<COMPILE_LANGUAGE:CXX>:-fno-rtti> -mcpu=cortex-m$ENV{CORTEX-M} -mthumb -mthumb-interwork) set(COMPILE_OPTIONS -ffunction-sections -fdata-sections -fno-common -fmessage-length=0 $<$<COMPILE_LANGUAGE:CXX>:-fno-rtti> -mcpu=cortex-m${CORTEX-M} -mthumb -mthumb-interwork)
message(WARNING "${LIB_NAME} compile with default options") message(WARNING "${LIB_NAME} compile with default options")
else () else ()
set(COMPILE_OPTIONS $ENV{COMPILE_OPTIONS}) set(COMPILE_OPTIONS ${COMPILE_OPTIONS})
endif() endif()
endif() endif()
add_library(${LIB_NAME} INTERFACE) add_library(${LIB_NAME} INTERFACE)
target_include_directories(${LIB_NAME} INTERFACE Include Device/ST/${MCU_SERIES_UPPERCASE}/Include) target_include_directories(${LIB_NAME} INTERFACE Include Device/ST/${MCU_SERIES_UPPERCASE}/Include)
target_compile_definitions(${LIB_NAME} INTERFACE "$ENV{MCU}") target_compile_definitions(${LIB_NAME} INTERFACE "${MCU}")
if (NOT $ENV{CORTEX-M} STREQUAL "3" AND NOT $ENV{CORTEX-M} STREQUAL "1" AND NOT $ENV{CORTEX-M} STREQUAL "0" AND NOT $ENV{CORTEX-M} STREQUAL "4" AND NOT $ENV{CORTEX-M} STREQUAL "3" AND NOT $ENV{CORTEX-M} STREQUAL "55") if (NOT ${CORTEX-M} STREQUAL "3" AND NOT ${CORTEX-M} STREQUAL "1" AND NOT ${CORTEX-M} STREQUAL "0" AND NOT ${CORTEX-M} STREQUAL "4" AND NOT ${CORTEX-M} STREQUAL "3" AND NOT ${CORTEX-M} STREQUAL "55")
message(FATAL_ERROR "Error: please set CORTEX-M") message(FATAL_ERROR "Error: please set CORTEX-M")
else () else ()
target_compile_options(${LIB_NAME} BEFORE INTERFACE ${COMPILE_OPTIONS}) target_compile_options(${LIB_NAME} BEFORE INTERFACE ${COMPILE_OPTIONS})

View File

@@ -1,2 +1,2 @@
add_subdirectory($ENV{MCU_SERIES}_HAL_Driver) add_subdirectory(${MCU_SERIES}_HAL_Driver)
add_subdirectory(CMSIS) add_subdirectory(CMSIS)

View File

@@ -1,8 +1,8 @@
set(LIB_NAME $ENV{MCU_SERIES}_HAL_DRIVER) set(LIB_NAME ${MCU_SERIES}_HAL_DRIVER)
string (TOLOWER $ENV{MCU_SERIES} MCU_SERIES) string (TOLOWER ${MCU_SERIES} MCU_SERIES)
if (NOT DEFINED ENV{HAL_DRIVER_CONFIG}) if (NOT DEFINED HAL_DRIVER_CONFIG)
message(WARNING "HAL_DRIVER_CONFIG not defined \r\n Project will be generate with default config. You can choose full path to configuration file ${MCU_SERIES}_hal_conf.h ENV{HAL_DRIVER_CONFIG} message(WARNING "HAL_DRIVER_CONFIG not defined \r\n Project will be generate with default config. You can choose full path to configuration file ${MCU_SERIES}_hal_conf.h
filename should be - ${MCU_SERIES}_hal_conf.h" ) filename should be - ${MCU_SERIES}_hal_conf.h" )
message(WARNING "PROJECT WILL BE GENERATED WITH DEFAULT CONFIG" ) message(WARNING "PROJECT WILL BE GENERATED WITH DEFAULT CONFIG" )
if (NOT EXISTS default_config) if (NOT EXISTS default_config)
@@ -12,21 +12,21 @@ filename should be - ${MCU_SERIES}_hal_conf.h" )
file(COPY Inc/${MCU_SERIES}_hal_conf_template.h DESTINATION ${CMAKE_CURRENT_LIST_DIR}/default_config) file(COPY Inc/${MCU_SERIES}_hal_conf_template.h DESTINATION ${CMAKE_CURRENT_LIST_DIR}/default_config)
file(RENAME ${CMAKE_CURRENT_LIST_DIR}/default_config/${MCU_SERIES}_hal_conf_template.h ${CMAKE_CURRENT_LIST_DIR}/default_config/${MCU_SERIES}_hal_conf.h ) file(RENAME ${CMAKE_CURRENT_LIST_DIR}/default_config/${MCU_SERIES}_hal_conf_template.h ${CMAKE_CURRENT_LIST_DIR}/default_config/${MCU_SERIES}_hal_conf.h )
endif() endif()
set ($ENV{HAL_DRIVER_CONFIG} ${CMAKE_CURRENT_LIST_DIR}/default_config) set (${HAL_DRIVER_CONFIG} ${CMAKE_CURRENT_LIST_DIR}/default_config)
else() else()
string(FIND $ENV{HAL_DRIVER_CONFIG} "${MCU_SERIES}_hal_conf.h" RESULT) string(FIND ${HAL_DRIVER_CONFIG} "${MCU_SERIES}_hal_conf.h" RESULT)
if (${RESULT} EQUAL -1) if (${RESULT} EQUAL -1)
message(FATAL_ERROR "filename should be - ${MCU_SERIES}_hal_conf.h") message(FATAL_ERROR "filename should be - ${MCU_SERIES}_hal_conf.h")
endif() endif()
file(MAKE_DIRECTORY config) file(MAKE_DIRECTORY config)
file(COPY $ENV{HAL_DRIVER_CONFIG} DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/config) file(COPY ${HAL_DRIVER_CONFIG} DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/config)
set (ENV{HAL_DRIVER_CONFIG} config) set (HAL_DRIVER_CONFIG config)
endif() endif()
project(${LIB_NAME} project(${LIB_NAME}
LANGUAGES C ASM LANGUAGES C ASM
) )
add_definitions(-DUSE_HAL_DRIVER -D$ENV{MCU}) add_definitions(-DUSE_HAL_DRIVER -D${MCU})
file(GLOB_RECURSE SOURCES "Src/*.c") file(GLOB_RECURSE SOURCES "Src/*.c")
add_library(${LIB_NAME} STATIC ${SOURCES}) add_library(${LIB_NAME} STATIC ${SOURCES})

View File

@@ -3,32 +3,31 @@ cmake_minimum_required(VERSION 3.23)
#/////////////////////////////////////////////PLEASE CHOOSE THIS OPTIONS BY YOURSELF #/////////////////////////////////////////////PLEASE CHOOSE THIS OPTIONS BY YOURSELF
set(ENV{MCU} "STM32G070xx") set(MCU "STM32G070xx")
set(ENV{LINKER_SCRIPT} ${CMAKE_SOURCE_DIR}/STM32G070CBTX_FLASH.ld) set(LINKER_SCRIPT ${CMAKE_SOURCE_DIR}/STM32G070CBTX_FLASH.ld)
set(ENV{FREERTOS_CONFIG} "${CMAKE_CURRENT_SOURCE_DIR}/main_prog/Core/Inc/FreeRTOSConfig.h") set(FREERTOS_CONFIG "${CMAKE_CURRENT_SOURCE_DIR}/main_prog/Core/Inc/FreeRTOSConfig.h")
#///////////////////////////////////////////// #/////////////////////////////////////////////
string (SUBSTRING "$ENV{MCU}" 0 7 MCU_SERIES) string (SUBSTRING "${MCU" 0 7 MCU_SERIES)
string(APPEND MCU_SERIES "XX") string(APPEND MCU_SERIES "XX")
if(${MCU_SERIES} MATCHES "STM32F4|STM32F3|STM32WB|STM32WL|STM32L4|STM32WB|STM32WL|STM32G4") if(${MCU_SERIES} MATCHES "STM32F4|STM32F3|STM32WB|STM32WL|STM32L4|STM32WB|STM32WL|STM32G4")
set(ENV{CORTEX-M} "4") set(CORTEX-M "4")
set(ENV{HARDWARE_FLOAT} 1) set(HARDWARE_FLOAT 1)
elseif(${MCU_SERIES} MATCHES "STM32F2|STM32F1") elseif(${MCU_SERIES} MATCHES "STM32F2|STM32F1")
set(ENV{CORTEX-M} "3") set(CORTEX-M "3")
set(ENV{HARDWARE_FLOAT} 0) set(HARDWARE_FLOAT 0)
elseif(${MCU_SERIES} MATCHES "STM32F0|STM32C0|STM32G0|STM32L0" ) elseif(${MCU_SERIES} MATCHES "STM32F0|STM32C0|STM32G0|STM32L0" )
set(ENV{CORTEX-M} "0") set(CORTEX-M "0")
set(ENV{HARDWARE_FLOAT} 0) set(HARDWARE_FLOAT 0)
else() else()
message(FATAL_ERROR "${MCU_SERIES} is not supported") message(FATAL_ERROR "${MCU_SERIES} is not supported")
endif() endif()
set(ENV{MCU_SERIES} ${MCU_SERIES})
add_subdirectory(Cmake_templates) add_subdirectory(Cmake_templates)
if(GTEST) if(GTEST)
add_subdirectory(libs/Drivers/CMSIS) add_subdirectory(libs/Drivers/CMSIS)
add_subdirectory(libs/Drivers/$ENV{MCU_SERIES}_HAL_Driver) add_subdirectory(libs/Drivers/${MCU_SERIES}_HAL_Driver)
add_subdirectory(gtests) add_subdirectory(gtests)
else() else()
set(CMAKE_SYSTEM_NAME Generic) set(CMAKE_SYSTEM_NAME Generic)
@@ -63,7 +62,7 @@ else()
set(COMPILE_OPTIONS set(COMPILE_OPTIONS
-mcpu=cortex-m$ENV{CORTEX-M} -mcpu=cortex-m${CORTEX-M}
-mthumb -mthumb-interwork -mthumb -mthumb-interwork
-ffunction-sections -ffunction-sections
-fdata-sections -fdata-sections
@@ -75,10 +74,10 @@ else()
) )
set(LINK_OPTIONS set(LINK_OPTIONS
-Wl,-gc-sections,--print-memory-usage,-Map=${PROJECT_BINARY_DIR}/${PROJECT_NAME}.map -Wl,-gc-sections,--print-memory-usage,-Map=${PROJECT_BINARY_DIR}/${PROJECT_NAME}.map
-mcpu=cortex-m$ENV{CORTEX-M} -mcpu=cortex-m${CORTEX-M}
-mthumb -mthumb
-mthumb-interwork -mthumb-interwork
-T $ENV{LINKER_SCRIPT} -T ${LINKER_SCRIPT}
) )
set(COMPILE_DEF set(COMPILE_DEF
@@ -91,21 +90,19 @@ else()
FW_VERSION="${FW_VERSION}" FW_VERSION="${FW_VERSION}"
) )
set(ENV{LINK_OPTIONS} "${LINK_OPTIONS}") set(LINK_OPTIONS "${LINK_OPTIONS}")
add_link_options($ENV{LINK_OPTIONS}) add_link_options(${LINK_OPTIONS})
if ($ENV{CORTEX-M} EQUAL 4) if (${CORTEX-M} EQUAL 4)
if ($ENV{HARDWARE_FLOAT} EQUAL 1) if (${HARDWARE_FLOAT} EQUAL 1)
add_compile_options(-mfloat-abi=hard -mfpu=fpv4-sp-d16) add_compile_options(-mfloat-abi=hard -mfpu=fpv4-sp-d16)
add_link_options(-mfloat-abi=hard -mfpu=fpv4-sp-d16) add_link_options(-mfloat-abi=hard -mfpu=fpv4-sp-d16)
add_compile_definitions(ARM_MATH_CM4 ARM_MATH_MATRIX_CHECK ARM_MATH_ROUNDING) add_compile_definitions(ARM_MATH_CM4 ARM_MATH_MATRIX_CHECK ARM_MATH_ROUNDING)
elseif($ENV{HARDWARE_FLOAT} EQUAL 0 AND $ENV}) elseif(${HARDWARE_FLOAT} EQUAL 0 AND $})
string(PREPEND COMPILE_OPTIONS " -mfloat-abi=soft") string(PREPEND COMPILE_OPTIONS " -mfloat-abi=soft")
endif () endif ()
endif() endif()
set(ENV{COMPILE_OPTIONS} "${COMPILE_OPTIONS}")
set(ENV{COMPILE_DEF} "${COMPILE_DEF}")
add_subdirectory(libs) add_subdirectory(libs)
add_subdirectory(main_prog) add_subdirectory(main_prog)

View File

@@ -73,11 +73,11 @@ set(FIRMWARE_DIR ${CMAKE_SOURCE_DIR}/utils/bin/)
add_executable(${PROJECT_NAME}.elf ${SOURCES}) add_executable(${PROJECT_NAME}.elf ${SOURCES})
target_compile_options(${PROJECT_NAME}.elf PUBLIC $ENV{COMPILE_OPTIONS}) target_compile_options(${PROJECT_NAME}.elf PUBLIC ${COMPILE_OPTIONS})
target_link_options(${PROJECT_NAME}.elf PUBLIC $ENV{LINK_OPTIONS}) target_link_options(${PROJECT_NAME}.elf PUBLIC ${LINK_OPTIONS})
target_include_directories(${PROJECT_NAME}.elf PUBLIC ${INCLUDE_DIR}) target_include_directories(${PROJECT_NAME}.elf PUBLIC ${INCLUDE_DIR})
target_link_libraries(${PROJECT_NAME}.elf PUBLIC $ENV{MCU_SERIES}_HAL_DRIVER CMSIS ) target_link_libraries(${PROJECT_NAME}.elf PUBLIC ${MCU_SERIES}_HAL_DRIVER CMSIS )
target_compile_definitions(${PROJECT_NAME}.elf PUBLIC $ENV{COMPILE_DEF}) target_compile_definitions(${PROJECT_NAME}.elf PUBLIC ${COMPILE_DEF})
set(HEX_FILE ${PROJECT_BINARY_DIR}/${PROJECT_NAME}.hex) set(HEX_FILE ${PROJECT_BINARY_DIR}/${PROJECT_NAME}.hex)
set(BIN_FILE ${PROJECT_BINARY_DIR}/${PROJECT_NAME}.bin) set(BIN_FILE ${PROJECT_BINARY_DIR}/${PROJECT_NAME}.bin)
add_custom_command(TARGET ${PROJECT_NAME}.elf PRE_BUILD add_custom_command(TARGET ${PROJECT_NAME}.elf PRE_BUILD

View File

@@ -1,31 +1,31 @@
set(LIB_NAME CMSIS) set(LIB_NAME CMSIS)
if(NOT DEFINED ENV{MCU_SERIES}) if(NOT DEFINED MCU_SERIES)
message(FATAL_ERROR "MCU_SERIES NOT DEFINED. Please define it like stm32fxx") message(FATAL_ERROR "MCU_SERIES NOT DEFINED. Please define it like stm32fxx")
else() else()
string(TOUPPER $ENV{MCU_SERIES} MCU_SERIES_UPPERCASE) string(TOUPPER ${MCU_SERIES} MCU_SERIES_UPPERCASE)
endif() endif()
project(${LIB_NAME} project(${LIB_NAME}
LANGUAGES C ASM LANGUAGES C ASM
) )
if (NOT DEFINED ENV{MCU}) if (NOT DEFINED MCU)
message(FATAL_ERROR "PLEASE DEFINE ENV{MCU} i.e STM32F427xx") message(FATAL_ERROR "PLEASE DEFINE MCU i.e STM32F427xx")
endif () endif ()
if (NOT GTEST) if (NOT GTEST)
if (NOT $ENV{CORTEX-M} STREQUAL "3" AND NOT $ENV{CORTEX-M} STREQUAL "1" AND NOT $ENV{CORTEX-M} STREQUAL "0" AND NOT $ENV{CORTEX-M} STREQUAL "4" AND NOT $ENV{CORTEX-M} STREQUAL "3" AND NOT $ENV{CORTEX-M} STREQUAL "55" AND NOT $ENV{CORTEX-M} STREQUAL "0+") if (NOT ${CORTEX-M} STREQUAL "3" AND NOT ${CORTEX-M} STREQUAL "1" AND NOT ${CORTEX-M} STREQUAL "0" AND NOT ${CORTEX-M} STREQUAL "4" AND NOT ${CORTEX-M} STREQUAL "3" AND NOT ${CORTEX-M} STREQUAL "55" AND NOT ${CORTEX-M} STREQUAL "0+")
message(FATAL_ERROR "Error: please set CORTEX-M") message(FATAL_ERROR "Error: please set CORTEX-M")
endif () endif ()
if (NOT DEFINED ENV{COMPILE_OPTIONS}) if (NOT DEFINED COMPILE_OPTIONS)
set(COMPILE_OPTIONS -ffunction-sections -fdata-sections -fno-common -fmessage-length=0 $<$<COMPILE_LANGUAGE:CXX>:-fno-rtti> -mcpu=cortex-m$ENV{CORTEX-M} -mthumb -mthumb-interwork) set(COMPILE_OPTIONS -ffunction-sections -fdata-sections -fno-common -fmessage-length=0 $<$<COMPILE_LANGUAGE:CXX>:-fno-rtti> -mcpu=cortex-m${CORTEX-M} -mthumb -mthumb-interwork)
message(WARNING "${LIB_NAME} compile with default options") message(WARNING "${LIB_NAME} compile with default options")
else () else ()
set(COMPILE_OPTIONS $ENV{COMPILE_OPTIONS}) set(COMPILE_OPTIONS ${COMPILE_OPTIONS})
endif() endif()
endif() endif()
add_library(${LIB_NAME} INTERFACE) add_library(${LIB_NAME} INTERFACE)
target_include_directories(${LIB_NAME} INTERFACE Include Device/ST/${MCU_SERIES_UPPERCASE}/Include) target_include_directories(${LIB_NAME} INTERFACE Include Device/ST/${MCU_SERIES_UPPERCASE}/Include)
target_compile_definitions(${LIB_NAME} INTERFACE "$ENV{MCU}") target_compile_definitions(${LIB_NAME} INTERFACE "${MCU}")
target_compile_options(${LIB_NAME} BEFORE INTERFACE ${COMPILE_OPTIONS}) target_compile_options(${LIB_NAME} BEFORE INTERFACE ${COMPILE_OPTIONS})

View File

@@ -1,2 +1,2 @@
add_subdirectory($ENV{MCU_SERIES}_HAL_Driver) add_subdirectory(${MCU_SERIES}_HAL_Driver)
add_subdirectory(CMSIS) add_subdirectory(CMSIS)

View File

@@ -1,8 +1,8 @@
set(LIB_NAME $ENV{MCU_SERIES}_HAL_DRIVER) set(LIB_NAME ${MCU_SERIES}_HAL_DRIVER)
string (TOLOWER $ENV{MCU_SERIES} MCU_SERIES) string (TOLOWER ${MCU_SERIES} MCU_SERIES)
if (NOT DEFINED ENV{HAL_DRIVER_CONFIG}) if (NOT DEFINED HAL_DRIVER_CONFIG)
message(WARNING "HAL_DRIVER_CONFIG not defined \r\n Project will be generate with default config. You can choose full path to configuration file ${MCU_SERIES}_hal_conf.h ENV{HAL_DRIVER_CONFIG} message(WARNING "HAL_DRIVER_CONFIG not defined \r\n Project will be generate with default config. You can choose full path to configuration file ${MCU_SERIES}_hal_conf.h
filename should be - ${MCU_SERIES}_hal_conf.h" ) filename should be - ${MCU_SERIES}_hal_conf.h" )
message(WARNING "PROJECT WILL BE GENERATED WITH DEFAULT CONFIG" ) message(WARNING "PROJECT WILL BE GENERATED WITH DEFAULT CONFIG" )
if (NOT EXISTS default_config) if (NOT EXISTS default_config)
@@ -12,17 +12,17 @@ filename should be - ${MCU_SERIES}_hal_conf.h" )
file(COPY Inc/${MCU_SERIES}_hal_conf_template.h DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/default_config) file(COPY Inc/${MCU_SERIES}_hal_conf_template.h DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/default_config)
file(RENAME ${CMAKE_CURRENT_SOURCE_DIR}/default_config/${MCU_SERIES}_hal_conf_template.h ${CMAKE_CURRENT_LIST_DIR}/default_config/${MCU_SERIES}_hal_conf.h ) file(RENAME ${CMAKE_CURRENT_SOURCE_DIR}/default_config/${MCU_SERIES}_hal_conf_template.h ${CMAKE_CURRENT_LIST_DIR}/default_config/${MCU_SERIES}_hal_conf.h )
endif() endif()
set ($ENV{HAL_DRIVER_CONFIG} ${CMAKE_CURRENT_LIST_DIR}/default_config) set (${HAL_DRIVER_CONFIG} ${CMAKE_CURRENT_LIST_DIR}/default_config)
else() else()
string(FIND $ENV{HAL_DRIVER_CONFIG} ${MCU_SERIES}_hal_conf.h output REVERSE) string(FIND ${HAL_DRIVER_CONFIG} ${MCU_SERIES}_hal_conf.h output REVERSE)
string(SUBSTRING $ENV{HAL_DRIVER_CONFIG} 0 ${output} output) string(SUBSTRING ${HAL_DRIVER_CONFIG} 0 ${output} output)
set (ENV{HAL_DRIVER_CONFIG} ${output}) set (HAL_DRIVER_CONFIG ${output})
endif() endif()
project(${LIB_NAME} project(${LIB_NAME}
LANGUAGES C ASM LANGUAGES C ASM
) )
add_definitions(-DUSE_HAL_DRIVER -D$ENV{MCU} -DUSE_FULL_LL_DRIVER) add_definitions(-DUSE_HAL_DRIVER -D${MCU} -DUSE_FULL_LL_DRIVER)
file(GLOB_RECURSE SOURCES "Src/*.c") file(GLOB_RECURSE SOURCES "Src/*.c")
add_library(${LIB_NAME} STATIC ${SOURCES}) add_library(${LIB_NAME} STATIC ${SOURCES})
@@ -30,6 +30,6 @@ add_library(${LIB_NAME}_INTERFACE INTERFACE)
if (GTEST) if (GTEST)
target_include_directories(${LIB_NAME}_INTERFACE INTERFACE Inc) target_include_directories(${LIB_NAME}_INTERFACE INTERFACE Inc)
else() else()
target_include_directories(${LIB_NAME} PUBLIC Inc $ENV{HAL_DRIVER_CONFIG}) target_include_directories(${LIB_NAME} PUBLIC Inc ${HAL_DRIVER_CONFIG})
endif() endif()
target_link_libraries(${LIB_NAME} PRIVATE CMSIS) target_link_libraries(${LIB_NAME} PRIVATE CMSIS)

View File

@@ -82,11 +82,11 @@ endif()
add_link_options(-specs=nano.specs -specs=nosys.specs) add_link_options(-specs=nano.specs -specs=nosys.specs)
add_executable(${PROJECT_NAME}.elf ${SOURCES}) add_executable(${PROJECT_NAME}.elf ${SOURCES})
target_compile_options(${PROJECT_NAME}.elf PUBLIC $ENV{COMPILE_OPTIONS}) target_compile_options(${PROJECT_NAME}.elf PUBLIC ${COMPILE_OPTIONS})
target_link_options(${PROJECT_NAME}.elf PUBLIC $ENV{LINK_OPTIONS}) target_link_options(${PROJECT_NAME}.elf PUBLIC ${LINK_OPTIONS})
target_include_directories(${PROJECT_NAME}.elf PUBLIC ${INCLUDE_DIR}) target_include_directories(${PROJECT_NAME}.elf PUBLIC ${INCLUDE_DIR})
target_link_libraries(${PROJECT_NAME}.elf PUBLIC $ENV{MCU_SERIES}_HAL_DRIVER CMSIS ) target_link_libraries(${PROJECT_NAME}.elf PUBLIC ${MCU_SERIES}_HAL_DRIVER CMSIS )
target_compile_definitions(${PROJECT_NAME}.elf PUBLIC $ENV{COMPILE_DEF}) target_compile_definitions(${PROJECT_NAME}.elf PUBLIC ${COMPILE_DEF})
set(HEX_FILE ${PROJECT_BINARY_DIR}/${PROJECT_NAME}.hex) set(HEX_FILE ${PROJECT_BINARY_DIR}/${PROJECT_NAME}.hex)
set(BIN_FILE ${PROJECT_BINARY_DIR}/${PROJECT_NAME}.bin) set(BIN_FILE ${PROJECT_BINARY_DIR}/${PROJECT_NAME}.bin)
if ("${CMAKE_BUILD_TYPE}" STREQUAL "Debug") if ("${CMAKE_BUILD_TYPE}" STREQUAL "Debug")