PanGu_MP157A_Template/CMakeLists.txt

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()