2017-12-21 07:45:38 +08:00
|
|
|
#
|
2018-09-18 15:11:08 +08:00
|
|
|
# Copyright (C) 2018 Intel Corporation
|
2017-12-21 07:45:38 +08:00
|
|
|
#
|
2018-09-18 15:11:08 +08:00
|
|
|
# SPDX-License-Identifier: MIT
|
2017-12-21 07:45:38 +08:00
|
|
|
#
|
|
|
|
|
2018-02-27 21:47:36 +08:00
|
|
|
if(POLICY CMP0042)
|
|
|
|
cmake_policy(SET CMP0042 NEW)
|
2018-02-05 18:22:11 +08:00
|
|
|
endif()
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-02-27 21:47:36 +08:00
|
|
|
if(POLICY CMP0063)
|
|
|
|
cmake_policy(SET CMP0063 NEW)
|
2018-02-05 18:22:11 +08:00
|
|
|
endif()
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-02-27 21:47:36 +08:00
|
|
|
project(neo)
|
2018-03-22 20:53:11 +08:00
|
|
|
set(MSVC_DEF_ADDITIONAL_EXPORTS "")
|
|
|
|
|
2018-02-27 21:47:36 +08:00
|
|
|
if(NOT TARGET ${BIKSIM_LIB_NAME})
|
|
|
|
add_subdirectory(builtin_kernels_simulation)
|
2018-02-08 17:53:47 +08:00
|
|
|
endif()
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-02-27 21:47:36 +08:00
|
|
|
hide_subdir(builtin_kernels_simulation)
|
|
|
|
hide_subdir(dll)
|
|
|
|
hide_subdir(instrumentation)
|
2018-01-09 21:08:34 +08:00
|
|
|
|
2018-02-27 21:47:36 +08:00
|
|
|
add_library(${NEO_STATIC_LIB_NAME} STATIC
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/CMakeLists.txt
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/enable_gens.cmake
|
|
|
|
$<TARGET_OBJECTS:${BIKSIM_LIB_NAME}>
|
|
|
|
)
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-02-27 21:47:36 +08:00
|
|
|
add_subdirectories()
|
|
|
|
add_subdirectory(instrumentation${IGDRCL__INSTRUMENTATION_DIR_SUFFIX})
|
2018-02-05 22:07:21 +08:00
|
|
|
include(enable_gens.cmake)
|
2017-12-21 07:45:38 +08:00
|
|
|
|
|
|
|
# Enable SSE4/AVX2 options for files that need them
|
|
|
|
if(MSVC)
|
2018-03-06 21:50:30 +08:00
|
|
|
set_source_files_properties(${CMAKE_CURRENT_SOURCE_DIR}/command_queue/local_id_gen_avx2.cpp PROPERTIES COMPILE_FLAGS /arch:AVX2)
|
2017-12-21 07:45:38 +08:00
|
|
|
else()
|
2018-03-06 21:50:30 +08: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 21:47:36 +08:00
|
|
|
endif()
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-03-06 21:50:30 +08: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 07:45:38 +08:00
|
|
|
target_link_libraries(${NEO_STATIC_LIB_NAME} elflib)
|
2018-10-31 01:29:32 +08:00
|
|
|
if(DEFINED AUB_STREAM_DIR)
|
|
|
|
target_link_libraries(${NEO_STATIC_LIB_NAME} ${AUB_STREAM_LIB_NAME})
|
|
|
|
endif()
|
2017-12-21 07:45:38 +08:00
|
|
|
|
|
|
|
target_include_directories(${NEO_STATIC_LIB_NAME} PRIVATE
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}
|
2018-02-27 21:47:36 +08:00
|
|
|
${KMDAF_HEADERS_DIR}
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
target_include_directories(${NEO_STATIC_LIB_NAME} PUBLIC
|
2018-03-02 16:49:46 +08:00
|
|
|
${KHRONOS_HEADERS_DIR}
|
2018-08-27 22:30:40 +08:00
|
|
|
${KHRONOS_GL_HEADERS_DIR}
|
2018-02-27 21:47:36 +08:00
|
|
|
${CIF_BASE_DIR}
|
2018-03-06 21:50:30 +08:00
|
|
|
${GMM_INCLUDE_PATHS}
|
|
|
|
${HW_SRC_INCLUDE_PATH}
|
2018-02-27 21:47:36 +08:00
|
|
|
${IGC_OCL_ADAPTOR_DIR}
|
|
|
|
${IGDRCL__IGC_INCLUDE_DIR}
|
|
|
|
${THIRD_PARTY_DIR}
|
2018-03-06 21:50:30 +08:00
|
|
|
${UMKM_SHAREDDATA_INCLUDE_PATHS}
|
2018-04-20 20:44:14 +08:00
|
|
|
${SOURCE_LEVEL_DEBUGGER_HEADERS_DIR}
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
|
|
|
|
2018-02-27 21:47:36 +08:00
|
|
|
if(WIN32)
|
2018-03-08 16:14:07 +08:00
|
|
|
set(IGDRCL_EXTRA_LIBS Ws2_32)
|
2017-12-21 07:45:38 +08:00
|
|
|
target_include_directories(${NEO_STATIC_LIB_NAME} PUBLIC
|
|
|
|
${WDK_INCLUDE_PATHS}
|
|
|
|
os_interface/windows
|
|
|
|
)
|
2018-03-06 21:50:30 +08:00
|
|
|
target_compile_definitions(${NEO_STATIC_LIB_NAME} PRIVATE OGL=1)
|
2018-02-27 21:47:36 +08:00
|
|
|
else()
|
2018-03-08 16:14:07 +08:00
|
|
|
set(IGDRCL_EXTRA_LIBS dl pthread)
|
2017-12-21 07:45:38 +08:00
|
|
|
target_include_directories(${NEO_STATIC_LIB_NAME} PUBLIC
|
|
|
|
os_interface/linux
|
2018-03-12 22:06:33 +08:00
|
|
|
${I915_INCLUDES_DIR}
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
2018-02-27 21:47:36 +08:00
|
|
|
endif()
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-09-26 14:31:01 +08:00
|
|
|
target_compile_definitions(${NEO_STATIC_LIB_NAME} PUBLIC GMM_LIB_DLL DEFAULT_PLATFORM=${DEFAULT_SUPPORTED_PLATFORM})
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-03-01 23:00:45 +08:00
|
|
|
if(INSTRUMENTATION_LIB_NAME)
|
2018-03-06 21:50:30 +08:00
|
|
|
add_dependencies(${NEO_STATIC_LIB_NAME} ${INSTRUMENTATION_LIB_NAME})
|
2018-03-01 23:00:45 +08:00
|
|
|
endif()
|
|
|
|
|
2017-12-21 07:45:38 +08: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 20:53:11 +08: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 07:45:38 +08:00
|
|
|
if(${GENERATE_EXECUTABLE})
|
2018-02-27 21:47:36 +08: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-27 10:17:57 +08:00
|
|
|
|
|
|
|
if(DEFINED AUB_STREAM_DIR)
|
|
|
|
list(APPEND NEO_DYNAMIC_LIB__TARGET_OBJECTS $<TARGET_OBJECTS:${AUB_STREAM_ENABLE_LIB_NAME}>)
|
|
|
|
endif()
|
|
|
|
|
2018-02-27 21:47:36 +08:00
|
|
|
add_library(${NEO_DYNAMIC_LIB_NAME} SHARED
|
|
|
|
${NEO_DYNAMIC_LIB__TARGET_OBJECTS}
|
2018-12-11 00:12:32 +08:00
|
|
|
${IGDRCL_SOURCE_DIR}/runtime/aub/aub_stream_interface.cpp
|
2018-02-27 21:47:36 +08:00
|
|
|
)
|
2018-09-26 21:01:17 +08:00
|
|
|
if(TARGET ${GMMUMD_LIB_NAME})
|
2018-06-21 15:55:20 +08:00
|
|
|
add_dependencies(${NEO_DYNAMIC_LIB_NAME} ${GMMUMD_LIB_NAME})
|
|
|
|
endif()
|
2018-02-27 21:47:36 +08:00
|
|
|
|
2018-08-30 20:20:31 +08:00
|
|
|
if(NOT DISABLED_GTPIN_SUPPORT)
|
2018-05-28 13:50:08 +08: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 17:53:47 +08:00
|
|
|
add_subdirectory(dll)
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-02-27 21:47:36 +08:00
|
|
|
if(HAVE_INSTRUMENTATION)
|
2018-03-06 21:50:30 +08:00
|
|
|
target_link_libraries(${NEO_DYNAMIC_LIB_NAME} ${INSTRUMENTATION_LIB_NAME})
|
2018-02-27 21:47:36 +08:00
|
|
|
endif()
|
|
|
|
|
2018-03-08 16:14:07 +08:00
|
|
|
target_link_libraries(${NEO_DYNAMIC_LIB_NAME} ${NEO_STATIC_LIB_NAME} ${IGDRCL_EXTRA_LIBS})
|
2018-02-27 21:47:36 +08:00
|
|
|
|
|
|
|
target_include_directories(${NEO_DYNAMIC_LIB_NAME} BEFORE PRIVATE
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}
|
|
|
|
${INSTRUMENTATION_INCLUDE_PATH}
|
2018-11-27 10:17:57 +08:00
|
|
|
${AUB_STREAM_DIR}/..
|
2018-02-27 21:47:36 +08:00
|
|
|
)
|
2018-03-06 21:50:30 +08:00
|
|
|
|
2018-02-08 17:53:47 +08:00
|
|
|
if(WIN32)
|
2018-03-08 16:14:07 +08:00
|
|
|
target_link_libraries(${NEO_DYNAMIC_LIB_NAME} dxgi)
|
2018-02-08 17:53:47 +08:00
|
|
|
else()
|
2018-03-06 21:50:30 +08:00
|
|
|
target_include_directories(${NEO_DYNAMIC_LIB_NAME} PRIVATE
|
2018-02-27 21:47:36 +08: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 17:53:47 +08:00
|
|
|
endif()
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-02-27 21:47:36 +08: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 20:53:11 +08:00
|
|
|
create_project_source_tree_with_exports(${NEO_DYNAMIC_LIB_NAME} "${EXPORTS_FILENAME}")
|
2017-12-21 07:45:38 +08:00
|
|
|
endif(${GENERATE_EXECUTABLE})
|
|
|
|
|
2018-03-01 18:59:54 +08:00
|
|
|
create_project_source_tree(${NEO_STATIC_LIB_NAME})
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-02-27 21:47:36 +08: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 16:14:07 +08:00
|
|
|
|
|
|
|
set(IGDRCL_EXTRA_LIBS ${IGDRCL_EXTRA_LIBS} PARENT_SCOPE)
|