blob: a2bf2c08bff96e53378b8a99742d319497f0661a [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})
9set(ARCH_DIR ${SDK_BASE}/arch/${ARCH})
Kelvin Zhangcd7e7972021-12-15 18:55:50 +080010set(SOC $ENV{SOC})
11set(SOC_DIR ${SDK_BASE}/soc/${ARCH}/${SOC})
bin.chen1a426d32021-10-13 10:52:36 +080012set(BOARD $ENV{BOARD})
13set(BOARD_DIR ${SDK_BASE}/boards/${ARCH}/${BOARD})
14set(CROSS_COMPILER $ENV{CROSS_COMPILER})
15set(KERNEL $ENV{KERNEL})
16set(PRODUCT $ENV{PRODUCT})
17
18set(SDK_OUT ${CMAKE_BINARY_DIR})
19set(PROJECT_BINARY_DIR ${CMAKE_BINARY_DIR})
20set(PROJECT_SOURCE_DIR ${SDK_BASE})
21set(APPLICATION_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR})
xiaohu.huang50acd142022-05-16 13:52:56 +080022set(COLLECT_LINK_LIBRARIES "" CACHE INTERNAL "")
23set(COLLECT_LINK_OBJS "" CACHE INTERNAL "")
xiaohu.huang0c43a622022-11-15 17:48:56 +080024set(COLLECT_IS_CPP_LIBRARIES "0" CACHE INTERNAL "")
bin.chen1a426d32021-10-13 10:52:36 +080025
26set(CMAKE_EXECUTABLE_SUFFIX ".elf")
27
28if(EXISTS ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080029 set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf)
bin.chen1a426d32021-10-13 10:52:36 +080030elseif(EXISTS ${APPLICATION_SOURCE_DIR}/prj.conf)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080031 set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj.conf)
bin.chen1a426d32021-10-13 10:52:36 +080032endif()
33
34set(UNSC_TOOLCHAIN_PATH $ENV{PATH} CACHE INTERNAL "")
35message(STATUS "CMAKE_SOURCE_DIR: ${CMAKE_SOURCE_DIR}")
36message(STATUS "CMAKE_BINARY_DIR: ${CMAKE_BINARY_DIR}")
37
bin.chen1a426d32021-10-13 10:52:36 +080038if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080039 if(NOT "${ARCH}" STREQUAL "xtensa")
40 add_compile_options(-fdiagnostics-color=always)
41 endif()
bin.chen1a426d32021-10-13 10:52:36 +080042elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
43 add_compile_options(-fcolor-diagnostics)
44endif()
45
kelvin.zhang80b62d72022-01-14 22:11:37 +080046include(${SDK_BASE}/build_system/cmake/extensions.cmake)
47include(${SDK_BASE}/build_system/cmake/python.cmake)
48include(${SDK_BASE}/build_system/cmake/kconfig.cmake)
xiaohu.huanga1268fd2022-06-07 11:10:48 +080049include(${SDK_BASE}/build_system/cmake/toolchains/${ARCH}_compiler.cmake)
bin.chen1a426d32021-10-13 10:52:36 +080050
51set(TARGET_NAME $ENV{KERNEL})
52
53# Do not prefix the output library file.
54set(CMAKE_STATIC_LIBRARY_PREFIX "")
55
Kelvin Zhang45e6c882022-03-21 16:37:54 +080056set(CMAKE_C_FLAGS "-imacros${AUTOCONF_H}")
57set(CMAKE_CXX_FLAGS "-imacros${AUTOCONF_H}")
58set(CMAKE_ASM_FLAGS "-imacros${AUTOCONF_H}")
59
Xiaohu.Huang7fef2b02021-12-21 14:26:38 +080060if(EXISTS ${ARCH_DIR}/compiler_options.cmake)
61 include(${ARCH_DIR}/compiler_options.cmake)
62endif()
63if(EXISTS ${SOC_DIR}/compiler_options.cmake)
64 include(${SOC_DIR}/compiler_options.cmake)
65endif()
66if(EXISTS ${BOARD_DIR}/compiler_options.cmake)
67 include(${BOARD_DIR}/compiler_options.cmake)
68endif()
bin.chen1a426d32021-10-13 10:52:36 +080069
70message(STATUS TARGET_NAME: ${TARGET_NAME})
bin.chen1a426d32021-10-13 10:52:36 +080071add_executable(${TARGET_NAME})
72add_subdirectory(${SDK_BASE} ${SDK_OUT}/obj)
73
74# Linker flags
75target_link_options(
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080076 ${TARGET_NAME}
77 PUBLIC ${common_flags} ${linker_flags}
bin.chen1a426d32021-10-13 10:52:36 +080078)
79
xiaohu.huang0c43a622022-11-15 17:48:56 +080080if(CONFIG_LIBC_STD AND CONFIG_LIBC_AML)
81 set(SYSTEM_LIBS m c gcc nosys)
82elseif(CONFIG_LIBC_AML)
83 set(SYSTEM_LIBS m gcc)
84elseif(CONFIG_LIBC_STD)
xiaohu.huang50acd142022-05-16 13:52:56 +080085 set(SYSTEM_LIBS m c gcc)
86else()
87 set(SYSTEM_LIBS m gcc)
88endif()
89
xiaohu.huang0c43a622022-11-15 17:48:56 +080090if("${COLLECT_IS_CPP_LIBRARIES}" STREQUAL "1")
91 message(STATUS "link c++ stand library for C++ use lib")
92 set(SYSTEM_LIBS ${SYSTEM_LIBS} stdc++ c g gcc nosys)
93endif()
94
xiaohu.huangb7758f32022-05-27 17:16:10 +080095if(CONFIG_LTO_OPTIMIZATION)
96set(LTO_SYMBOL_WRAP -u__wrap__malloc_r -u__wrap__free_r -u__wrap__realloc_r -u__wrap__calloc_r
97 -u__wrap__getpid_r -u__wrap__kill_r -u_isatty -u_fstat)
98endif()
99
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +0800100if(CONFIG_XTENSA)
xiaohu.huangb7758f32022-05-27 17:16:10 +0800101#arch XTENSA not support LTO option
102 add_custom_command(TARGET ${TARGET_NAME} PRE_BUILD COMMAND ${CMAKE_LDGEN_COMPILER} -b ${BOARD_DIR}/lsp_dsp/ >/dev/null)
103 target_link_libraries(
104 ${TARGET_NAME}
105 -Wl,--start-group
106 ${COLLECT_LINK_OBJS}
107 ${SYSTEM_LIBS} ${COLLECT_LINK_LIBRARIES}
108 -Wl,--end-group
109 -mlsp="${BOARD_DIR}/lsp_dsp/"
bin.chen1a426d32021-10-13 10:52:36 +0800110)
Kelvin Zhang0faff272022-03-02 11:30:20 +0800111elseif(CONFIG_ARM64 OR CONFIG_ARM)
xiaohu.huang091d05d2022-10-19 17:01:27 +0800112 add_custom_command(TARGET ${TARGET_NAME} PRE_BUILD COMMAND ${COMPILER_CC} -I ${BOARD_DIR} -DCONFIG_EXCEPTION_SVC=1 -E -xc -P ${SDK_BASE}/boards/${ARCH}/lscript > ${BOARD_DIR}/lscript.ld)
xiaohu.huang50acd142022-05-16 13:52:56 +0800113 target_link_libraries(
114 ${TARGET_NAME}
115 -Wl,--start-group
xiaohu.huangb7758f32022-05-27 17:16:10 +0800116 ${LTO_SYMBOL_WRAP}
xiaohu.huang50acd142022-05-16 13:52:56 +0800117 ${COLLECT_LINK_OBJS}
118 ${SYSTEM_LIBS} ${COLLECT_LINK_LIBRARIES}
119 -Wl,--end-group
120 -T"${BOARD_DIR}/lscript.ld"
121 )
bin.chena99fbfc2021-12-17 11:09:59 +0800122elseif(CONFIG_RISCV)
xiaohu.huang50acd142022-05-16 13:52:56 +0800123 target_link_libraries(
124 ${TARGET_NAME}
125 -Wl,--start-group
xiaohu.huangb7758f32022-05-27 17:16:10 +0800126 ${LTO_SYMBOL_WRAP}
xiaohu.huang50acd142022-05-16 13:52:56 +0800127 ${COLLECT_LINK_OBJS}
128 ${SYSTEM_LIBS} ${COLLECT_LINK_LIBRARIES}
129 -Wl,--end-group
130 -T"${BOARD_DIR}/lscript.ld"
131 )
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +0800132endif()
bin.chen1a426d32021-10-13 10:52:36 +0800133
134#Generate binary file from elf
135compiler_generate_binary_output(${TARGET_NAME})
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +0800136
bin.chen1a426d32021-10-13 10:52:36 +0800137#Generate lst file from lst
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +0800138if(CONFIG_XTENSA)
139compiler_generate_lst_output(${TARGET_NAME} -D)
140else()
141compiler_generate_lst_output(${TARGET_NAME} -S)
xiaohu.huang8619de92022-11-01 18:02:58 +0800142
143#Generate module memory size information
144generate_module_info_output(${TARGET_NAME})
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +0800145endif()