mirror of
https://github.com/intel/compute-runtime.git
synced 2025-11-10 05:49:51 +08:00
allow disable builtins compilation
Related-To: NEO-6011 Signed-off-by: Artur Harasimiuk <artur.harasimiuk@intel.com>
This commit is contained in:
committed by
Compute-Runtime-Automation
parent
10a6934119
commit
5be234111c
@@ -1024,8 +1024,12 @@ macro(generate_runtime_lib LIB_NAME MOCKABLE GENERATE_EXEC)
|
|||||||
target_compile_definitions(${BUILTINS_VME_LIB_NAME} PUBLIC MOCKABLE_VIRTUAL=)
|
target_compile_definitions(${BUILTINS_VME_LIB_NAME} PUBLIC MOCKABLE_VIRTUAL=)
|
||||||
target_compile_definitions(${BUILTINS_BINARIES_BINDFUL_LIB_NAME} PUBLIC MOCKABLE_VIRTUAL=)
|
target_compile_definitions(${BUILTINS_BINARIES_BINDFUL_LIB_NAME} PUBLIC MOCKABLE_VIRTUAL=)
|
||||||
target_compile_definitions(${BUILTINS_BINARIES_BINDLESS_LIB_NAME} PUBLIC MOCKABLE_VIRTUAL=)
|
target_compile_definitions(${BUILTINS_BINARIES_BINDLESS_LIB_NAME} PUBLIC MOCKABLE_VIRTUAL=)
|
||||||
target_compile_definitions(${BUILTINS_SPIRV_LIB_NAME} PUBLIC MOCKABLE_VIRTUAL=)
|
if(TARGET ${BUILTINS_SPIRV_LIB_NAME})
|
||||||
target_compile_definitions(${SCHEDULER_BINARY_LIB_NAME} PUBLIC MOCKABLE_VIRTUAL=)
|
target_compile_definitions(${BUILTINS_SPIRV_LIB_NAME} PUBLIC MOCKABLE_VIRTUAL=)
|
||||||
|
endif()
|
||||||
|
if(TARGET ${SCHEDULER_BINARY_LIB_NAME})
|
||||||
|
target_compile_definitions(${SCHEDULER_BINARY_LIB_NAME} PUBLIC MOCKABLE_VIRTUAL=)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(${MOCKABLE})
|
if(${MOCKABLE})
|
||||||
target_compile_definitions(${LIB_NAME} PUBLIC MOCKABLE_VIRTUAL=virtual)
|
target_compile_definitions(${LIB_NAME} PUBLIC MOCKABLE_VIRTUAL=virtual)
|
||||||
|
|||||||
@@ -282,10 +282,12 @@ if(BUILD_WITH_L0)
|
|||||||
$<TARGET_OBJECTS:aub_stream_all_hw>
|
$<TARGET_OBJECTS:aub_stream_all_hw>
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
target_sources(${TARGET_NAME_L0}
|
if(TARGET ${BUILTINS_SPIRV_LIB_NAME})
|
||||||
PRIVATE
|
target_sources(${TARGET_NAME_L0}
|
||||||
$<TARGET_OBJECTS:${BUILTINS_SPIRV_LIB_NAME}>
|
PRIVATE
|
||||||
)
|
$<TARGET_OBJECTS:${BUILTINS_SPIRV_LIB_NAME}>
|
||||||
|
)
|
||||||
|
endif()
|
||||||
if(NOT ${DONT_USE_PREBUILT_KERNELS_L0})
|
if(NOT ${DONT_USE_PREBUILT_KERNELS_L0})
|
||||||
message("Prebuilt kernels are linked to Level Zero.")
|
message("Prebuilt kernels are linked to Level Zero.")
|
||||||
target_sources(${TARGET_NAME_L0}
|
target_sources(${TARGET_NAME_L0}
|
||||||
|
|||||||
@@ -72,10 +72,14 @@ target_sources(${TARGET_NAME} PRIVATE
|
|||||||
$<TARGET_OBJECTS:${TARGET_NAME_L0}_fixtures>
|
$<TARGET_OBJECTS:${TARGET_NAME_L0}_fixtures>
|
||||||
$<TARGET_OBJECTS:${TARGET_NAME_L0}_mocks>
|
$<TARGET_OBJECTS:${TARGET_NAME_L0}_mocks>
|
||||||
$<TARGET_OBJECTS:igdrcl_libult_common>
|
$<TARGET_OBJECTS:igdrcl_libult_common>
|
||||||
$<TARGET_OBJECTS:${BUILTINS_SPIRV_LIB_NAME}>
|
|
||||||
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDFUL_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDFUL_LIB_NAME}>
|
||||||
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDLESS_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDLESS_LIB_NAME}>
|
||||||
)
|
)
|
||||||
|
if(TARGET ${BUILTINS_SPIRV_LIB_NAME})
|
||||||
|
target_sources(${TARGET_NAME} PRIVATE
|
||||||
|
$<TARGET_OBJECTS:${BUILTINS_SPIRV_LIB_NAME}>
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
target_sources(${TARGET_NAME} PRIVATE
|
target_sources(${TARGET_NAME} PRIVATE
|
||||||
${NEO_SOURCE_DIR}/opencl/test/unit_test/helpers${BRANCH_DIR_SUFFIX}/kernel_binary_helper_hash_value.cpp
|
${NEO_SOURCE_DIR}/opencl/test/unit_test/helpers${BRANCH_DIR_SUFFIX}/kernel_binary_helper_hash_value.cpp
|
||||||
|
|||||||
@@ -126,10 +126,14 @@ target_sources(${TARGET_NAME} PRIVATE
|
|||||||
$<TARGET_OBJECTS:mock_gmm>
|
$<TARGET_OBJECTS:mock_gmm>
|
||||||
$<TARGET_OBJECTS:${TARGET_NAME_L0}_fixtures>
|
$<TARGET_OBJECTS:${TARGET_NAME_L0}_fixtures>
|
||||||
$<TARGET_OBJECTS:${TARGET_NAME_L0}_mocks>
|
$<TARGET_OBJECTS:${TARGET_NAME_L0}_mocks>
|
||||||
$<TARGET_OBJECTS:${BUILTINS_SPIRV_LIB_NAME}>
|
|
||||||
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDFUL_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDFUL_LIB_NAME}>
|
||||||
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDLESS_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDLESS_LIB_NAME}>
|
||||||
)
|
)
|
||||||
|
if(TARGET ${BUILTINS_SPIRV_LIB_NAME})
|
||||||
|
target_sources(${TARGET_NAME} PRIVATE
|
||||||
|
$<TARGET_OBJECTS:${BUILTINS_SPIRV_LIB_NAME}>
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
set(TEST_MODULES
|
set(TEST_MODULES
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/test_modules/test_kernel.cl
|
${CMAKE_CURRENT_SOURCE_DIR}/test_modules/test_kernel.cl
|
||||||
|
|||||||
@@ -116,10 +116,14 @@ target_sources(${TARGET_NAME} PRIVATE
|
|||||||
$<TARGET_OBJECTS:mock_gmm>
|
$<TARGET_OBJECTS:mock_gmm>
|
||||||
$<TARGET_OBJECTS:${TARGET_NAME_L0}_fixtures>
|
$<TARGET_OBJECTS:${TARGET_NAME_L0}_fixtures>
|
||||||
$<TARGET_OBJECTS:${TARGET_NAME_L0}_mocks>
|
$<TARGET_OBJECTS:${TARGET_NAME_L0}_mocks>
|
||||||
$<TARGET_OBJECTS:${BUILTINS_SPIRV_LIB_NAME}>
|
|
||||||
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDFUL_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDFUL_LIB_NAME}>
|
||||||
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDLESS_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDLESS_LIB_NAME}>
|
||||||
)
|
)
|
||||||
|
if(TARGET ${BUILTINS_SPIRV_LIB_NAME})
|
||||||
|
target_sources(${TARGET_NAME} PRIVATE
|
||||||
|
$<TARGET_OBJECTS:${BUILTINS_SPIRV_LIB_NAME}>
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
option(L0_ULT_VERBOSE "Use the default/verbose test output" OFF)
|
option(L0_ULT_VERBOSE "Use the default/verbose test output" OFF)
|
||||||
if(NOT L0_ULT_VERBOSE)
|
if(NOT L0_ULT_VERBOSE)
|
||||||
|
|||||||
@@ -123,8 +123,12 @@ if(${GENERATE_EXECUTABLE})
|
|||||||
$<TARGET_OBJECTS:${BUILTINS_SOURCES_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_SOURCES_LIB_NAME}>
|
||||||
$<TARGET_OBJECTS:${BUILTINS_VME_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_VME_LIB_NAME}>
|
||||||
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDFUL_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDFUL_LIB_NAME}>
|
||||||
$<TARGET_OBJECTS:${SCHEDULER_BINARY_LIB_NAME}>
|
|
||||||
)
|
)
|
||||||
|
if(TARGET ${SCHEDULER_BINARY_LIB_NAME})
|
||||||
|
list(APPEND NEO_DYNAMIC_LIB__TARGET_OBJECTS
|
||||||
|
$<TARGET_OBJECTS:${SCHEDULER_BINARY_LIB_NAME}>
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(DEFINED AUB_STREAM_PROJECT_NAME)
|
if(DEFINED AUB_STREAM_PROJECT_NAME)
|
||||||
list(APPEND NEO_DYNAMIC_LIB__TARGET_OBJECTS $<TARGET_OBJECTS:${AUB_STREAM_PROJECT_NAME}_all_hw>)
|
list(APPEND NEO_DYNAMIC_LIB__TARGET_OBJECTS $<TARGET_OBJECTS:${AUB_STREAM_PROJECT_NAME}_all_hw>)
|
||||||
|
|||||||
@@ -4,104 +4,106 @@
|
|||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
#
|
#
|
||||||
|
|
||||||
add_custom_target(builtins_vme_sources)
|
if(NOT NEO_DISABLE_BUILTINS_COMPILATION)
|
||||||
set_target_properties(builtins_vme_sources PROPERTIES FOLDER "${OPENCL_RUNTIME_PROJECTS_FOLDER}/${OPENCL_BUIILINS_PROJECTS_FOLDER}")
|
add_custom_target(builtins_vme_sources)
|
||||||
set(BUILTINS_OUTDIR_WITH_ARCH "${TargetDir}/built_ins/${NEO_ARCH}")
|
set_target_properties(builtins_vme_sources PROPERTIES FOLDER "${OPENCL_RUNTIME_PROJECTS_FOLDER}/${OPENCL_BUIILINS_PROJECTS_FOLDER}")
|
||||||
add_dependencies(${BUILTINS_BINARIES_BINDFUL_LIB_NAME} builtins_vme_sources)
|
set(BUILTINS_OUTDIR_WITH_ARCH "${TargetDir}/built_ins/${NEO_ARCH}")
|
||||||
add_subdirectories()
|
add_dependencies(${BUILTINS_BINARIES_BINDFUL_LIB_NAME} builtins_vme_sources)
|
||||||
set(GENERATED_BUILTINS ${GENERATED_BUILTINS} PARENT_SCOPE)
|
add_subdirectories()
|
||||||
set(GENERATED_BUILTINS_STATELESS ${GENERATED_BUILTINS_STATELESS} PARENT_SCOPE)
|
set(GENERATED_BUILTINS ${GENERATED_BUILTINS} PARENT_SCOPE)
|
||||||
|
set(GENERATED_BUILTINS_STATELESS ${GENERATED_BUILTINS_STATELESS} PARENT_SCOPE)
|
||||||
|
|
||||||
if("${NEO_ARCH}" STREQUAL "x32")
|
if("${NEO_ARCH}" STREQUAL "x32")
|
||||||
set(BUILTIN_OPTIONS "-cl-intel-greater-than-4GB-buffer-required")
|
set(BUILTIN_OPTIONS "-cl-intel-greater-than-4GB-buffer-required")
|
||||||
else()
|
|
||||||
set(BUILTIN_OPTIONS "")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(BUILTIN_OPTIONS_STATELESS
|
|
||||||
"-cl-intel-greater-than-4GB-buffer-required"
|
|
||||||
)
|
|
||||||
|
|
||||||
if("${CMAKE_BUILD_TYPE}" STREQUAL "Debug")
|
|
||||||
list(APPEND __cloc__options__ "-D DEBUG")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(BUILTINS_INCLUDE_DIR ${TargetDir} PARENT_SCOPE)
|
|
||||||
set(BUILTIN_CPP "")
|
|
||||||
|
|
||||||
function(get_bits_for_stateless gen_type platform_type)
|
|
||||||
# Force 32bits compiling on gen9lp for stateless builtins
|
|
||||||
if((${GEN_TYPE} STREQUAL "GEN9") AND (${PLATFORM_TYPE} STREQUAL "LP"))
|
|
||||||
set(BITS "32" PARENT_SCOPE)
|
|
||||||
else()
|
else()
|
||||||
set(BITS ${NEO_BITS} PARENT_SCOPE)
|
set(BUILTIN_OPTIONS "")
|
||||||
endif()
|
endif()
|
||||||
endfunction()
|
|
||||||
|
|
||||||
# Define function for compiling built-ins (with ocloc)
|
set(BUILTIN_OPTIONS_STATELESS
|
||||||
function(compile_builtin gen_type platform_type builtin bits builtin_options)
|
"-cl-intel-greater-than-4GB-buffer-required"
|
||||||
string(TOLOWER ${gen_type} gen_type_lower)
|
|
||||||
get_family_name_with_type(${gen_type} ${platform_type})
|
|
||||||
set(OUTPUTDIR "${BUILTINS_OUTDIR_WITH_ARCH}/${gen_type_lower}")
|
|
||||||
# get filename
|
|
||||||
set(FILENAME ${builtin})
|
|
||||||
# get name of the file w/o extension
|
|
||||||
get_filename_component(BASENAME ${builtin} NAME_WE)
|
|
||||||
|
|
||||||
set(OUTPUTPATH_BASE "${OUTPUTDIR}/${BASENAME}_${family_name_with_type}")
|
|
||||||
set(OUTPUT_FILES
|
|
||||||
${OUTPUTPATH_BASE}.spv
|
|
||||||
${OUTPUTPATH_BASE}.bin
|
|
||||||
${OUTPUTPATH_BASE}.cpp
|
|
||||||
${OUTPUTPATH_BASE}.gen
|
|
||||||
)
|
)
|
||||||
|
|
||||||
# function returns builtin cpp filename
|
if("${CMAKE_BUILD_TYPE}" STREQUAL "Debug")
|
||||||
unset(BUILTIN_CPP)
|
list(APPEND __cloc__options__ "-D DEBUG")
|
||||||
# set variable outside function
|
endif()
|
||||||
set(BUILTIN_CPP built_ins/${NEO_ARCH}/${gen_type_lower}/${BASENAME}_${family_name_with_type}.cpp PARENT_SCOPE)
|
|
||||||
if(NOT DEFINED cloc_cmd_prefix)
|
set(BUILTINS_INCLUDE_DIR ${TargetDir} PARENT_SCOPE)
|
||||||
if(WIN32)
|
set(BUILTIN_CPP "")
|
||||||
set(cloc_cmd_prefix ocloc)
|
|
||||||
|
function(get_bits_for_stateless gen_type platform_type)
|
||||||
|
# Force 32bits compiling on gen9lp for stateless builtins
|
||||||
|
if((${GEN_TYPE} STREQUAL "GEN9") AND (${PLATFORM_TYPE} STREQUAL "LP"))
|
||||||
|
set(BITS "32" PARENT_SCOPE)
|
||||||
else()
|
else()
|
||||||
if(DEFINED NEO__IGC_LIBRARY_PATH)
|
set(BITS ${NEO_BITS} PARENT_SCOPE)
|
||||||
set(cloc_cmd_prefix LD_LIBRARY_PATH=${NEO__IGC_LIBRARY_PATH}:$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>)
|
endif()
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
# Define function for compiling built-ins (with ocloc)
|
||||||
|
function(compile_builtin gen_type platform_type builtin bits builtin_options)
|
||||||
|
string(TOLOWER ${gen_type} gen_type_lower)
|
||||||
|
get_family_name_with_type(${gen_type} ${platform_type})
|
||||||
|
set(OUTPUTDIR "${BUILTINS_OUTDIR_WITH_ARCH}/${gen_type_lower}")
|
||||||
|
# get filename
|
||||||
|
set(FILENAME ${builtin})
|
||||||
|
# get name of the file w/o extension
|
||||||
|
get_filename_component(BASENAME ${builtin} NAME_WE)
|
||||||
|
|
||||||
|
set(OUTPUTPATH_BASE "${OUTPUTDIR}/${BASENAME}_${family_name_with_type}")
|
||||||
|
set(OUTPUT_FILES
|
||||||
|
${OUTPUTPATH_BASE}.spv
|
||||||
|
${OUTPUTPATH_BASE}.bin
|
||||||
|
${OUTPUTPATH_BASE}.cpp
|
||||||
|
${OUTPUTPATH_BASE}.gen
|
||||||
|
)
|
||||||
|
|
||||||
|
# function returns builtin cpp filename
|
||||||
|
unset(BUILTIN_CPP)
|
||||||
|
# set variable outside function
|
||||||
|
set(BUILTIN_CPP built_ins/${NEO_ARCH}/${gen_type_lower}/${BASENAME}_${family_name_with_type}.cpp PARENT_SCOPE)
|
||||||
|
if(NOT DEFINED cloc_cmd_prefix)
|
||||||
|
if(WIN32)
|
||||||
|
set(cloc_cmd_prefix ocloc)
|
||||||
else()
|
else()
|
||||||
set(cloc_cmd_prefix LD_LIBRARY_PATH=$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>)
|
if(DEFINED NEO__IGC_LIBRARY_PATH)
|
||||||
|
set(cloc_cmd_prefix LD_LIBRARY_PATH=${NEO__IGC_LIBRARY_PATH}:$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>)
|
||||||
|
else()
|
||||||
|
set(cloc_cmd_prefix LD_LIBRARY_PATH=$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>)
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
|
||||||
|
|
||||||
list(APPEND __cloc__options__ "-cl-kernel-arg-info")
|
list(APPEND __cloc__options__ "-cl-kernel-arg-info")
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT ${OUTPUT_FILES}
|
OUTPUT ${OUTPUT_FILES}
|
||||||
COMMAND ${cloc_cmd_prefix} -q -file ${FILENAME} -device ${DEFAULT_SUPPORTED_${gen_type}_${platform_type}_PLATFORM} ${builtin_options} -${bits} -out_dir ${OUTPUTDIR} -options "$<JOIN:${__cloc__options__}, >"
|
COMMAND ${cloc_cmd_prefix} -q -file ${FILENAME} -device ${DEFAULT_SUPPORTED_${gen_type}_${platform_type}_PLATFORM} ${builtin_options} -${bits} -out_dir ${OUTPUTDIR} -options "$<JOIN:${__cloc__options__}, >"
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
DEPENDS ${builtin} ocloc copy_compiler_files
|
DEPENDS ${builtin} ocloc copy_compiler_files
|
||||||
)
|
)
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
macro(macro_for_each_gen)
|
macro(macro_for_each_gen)
|
||||||
foreach(PLATFORM_TYPE ${PLATFORM_TYPES})
|
foreach(PLATFORM_TYPE ${PLATFORM_TYPES})
|
||||||
if(${GEN_TYPE}_HAS_${PLATFORM_TYPE})
|
if(${GEN_TYPE}_HAS_${PLATFORM_TYPE})
|
||||||
get_family_name_with_type(${GEN_TYPE} ${PLATFORM_TYPE})
|
get_family_name_with_type(${GEN_TYPE} ${PLATFORM_TYPE})
|
||||||
string(TOLOWER ${PLATFORM_TYPE} PLATFORM_TYPE_LOWER)
|
string(TOLOWER ${PLATFORM_TYPE} PLATFORM_TYPE_LOWER)
|
||||||
unset(BUILTINS_COMMANDS)
|
unset(BUILTINS_COMMANDS)
|
||||||
foreach(GENERATED_BUILTIN ${GENERATED_BUILTINS})
|
foreach(GENERATED_BUILTIN ${GENERATED_BUILTINS})
|
||||||
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN}.builtin_kernel ${NEO_BITS} "${BUILTIN_OPTIONS}")
|
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN}.builtin_kernel ${NEO_BITS} "${BUILTIN_OPTIONS}")
|
||||||
list(APPEND BUILTINS_COMMANDS ${TargetDir}/${BUILTIN_CPP})
|
list(APPEND BUILTINS_COMMANDS ${TargetDir}/${BUILTIN_CPP})
|
||||||
endforeach()
|
endforeach()
|
||||||
get_bits_for_stateless(${GEN_TYPE} ${PLATFORM_TYPE})
|
get_bits_for_stateless(${GEN_TYPE} ${PLATFORM_TYPE})
|
||||||
foreach(GENERATED_BUILTIN_STATELESS ${GENERATED_BUILTINS_STATELESS})
|
foreach(GENERATED_BUILTIN_STATELESS ${GENERATED_BUILTINS_STATELESS})
|
||||||
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN_STATELESS}.builtin_kernel ${BITS} "${BUILTIN_OPTIONS_STATELESS}")
|
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN_STATELESS}.builtin_kernel ${BITS} "${BUILTIN_OPTIONS_STATELESS}")
|
||||||
list(APPEND BUILTINS_COMMANDS ${TargetDir}/${BUILTIN_CPP})
|
list(APPEND BUILTINS_COMMANDS ${TargetDir}/${BUILTIN_CPP})
|
||||||
endforeach()
|
endforeach()
|
||||||
set(target_name builtins_${family_name_with_type}_vme)
|
set(target_name builtins_${family_name_with_type}_vme)
|
||||||
add_custom_target(${target_name} DEPENDS ${BUILTINS_COMMANDS})
|
add_custom_target(${target_name} DEPENDS ${BUILTINS_COMMANDS})
|
||||||
add_dependencies(builtins ${target_name})
|
add_dependencies(builtins ${target_name})
|
||||||
set_target_properties(${target_name} PROPERTIES FOLDER "${OPENCL_RUNTIME_PROJECTS_FOLDER}/built_ins/${family_name_with_type}")
|
set_target_properties(${target_name} PROPERTIES FOLDER "${OPENCL_RUNTIME_PROJECTS_FOLDER}/built_ins/${family_name_with_type}")
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
apply_macro_for_each_gen("SUPPORTED")
|
apply_macro_for_each_gen("SUPPORTED")
|
||||||
|
endif()
|
||||||
|
|||||||
@@ -13,6 +13,6 @@ set(RUNTIME_SRCS_SCHEDULER
|
|||||||
target_sources(${NEO_STATIC_LIB_NAME} PRIVATE ${RUNTIME_SRCS_SCHEDULER})
|
target_sources(${NEO_STATIC_LIB_NAME} PRIVATE ${RUNTIME_SRCS_SCHEDULER})
|
||||||
set_property(GLOBAL PROPERTY RUNTIME_SRCS_SCHEDULER ${RUNTIME_SRCS_SCHEDULER})
|
set_property(GLOBAL PROPERTY RUNTIME_SRCS_SCHEDULER ${RUNTIME_SRCS_SCHEDULER})
|
||||||
|
|
||||||
if(NOT (TARGET ${SCHEDULER_BINARY_LIB_NAME}))
|
if(NOT NEO_DISABLE_BUILTINS_COMPILATION AND NOT (TARGET ${SCHEDULER_BINARY_LIB_NAME}))
|
||||||
include(scheduler_binary.cmake)
|
include(scheduler_binary.cmake)
|
||||||
endif()
|
endif()
|
||||||
|
|||||||
@@ -70,8 +70,12 @@ set(NEO_IGDRCL_TESTS__TARGET_OBJECTS
|
|||||||
$<TARGET_OBJECTS:${BUILTINS_SOURCES_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_SOURCES_LIB_NAME}>
|
||||||
$<TARGET_OBJECTS:${BUILTINS_VME_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_VME_LIB_NAME}>
|
||||||
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDFUL_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_BINARIES_BINDFUL_LIB_NAME}>
|
||||||
$<TARGET_OBJECTS:${SCHEDULER_BINARY_LIB_NAME}>
|
|
||||||
)
|
)
|
||||||
|
if(TARGET ${SCHEDULER_BINARY_LIB_NAME})
|
||||||
|
list(APPEND NEO_IGDRCL_TESTS__TARGET_OBJECTS
|
||||||
|
$<TARGET_OBJECTS:${SCHEDULER_BINARY_LIB_NAME}>
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(DEFINED AUB_STREAM_PROJECT_NAME)
|
if(DEFINED AUB_STREAM_PROJECT_NAME)
|
||||||
add_library(aub_stream_mock_lib OBJECT EXCLUDE_FROM_ALL
|
add_library(aub_stream_mock_lib OBJECT EXCLUDE_FROM_ALL
|
||||||
|
|||||||
@@ -17,12 +17,16 @@ list(APPEND IGDRCL_AUB_TESTS__TARGET_OBJECTS
|
|||||||
${NEO_SOURCE_DIR}/shared/test/common/test_macros/test_checks_shared.cpp
|
${NEO_SOURCE_DIR}/shared/test/common/test_macros/test_checks_shared.cpp
|
||||||
${NEO_SHARED_aub_tests_configurations}
|
${NEO_SHARED_aub_tests_configurations}
|
||||||
$<TARGET_OBJECTS:${BUILTINS_SOURCES_LIB_NAME}>
|
$<TARGET_OBJECTS:${BUILTINS_SOURCES_LIB_NAME}>
|
||||||
$<TARGET_OBJECTS:${SCHEDULER_BINARY_LIB_NAME}>
|
|
||||||
$<TARGET_OBJECTS:igdrcl_libult>
|
$<TARGET_OBJECTS:igdrcl_libult>
|
||||||
$<TARGET_OBJECTS:igdrcl_libult_common>
|
$<TARGET_OBJECTS:igdrcl_libult_common>
|
||||||
$<TARGET_OBJECTS:igdrcl_libult_cs>
|
$<TARGET_OBJECTS:igdrcl_libult_cs>
|
||||||
$<TARGET_OBJECTS:igdrcl_libult_env>
|
$<TARGET_OBJECTS:igdrcl_libult_env>
|
||||||
)
|
)
|
||||||
|
if(TARGET ${SCHEDULER_BINARY_LIB_NAME})
|
||||||
|
list(APPEND IGDRCL_AUB_TESTS__TARGET_OBJECTS
|
||||||
|
$<TARGET_OBJECTS:${SCHEDULER_BINARY_LIB_NAME}>
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(DEFINED AUB_STREAM_PROJECT_NAME)
|
if(DEFINED AUB_STREAM_PROJECT_NAME)
|
||||||
list(APPEND IGDRCL_AUB_TESTS__TARGET_OBJECTS $<TARGET_OBJECTS:${AUB_STREAM_PROJECT_NAME}_all_hw>)
|
list(APPEND IGDRCL_AUB_TESTS__TARGET_OBJECTS $<TARGET_OBJECTS:${AUB_STREAM_PROJECT_NAME}_all_hw>)
|
||||||
|
|||||||
@@ -4,209 +4,211 @@
|
|||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
#
|
#
|
||||||
|
|
||||||
add_custom_target(builtins)
|
if(NOT NEO_DISABLE_BUILTINS_COMPILATION)
|
||||||
set_target_properties(builtins PROPERTIES FOLDER "${SHARED_SOURCE_PROJECTS_FOLDER}/${SHARED_BUIILINS_PROJECTS_FOLDER}")
|
add_custom_target(builtins)
|
||||||
set(BUILTINS_OUTDIR_WITH_ARCH "${TargetDir}/built_ins/${NEO_ARCH}")
|
set_target_properties(builtins PROPERTIES FOLDER "${SHARED_SOURCE_PROJECTS_FOLDER}/${SHARED_BUIILINS_PROJECTS_FOLDER}")
|
||||||
add_dependencies(${BUILTINS_BINARIES_BINDFUL_LIB_NAME} builtins)
|
set(BUILTINS_OUTDIR_WITH_ARCH "${TargetDir}/built_ins/${NEO_ARCH}")
|
||||||
add_dependencies(${BUILTINS_BINARIES_BINDLESS_LIB_NAME} builtins)
|
add_dependencies(${BUILTINS_BINARIES_BINDFUL_LIB_NAME} builtins)
|
||||||
add_subdirectories()
|
add_dependencies(${BUILTINS_BINARIES_BINDLESS_LIB_NAME} builtins)
|
||||||
set(GENERATED_BUILTINS ${GENERATED_BUILTINS} PARENT_SCOPE)
|
add_subdirectories()
|
||||||
set(GENERATED_BUILTINS_IMAGES ${GENERATED_BUILTINS_IMAGES} PARENT_SCOPE)
|
set(GENERATED_BUILTINS ${GENERATED_BUILTINS} PARENT_SCOPE)
|
||||||
set(GENERATED_BUILTINS_STATELESS ${GENERATED_BUILTINS_STATELESS} PARENT_SCOPE)
|
set(GENERATED_BUILTINS_IMAGES ${GENERATED_BUILTINS_IMAGES} PARENT_SCOPE)
|
||||||
|
set(GENERATED_BUILTINS_STATELESS ${GENERATED_BUILTINS_STATELESS} PARENT_SCOPE)
|
||||||
|
|
||||||
if("${NEO_ARCH}" STREQUAL "x32")
|
if("${NEO_ARCH}" STREQUAL "x32")
|
||||||
set(BUILTIN_OPTIONS "-cl-intel-greater-than-4GB-buffer-required")
|
set(BUILTIN_OPTIONS "-cl-intel-greater-than-4GB-buffer-required")
|
||||||
else()
|
|
||||||
set(BUILTIN_OPTIONS "")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(BUILTIN_OPTIONS_STATELESS
|
|
||||||
"-cl-intel-greater-than-4GB-buffer-required"
|
|
||||||
)
|
|
||||||
|
|
||||||
set(bindless_OPTIONS
|
|
||||||
-internal_options "-cl-intel-use-bindless-mode"
|
|
||||||
)
|
|
||||||
|
|
||||||
set(bindful_OPTIONS
|
|
||||||
""
|
|
||||||
)
|
|
||||||
|
|
||||||
if("${CMAKE_BUILD_TYPE}" STREQUAL "Debug")
|
|
||||||
list(APPEND __cloc__options__ "-D DEBUG")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(BUILTINS_INCLUDE_DIR ${TargetDir} PARENT_SCOPE)
|
|
||||||
set(BUILTIN_CPP "")
|
|
||||||
|
|
||||||
function(get_bits_for_stateless gen_type platform_type)
|
|
||||||
# Force 32bits compiling on gen9lp for stateless builtins
|
|
||||||
if((${gen_type} STREQUAL "GEN9") AND (${platform_type} STREQUAL "LP"))
|
|
||||||
set(BITS "32" PARENT_SCOPE)
|
|
||||||
else()
|
else()
|
||||||
set(BITS ${NEO_BITS} PARENT_SCOPE)
|
set(BUILTIN_OPTIONS "")
|
||||||
endif()
|
endif()
|
||||||
endfunction()
|
|
||||||
|
|
||||||
# Define function for compiling built-ins (with ocloc)
|
set(BUILTIN_OPTIONS_STATELESS
|
||||||
function(compile_builtin gen_type platform_type builtin bits builtin_options mode)
|
"-cl-intel-greater-than-4GB-buffer-required"
|
||||||
string(TOLOWER ${gen_type} gen_type_lower)
|
|
||||||
get_family_name_with_type(${gen_type} ${platform_type})
|
|
||||||
set(OUTPUTDIR "${BUILTINS_OUTDIR_WITH_ARCH}/${gen_type_lower}")
|
|
||||||
# get filename
|
|
||||||
set(FILENAME ${builtin})
|
|
||||||
# get name of the file w/o extension
|
|
||||||
get_filename_component(BASENAME ${builtin} NAME_WE)
|
|
||||||
|
|
||||||
set(OUTPUT_FILE_SPV
|
|
||||||
${OUTPUTDIR}/${mode}_${BASENAME}_${family_name_with_type}.spv
|
|
||||||
)
|
)
|
||||||
|
|
||||||
if(NOT DEFINED cloc_cmd_prefix)
|
set(bindless_OPTIONS
|
||||||
if(WIN32)
|
-internal_options "-cl-intel-use-bindless-mode"
|
||||||
set(cloc_cmd_prefix ocloc)
|
)
|
||||||
|
|
||||||
|
set(bindful_OPTIONS
|
||||||
|
""
|
||||||
|
)
|
||||||
|
|
||||||
|
if("${CMAKE_BUILD_TYPE}" STREQUAL "Debug")
|
||||||
|
list(APPEND __cloc__options__ "-D DEBUG")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(BUILTINS_INCLUDE_DIR ${TargetDir} PARENT_SCOPE)
|
||||||
|
set(BUILTIN_CPP "")
|
||||||
|
|
||||||
|
function(get_bits_for_stateless gen_type platform_type)
|
||||||
|
# Force 32bits compiling on gen9lp for stateless builtins
|
||||||
|
if((${gen_type} STREQUAL "GEN9") AND (${platform_type} STREQUAL "LP"))
|
||||||
|
set(BITS "32" PARENT_SCOPE)
|
||||||
else()
|
else()
|
||||||
if(DEFINED NEO__IGC_LIBRARY_PATH)
|
set(BITS ${NEO_BITS} PARENT_SCOPE)
|
||||||
set(cloc_cmd_prefix LD_LIBRARY_PATH=${NEO__IGC_LIBRARY_PATH}:$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>)
|
endif()
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
# Define function for compiling built-ins (with ocloc)
|
||||||
|
function(compile_builtin gen_type platform_type builtin bits builtin_options mode)
|
||||||
|
string(TOLOWER ${gen_type} gen_type_lower)
|
||||||
|
get_family_name_with_type(${gen_type} ${platform_type})
|
||||||
|
set(OUTPUTDIR "${BUILTINS_OUTDIR_WITH_ARCH}/${gen_type_lower}")
|
||||||
|
# get filename
|
||||||
|
set(FILENAME ${builtin})
|
||||||
|
# get name of the file w/o extension
|
||||||
|
get_filename_component(BASENAME ${builtin} NAME_WE)
|
||||||
|
|
||||||
|
set(OUTPUT_FILE_SPV
|
||||||
|
${OUTPUTDIR}/${mode}_${BASENAME}_${family_name_with_type}.spv
|
||||||
|
)
|
||||||
|
|
||||||
|
if(NOT DEFINED cloc_cmd_prefix)
|
||||||
|
if(WIN32)
|
||||||
|
set(cloc_cmd_prefix ocloc)
|
||||||
else()
|
else()
|
||||||
set(cloc_cmd_prefix LD_LIBRARY_PATH=$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>)
|
if(DEFINED NEO__IGC_LIBRARY_PATH)
|
||||||
|
set(cloc_cmd_prefix LD_LIBRARY_PATH=${NEO__IGC_LIBRARY_PATH}:$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>)
|
||||||
|
else()
|
||||||
|
set(cloc_cmd_prefix LD_LIBRARY_PATH=$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>)
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
list(APPEND __cloc__options__ "-cl-kernel-arg-info")
|
||||||
list(APPEND __cloc__options__ "-cl-kernel-arg-info")
|
set(INTERNAL_OPTIONS "${${mode}_OPTIONS}")
|
||||||
set(INTERNAL_OPTIONS "${${mode}_OPTIONS}")
|
|
||||||
add_custom_command(
|
|
||||||
OUTPUT ${OUTPUT_FILE_SPV}
|
|
||||||
COMMAND ${cloc_cmd_prefix} -q -file ${FILENAME} -spv_only -device ${DEFAULT_SUPPORTED_${gen_type}_${platform_type}_PLATFORM} ${builtin_options} -${bits} -output ${mode}_${BASENAME} -out_dir ${OUTPUTDIR} ${INTERNAL_OPTIONS} -options "$<JOIN:${__cloc__options__}, >"
|
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
|
||||||
DEPENDS ${builtin} ocloc copy_compiler_files
|
|
||||||
)
|
|
||||||
foreach(REVISION_ID ${${platform_type}_${gen_type}_REVISIONS})
|
|
||||||
set(OUTPUT_FILE_CPP
|
|
||||||
${OUTPUTDIR}/${mode}_${BASENAME}_${family_name_with_type}_${REVISION_ID}.cpp
|
|
||||||
)
|
|
||||||
set(BINARY_OUTPUT "${OUTPUTDIR}/${mode}_${BASENAME}_${REVISION_ID}_${family_name_with_type}")
|
|
||||||
set(OUTPUT_FILES_BINARIES
|
|
||||||
${BINARY_OUTPUT}.gen
|
|
||||||
${BINARY_OUTPUT}.bin
|
|
||||||
)
|
|
||||||
list(APPEND BUILTINS_COMMANDS "${OUTPUT_FILE_CPP}")
|
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT ${OUTPUT_FILES_BINARIES}
|
OUTPUT ${OUTPUT_FILE_SPV}
|
||||||
COMMAND ${cloc_cmd_prefix} -q -file ${OUTPUT_FILE_SPV} -spirv_input -device ${DEFAULT_SUPPORTED_${gen_type}_${platform_type}_PLATFORM} ${builtin_options} -${bits} -output ${mode}_${BASENAME}_${REVISION_ID} -out_dir ${OUTPUTDIR} -revision_id ${REVISION_ID} ${INTERNAL_OPTIONS} -options "$<JOIN:${__cloc__options__}, >"
|
COMMAND ${cloc_cmd_prefix} -q -file ${FILENAME} -spv_only -device ${DEFAULT_SUPPORTED_${gen_type}_${platform_type}_PLATFORM} ${builtin_options} -${bits} -output ${mode}_${BASENAME} -out_dir ${OUTPUTDIR} ${INTERNAL_OPTIONS} -options "$<JOIN:${__cloc__options__}, >"
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
DEPENDS ${OUTPUT_FILE_SPV} ocloc copy_compiler_files
|
DEPENDS ${builtin} ocloc copy_compiler_files
|
||||||
|
)
|
||||||
|
foreach(REVISION_ID ${${platform_type}_${gen_type}_REVISIONS})
|
||||||
|
set(OUTPUT_FILE_CPP
|
||||||
|
${OUTPUTDIR}/${mode}_${BASENAME}_${family_name_with_type}_${REVISION_ID}.cpp
|
||||||
|
)
|
||||||
|
set(BINARY_OUTPUT "${OUTPUTDIR}/${mode}_${BASENAME}_${REVISION_ID}_${family_name_with_type}")
|
||||||
|
set(OUTPUT_FILES_BINARIES
|
||||||
|
${BINARY_OUTPUT}.gen
|
||||||
|
${BINARY_OUTPUT}.bin
|
||||||
|
)
|
||||||
|
list(APPEND BUILTINS_COMMANDS "${OUTPUT_FILE_CPP}")
|
||||||
|
add_custom_command(
|
||||||
|
OUTPUT ${OUTPUT_FILES_BINARIES}
|
||||||
|
COMMAND ${cloc_cmd_prefix} -q -file ${OUTPUT_FILE_SPV} -spirv_input -device ${DEFAULT_SUPPORTED_${gen_type}_${platform_type}_PLATFORM} ${builtin_options} -${bits} -output ${mode}_${BASENAME}_${REVISION_ID} -out_dir ${OUTPUTDIR} -revision_id ${REVISION_ID} ${INTERNAL_OPTIONS} -options "$<JOIN:${__cloc__options__}, >"
|
||||||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
|
DEPENDS ${OUTPUT_FILE_SPV} ocloc copy_compiler_files
|
||||||
|
)
|
||||||
|
add_custom_command(
|
||||||
|
OUTPUT ${OUTPUT_FILE_CPP}
|
||||||
|
COMMAND $<TARGET_FILE:cpp_generate_tool> --file ${BINARY_OUTPUT}.gen --output ${OUTPUT_FILE_CPP} --array ${mode}_${BASENAME} --platform ${family_name_with_type} --revision_id ${REVISION_ID}
|
||||||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
|
DEPENDS ${OUTPUT_FILES_BINARIES} $<TARGET_FILE:cpp_generate_tool>
|
||||||
|
)
|
||||||
|
endforeach()
|
||||||
|
set(BUILTINS_COMMANDS ${BUILTINS_COMMANDS} PARENT_SCOPE)
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
function(generate_cpp_spirv builtin)
|
||||||
|
if(NOT DEFINED cloc_cmd_prefix)
|
||||||
|
if(WIN32)
|
||||||
|
set(cloc_cmd_prefix $<TARGET_FILE:ocloc>)
|
||||||
|
else()
|
||||||
|
if(DEFINED NEO__IGC_LIBRARY_PATH)
|
||||||
|
set(cloc_cmd_prefix LD_LIBRARY_PATH=${NEO__IGC_LIBRARY_PATH}:$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>)
|
||||||
|
else()
|
||||||
|
set(cloc_cmd_prefix LD_LIBRARY_PATH=$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
get_filename_component(BASENAME ${builtin} NAME_WE)
|
||||||
|
get_filename_component(DIR ${builtin} DIRECTORY)
|
||||||
|
|
||||||
|
set(OUTPUTDIR "${BUILTINS_OUTDIR_WITH_ARCH}/spirv/${DIR}")
|
||||||
|
string(REPLACE "//" "/" OUTPUTDIR ${OUTPUTDIR})
|
||||||
|
|
||||||
|
set(INPUT_FILENAME ${builtin}.builtin_kernel)
|
||||||
|
|
||||||
|
set(GENERATED_SPV_INPUT ${OUTPUTDIR}/${BASENAME}.spv)
|
||||||
|
set(OUTPUT_FILE_CPP
|
||||||
|
${OUTPUTDIR}/${BASENAME}.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
set(OUTPUT_LIST_SPV_FILES ${OUTPUT_LIST_SPV_FILES} ${OUTPUT_FILES_FOR_SPV} PARENT_SCOPE)
|
||||||
|
set(OUTPUT_LIST_CPP_FILES ${OUTPUT_LIST_CPP_FILES} ${OUTPUT_FILE_CPP} PARENT_SCOPE)
|
||||||
|
add_custom_command(
|
||||||
|
OUTPUT ${GENERATED_SPV_INPUT}
|
||||||
|
COMMAND ${cloc_cmd_prefix} -q -spv_only -file ${INPUT_FILENAME} -out_dir ${OUTPUTDIR} -output_no_suffix -options "-cl-kernel-arg-info"
|
||||||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
|
DEPENDS ${INPUT_FILENAME} ocloc copy_compiler_files
|
||||||
)
|
)
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT ${OUTPUT_FILE_CPP}
|
OUTPUT ${OUTPUT_FILE_CPP}
|
||||||
COMMAND $<TARGET_FILE:cpp_generate_tool> --file ${BINARY_OUTPUT}.gen --output ${OUTPUT_FILE_CPP} --array ${mode}_${BASENAME} --platform ${family_name_with_type} --revision_id ${REVISION_ID}
|
COMMAND $<TARGET_FILE:cpp_generate_tool> --file ${GENERATED_SPV_INPUT} --output ${OUTPUT_FILE_CPP} --array ${BASENAME}
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
DEPENDS ${OUTPUT_FILES_BINARIES} $<TARGET_FILE:cpp_generate_tool>
|
DEPENDS ${GENERATED_SPV_INPUT} $<TARGET_FILE:cpp_generate_tool>
|
||||||
)
|
)
|
||||||
endforeach()
|
endfunction()
|
||||||
set(BUILTINS_COMMANDS ${BUILTINS_COMMANDS} PARENT_SCOPE)
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
function(generate_cpp_spirv builtin)
|
macro(macro_for_each_gen)
|
||||||
if(NOT DEFINED cloc_cmd_prefix)
|
foreach(PLATFORM_TYPE ${PLATFORM_TYPES})
|
||||||
if(WIN32)
|
if(${GEN_TYPE}_HAS_${PLATFORM_TYPE})
|
||||||
set(cloc_cmd_prefix $<TARGET_FILE:ocloc>)
|
unset(IMAGE_SUPPORT)
|
||||||
else()
|
GEN_CONTAINS_PLATFORMS("SUPPORTED_IMAGES" ${GEN_TYPE} IMAGE_SUPPORT)
|
||||||
if(DEFINED NEO__IGC_LIBRARY_PATH)
|
get_family_name_with_type(${GEN_TYPE} ${PLATFORM_TYPE})
|
||||||
set(cloc_cmd_prefix LD_LIBRARY_PATH=${NEO__IGC_LIBRARY_PATH}:$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>)
|
string(TOLOWER ${PLATFORM_TYPE} PLATFORM_TYPE_LOWER)
|
||||||
else()
|
get_bits_for_stateless(${GEN_TYPE} ${PLATFORM_TYPE})
|
||||||
set(cloc_cmd_prefix LD_LIBRARY_PATH=$<TARGET_FILE_DIR:ocloc_lib> $<TARGET_FILE:ocloc>)
|
set(target_name builtins_${family_name_with_type})
|
||||||
|
add_custom_target(${target_name})
|
||||||
|
add_dependencies(builtins ${target_name})
|
||||||
|
set_target_properties(${target_name} PROPERTIES FOLDER "${SHARED_SOURCE_PROJECTS_FOLDER}/${SHARED_BUIILINS_PROJECTS_FOLDER}/${family_name_with_type}")
|
||||||
|
foreach(MODE ${BIND_MODES})
|
||||||
|
unset(BUILTINS_COMMANDS)
|
||||||
|
foreach(GENERATED_BUILTIN ${GENERATED_BUILTINS})
|
||||||
|
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN}.builtin_kernel ${NEO_BITS} "${BUILTIN_OPTIONS}" ${MODE})
|
||||||
|
endforeach()
|
||||||
|
foreach(GENERATED_BUILTIN_STATELESS ${GENERATED_BUILTINS_STATELESS})
|
||||||
|
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN_STATELESS}.builtin_kernel ${BITS} "${BUILTIN_OPTIONS_STATELESS}" ${MODE})
|
||||||
|
endforeach()
|
||||||
|
if(${IMAGE_SUPPORT})
|
||||||
|
foreach(GENERATED_BUILTINS_IMAGES ${GENERATED_BUILTINS_IMAGES})
|
||||||
|
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTINS_IMAGES}.builtin_kernel ${NEO_BITS} "${BUILTIN_OPTIONS}" ${MODE})
|
||||||
|
endforeach()
|
||||||
|
foreach(GENERATED_BUILTIN_IMAGES_STATELESS ${GENERATED_BUILTINS_IMAGES_STATELESS})
|
||||||
|
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN_IMAGES_STATELESS}.builtin_kernel ${BITS} "${BUILTIN_OPTIONS_STATELESS}" ${MODE})
|
||||||
|
endforeach()
|
||||||
|
endif()
|
||||||
|
get_property(GENERATED_BUILTINS_CPPS_${MODE} GLOBAL PROPERTY GENERATED_BUILTINS_CPPS_${MODE})
|
||||||
|
foreach(BUILTIN ${BUILTINS_COMMANDS})
|
||||||
|
list(APPEND GENERATED_BUILTINS_CPPS_${MODE} ${BUILTIN})
|
||||||
|
endforeach()
|
||||||
|
set_property(GLOBAL PROPERTY GENERATED_BUILTINS_CPPS_${MODE} ${GENERATED_BUILTINS_CPPS_${MODE}})
|
||||||
|
add_custom_target(${target_name}_${MODE} DEPENDS ${BUILTINS_COMMANDS})
|
||||||
|
add_dependencies(${target_name} ${target_name}_${MODE})
|
||||||
|
set_target_properties(${target_name}_${MODE} PROPERTIES FOLDER "${SHARED_SOURCE_PROJECTS_FOLDER}/${SHARED_BUIILINS_PROJECTS_FOLDER}/${family_name_with_type}")
|
||||||
|
endforeach()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endforeach()
|
||||||
endif()
|
endmacro()
|
||||||
|
|
||||||
get_filename_component(BASENAME ${builtin} NAME_WE)
|
file(MAKE_DIRECTORY "${BUILTINS_OUTDIR_WITH_ARCH}/spirv")
|
||||||
get_filename_component(DIR ${builtin} DIRECTORY)
|
foreach(builtin ${GENERATED_BUILTINS})
|
||||||
|
generate_cpp_spirv(${builtin})
|
||||||
set(OUTPUTDIR "${BUILTINS_OUTDIR_WITH_ARCH}/spirv/${DIR}")
|
|
||||||
string(REPLACE "//" "/" OUTPUTDIR ${OUTPUTDIR})
|
|
||||||
|
|
||||||
set(INPUT_FILENAME ${builtin}.builtin_kernel)
|
|
||||||
|
|
||||||
set(GENERATED_SPV_INPUT ${OUTPUTDIR}/${BASENAME}.spv)
|
|
||||||
set(OUTPUT_FILE_CPP
|
|
||||||
${OUTPUTDIR}/${BASENAME}.cpp
|
|
||||||
)
|
|
||||||
|
|
||||||
set(OUTPUT_LIST_SPV_FILES ${OUTPUT_LIST_SPV_FILES} ${OUTPUT_FILES_FOR_SPV} PARENT_SCOPE)
|
|
||||||
set(OUTPUT_LIST_CPP_FILES ${OUTPUT_LIST_CPP_FILES} ${OUTPUT_FILE_CPP} PARENT_SCOPE)
|
|
||||||
add_custom_command(
|
|
||||||
OUTPUT ${GENERATED_SPV_INPUT}
|
|
||||||
COMMAND ${cloc_cmd_prefix} -q -spv_only -file ${INPUT_FILENAME} -out_dir ${OUTPUTDIR} -output_no_suffix -options "-cl-kernel-arg-info"
|
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
|
||||||
DEPENDS ${INPUT_FILENAME} ocloc copy_compiler_files
|
|
||||||
)
|
|
||||||
add_custom_command(
|
|
||||||
OUTPUT ${OUTPUT_FILE_CPP}
|
|
||||||
COMMAND $<TARGET_FILE:cpp_generate_tool> --file ${GENERATED_SPV_INPUT} --output ${OUTPUT_FILE_CPP} --array ${BASENAME}
|
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
|
||||||
DEPENDS ${GENERATED_SPV_INPUT} $<TARGET_FILE:cpp_generate_tool>
|
|
||||||
)
|
|
||||||
endfunction()
|
|
||||||
|
|
||||||
macro(macro_for_each_gen)
|
|
||||||
foreach(PLATFORM_TYPE ${PLATFORM_TYPES})
|
|
||||||
if(${GEN_TYPE}_HAS_${PLATFORM_TYPE})
|
|
||||||
unset(IMAGE_SUPPORT)
|
|
||||||
GEN_CONTAINS_PLATFORMS("SUPPORTED_IMAGES" ${GEN_TYPE} IMAGE_SUPPORT)
|
|
||||||
get_family_name_with_type(${GEN_TYPE} ${PLATFORM_TYPE})
|
|
||||||
string(TOLOWER ${PLATFORM_TYPE} PLATFORM_TYPE_LOWER)
|
|
||||||
get_bits_for_stateless(${GEN_TYPE} ${PLATFORM_TYPE})
|
|
||||||
set(target_name builtins_${family_name_with_type})
|
|
||||||
add_custom_target(${target_name})
|
|
||||||
add_dependencies(builtins ${target_name})
|
|
||||||
set_target_properties(${target_name} PROPERTIES FOLDER "${SHARED_SOURCE_PROJECTS_FOLDER}/${SHARED_BUIILINS_PROJECTS_FOLDER}/${family_name_with_type}")
|
|
||||||
foreach(MODE ${BIND_MODES})
|
|
||||||
unset(BUILTINS_COMMANDS)
|
|
||||||
foreach(GENERATED_BUILTIN ${GENERATED_BUILTINS})
|
|
||||||
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN}.builtin_kernel ${NEO_BITS} "${BUILTIN_OPTIONS}" ${MODE})
|
|
||||||
endforeach()
|
|
||||||
foreach(GENERATED_BUILTIN_STATELESS ${GENERATED_BUILTINS_STATELESS})
|
|
||||||
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN_STATELESS}.builtin_kernel ${BITS} "${BUILTIN_OPTIONS_STATELESS}" ${MODE})
|
|
||||||
endforeach()
|
|
||||||
if(${IMAGE_SUPPORT})
|
|
||||||
foreach(GENERATED_BUILTINS_IMAGES ${GENERATED_BUILTINS_IMAGES})
|
|
||||||
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTINS_IMAGES}.builtin_kernel ${NEO_BITS} "${BUILTIN_OPTIONS}" ${MODE})
|
|
||||||
endforeach()
|
|
||||||
foreach(GENERATED_BUILTIN_IMAGES_STATELESS ${GENERATED_BUILTINS_IMAGES_STATELESS})
|
|
||||||
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN_IMAGES_STATELESS}.builtin_kernel ${BITS} "${BUILTIN_OPTIONS_STATELESS}" ${MODE})
|
|
||||||
endforeach()
|
|
||||||
endif()
|
|
||||||
get_property(GENERATED_BUILTINS_CPPS_${MODE} GLOBAL PROPERTY GENERATED_BUILTINS_CPPS_${MODE})
|
|
||||||
foreach(BUILTIN ${BUILTINS_COMMANDS})
|
|
||||||
list(APPEND GENERATED_BUILTINS_CPPS_${MODE} ${BUILTIN})
|
|
||||||
endforeach()
|
|
||||||
set_property(GLOBAL PROPERTY GENERATED_BUILTINS_CPPS_${MODE} ${GENERATED_BUILTINS_CPPS_${MODE}})
|
|
||||||
add_custom_target(${target_name}_${MODE} DEPENDS ${BUILTINS_COMMANDS})
|
|
||||||
add_dependencies(${target_name} ${target_name}_${MODE})
|
|
||||||
set_target_properties(${target_name}_${MODE} PROPERTIES FOLDER "${SHARED_SOURCE_PROJECTS_FOLDER}/${SHARED_BUIILINS_PROJECTS_FOLDER}/${family_name_with_type}")
|
|
||||||
endforeach()
|
|
||||||
endif()
|
|
||||||
endforeach()
|
endforeach()
|
||||||
endmacro()
|
foreach(builtin_images ${GENERATED_BUILTINS_IMAGES})
|
||||||
|
generate_cpp_spirv(${builtin_images})
|
||||||
|
endforeach()
|
||||||
|
foreach(builtin_stateless ${GENERATED_BUILTINS_STATELESS})
|
||||||
|
generate_cpp_spirv(${builtin_stateless})
|
||||||
|
endforeach()
|
||||||
|
foreach(builtin_images_stateless ${GENERATED_BUILTINS_IMAGES_STATELESS})
|
||||||
|
generate_cpp_spirv(${builtin_images_stateless})
|
||||||
|
endforeach()
|
||||||
|
add_library(${BUILTINS_SPIRV_LIB_NAME} OBJECT ${OUTPUT_LIST_CPP_FILES})
|
||||||
|
set_target_properties(${BUILTINS_SPIRV_LIB_NAME} PROPERTIES
|
||||||
|
POSITION_INDEPENDENT_CODE ON
|
||||||
|
FOLDER "${SHARED_SOURCE_PROJECTS_FOLDER}/${SHARED_BUIILINS_PROJECTS_FOLDER}"
|
||||||
|
)
|
||||||
|
|
||||||
file(MAKE_DIRECTORY "${BUILTINS_OUTDIR_WITH_ARCH}/spirv")
|
apply_macro_for_each_gen("SUPPORTED")
|
||||||
foreach(builtin ${GENERATED_BUILTINS})
|
endif()
|
||||||
generate_cpp_spirv(${builtin})
|
|
||||||
endforeach()
|
|
||||||
foreach(builtin_images ${GENERATED_BUILTINS_IMAGES})
|
|
||||||
generate_cpp_spirv(${builtin_images})
|
|
||||||
endforeach()
|
|
||||||
foreach(builtin_stateless ${GENERATED_BUILTINS_STATELESS})
|
|
||||||
generate_cpp_spirv(${builtin_stateless})
|
|
||||||
endforeach()
|
|
||||||
foreach(builtin_images_stateless ${GENERATED_BUILTINS_IMAGES_STATELESS})
|
|
||||||
generate_cpp_spirv(${builtin_images_stateless})
|
|
||||||
endforeach()
|
|
||||||
add_library(${BUILTINS_SPIRV_LIB_NAME} OBJECT ${OUTPUT_LIST_CPP_FILES})
|
|
||||||
set_target_properties(${BUILTINS_SPIRV_LIB_NAME} PROPERTIES
|
|
||||||
POSITION_INDEPENDENT_CODE ON
|
|
||||||
FOLDER "${SHARED_SOURCE_PROJECTS_FOLDER}/${SHARED_BUIILINS_PROJECTS_FOLDER}"
|
|
||||||
)
|
|
||||||
|
|
||||||
apply_macro_for_each_gen("SUPPORTED")
|
|
||||||
|
|||||||
Reference in New Issue
Block a user