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 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163
|
#=========================== 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}/bin_and_cmake
)
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>/${cpuSuffix}/$<$<CONFIG:Debug>:Debug>$<$<CONFIG:Release>:Release>$<$<CONFIG:ReleaseInternal>:Release>")
# 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")
#No need to use anything but Release versions of these binaries.
#This should speed up overall build time
set(LLVM_LINK_EXE "${LLVM_DIR}/bin/llvm-link.exe" CACHE STRING "")
set(LLVM_AS_EXE "${LLVM_DIR}/bin/llvm-as.exe" CACHE STRING "")
set(LLVM_OPT_EXE "${LLVM_DIR}/bin/opt.exe" CACHE STRING "")
set(LLVM_TABLEGEN_EXE "${LLVM_DIR}/bin/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})
set(IGC_BUILD__OPAQUE_POINTERS_DISABLE_OPT "")
set(IGC_BUILD__OPAQUE_POINTERS_DISABLE_CLANG "")
set(IGC_BUILD__OPAQUE_POINTERS_ENABLE_OPT "")
set(IGC_BUILD__OPAQUE_POINTERS_ENABLE_CLANG "")
# TODO: If/when the base LLVM version of OCL FE gets decoupled from the
# LLVM_VERSION_MAJOR variable and usage of non-major-release LLVM within
# core IGC becomes possible, this condition should refer to the FE version.
if(LLVM_VERSION_MAJOR EQUAL 14)
set(IGC_BUILD__OPAQUE_POINTERS_ENABLE_OPT "-opaque-pointers=1")
# NB: The option to do the below only got introduced post-LLVM 14
# set(IGC_BUILD__OPAQUE_POINTERS_ENABLE_CLANG "-opaque-pointers"
#
# (see github.com/llvm/llvm-project/commit/d69e9f9d8)
elseif(LLVM_VERSION_MAJOR GREATER 14)
set(IGC_BUILD__OPAQUE_POINTERS_DISABLE_OPT "-opaque-pointers=0")
set(IGC_BUILD__OPAQUE_POINTERS_DISABLE_CLANG "-no-opaque-pointers")
endif()
# Based on the default behavior for opaque/typed pointers, propagate
# corresponding options to all the in-tree calls of clang/opt tools.
if(IGC_OPTION__API_ENABLE_OPAQUE_POINTERS)
if(LLVM_VERSION_MAJOR LESS 14)
message(WARNING "IGC_OPTION__API_ENABLE_OPAQUE_POINTERS ignored: opaque pointers are not available prior to LLVM 14")
set(IGC_OPAQUE_POINTERS_FORCE_DISABLED OFF)
elseif(LLVM_VERSION_MAJOR)
set(IGC_BUILD__OPAQUE_POINTERS_DEFAULT_ARG_OPT ${IGC_BUILD__OPAQUE_POINTERS_ENABLE_OPT})
set(IGC_BUILD__OPAQUE_POINTERS_DEFAULT_ARG_CLANG ${IGC_BUILD__OPAQUE_POINTERS_ENABLE_CLANG})
add_compile_definitions(__IGC_OPAQUE_POINTERS_API_ENABLED=true)
endif()
else(IGC_OPTION__API_ENABLE_OPAQUE_POINTERS)
set(IGC_BUILD__OPAQUE_POINTERS_DEFAULT_ARG_OPT ${IGC_BUILD__OPAQUE_POINTERS_DISABLE_OPT})
set(IGC_BUILD__OPAQUE_POINTERS_DEFAULT_ARG_CLANG ${IGC_BUILD__OPAQUE_POINTERS_DISABLE_CLANG})
add_compile_definitions(__IGC_OPAQUE_POINTERS_API_ENABLED=false)
endif()
add_compile_definitions(__IGC_OPAQUE_POINTERS_DEFAULT_ARG_CLANG="${IGC_BUILD__OPAQUE_POINTERS_DEFAULT_ARG_CLANG}")
# 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
)
list(APPEND IGC_LLVM_COMPONENTS
InstCombine
)
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})
|