blob: ba9f73b21e1730e2b4b1a490f5399755b12fe529 [file] [log] [blame]
bin.chen1a426d32021-10-13 10:52:36 +08001cmake_minimum_required(VERSION 3.13.1)
2
3set(SDK_BASE $ENV{SDK_BASE})
4set(ARCH $ENV{ARCH})
5set(ARCH_DIR ${SDK_BASE}/arch/${ARCH})
Kelvin Zhangcd7e7972021-12-15 18:55:50 +08006set(SOC $ENV{SOC})
7set(SOC_DIR ${SDK_BASE}/soc/${ARCH}/${SOC})
bin.chen1a426d32021-10-13 10:52:36 +08008set(BOARD $ENV{BOARD})
9set(BOARD_DIR ${SDK_BASE}/boards/${ARCH}/${BOARD})
10set(CROSS_COMPILER $ENV{CROSS_COMPILER})
11set(KERNEL $ENV{KERNEL})
12set(PRODUCT $ENV{PRODUCT})
13
14set(SDK_OUT ${CMAKE_BINARY_DIR})
15set(PROJECT_BINARY_DIR ${CMAKE_BINARY_DIR})
16set(PROJECT_SOURCE_DIR ${SDK_BASE})
17set(APPLICATION_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR})
18
19set(CMAKE_EXECUTABLE_SUFFIX ".elf")
20
21if(EXISTS ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080022 set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf)
bin.chen1a426d32021-10-13 10:52:36 +080023elseif(EXISTS ${APPLICATION_SOURCE_DIR}/prj.conf)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080024 set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj.conf)
bin.chen1a426d32021-10-13 10:52:36 +080025endif()
26
27set(UNSC_TOOLCHAIN_PATH $ENV{PATH} CACHE INTERNAL "")
28message(STATUS "CMAKE_SOURCE_DIR: ${CMAKE_SOURCE_DIR}")
29message(STATUS "CMAKE_BINARY_DIR: ${CMAKE_BINARY_DIR}")
30
bin.chen1a426d32021-10-13 10:52:36 +080031if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080032 if(NOT "${ARCH}" STREQUAL "xtensa")
33 add_compile_options(-fdiagnostics-color=always)
34 endif()
bin.chen1a426d32021-10-13 10:52:36 +080035elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
36 add_compile_options(-fcolor-diagnostics)
37endif()
38
39include(${SDK_BASE}/build/cmake/extensions.cmake)
40include(${SDK_BASE}/build/cmake/python.cmake)
bin.chen1a426d32021-10-13 10:52:36 +080041include(${SDK_BASE}/build/cmake/kconfig.cmake)
42
43set(TARGET_NAME $ENV{KERNEL})
44
45# Do not prefix the output library file.
46set(CMAKE_STATIC_LIBRARY_PREFIX "")
47
Xiaohu.Huang7fef2b02021-12-21 14:26:38 +080048if(EXISTS ${ARCH_DIR}/compiler_options.cmake)
49 include(${ARCH_DIR}/compiler_options.cmake)
50endif()
51if(EXISTS ${SOC_DIR}/compiler_options.cmake)
52 include(${SOC_DIR}/compiler_options.cmake)
53endif()
54if(EXISTS ${BOARD_DIR}/compiler_options.cmake)
55 include(${BOARD_DIR}/compiler_options.cmake)
56endif()
bin.chen1a426d32021-10-13 10:52:36 +080057
58message(STATUS TARGET_NAME: ${TARGET_NAME})
59
60add_executable(${TARGET_NAME})
61add_subdirectory(${SDK_BASE} ${SDK_OUT}/obj)
62
63# Linker flags
64target_link_options(
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080065 ${TARGET_NAME}
66 PUBLIC ${common_flags} ${linker_flags}
bin.chen1a426d32021-10-13 10:52:36 +080067)
68
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080069if(CONFIG_XTENSA)
Xiaohu.Huanga4ed60c2021-12-16 15:13:23 +080070add_custom_command(TARGET ${TARGET_NAME} PRE_BUILD COMMAND ${CMAKE_LDGEN_COMPILER} -b ${BOARD_DIR}/lsp_dsp/ >/dev/null)
71
bin.chen1a426d32021-10-13 10:52:36 +080072target_link_libraries(
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080073 ${TARGET_NAME}
74 -mlsp="${BOARD_DIR}/lsp_dsp/"
75 -lgcc
bin.chen1a426d32021-10-13 10:52:36 +080076)
bin.chena99fbfc2021-12-17 11:09:59 +080077elseif(CONFIG_ARM64)
bin.chen99c339a2021-12-17 14:49:41 +080078add_custom_command(TARGET ${TARGET_NAME} PRE_BUILD COMMAND ${COMPILER_CC} -I ${BOARD_DIR} -I ${ARCH_DIR} -DGUEST=1 -E -xc -P ${SDK_BASE}/boards/${ARCH}/lscript > ${BOARD_DIR}/lscript.ld)
bin.chena99fbfc2021-12-17 11:09:59 +080079
80target_link_libraries(
81 ${TARGET_NAME}
82 -T"${BOARD_DIR}/lscript.ld"
83 -lgcc
84)
85elseif(CONFIG_RISCV)
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080086target_link_libraries(
87 ${TARGET_NAME}
88 -T"${BOARD_DIR}/lscript.ld"
89 -lgcc
90)
91endif()
bin.chen1a426d32021-10-13 10:52:36 +080092
93#Generate binary file from elf
94compiler_generate_binary_output(${TARGET_NAME})
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080095
bin.chen1a426d32021-10-13 10:52:36 +080096#Generate lst file from lst
Xiaohu.Huangc2e6cfd2021-12-13 17:08:20 +080097if(CONFIG_XTENSA)
98compiler_generate_lst_output(${TARGET_NAME} -D)
99else()
100compiler_generate_lst_output(${TARGET_NAME} -S)
101endif()