blob: dd1cc5d1f64a8b7231998d76e8c040a4929d2dc9 [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})
22
23set(CMAKE_EXECUTABLE_SUFFIX ".elf")
24
25if(EXISTS ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080026 set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf)
bin.chen1a426d32021-10-13 10:52:36 +080027elseif(EXISTS ${APPLICATION_SOURCE_DIR}/prj.conf)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080028 set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj.conf)
bin.chen1a426d32021-10-13 10:52:36 +080029endif()
30
31set(UNSC_TOOLCHAIN_PATH $ENV{PATH} CACHE INTERNAL "")
32message(STATUS "CMAKE_SOURCE_DIR: ${CMAKE_SOURCE_DIR}")
33message(STATUS "CMAKE_BINARY_DIR: ${CMAKE_BINARY_DIR}")
34
bin.chen1a426d32021-10-13 10:52:36 +080035if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080036 if(NOT "${ARCH}" STREQUAL "xtensa")
37 add_compile_options(-fdiagnostics-color=always)
38 endif()
bin.chen1a426d32021-10-13 10:52:36 +080039elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
40 add_compile_options(-fcolor-diagnostics)
41endif()
42
kelvin.zhang80b62d72022-01-14 22:11:37 +080043include(${SDK_BASE}/build_system/cmake/extensions.cmake)
44include(${SDK_BASE}/build_system/cmake/python.cmake)
45include(${SDK_BASE}/build_system/cmake/kconfig.cmake)
bin.chen1a426d32021-10-13 10:52:36 +080046
47set(TARGET_NAME $ENV{KERNEL})
48
49# Do not prefix the output library file.
50set(CMAKE_STATIC_LIBRARY_PREFIX "")
51
Xiaohu.Huang7fef2b02021-12-21 14:26:38 +080052if(EXISTS ${ARCH_DIR}/compiler_options.cmake)
53 include(${ARCH_DIR}/compiler_options.cmake)
54endif()
55if(EXISTS ${SOC_DIR}/compiler_options.cmake)
56 include(${SOC_DIR}/compiler_options.cmake)
57endif()
58if(EXISTS ${BOARD_DIR}/compiler_options.cmake)
59 include(${BOARD_DIR}/compiler_options.cmake)
60endif()
bin.chen1a426d32021-10-13 10:52:36 +080061
62message(STATUS TARGET_NAME: ${TARGET_NAME})
63
64add_executable(${TARGET_NAME})
65add_subdirectory(${SDK_BASE} ${SDK_OUT}/obj)
66
67# Linker flags
68target_link_options(
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080069 ${TARGET_NAME}
70 PUBLIC ${common_flags} ${linker_flags}
bin.chen1a426d32021-10-13 10:52:36 +080071)
72
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080073if(CONFIG_XTENSA)
Xiaohu.Huanga4ed60c2021-12-16 15:13:23 +080074add_custom_command(TARGET ${TARGET_NAME} PRE_BUILD COMMAND ${CMAKE_LDGEN_COMPILER} -b ${BOARD_DIR}/lsp_dsp/ >/dev/null)
75
bin.chen1a426d32021-10-13 10:52:36 +080076target_link_libraries(
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080077 ${TARGET_NAME}
78 -mlsp="${BOARD_DIR}/lsp_dsp/"
79 -lgcc
bin.chen1a426d32021-10-13 10:52:36 +080080)
Kelvin Zhang0faff272022-03-02 11:30:20 +080081elseif(CONFIG_ARM64 OR CONFIG_ARM)
bin.chen06084dd2022-01-14 10:24:52 +080082add_custom_command(TARGET ${TARGET_NAME} PRE_BUILD COMMAND ${COMPILER_CC} -I ${BOARD_DIR} -I ${ARCH_DIR} -DCONFIG_EXCEPTION_SVC=1 -E -xc -P ${SDK_BASE}/boards/${ARCH}/lscript > ${BOARD_DIR}/lscript.ld)
bin.chena99fbfc2021-12-17 11:09:59 +080083
84target_link_libraries(
85 ${TARGET_NAME}
86 -T"${BOARD_DIR}/lscript.ld"
87 -lgcc
88)
89elseif(CONFIG_RISCV)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080090target_link_libraries(
91 ${TARGET_NAME}
92 -T"${BOARD_DIR}/lscript.ld"
93 -lgcc
94)
95endif()
bin.chen1a426d32021-10-13 10:52:36 +080096
97#Generate binary file from elf
98compiler_generate_binary_output(${TARGET_NAME})
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080099
bin.chen1a426d32021-10-13 10:52:36 +0800100#Generate lst file from lst
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +0800101if(CONFIG_XTENSA)
102compiler_generate_lst_output(${TARGET_NAME} -D)
103else()
104compiler_generate_lst_output(${TARGET_NAME} -S)
105endif()