bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 1 | cmake_minimum_required(VERSION 3.13.1) |
| 2 | |
| 3 | set(SDK_BASE $ENV{SDK_BASE}) |
| 4 | set(ARCH $ENV{ARCH}) |
| 5 | set(ARCH_DIR ${SDK_BASE}/arch/${ARCH}) |
Kelvin Zhang | cd7e797 | 2021-12-15 18:55:50 +0800 | [diff] [blame] | 6 | set(SOC $ENV{SOC}) |
| 7 | set(SOC_DIR ${SDK_BASE}/soc/${ARCH}/${SOC}) |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 8 | set(BOARD $ENV{BOARD}) |
| 9 | set(BOARD_DIR ${SDK_BASE}/boards/${ARCH}/${BOARD}) |
| 10 | set(CROSS_COMPILER $ENV{CROSS_COMPILER}) |
| 11 | set(KERNEL $ENV{KERNEL}) |
| 12 | set(PRODUCT $ENV{PRODUCT}) |
| 13 | |
| 14 | set(SDK_OUT ${CMAKE_BINARY_DIR}) |
| 15 | set(PROJECT_BINARY_DIR ${CMAKE_BINARY_DIR}) |
| 16 | set(PROJECT_SOURCE_DIR ${SDK_BASE}) |
| 17 | set(APPLICATION_SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}) |
| 18 | |
| 19 | set(CMAKE_EXECUTABLE_SUFFIX ".elf") |
| 20 | |
| 21 | if(EXISTS ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf) |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 22 | set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj_${BOARD}.conf) |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 23 | elseif(EXISTS ${APPLICATION_SOURCE_DIR}/prj.conf) |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 24 | set(CONF_FILE ${APPLICATION_SOURCE_DIR}/prj.conf) |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 25 | endif() |
| 26 | |
| 27 | set(UNSC_TOOLCHAIN_PATH $ENV{PATH} CACHE INTERNAL "") |
| 28 | message(STATUS "CMAKE_SOURCE_DIR: ${CMAKE_SOURCE_DIR}") |
| 29 | message(STATUS "CMAKE_BINARY_DIR: ${CMAKE_BINARY_DIR}") |
| 30 | |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 31 | if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU") |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 32 | if(NOT "${ARCH}" STREQUAL "xtensa") |
| 33 | add_compile_options(-fdiagnostics-color=always) |
| 34 | endif() |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 35 | elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang") |
| 36 | add_compile_options(-fcolor-diagnostics) |
| 37 | endif() |
| 38 | |
| 39 | include(${SDK_BASE}/build/cmake/extensions.cmake) |
| 40 | include(${SDK_BASE}/build/cmake/python.cmake) |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 41 | include(${SDK_BASE}/build/cmake/kconfig.cmake) |
| 42 | |
| 43 | set(TARGET_NAME $ENV{KERNEL}) |
| 44 | |
| 45 | # Do not prefix the output library file. |
| 46 | set(CMAKE_STATIC_LIBRARY_PREFIX "") |
| 47 | |
| 48 | # Compiler.cmake set compiler flag. |
| 49 | include(${ARCH_DIR}/compiler.cmake) |
| 50 | |
| 51 | message(STATUS TARGET_NAME: ${TARGET_NAME}) |
| 52 | |
| 53 | add_executable(${TARGET_NAME}) |
| 54 | add_subdirectory(${SDK_BASE} ${SDK_OUT}/obj) |
| 55 | |
| 56 | # Linker flags |
| 57 | target_link_options( |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 58 | ${TARGET_NAME} |
| 59 | PUBLIC ${common_flags} ${linker_flags} |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 60 | ) |
| 61 | |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 62 | if(CONFIG_XTENSA) |
Xiaohu.Huang | a4ed60c | 2021-12-16 15:13:23 +0800 | [diff] [blame] | 63 | add_custom_command(TARGET ${TARGET_NAME} PRE_BUILD COMMAND ${CMAKE_LDGEN_COMPILER} -b ${BOARD_DIR}/lsp_dsp/ >/dev/null) |
| 64 | |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 65 | target_link_libraries( |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 66 | ${TARGET_NAME} |
| 67 | -mlsp="${BOARD_DIR}/lsp_dsp/" |
| 68 | -lgcc |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 69 | ) |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 70 | else() |
| 71 | target_link_libraries( |
| 72 | ${TARGET_NAME} |
| 73 | -T"${BOARD_DIR}/lscript.ld" |
| 74 | -lgcc |
| 75 | ) |
| 76 | endif() |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 77 | |
| 78 | #Generate binary file from elf |
| 79 | compiler_generate_binary_output(${TARGET_NAME}) |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 80 | |
bin.chen | 1a426d3 | 2021-10-13 10:52:36 +0800 | [diff] [blame] | 81 | #Generate lst file from lst |
Xiaohu.Huang | c2e6cfd | 2021-12-13 17:08:20 +0800 | [diff] [blame] | 82 | if(CONFIG_XTENSA) |
| 83 | compiler_generate_lst_output(${TARGET_NAME} -D) |
| 84 | else() |
| 85 | compiler_generate_lst_output(${TARGET_NAME} -S) |
| 86 | endif() |