2d12766e78
The oneApi support has bit rotten since it was first introduced. Update the support to function with the latest 2023.0.0 release and add a check to only support that version or newer for now. Versions before 2021.2.0 have linker script failures. Various fixes made: * In the 2023.0.0 release, various binaries are in a llvm-bin path so add support to search in that path. This replaces the python search path that much older versions needed. * newlib isn't supported with oneApi so set TOOLCHAIN_HAS_NEWLIB to OFF to match that. * 2023.0.0 doesn't back llvm-nm, so use binutils version. This is expected to be fixed in 2023.1.0 release so add a check to handle either case. * Update compiler flag check based on clang to also support CMAKE_C_COMPILER_ID of "IntelLLVM" as that is how the oneApi toolchain reports itself. Signed-off-by: Kumar Gala <kumar.gala@intel.com>
49 lines
1.5 KiB
CMake
49 lines
1.5 KiB
CMake
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
if(DEFINED ENV{ONEAPI_ROOT})
|
|
set_ifndef(ONEAPI_TOOLCHAIN_PATH $ENV{ONEAPI_ROOT})
|
|
else()
|
|
zephyr_get(ONEAPI_TOOLCHAIN_PATH)
|
|
endif()
|
|
|
|
# the default oneApi installation path is related to os
|
|
string(TOLOWER ${CMAKE_HOST_SYSTEM_NAME} system)
|
|
if(ONEAPI_TOOLCHAIN_PATH)
|
|
set(TOOLCHAIN_HOME ${ONEAPI_TOOLCHAIN_PATH}/compiler/latest/${system}/bin/)
|
|
set(ONEAPI_LLVM_BIN_PATH ${ONEAPI_TOOLCHAIN_PATH}/compiler/latest/${system}/bin-llvm)
|
|
endif()
|
|
|
|
set(ONEAPI_TOOLCHAIN_PATH ${ONEAPI_TOOLCHAIN_PATH} CACHE PATH "oneApi install directory")
|
|
|
|
set(LINKER lld)
|
|
set(BINTOOLS oneApi)
|
|
|
|
if(CONFIG_64BIT)
|
|
set(triple x86_64-pc-none-elf)
|
|
else()
|
|
set(triple i686-pc-none-elf)
|
|
endif()
|
|
|
|
if(system STREQUAL "linux")
|
|
set(COMPILER icx)
|
|
set(CMAKE_C_COMPILER_TARGET ${triple})
|
|
set(CMAKE_ASM_COMPILER_TARGET ${triple})
|
|
set(CMAKE_CXX_COMPILER_TARGET ${triple})
|
|
|
|
# icx compiler of oneApi will invoke clang-cl on windows,
|
|
# this is not supported in zephyr now, so change to use
|
|
# clang directly.
|
|
# and the clang from oneApi can't recognize those cross
|
|
# compiling target variables of cmake, so used other
|
|
# cmake functions to pass them to clang.
|
|
elseif(system STREQUAL "windows")
|
|
set(COMPILER clang)
|
|
list(APPEND CMAKE_REQUIRED_FLAGS --target=${triple})
|
|
add_compile_options(--target=${triple})
|
|
add_link_options(--target=${triple})
|
|
endif()
|
|
|
|
set(TOOLCHAIN_HAS_NEWLIB OFF CACHE BOOL "True if toolchain supports newlib")
|
|
|
|
message(STATUS "Found toolchain: host (clang/ld)")
|