yang.li | d6fe624 | 2022-01-13 14:44:24 +0800 | [diff] [blame] | 1 | # Copyright (c) 2021-2022 Amlogic, Inc. All rights reserved. |
| 2 | |
| 3 | # SPDX-License-Identifier: MIT |
| 4 | |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 5 | cmake_minimum_required(VERSION 3.13.1) |
| 6 | |
| 7 | set(SDK_BASE $ENV{SDK_BASE}) |
| 8 | set(ARCH $ENV{ARCH}) |
shijie.xiong | f00d0fe | 2024-01-11 17:18:58 +0800 | [diff] [blame^] | 9 | set(SPLIT_ARCH_DIR $ENV{SPLIT_ARCH_DIR}) |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 10 | set(ARCH_DIR ${SDK_BASE}/arch/${ARCH}) |
Kelvin Zhang | cd7e797 | 2021-12-15 18:55:50 +0800 | [diff] [blame] | 11 | set(SOC $ENV{SOC}) |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 12 | set(BOARD $ENV{BOARD}) |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 13 | set(CROSS_COMPILER $ENV{CROSS_COMPILER}) |
| 14 | set(KERNEL $ENV{KERNEL}) |
| 15 | set(PRODUCT $ENV{PRODUCT}) |
| 16 | |
shijie.xiong | f00d0fe | 2024-01-11 17:18:58 +0800 | [diff] [blame^] | 17 | if(NOT SPLIT_ARCH_DIR) |
| 18 | set(SOC_DIR ${SDK_BASE}/soc/${ARCH}/${SOC}) |
| 19 | set(BOARD_DIR ${SDK_BASE}/boards/${ARCH}/${BOARD}) |
| 20 | else() |
| 21 | set(SOC_DIR ${SDK_BASE}/soc/${ARCH}/${SPLIT_ARCH_DIR}/${SOC}) |
| 22 | set(BOARD_DIR ${SDK_BASE}/boards/${ARCH}/${SPLIT_ARCH_DIR}/${BOARD}) |
| 23 | endif() |
| 24 | |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 25 | set(SDK_OUT ${CMAKE_BINARY_DIR}) |
| 26 | set(PROJECT_BINARY_DIR ${CMAKE_BINARY_DIR}) |
| 27 | set(PROJECT_SOURCE_DIR ${SDK_BASE}) |
| 28 | set(APPLICATION_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}) |
xiaohu.huang | 50acd14 | 2022-05-16 13:52:56 +0800 | [diff] [blame] | 29 | set(COLLECT_LINK_LIBRARIES "" CACHE INTERNAL "") |
| 30 | set(COLLECT_LINK_OBJS "" CACHE INTERNAL "") |
xiaohu.huang | 0c43a62 | 2022-11-15 17:48:56 +0800 | [diff] [blame] | 31 | set(COLLECT_IS_CPP_LIBRARIES "0" CACHE INTERNAL "") |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 32 | |
| 33 | set(CMAKE_EXECUTABLE_SUFFIX ".elf") |
| 34 | |
| 35 | if(EXISTS ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf) |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 36 | set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf) |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 37 | elseif(EXISTS ${APPLICATION_SOURCE_DIR}/prj.conf) |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 38 | set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj.conf) |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 39 | endif() |
| 40 | |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 41 | message(STATUS "CMAKE_SOURCE_DIR: ${CMAKE_SOURCE_DIR}") |
| 42 | message(STATUS "CMAKE_BINARY_DIR: ${CMAKE_BINARY_DIR}") |
| 43 | |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 44 | if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU") |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 45 | if(NOT "${ARCH}" STREQUAL "xtensa") |
| 46 | add_compile_options(-fdiagnostics-color=always) |
| 47 | endif() |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 48 | elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang") |
| 49 | add_compile_options(-fcolor-diagnostics) |
| 50 | endif() |
| 51 | |
kelvin.zhang | 80b62d7 | 2022-01-14 22:11:37 +0800 | [diff] [blame] | 52 | include(${SDK_BASE}/build_system/cmake/extensions.cmake) |
| 53 | include(${SDK_BASE}/build_system/cmake/python.cmake) |
| 54 | include(${SDK_BASE}/build_system/cmake/kconfig.cmake) |
xiaohu.huang | a1268fd | 2022-06-07 11:10:48 +0800 | [diff] [blame] | 55 | include(${SDK_BASE}/build_system/cmake/toolchains/${ARCH}_compiler.cmake) |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 56 | |
| 57 | set(TARGET_NAME $ENV{KERNEL}) |
| 58 | |
| 59 | # Do not prefix the output library file. |
| 60 | set(CMAKE_STATIC_LIBRARY_PREFIX "") |
| 61 | |
Kelvin Zhang | 45e6c88 | 2022-03-21 16:37:54 +0800 | [diff] [blame] | 62 | set(CMAKE_C_FLAGS "-imacros${AUTOCONF_H}") |
| 63 | set(CMAKE_CXX_FLAGS "-imacros${AUTOCONF_H}") |
| 64 | set(CMAKE_ASM_FLAGS "-imacros${AUTOCONF_H}") |
| 65 | |
Xiaohu.Huang | 7fef2b0 | 2021-12-21 14:26:38 +0800 | [diff] [blame] | 66 | if(EXISTS ${ARCH_DIR}/compiler_options.cmake) |
| 67 | include(${ARCH_DIR}/compiler_options.cmake) |
| 68 | endif() |
| 69 | if(EXISTS ${SOC_DIR}/compiler_options.cmake) |
| 70 | include(${SOC_DIR}/compiler_options.cmake) |
| 71 | endif() |
| 72 | if(EXISTS ${BOARD_DIR}/compiler_options.cmake) |
| 73 | include(${BOARD_DIR}/compiler_options.cmake) |
| 74 | endif() |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 75 | |
| 76 | message(STATUS TARGET_NAME: ${TARGET_NAME}) |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 77 | add_executable(${TARGET_NAME}) |
| 78 | add_subdirectory(${SDK_BASE} ${SDK_OUT}/obj) |
| 79 | |
| 80 | # Linker flags |
| 81 | target_link_options( |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 82 | ${TARGET_NAME} |
| 83 | PUBLIC ${common_flags} ${linker_flags} |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 84 | ) |
| 85 | |
xiaohu.huang | 929bf97 | 2022-12-19 14:38:39 +0800 | [diff] [blame] | 86 | if($ENV{COMPILER} STREQUAL "clang+llvm") |
| 87 | if(CONFIG_LIBC_STD AND CONFIG_LIBC_AML) |
| 88 | set(SYSTEM_LIBS m c nosys) |
| 89 | elseif(CONFIG_LIBC_AML) |
| 90 | set(SYSTEM_LIBS m) |
| 91 | elseif(CONFIG_LIBC_STD) |
| 92 | set(SYSTEM_LIBS m c) |
| 93 | else() |
| 94 | set(SYSTEM_LIBS m) |
| 95 | endif() |
| 96 | elseif($ENV{COMPILER} STREQUAL "xcc") |
xiaohu.huang | 0c43a62 | 2022-11-15 17:48:56 +0800 | [diff] [blame] | 97 | set(SYSTEM_LIBS m gcc) |
xiaohu.huang | 50acd14 | 2022-05-16 13:52:56 +0800 | [diff] [blame] | 98 | else() |
xiaohu.huang | 929bf97 | 2022-12-19 14:38:39 +0800 | [diff] [blame] | 99 | #compiler gcc |
| 100 | if(CONFIG_LIBC_STD AND CONFIG_LIBC_AML) |
| 101 | set(SYSTEM_LIBS m c gcc nosys) |
| 102 | elseif(CONFIG_LIBC_AML) |
| 103 | set(SYSTEM_LIBS gcc m) |
| 104 | elseif(CONFIG_LIBC_STD) |
| 105 | set(SYSTEM_LIBS m c gcc) |
| 106 | else() |
| 107 | set(SYSTEM_LIBS m gcc) |
| 108 | endif() |
xiaohu.huang | 50acd14 | 2022-05-16 13:52:56 +0800 | [diff] [blame] | 109 | endif() |
| 110 | |
xiaohu.huang | 0c43a62 | 2022-11-15 17:48:56 +0800 | [diff] [blame] | 111 | if("${COLLECT_IS_CPP_LIBRARIES}" STREQUAL "1") |
| 112 | message(STATUS "link c++ stand library for C++ use lib") |
| 113 | set(SYSTEM_LIBS ${SYSTEM_LIBS} stdc++ c g gcc nosys) |
| 114 | endif() |
| 115 | |
xiaohu.huang | 929bf97 | 2022-12-19 14:38:39 +0800 | [diff] [blame] | 116 | if(CONFIG_LTO_OPTIMIZATION AND $ENV{COMPILER} STREQUAL "gcc") |
| 117 | message(STATUS "gcc LTO optimization enabled") |
| 118 | set(LTO_SYMBOL_WRAP -u__wrap__malloc_r -u__wrap__free_r -u__wrap__realloc_r -u__wrap__calloc_r |
xiaohu.huang | b7758f3 | 2022-05-27 17:16:10 +0800 | [diff] [blame] | 119 | -u__wrap__getpid_r -u__wrap__kill_r -u_isatty -u_fstat) |
| 120 | endif() |
| 121 | |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 122 | if(CONFIG_XTENSA) |
xiaohu.huang | b7758f3 | 2022-05-27 17:16:10 +0800 | [diff] [blame] | 123 | #arch XTENSA not support LTO option |
bangzheng.liu | a1c7da4 | 2023-09-26 15:24:50 +0800 | [diff] [blame] | 124 | add_custom_command(TARGET ${TARGET_NAME} PRE_BUILD COMMAND ${CMAKE_C_COMPILER} -I ${BOARD_DIR} -E -xc -P ${BOARD_DIR}/lsp_dsp/memmap.ld > ${BOARD_DIR}/lsp_dsp/memmap.xmm) |
xiaohu.huang | b7758f3 | 2022-05-27 17:16:10 +0800 | [diff] [blame] | 125 | add_custom_command(TARGET ${TARGET_NAME} PRE_BUILD COMMAND ${CMAKE_LDGEN_COMPILER} -b ${BOARD_DIR}/lsp_dsp/ >/dev/null) |
| 126 | target_link_libraries( |
| 127 | ${TARGET_NAME} |
| 128 | -Wl,--start-group |
| 129 | ${COLLECT_LINK_OBJS} |
| 130 | ${SYSTEM_LIBS} ${COLLECT_LINK_LIBRARIES} |
| 131 | -Wl,--end-group |
| 132 | -mlsp="${BOARD_DIR}/lsp_dsp/" |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 133 | ) |
Kelvin Zhang | 0faff27 | 2022-03-02 11:30:20 +0800 | [diff] [blame] | 134 | elseif(CONFIG_ARM64 OR CONFIG_ARM) |
fugui.zhang | 85dbbfe | 2023-09-27 10:50:52 +0800 | [diff] [blame] | 135 | if(CONFIG_LIB_MCUBOOT_BOOTLOADER) |
| 136 | add_custom_command(TARGET ${TARGET_NAME} PRE_BUILD COMMAND ${CMAKE_C_COMPILER} -I ${BOARD_DIR} -DCONFIG_EXCEPTION_SVC=1 -DCONFIG_LIB_MCUBOOT_BOOTLOADER=1 -E -xc -P ${SDK_BASE}/boards/${ARCH}/lscript > ${BOARD_DIR}/lscript.ld) |
| 137 | else() |
| 138 | add_custom_command(TARGET ${TARGET_NAME} PRE_BUILD COMMAND ${CMAKE_C_COMPILER} -I ${BOARD_DIR} -DCONFIG_EXCEPTION_SVC=1 -E -xc -P ${SDK_BASE}/boards/${ARCH}/lscript > ${BOARD_DIR}/lscript.ld) |
| 139 | endif() |
| 140 | |
xiaohu.huang | 50acd14 | 2022-05-16 13:52:56 +0800 | [diff] [blame] | 141 | target_link_libraries( |
| 142 | ${TARGET_NAME} |
| 143 | -Wl,--start-group |
xiaohu.huang | b7758f3 | 2022-05-27 17:16:10 +0800 | [diff] [blame] | 144 | ${LTO_SYMBOL_WRAP} |
xiaohu.huang | 50acd14 | 2022-05-16 13:52:56 +0800 | [diff] [blame] | 145 | ${COLLECT_LINK_OBJS} |
| 146 | ${SYSTEM_LIBS} ${COLLECT_LINK_LIBRARIES} |
| 147 | -Wl,--end-group |
| 148 | -T"${BOARD_DIR}/lscript.ld" |
| 149 | ) |
bin.chen | a99fbfc | 2021-12-17 11:09:59 +0800 | [diff] [blame] | 150 | elseif(CONFIG_RISCV) |
shijie.xiong | b306ff0 | 2023-09-21 15:24:04 +0800 | [diff] [blame] | 151 | add_custom_command(TARGET ${TARGET_NAME} PRE_BUILD COMMAND ${CMAKE_C_COMPILER} -I ${BOARD_DIR} -E -xc -P ${BOARD_DIR}/lscript.ld > ${BOARD_DIR}/lscript) |
xiaohu.huang | 50acd14 | 2022-05-16 13:52:56 +0800 | [diff] [blame] | 152 | target_link_libraries( |
| 153 | ${TARGET_NAME} |
| 154 | -Wl,--start-group |
xiaohu.huang | b7758f3 | 2022-05-27 17:16:10 +0800 | [diff] [blame] | 155 | ${LTO_SYMBOL_WRAP} |
xiaohu.huang | 50acd14 | 2022-05-16 13:52:56 +0800 | [diff] [blame] | 156 | ${COLLECT_LINK_OBJS} |
| 157 | ${SYSTEM_LIBS} ${COLLECT_LINK_LIBRARIES} |
| 158 | -Wl,--end-group |
shijie.xiong | b306ff0 | 2023-09-21 15:24:04 +0800 | [diff] [blame] | 159 | -T"${BOARD_DIR}/lscript" |
xiaohu.huang | 50acd14 | 2022-05-16 13:52:56 +0800 | [diff] [blame] | 160 | ) |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 161 | endif() |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 162 | |
| 163 | #Generate binary file from elf |
| 164 | compiler_generate_binary_output(${TARGET_NAME}) |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 165 | |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 166 | #Generate lst file from lst |
xiaohu.huang | 929bf97 | 2022-12-19 14:38:39 +0800 | [diff] [blame] | 167 | if($ENV{COMPILER} STREQUAL "clang+llvm") |
| 168 | compiler_generate_lst_output(${TARGET_NAME} -D) |
| 169 | elseif($ENV{COMPILER} STREQUAL "xcc") |
| 170 | compiler_generate_lst_output(${TARGET_NAME} -D) |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 171 | else() |
xiaohu.huang | 929bf97 | 2022-12-19 14:38:39 +0800 | [diff] [blame] | 172 | #compiler gcc |
| 173 | compiler_generate_lst_output(${TARGET_NAME} -S) |
xiaohu.huang | 2061cc5 | 2022-12-05 10:12:32 +0800 | [diff] [blame] | 174 | endif() |
xiaohu.huang | 8619de9 | 2022-11-01 18:02:58 +0800 | [diff] [blame] | 175 | |
| 176 | #Generate module memory size information |
| 177 | generate_module_info_output(${TARGET_NAME}) |