1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
|
#=========================== begin_copyright_notice ============================
#
# Copyright (C) 2021 Intel Corporation
#
# SPDX-License-Identifier: MIT
#
#============================ end_copyright_notice =============================
include_guard(DIRECTORY)
if(NOT IGC_BUILD__LLVM_SOURCES)
message(STATUS "[IGC] IGC will take prebuilt LLVM")
message(STATUS "[IGC] Searching for prebuilt LLVM in ${LLVM_ROOT} and system directories")
find_package(LLVM ${IGC_OPTION__LLVM_PREFERRED_VERSION}
REQUIRED
PATHS ${LLVM_ROOT}
)
message(STATUS "[IGC] Found LLVM: ${LLVM_DIR}")
set(LLVM_DIR "${LLVM_DIR}" PARENT_SCOPE)
set(LLVM_DIR_CONFIGURATION_ADJUSTED "${LLVM_DIR}/$<$<CONFIG:Debug>:Debug>$<$<CONFIG:Release>:Release>$<$<CONFIG:ReleaseInternal>:Release>")
set(LLVM_BIN_DIR_CONFIGURATION_ADJUSTED "${LLVM_DIR_CONFIGURATION_ADJUSTED}/bin")
# Tell the build that we are using prebuilds.
set(IGC_BUILD__LLVM_PREBUILDS ON)
set(IGC_OPTION__LLDELF_LIB_DIR ${LLVM_ROOT} PARENT_SCOPE)
endif()
# Include commonly used modules.
set(CMAKE_MODULE_PATH
${LLVM_CMAKE_DIR}
${CMAKE_MODULE_PATH}
)
if(IGC_OPTION__LLVM_MODE STREQUAL PREBUILDS_MODE_NAME AND WIN32)
set(IGC_OPTION__LLVM_MODE "${IGC_OPTION__LLVM_MODE}" CACHE STRING "")
set(IGC_OPTION__LLD_DIR "${LLVM_DIR}")
set(IGC_OPTION__LLDELF_H_DIR "${DEFAULT_IGC_LLVM_SOURCES_DIR}/lld")
set(LLVM_LINK_EXE "${LLVM_BIN_DIR_CONFIGURATION_ADJUSTED}/llvm-link.exe" CACHE STRING "")
set(LLVM_AS_EXE "${LLVM_BIN_DIR_CONFIGURATION_ADJUSTED}/llvm-as.exe" CACHE STRING "")
set(LLVM_OPT_EXE "${LLVM_BIN_DIR_CONFIGURATION_ADJUSTED}/opt.exe" CACHE STRING "")
set(LLVM_TABLEGEN_EXE "${LLVM_BIN_DIR_CONFIGURATION_ADJUSTED}/llvm-tblgen.exe" CACHE STRING "")
set(LLVM_INCLUDE_DIRS "${LLVM_DIR_CONFIGURATION_ADJUSTED}/include;${DEFAULT_IGC_LLVM_SOURCES_DIR}/llvm/include")
set(LLVM_INCLUDE_DIRS "${LLVM_INCLUDE_DIRS}" PARENT_SCOPE)
else()
set(LLVM_LINK_EXE "llvm-link" CACHE STRING "")
set(LLVM_AS_EXE "llvm-as" CACHE STRING "")
set(LLVM_OPT_EXE "opt" CACHE STRING "")
set(LLVM_TABLEGEN_EXE "llvm-tblgen")
if(CMAKE_CROSSCOMPILING)
if(DEFINED LLVM_TABLEGEN)
set(LLVM_TABLEGEN_EXE ${LLVM_TABLEGEN})
else()
find_program(LLVM_TABLEGEN_EXE "llvm-tblgen" ${LLVM_TOOLS_BINARY_DIR} NO_DEFAULT_PATH)
endif()
endif()
endif()
include(AddLLVM)
include(TableGen)
# Set LLVM_TABLEGEN_FLAGS manually based on include dirs.
list(TRANSFORM LLVM_INCLUDE_DIRS PREPEND "-I=" OUTPUT_VARIABLE LLVM_TABLEGEN_FLAGS)
# Add major version definition for llvm wrapper.
add_compile_definitions(LLVM_VERSION_MAJOR=${LLVM_VERSION_MAJOR})
# Include LLVM headers as system ones.
# This will disable warnings on linux.
include_directories(SYSTEM ${LLVM_INCLUDE_DIRS})
# Disable warnings from LLVM headers for msvc.
if(MSVC_IDE)
add_compile_options(/experimental:external)
foreach(INCDIR IN LISTS LLVM_INCLUDE_DIRS)
add_compile_options("SHELL:/external:I ${INCDIR}")
endforeach()
add_compile_options(/external:W0)
endif()
if(IGC_OPTION__ENABLE_LIT_TESTS)
# Lit testing infrastructure. Find lit tools for tests.
igc_find_external_lit()
endif()
set(IGC_LLVM_COMPONENTS
AggressiveInstCombine
Analysis
AsmParser
BinaryFormat
BitReader
BitWriter
CodeGen
Core
Demangle
InstCombine
Instrumentation
Ipo
IRReader
Linker
MC
MCParser
ObjCARCOpts
Object
ProfileData
Remarks
ScalarOpts
Support
Target
TransformUtils
Vectorize
)
if(LLVM_VERSION_MAJOR GREATER_EQUAL 8)
list(APPEND IGC_LLVM_COMPONENTS
InstCombine
)
endif()
if(LLVM_VERSION_MAJOR GREATER_EQUAL 9)
list(APPEND IGC_LLVM_COMPONENTS
BitstreamReader
)
endif()
igc_get_llvm_targets(IGC_BUILD__LLVM_LIBS_TO_LINK ${IGC_LLVM_COMPONENTS})
|