blob: e4f4b9457466857fda66130eda5db4335f79065b [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
shijie.xiong377f17a2024-07-26 15:02:36 +08005set(SPLIT_ARCH_DIR $ENV{SPLIT_ARCH_DIR})
6if(NOT SPLIT_ARCH_DIR)
7 set(SOC_DIR $ENV{SDK_BASE}/soc/$ENV{ARCH}/$ENV{SOC})
8else()
9 set(SOC_DIR $ENV{SDK_BASE}/soc/$ENV{ARCH}/${SPLIT_ARCH_DIR}/$ENV{SOC})
10endif()
11
12if(EXISTS ${SOC_DIR}/toolchain_path.cmake)
13 include(${SOC_DIR}/toolchain_path.cmake)
shijie.xiong13204eb2024-08-08 10:54:48 +080014 # This information is provided by U-Boot and includes the toolchain internally.
15 get_filename_component(PREBUILD_DIR $ENV{SDK_BASE} DIRECTORY)
16 get_filename_component(PREBUILD_DIR ${PREBUILD_DIR} DIRECTORY)
17 if(EXISTS ${PREBUILD_DIR}/prebuild/riscv-none-gcc AND IS_DIRECTORY ${PREBUILD_DIR}/prebuild/riscv-none-gcc)
18 get_filename_component(LAST_COMPONENT $ENV{TOOLCHAIN_PATH} NAME)
19 set(ENV{TOOLCHAIN_PATH} ${PREBUILD_DIR}/prebuild/riscv-none-gcc/${LAST_COMPONENT})
20 endif()
shijie.xiong377f17a2024-07-26 15:02:36 +080021endif()
22
bin.chen1a426d32021-10-13 10:52:36 +080023include("${CMAKE_CURRENT_LIST_DIR}/find_compiler.cmake")
24
25set(CMAKE_SYSTEM_NAME Generic)
26
27# Find GCC for RISCV.
28aml_find_compiler(COMPILER_CC riscv-none-embed-gcc)
29aml_find_compiler(COMPILER_CXX riscv-none-embed-g++)
30set(COMPILER_ASM "${COMPILER_CC}" CACHE INTERNAL "")
31aml_find_compiler(COMPILER_OBJCOPY riscv-none-embed-objcopy)
32aml_find_compiler(COMPILER_OBJDUMP riscv-none-embed-objdump)
33
xiaohu.huanga1268fd2022-06-07 11:10:48 +080034# Specify the cross compiler.
bin.chen1a426d32021-10-13 10:52:36 +080035set(CMAKE_C_COMPILER ${COMPILER_CC} CACHE FILEPATH "C compiler")
36set(CMAKE_CXX_COMPILER ${COMPILER_CXX} CACHE FILEPATH "C++ compiler")
37set(CMAKE_ASM_COMPILER ${COMPILER_ASM} CACHE FILEPATH "ASM compiler")
38#set(CMAKE_C_LINK_EXECUTABLE ${COMPILER_LD} CACHE FILEPATH "LD linker")
39set(CMAKE_OBJCOPY_COMPILER ${COMPILER_OBJCOPY} CACHE FILEPATH "objcopy compiler")
40set(CMAKE_OBJDUMP_COMPILER ${COMPILER_OBJDUMP} CACHE FILEPATH "objdump compiler")
41# Disable compiler checks.
42set(CMAKE_C_COMPILER_FORCED TRUE)
43set(CMAKE_CXX_COMPILER_FORCED TRUE)
44
45# Add target system root to cmake find path.
46get_filename_component(COMPILER_DIR "${COMPILER_CC}" DIRECTORY)
47get_filename_component(CMAKE_FIND_ROOT_PATH "${COMPILER_DIR}" DIRECTORY)
48
49# Look for includes and libraries only in the target system prefix.
50#set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)
51#set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)
52
53# Helper variables to abstracts some common compiler flags.
54set(COMPILER_NO_WARNINGS "-w" CACHE INTERNAL "")