blob: cd5fc5e09dc078997ecb957a477b110f06ff70c6 [file] [log] [blame]
yang.lid6fe6242022-01-13 14:44:24 +08001# Copyright (c) 2021-2022 Amlogic, Inc. All rights reserved.
2
3# SPDX-License-Identifier: MIT
4
bin.chen1a426d32021-10-13 10:52:36 +08005cmake_minimum_required(VERSION 3.13.1)
6
7set(SDK_BASE $ENV{SDK_BASE})
8set(ARCH $ENV{ARCH})
shijie.xiongf00d0fe2024-01-11 17:18:58 +08009set(SPLIT_ARCH_DIR $ENV{SPLIT_ARCH_DIR})
bin.chen1a426d32021-10-13 10:52:36 +080010set(ARCH_DIR ${SDK_BASE}/arch/${ARCH})
Kelvin Zhangcd7e7972021-12-15 18:55:50 +080011set(SOC $ENV{SOC})
bin.chen1a426d32021-10-13 10:52:36 +080012set(BOARD $ENV{BOARD})
bin.chen1a426d32021-10-13 10:52:36 +080013set(CROSS_COMPILER $ENV{CROSS_COMPILER})
14set(KERNEL $ENV{KERNEL})
15set(PRODUCT $ENV{PRODUCT})
16
shijie.xiongf00d0fe2024-01-11 17:18:58 +080017if(NOT SPLIT_ARCH_DIR)
18 set(SOC_DIR ${SDK_BASE}/soc/${ARCH}/${SOC})
19 set(BOARD_DIR ${SDK_BASE}/boards/${ARCH}/${BOARD})
20else()
21 set(SOC_DIR ${SDK_BASE}/soc/${ARCH}/${SPLIT_ARCH_DIR}/${SOC})
22 set(BOARD_DIR ${SDK_BASE}/boards/${ARCH}/${SPLIT_ARCH_DIR}/${BOARD})
23endif()
24
bin.chen1a426d32021-10-13 10:52:36 +080025set(SDK_OUT ${CMAKE_BINARY_DIR})
26set(PROJECT_BINARY_DIR ${CMAKE_BINARY_DIR})
27set(PROJECT_SOURCE_DIR ${SDK_BASE})
28set(APPLICATION_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR})
xiaohu.huang50acd142022-05-16 13:52:56 +080029set(COLLECT_LINK_LIBRARIES "" CACHE INTERNAL "")
30set(COLLECT_LINK_OBJS "" CACHE INTERNAL "")
xiaohu.huang0c43a622022-11-15 17:48:56 +080031set(COLLECT_IS_CPP_LIBRARIES "0" CACHE INTERNAL "")
bin.chen1a426d32021-10-13 10:52:36 +080032
33set(CMAKE_EXECUTABLE_SUFFIX ".elf")
34
35if(EXISTS ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080036 set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf)
bin.chen1a426d32021-10-13 10:52:36 +080037elseif(EXISTS ${APPLICATION_SOURCE_DIR}/prj.conf)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080038 set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj.conf)
bin.chen1a426d32021-10-13 10:52:36 +080039endif()
40
bin.chen1a426d32021-10-13 10:52:36 +080041message(STATUS "CMAKE_SOURCE_DIR: ${CMAKE_SOURCE_DIR}")
42message(STATUS "CMAKE_BINARY_DIR: ${CMAKE_BINARY_DIR}")
43
bin.chen1a426d32021-10-13 10:52:36 +080044if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080045 if(NOT "${ARCH}" STREQUAL "xtensa")
46 add_compile_options(-fdiagnostics-color=always)
47 endif()
bin.chen1a426d32021-10-13 10:52:36 +080048elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
49 add_compile_options(-fcolor-diagnostics)
50endif()
51
kelvin.zhang80b62d72022-01-14 22:11:37 +080052include(${SDK_BASE}/build_system/cmake/extensions.cmake)
53include(${SDK_BASE}/build_system/cmake/python.cmake)
54include(${SDK_BASE}/build_system/cmake/kconfig.cmake)
xiaohu.huanga1268fd2022-06-07 11:10:48 +080055include(${SDK_BASE}/build_system/cmake/toolchains/${ARCH}_compiler.cmake)
bin.chen1a426d32021-10-13 10:52:36 +080056
57set(TARGET_NAME $ENV{KERNEL})
58
59# Do not prefix the output library file.
60set(CMAKE_STATIC_LIBRARY_PREFIX "")
61
Kelvin Zhang45e6c882022-03-21 16:37:54 +080062set(CMAKE_C_FLAGS "-imacros${AUTOCONF_H}")
63set(CMAKE_CXX_FLAGS "-imacros${AUTOCONF_H}")
64set(CMAKE_ASM_FLAGS "-imacros${AUTOCONF_H}")
65
Xiaohu.Huang7fef2b02021-12-21 14:26:38 +080066if(EXISTS ${ARCH_DIR}/compiler_options.cmake)
67 include(${ARCH_DIR}/compiler_options.cmake)
68endif()
69if(EXISTS ${SOC_DIR}/compiler_options.cmake)
70 include(${SOC_DIR}/compiler_options.cmake)
71endif()
72if(EXISTS ${BOARD_DIR}/compiler_options.cmake)
73 include(${BOARD_DIR}/compiler_options.cmake)
74endif()
bin.chen1a426d32021-10-13 10:52:36 +080075
76message(STATUS TARGET_NAME: ${TARGET_NAME})
bin.chen1a426d32021-10-13 10:52:36 +080077add_executable(${TARGET_NAME})
78add_subdirectory(${SDK_BASE} ${SDK_OUT}/obj)
79
80# Linker flags
81target_link_options(
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080082 ${TARGET_NAME}
83 PUBLIC ${common_flags} ${linker_flags}
bin.chen1a426d32021-10-13 10:52:36 +080084)
85
xiaohu.huang929bf972022-12-19 14:38:39 +080086if($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()
96elseif($ENV{COMPILER} STREQUAL "xcc")
xiaohu.huang0c43a622022-11-15 17:48:56 +080097 set(SYSTEM_LIBS m gcc)
xiaohu.huang50acd142022-05-16 13:52:56 +080098else()
xiaohu.huang929bf972022-12-19 14:38:39 +080099 #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.huang50acd142022-05-16 13:52:56 +0800109endif()
110
xiaohu.huang0c43a622022-11-15 17:48:56 +0800111if("${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)
114endif()
115
xiaohu.huang929bf972022-12-19 14:38:39 +0800116if(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.huangb7758f32022-05-27 17:16:10 +0800119 -u__wrap__getpid_r -u__wrap__kill_r -u_isatty -u_fstat)
120endif()
121
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +0800122if(CONFIG_XTENSA)
xiaohu.huangb7758f32022-05-27 17:16:10 +0800123#arch XTENSA not support LTO option
bangzheng.liua1c7da42023-09-26 15:24:50 +0800124 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.huangb7758f32022-05-27 17:16:10 +0800125 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.chen1a426d32021-10-13 10:52:36 +0800133)
Kelvin Zhang0faff272022-03-02 11:30:20 +0800134elseif(CONFIG_ARM64 OR CONFIG_ARM)
fugui.zhang85dbbfe2023-09-27 10:50:52 +0800135 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.huang50acd142022-05-16 13:52:56 +0800141 target_link_libraries(
142 ${TARGET_NAME}
143 -Wl,--start-group
xiaohu.huangb7758f32022-05-27 17:16:10 +0800144 ${LTO_SYMBOL_WRAP}
xiaohu.huang50acd142022-05-16 13:52:56 +0800145 ${COLLECT_LINK_OBJS}
146 ${SYSTEM_LIBS} ${COLLECT_LINK_LIBRARIES}
147 -Wl,--end-group
148 -T"${BOARD_DIR}/lscript.ld"
149 )
bin.chena99fbfc2021-12-17 11:09:59 +0800150elseif(CONFIG_RISCV)
shijie.xiongb306ff02023-09-21 15:24:04 +0800151add_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.huang50acd142022-05-16 13:52:56 +0800152 target_link_libraries(
153 ${TARGET_NAME}
154 -Wl,--start-group
xiaohu.huangb7758f32022-05-27 17:16:10 +0800155 ${LTO_SYMBOL_WRAP}
xiaohu.huang50acd142022-05-16 13:52:56 +0800156 ${COLLECT_LINK_OBJS}
157 ${SYSTEM_LIBS} ${COLLECT_LINK_LIBRARIES}
158 -Wl,--end-group
shijie.xiongb306ff02023-09-21 15:24:04 +0800159 -T"${BOARD_DIR}/lscript"
xiaohu.huang50acd142022-05-16 13:52:56 +0800160 )
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +0800161endif()
bin.chen1a426d32021-10-13 10:52:36 +0800162
163#Generate binary file from elf
164compiler_generate_binary_output(${TARGET_NAME})
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +0800165
bin.chen1a426d32021-10-13 10:52:36 +0800166#Generate lst file from lst
xiaohu.huang929bf972022-12-19 14:38:39 +0800167if($ENV{COMPILER} STREQUAL "clang+llvm")
168 compiler_generate_lst_output(${TARGET_NAME} -D)
169elseif($ENV{COMPILER} STREQUAL "xcc")
170 compiler_generate_lst_output(${TARGET_NAME} -D)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +0800171else()
xiaohu.huang929bf972022-12-19 14:38:39 +0800172 #compiler gcc
173 compiler_generate_lst_output(${TARGET_NAME} -S)
xiaohu.huang2061cc52022-12-05 10:12:32 +0800174endif()
xiaohu.huang8619de92022-11-01 18:02:58 +0800175
176#Generate module memory size information
177generate_module_info_output(${TARGET_NAME})