168 lines
7.4 KiB
CMake
168 lines
7.4 KiB
CMake
cmake_minimum_required(VERSION 3.10)
|
|
|
|
project(pangu_m4_template)
|
|
|
|
enable_language(CXX)
|
|
enable_language(ASM)
|
|
|
|
# Different linker scripts
|
|
set(TARGET_LDSCRIPT "${CMAKE_SOURCE_DIR}/GCC/stm32mp15xx_m4.ld")
|
|
|
|
set(TARGET_SOURCES
|
|
"GCC/startup_stm32mp15xx.s"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_adc.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_adc_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_cec.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_cortex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_crc.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_crc_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_cryp.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_cryp_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_dac.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_dac_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_dcmi.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_dfsdm.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_dfsdm_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_dma.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_dma_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_exti.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_fdcan.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_gpio.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_hash.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_hash_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_hsem.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_i2c.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_i2c_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_ipcc.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_lptim.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_mdios.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_mdma.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_pwr.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_pwr_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_qspi.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_rcc.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_rcc_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_rng.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_rtc.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_rtc_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_sai.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_sai_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_sd.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_sd_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_smartcard.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_smartcard_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_smbus.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_smbus_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_spdifrx.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_spi.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_spi_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_sram.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_tim.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_tim_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_uart.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_uart_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_usart.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_usart_ex.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_hal_wwdg.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_adc.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_delayblock.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_dma.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_exti.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_fmc.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_gpio.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_i2c.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_lptim.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_pwr.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_rcc.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_rtc.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_sdmmc.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_spi.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_tim.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_usart.c"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Src/stm32mp1xx_ll_utils.c"
|
|
"board/board.c"
|
|
"board/clock_config.c"
|
|
"board/peripherals.c"
|
|
"board/pin_mux.c"
|
|
"board/stm32mp1xx_it.c"
|
|
"board/system_stm32mp1xx.c"
|
|
"src/main.c"
|
|
"src/syscalls.c"
|
|
)
|
|
|
|
set(TARGET_C_DEFINES
|
|
"CORE_CM4"
|
|
"STM32MP157Axx"
|
|
"USE_HAL_DRIVER"
|
|
)
|
|
|
|
set(TARGET_C_INCLUDES
|
|
"SDK/Drivers/CMSIS/Core/Include"
|
|
"SDK/Drivers/CMSIS/Device/ST/STM32MP1xx/Include"
|
|
"SDK/Drivers/STM32MP1xx_HAL_Driver/Inc"
|
|
"board"
|
|
"include"
|
|
)
|
|
|
|
# Shared libraries linked with application
|
|
set(TARGET_LIBS
|
|
"c"
|
|
"m"
|
|
"nosys"
|
|
)
|
|
|
|
# Shared library and linker script search paths
|
|
set(TARGET_LIB_DIRECTORIES
|
|
|
|
)
|
|
|
|
# Conditional flags
|
|
# DEBUG
|
|
set(CMAKE_C_FLAGS_DEBUG "-DDEBUG -O0 -g")
|
|
set(CMAKE_CXX_FLAGS_DEBUG "-DDEBUG -O0 -g")
|
|
set(CMAKE_ASM_FLAGS_DEBUG "-DDEBUG -O0 -g")
|
|
|
|
# RELEASE
|
|
set(CMAKE_C_FLAGS_RELEASE "-DNDEBUG -O2")
|
|
set(CMAKE_CXX_FLAGS_RELEASE "-DNDEBUG -O2")
|
|
set(CMAKE_ASM_FLAGS_RELEASE "-DNDEBUG -O2")
|
|
set(CMAKE_EXE_LINKER_FLAGS_RELEASE "")
|
|
|
|
# Final compiler flags
|
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -fno-common -fno-builtin -ffreestanding -fdata-sections -ffunction-sections")
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -fno-common -fno-builtin -ffreestanding -fdata-sections -ffunction-sections")
|
|
set(CMAKE_ASM_FLAGS "${CMAKE_C_FLAGS} -x assembler-with-cpp")
|
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,--gc-sections")
|
|
|
|
# Shared sources, includes and definitions
|
|
add_compile_definitions(${TARGET_C_DEFINES})
|
|
include_directories(${TARGET_C_INCLUDES})
|
|
link_directories(${TARGET_LIB_DIRECTORIES})
|
|
link_libraries(${TARGET_LIBS})
|
|
|
|
# Main targets are added here
|
|
|
|
# Create ELF
|
|
add_executable("${CMAKE_PROJECT_NAME}.elf" ${TARGET_SOURCES})
|
|
target_compile_definitions("${CMAKE_PROJECT_NAME}.elf"
|
|
PRIVATE ${TARGET_C_DEFINES_XIP}
|
|
)
|
|
target_link_options("${CMAKE_PROJECT_NAME}.elf"
|
|
PRIVATE "-T${TARGET_LDSCRIPT}"
|
|
PRIVATE "-Wl,--Map=${CMAKE_PROJECT_NAME}.map"
|
|
)
|
|
set_property(TARGET "${CMAKE_PROJECT_NAME}.elf" APPEND
|
|
PROPERTY ADDITIONAL_CLEAN_FILES "${CMAKE_PROJECT_NAME}.map"
|
|
)
|
|
add_custom_command(OUTPUT "${CMAKE_PROJECT_NAME}.hex"
|
|
COMMAND ${CMAKE_OBJCOPY} "-O" "ihex" "${CMAKE_PROJECT_NAME}.elf" "${CMAKE_PROJECT_NAME}.hex"
|
|
DEPENDS "${CMAKE_PROJECT_NAME}.elf"
|
|
)
|
|
add_custom_target("${CMAKE_PROJECT_NAME}_HEX" DEPENDS "${CMAKE_PROJECT_NAME}.hex")
|
|
if(DEFINED TARGET_TOOLCHAIN_SIZE)
|
|
add_custom_command(TARGET "${CMAKE_PROJECT_NAME}.elf" POST_BUILD
|
|
COMMAND ${TARGET_TOOLCHAIN_SIZE} "${CMAKE_PROJECT_NAME}.elf"
|
|
)
|
|
endif()
|