blob: 9fb832f837ed48ef7c32307e3b1459325f203ad0 [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})
Kelvin Zhangcd7e7972021-12-15 18:55:50 +08009set(SOC $ENV{SOC})
bin.chen1a426d32021-10-13 10:52:36 +080010set(BOARD $ENV{BOARD})
bin.chen1a426d32021-10-13 10:52:36 +080011set(CROSS_COMPILER $ENV{CROSS_COMPILER})
12set(KERNEL $ENV{KERNEL})
13set(PRODUCT $ENV{PRODUCT})
xiaohu.huang480b7142024-07-04 14:32:22 +080014set(COMPILER $ENV{COMPILER})
bin.chen1a426d32021-10-13 10:52:36 +080015
xiaohu.huang480b7142024-07-04 14:32:22 +080016set(SPLIT_ARCH_DIR $ENV{SPLIT_ARCH_DIR})
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()
bin.chen1a426d32021-10-13 10:52:36 +080024set(SDK_OUT ${CMAKE_BINARY_DIR})
25set(PROJECT_BINARY_DIR ${CMAKE_BINARY_DIR})
26set(PROJECT_SOURCE_DIR ${SDK_BASE})
27set(APPLICATION_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR})
xiaohu.huang480b7142024-07-04 14:32:22 +080028set(ARCH_DIR ${SDK_BASE}/arch/${ARCH})
29set(CMAKE_TOOLCAHIN_DIR ${SDK_BASE}/build_system/cmake/toolchains)
30
xiaohu.huang50acd142022-05-16 13:52:56 +080031set(COLLECT_LINK_LIBRARIES "" CACHE INTERNAL "")
32set(COLLECT_LINK_OBJS "" CACHE INTERNAL "")
xiaohu.huang0c43a622022-11-15 17:48:56 +080033set(COLLECT_IS_CPP_LIBRARIES "0" CACHE INTERNAL "")
bin.chen1a426d32021-10-13 10:52:36 +080034
35set(CMAKE_EXECUTABLE_SUFFIX ".elf")
36
37if(EXISTS ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080038 set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf)
bin.chen1a426d32021-10-13 10:52:36 +080039elseif(EXISTS ${APPLICATION_SOURCE_DIR}/prj.conf)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080040 set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj.conf)
bin.chen1a426d32021-10-13 10:52:36 +080041endif()
42
bin.chen1a426d32021-10-13 10:52:36 +080043message(STATUS "CMAKE_SOURCE_DIR: ${CMAKE_SOURCE_DIR}")
44message(STATUS "CMAKE_BINARY_DIR: ${CMAKE_BINARY_DIR}")
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)
bin.chen1a426d32021-10-13 10:52:36 +080049
50set(TARGET_NAME $ENV{KERNEL})
51
52# Do not prefix the output library file.
53set(CMAKE_STATIC_LIBRARY_PREFIX "")
54
Kelvin Zhang45e6c882022-03-21 16:37:54 +080055set(CMAKE_C_FLAGS "-imacros${AUTOCONF_H}")
56set(CMAKE_CXX_FLAGS "-imacros${AUTOCONF_H}")
57set(CMAKE_ASM_FLAGS "-imacros${AUTOCONF_H}")
58
Xiaohu.Huang7fef2b02021-12-21 14:26:38 +080059if(EXISTS ${ARCH_DIR}/compiler_options.cmake)
60 include(${ARCH_DIR}/compiler_options.cmake)
61endif()
62if(EXISTS ${SOC_DIR}/compiler_options.cmake)
63 include(${SOC_DIR}/compiler_options.cmake)
64endif()
65if(EXISTS ${BOARD_DIR}/compiler_options.cmake)
66 include(${BOARD_DIR}/compiler_options.cmake)
67endif()
bin.chen1a426d32021-10-13 10:52:36 +080068
xiaohu.huang480b7142024-07-04 14:32:22 +080069# The compile options which are differ with toolchain should in ${ARCH}_compiler_compile_options.cmake.
70if(EXISTS ${CMAKE_TOOLCAHIN_DIR}/${ARCH}_compiler_compile_options.cmake)
71 include(${CMAKE_TOOLCAHIN_DIR}/${ARCH}_compiler_compile_options.cmake)
72endif()
73
bin.chen1a426d32021-10-13 10:52:36 +080074message(STATUS TARGET_NAME: ${TARGET_NAME})
bin.chen1a426d32021-10-13 10:52:36 +080075add_executable(${TARGET_NAME})
76add_subdirectory(${SDK_BASE} ${SDK_OUT}/obj)
77
xiaohu.huang480b7142024-07-04 14:32:22 +080078# The link options which are differ with toolchain should in ${ARCH}_compiler_link_options.cmake.
79include(${CMAKE_TOOLCAHIN_DIR}/${ARCH}_compiler_link_options.cmake)
80
bin.chen1a426d32021-10-13 10:52:36 +080081# Linker flags
82target_link_options(
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080083 ${TARGET_NAME}
84 PUBLIC ${common_flags} ${linker_flags}
bin.chen1a426d32021-10-13 10:52:36 +080085)
86
bin.chen1a426d32021-10-13 10:52:36 +080087#Generate binary file from elf
88compiler_generate_binary_output(${TARGET_NAME})
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080089
xiaohu.huang616e6992024-06-26 15:45:49 +080090#Generate disassembly file from elf
91compiler_generate_lst_output(${TARGET_NAME})
xiaohu.huang8619de92022-11-01 18:02:58 +080092
93#Generate module memory size information
xiaohu.huang480b7142024-07-04 14:32:22 +080094generate_module_info_output(${TARGET_NAME})