2017-12-21 00:45:38 +01:00
|
|
|
#
|
2019-01-18 21:44:23 +01:00
|
|
|
# Copyright (C) 2018-2019 Intel Corporation
|
2017-12-21 00:45:38 +01:00
|
|
|
#
|
2018-09-18 09:11:08 +02:00
|
|
|
# SPDX-License-Identifier: MIT
|
2017-12-21 00:45:38 +01:00
|
|
|
#
|
|
|
|
|
2018-02-27 14:47:36 +01:00
|
|
|
if(POLICY CMP0042)
|
|
|
|
cmake_policy(SET CMP0042 NEW)
|
2018-02-05 11:22:11 +01:00
|
|
|
endif()
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2018-02-27 14:47:36 +01:00
|
|
|
if(POLICY CMP0063)
|
|
|
|
cmake_policy(SET CMP0063 NEW)
|
2018-02-05 11:22:11 +01:00
|
|
|
endif()
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2018-02-27 14:47:36 +01:00
|
|
|
project(neo)
|
2018-03-22 13:53:11 +01:00
|
|
|
set(MSVC_DEF_ADDITIONAL_EXPORTS "")
|
|
|
|
|
2018-02-27 14:47:36 +01:00
|
|
|
if(NOT TARGET ${BIKSIM_LIB_NAME})
|
|
|
|
add_subdirectory(builtin_kernels_simulation)
|
2018-02-08 10:53:47 +01:00
|
|
|
endif()
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2018-02-27 14:47:36 +01:00
|
|
|
hide_subdir(builtin_kernels_simulation)
|
|
|
|
hide_subdir(dll)
|
|
|
|
hide_subdir(instrumentation)
|
2018-01-09 14:08:34 +01:00
|
|
|
|
2019-06-24 13:48:14 +02:00
|
|
|
add_library(${NEO_STATIC_LIB_NAME} STATIC EXCLUDE_FROM_ALL
|
2018-02-27 14:47:36 +01:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/CMakeLists.txt
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/enable_gens.cmake
|
|
|
|
$<TARGET_OBJECTS:${BIKSIM_LIB_NAME}>
|
|
|
|
)
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2018-02-27 14:47:36 +01:00
|
|
|
add_subdirectories()
|
|
|
|
add_subdirectory(instrumentation${IGDRCL__INSTRUMENTATION_DIR_SUFFIX})
|
2018-02-05 15:07:21 +01:00
|
|
|
include(enable_gens.cmake)
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
# Enable SSE4/AVX2 options for files that need them
|
|
|
|
if(MSVC)
|
2018-03-06 14:50:30 +01:00
|
|
|
set_source_files_properties(${CMAKE_CURRENT_SOURCE_DIR}/command_queue/local_id_gen_avx2.cpp PROPERTIES COMPILE_FLAGS /arch:AVX2)
|
2017-12-21 00:45:38 +01:00
|
|
|
else()
|
2018-03-06 14:50:30 +01:00
|
|
|
set_source_files_properties(${CMAKE_CURRENT_SOURCE_DIR}/command_queue/local_id_gen_avx2.cpp PROPERTIES COMPILE_FLAGS -mavx2)
|
|
|
|
set_source_files_properties(${CMAKE_CURRENT_SOURCE_DIR}/command_queue/local_id_gen_sse4.cpp PROPERTIES COMPILE_FLAGS -msse4.2)
|
2018-02-27 14:47:36 +01:00
|
|
|
endif()
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2018-03-06 14:50:30 +01:00
|
|
|
if(WIN32)
|
|
|
|
if("${IGDRCL_OPTION__BITS}" STREQUAL "32" )
|
|
|
|
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} /SAFESEH:NO")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
2017-12-21 00:45:38 +01:00
|
|
|
target_link_libraries(${NEO_STATIC_LIB_NAME} elflib)
|
2018-10-30 18:29:32 +01:00
|
|
|
if(DEFINED AUB_STREAM_DIR)
|
2019-01-18 21:44:23 +01:00
|
|
|
target_link_libraries(${NEO_STATIC_LIB_NAME} ${AUB_STREAM_PROJECT_NAME})
|
2018-10-30 18:29:32 +01:00
|
|
|
endif()
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
target_include_directories(${NEO_STATIC_LIB_NAME} PRIVATE
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}
|
2018-02-27 14:47:36 +01:00
|
|
|
${KMDAF_HEADERS_DIR}
|
2017-12-21 00:45:38 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
target_include_directories(${NEO_STATIC_LIB_NAME} PUBLIC
|
2019-03-27 10:06:29 +01:00
|
|
|
${ENGINE_NODE_DIR}
|
2018-03-02 09:49:46 +01:00
|
|
|
${KHRONOS_HEADERS_DIR}
|
2018-08-27 16:30:40 +02:00
|
|
|
${KHRONOS_GL_HEADERS_DIR}
|
2018-02-27 14:47:36 +01:00
|
|
|
${CIF_BASE_DIR}
|
2018-03-06 14:50:30 +01:00
|
|
|
${GMM_INCLUDE_PATHS}
|
|
|
|
${HW_SRC_INCLUDE_PATH}
|
2018-02-27 14:47:36 +01:00
|
|
|
${IGC_OCL_ADAPTOR_DIR}
|
2019-07-11 09:41:40 +02:00
|
|
|
${VISA_INCLUDE_DIR}
|
2018-02-27 14:47:36 +01:00
|
|
|
${IGDRCL__IGC_INCLUDE_DIR}
|
|
|
|
${THIRD_PARTY_DIR}
|
2018-03-06 14:50:30 +01:00
|
|
|
${UMKM_SHAREDDATA_INCLUDE_PATHS}
|
2018-04-20 14:44:14 +02:00
|
|
|
${SOURCE_LEVEL_DEBUGGER_HEADERS_DIR}
|
2017-12-21 00:45:38 +01:00
|
|
|
)
|
|
|
|
|
2018-02-27 14:47:36 +01:00
|
|
|
if(WIN32)
|
2018-03-08 09:14:07 +01:00
|
|
|
set(IGDRCL_EXTRA_LIBS Ws2_32)
|
2017-12-21 00:45:38 +01:00
|
|
|
target_include_directories(${NEO_STATIC_LIB_NAME} PUBLIC
|
|
|
|
${WDK_INCLUDE_PATHS}
|
|
|
|
os_interface/windows
|
|
|
|
)
|
2018-03-06 14:50:30 +01:00
|
|
|
target_compile_definitions(${NEO_STATIC_LIB_NAME} PRIVATE OGL=1)
|
2018-02-27 14:47:36 +01:00
|
|
|
else()
|
2018-03-08 09:14:07 +01:00
|
|
|
set(IGDRCL_EXTRA_LIBS dl pthread)
|
2017-12-21 00:45:38 +01:00
|
|
|
target_include_directories(${NEO_STATIC_LIB_NAME} PUBLIC
|
|
|
|
os_interface/linux
|
2018-03-12 15:06:33 +01:00
|
|
|
${I915_INCLUDES_DIR}
|
2017-12-21 00:45:38 +01:00
|
|
|
)
|
2018-02-27 14:47:36 +01:00
|
|
|
endif()
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2018-09-26 06:31:01 +00:00
|
|
|
target_compile_definitions(${NEO_STATIC_LIB_NAME} PUBLIC GMM_LIB_DLL DEFAULT_PLATFORM=${DEFAULT_SUPPORTED_PLATFORM})
|
2017-12-21 00:45:38 +01:00
|
|
|
|
|
|
|
list(APPEND LIB_FLAGS_DEFINITIONS -DCIF_HEADERS_ONLY_BUILD ${SUPPORTED_GEN_FLAGS_DEFINITONS})
|
|
|
|
|
|
|
|
target_compile_definitions(${NEO_STATIC_LIB_NAME} PUBLIC ${LIB_FLAGS_DEFINITIONS})
|
|
|
|
|
|
|
|
set_target_properties(${NEO_STATIC_LIB_NAME} PROPERTIES POSITION_INDEPENDENT_CODE ON)
|
|
|
|
|
|
|
|
set_property(TARGET ${NEO_STATIC_LIB_NAME} APPEND_STRING PROPERTY COMPILE_FLAGS ${ASAN_FLAGS} ${TSAN_FLAGS})
|
|
|
|
|
|
|
|
set_target_properties(${NEO_STATIC_LIB_NAME} PROPERTIES FOLDER "opencl runtime")
|
|
|
|
|
2018-03-22 13:53:11 +01:00
|
|
|
set(EXPORTS_FILENAME "")
|
|
|
|
if(WIN32)
|
|
|
|
set(EXPORTS_FILENAME "${CMAKE_CURRENT_BINARY_DIR}/OpenCLExports${IGDRCL_OPTION__BITS}.def")
|
|
|
|
set(MSVC_DEF_LIB_NAME "igdrcl${IGDRCL_OPTION__BITS}")
|
|
|
|
set(MSVC_DEF_HEADER "This file was generated during CMake project configuration - please don't edit")
|
|
|
|
configure_file("${CMAKE_CURRENT_SOURCE_DIR}/dll/windows/OpenCLExports.def.in" "${EXPORTS_FILENAME}")
|
|
|
|
endif(WIN32)
|
|
|
|
|
2017-12-21 00:45:38 +01:00
|
|
|
if(${GENERATE_EXECUTABLE})
|
2018-02-27 14:47:36 +01:00
|
|
|
list(APPEND NEO_DYNAMIC_LIB__TARGET_OBJECTS
|
|
|
|
$<TARGET_OBJECTS:${SHARINGS_ENABLE_LIB_NAME}>
|
|
|
|
$<TARGET_OBJECTS:${BUILTINS_SOURCES_LIB_NAME}>
|
|
|
|
$<TARGET_OBJECTS:${BUILTINS_BINARIES_LIB_NAME}>
|
|
|
|
$<TARGET_OBJECTS:${SCHEDULER_BINARY_LIB_NAME}>
|
|
|
|
)
|
2018-11-26 18:17:57 -08:00
|
|
|
|
|
|
|
if(DEFINED AUB_STREAM_DIR)
|
2019-01-18 21:44:23 +01:00
|
|
|
list(APPEND NEO_DYNAMIC_LIB__TARGET_OBJECTS $<TARGET_OBJECTS:${AUB_STREAM_PROJECT_NAME}_all_hw>)
|
2018-11-26 18:17:57 -08:00
|
|
|
endif()
|
|
|
|
|
2018-02-27 14:47:36 +01:00
|
|
|
add_library(${NEO_DYNAMIC_LIB_NAME} SHARED
|
|
|
|
${NEO_DYNAMIC_LIB__TARGET_OBJECTS}
|
2018-12-10 17:12:32 +01:00
|
|
|
${IGDRCL_SOURCE_DIR}/runtime/aub/aub_stream_interface.cpp
|
2018-02-27 14:47:36 +01:00
|
|
|
)
|
2019-01-18 21:44:23 +01:00
|
|
|
|
2019-05-15 18:06:16 +02:00
|
|
|
if(UNIX)
|
|
|
|
install(FILES
|
|
|
|
$<TARGET_FILE:${NEO_DYNAMIC_LIB_NAME}>
|
|
|
|
DESTINATION ${CMAKE_INSTALL_LIBDIR}/intel-opencl
|
|
|
|
COMPONENT opencl
|
|
|
|
)
|
|
|
|
set_property(GLOBAL APPEND PROPERTY NEO_COMPONENTS_LIST "opencl")
|
|
|
|
endif()
|
|
|
|
|
2018-09-26 13:01:17 +00:00
|
|
|
if(TARGET ${GMMUMD_LIB_NAME})
|
2018-06-21 09:55:20 +02:00
|
|
|
add_dependencies(${NEO_DYNAMIC_LIB_NAME} ${GMMUMD_LIB_NAME})
|
|
|
|
endif()
|
2018-02-27 14:47:36 +01:00
|
|
|
|
2018-08-30 14:20:31 +02:00
|
|
|
if(NOT DISABLED_GTPIN_SUPPORT)
|
2018-05-27 22:50:08 -07:00
|
|
|
macro(macro_for_each_gen)
|
|
|
|
target_sources(${NEO_DYNAMIC_LIB_NAME} PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/${GEN_TYPE_LOWER}/gtpin_setup_${GEN_TYPE_LOWER}.cpp)
|
|
|
|
endmacro()
|
|
|
|
apply_macro_for_each_gen("SUPPORTED")
|
|
|
|
endif()
|
|
|
|
|
2018-02-08 10:53:47 +01:00
|
|
|
add_subdirectory(dll)
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2018-03-08 09:14:07 +01:00
|
|
|
target_link_libraries(${NEO_DYNAMIC_LIB_NAME} ${NEO_STATIC_LIB_NAME} ${IGDRCL_EXTRA_LIBS})
|
2018-02-27 14:47:36 +01:00
|
|
|
|
|
|
|
target_include_directories(${NEO_DYNAMIC_LIB_NAME} BEFORE PRIVATE
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}
|
2018-11-26 18:17:57 -08:00
|
|
|
${AUB_STREAM_DIR}/..
|
2018-02-27 14:47:36 +01:00
|
|
|
)
|
2018-03-06 14:50:30 +01:00
|
|
|
|
2018-02-08 10:53:47 +01:00
|
|
|
if(WIN32)
|
2018-03-08 09:14:07 +01:00
|
|
|
target_link_libraries(${NEO_DYNAMIC_LIB_NAME} dxgi)
|
2018-02-08 10:53:47 +01:00
|
|
|
else()
|
2018-03-06 14:50:30 +01:00
|
|
|
target_include_directories(${NEO_DYNAMIC_LIB_NAME} PRIVATE
|
2018-02-27 14:47:36 +01:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/dll/linux/devices${BRANCH_DIR_SUFFIX}
|
|
|
|
)
|
|
|
|
set_property(TARGET ${NEO_DYNAMIC_LIB_NAME}
|
|
|
|
APPEND_STRING PROPERTY LINK_FLAGS " -Wl,--version-script=${CMAKE_CURRENT_SOURCE_DIR}/dll/linux/ocl.exports"
|
|
|
|
)
|
|
|
|
set_property(TARGET ${NEO_DYNAMIC_LIB_NAME}
|
|
|
|
APPEND_STRING PROPERTY LINK_FLAGS " -Wl,-Bsymbolic"
|
|
|
|
)
|
|
|
|
set_property(TARGET ${NEO_DYNAMIC_LIB_NAME} APPEND_STRING PROPERTY COMPILE_FLAGS ${ASAN_FLAGS})
|
2018-02-08 10:53:47 +01:00
|
|
|
endif()
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2018-02-27 14:47:36 +01:00
|
|
|
set_target_properties(${NEO_DYNAMIC_LIB_NAME} PROPERTIES
|
|
|
|
DEBUG_OUTPUT_NAME "${NEO_DLL_NAME_BASE}${IGDRCL_NAME_POSTFIX}${IGDRCL_OPTION__BITS}"
|
|
|
|
RELEASE_OUTPUT_NAME "${NEO_DLL_NAME_BASE}${IGDRCL_NAME_POSTFIX}${IGDRCL_OPTION__BITS}"
|
|
|
|
RELEASEINTERNAL_OUTPUT_NAME "${NEO_DLL_NAME_BASE}${IGDRCL_NAME_POSTFIX}${IGDRCL_OPTION__BITS}"
|
|
|
|
OUTPUT_NAME "${NEO_DLL_NAME_BASE}${IGDRCL_NAME_POSTFIX}${IGDRCL_OPTION__BITS}"
|
|
|
|
)
|
|
|
|
set_target_properties(${NEO_DYNAMIC_LIB_NAME} PROPERTIES FOLDER "opencl runtime")
|
2018-03-22 13:53:11 +01:00
|
|
|
create_project_source_tree_with_exports(${NEO_DYNAMIC_LIB_NAME} "${EXPORTS_FILENAME}")
|
2017-12-21 00:45:38 +01:00
|
|
|
endif(${GENERATE_EXECUTABLE})
|
|
|
|
|
2019-05-13 12:53:40 +02:00
|
|
|
create_project_source_tree(${NEO_STATIC_LIB_NAME} ${IGDRCL_SOURCE_DIR})
|
2017-12-21 00:45:38 +01:00
|
|
|
|
2018-02-27 14:47:36 +01:00
|
|
|
if(UNIX AND NOT (TARGET clang-tidy))
|
|
|
|
add_custom_target(clang-tidy
|
|
|
|
DEPENDS scheduler
|
|
|
|
)
|
|
|
|
add_custom_command(
|
|
|
|
TARGET clang-tidy
|
|
|
|
POST_BUILD
|
|
|
|
COMMAND echo clang-tidy...
|
|
|
|
COMMAND find ${CMAKE_CURRENT_SOURCE_DIR} -name *.cpp -print0 | xargs -0 -I{} -P`nproc` clang-tidy -p ${IGDRCL_BINARY_DIR} {} | tee ${IGDRCL_BINARY_DIR}/clang-tidy.log
|
|
|
|
WORKING_DIRECTORY ${IGDRCL_SOURCE_DIR}
|
|
|
|
)
|
|
|
|
endif()
|
2018-03-08 09:14:07 +01:00
|
|
|
|
|
|
|
set(IGDRCL_EXTRA_LIBS ${IGDRCL_EXTRA_LIBS} PARENT_SCOPE)
|