Update builtins generation
Use revision id when generating cpp files. Related-To: NEO-5167 Signed-off-by: Filip Hazubski <filip.hazubski@intel.com>
This commit is contained in:
parent
9d0422cf69
commit
ae484993e2
|
@ -1,5 +1,5 @@
|
||||||
#
|
#
|
||||||
# Copyright (C) 2017-2020 Intel Corporation
|
# Copyright (C) 2017-2021 Intel Corporation
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
#
|
#
|
||||||
|
@ -90,13 +90,11 @@ macro(macro_for_each_gen)
|
||||||
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})
|
||||||
set(RUNTIME_GENERATED_${GENERATED_BUILTIN}_${family_name_with_type} ${BUILTIN_CPP} PARENT_SCOPE)
|
|
||||||
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})
|
||||||
set(RUNTIME_GENERATED_${GENERATED_BUILTIN_STATELESS}_${family_name_with_type} ${BUILTIN_CPP} PARENT_SCOPE)
|
|
||||||
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})
|
||||||
|
|
|
@ -1199,3 +1199,14 @@ TEST_F(HwHelperTest, whenFtrGpGpuMidThreadLevelPreemptFeatureDisabledThenFalseIs
|
||||||
bool result = hwHelper.isAdditionalFeatureFlagRequired(&featureTable);
|
bool result = hwHelper.isAdditionalFeatureFlagRequired(&featureTable);
|
||||||
EXPECT_FALSE(result);
|
EXPECT_FALSE(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST_F(HwHelperTest, whenGettingDefaultRevisionIdThenCorrectValueIsReturned) {
|
||||||
|
auto &hwHelper = HwHelper::get(renderCoreFamily);
|
||||||
|
auto revisionId = hwHelper.getDefaultRevisionId(*defaultHwInfo);
|
||||||
|
if ((defaultHwInfo->platform.eRenderCoreFamily == IGFX_GEN9_CORE) &&
|
||||||
|
(strcmp(defaultHwInfo->capabilityTable.platformType, "core") == 0)) {
|
||||||
|
EXPECT_EQ(9u, revisionId);
|
||||||
|
} else {
|
||||||
|
EXPECT_EQ(0u, revisionId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2020 Intel Corporation
|
* Copyright (C) 2020-2021 Intel Corporation
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: MIT
|
* SPDX-License-Identifier: MIT
|
||||||
*
|
*
|
||||||
|
@ -20,13 +20,13 @@ static void show_usage(std::string name) {
|
||||||
<< "\t -p, --platform\t\tOPTIONAL - Family name with type\n"
|
<< "\t -p, --platform\t\tOPTIONAL - Family name with type\n"
|
||||||
<< "\t -a, --array\t\tName of an uin32_t type array containing parsed input file" << std::endl;
|
<< "\t -a, --array\t\tName of an uin32_t type array containing parsed input file" << std::endl;
|
||||||
}
|
}
|
||||||
std::string parseToCharArray(std::unique_ptr<uint8_t[]> binary, size_t size, std::string &builtinName, std::string &platform, bool isSpirV) {
|
std::string parseToCharArray(std::unique_ptr<uint8_t[]> binary, size_t size, std::string &builtinName, std::string &platform, std::string revisionId, bool isSpirV) {
|
||||||
std::ostringstream out;
|
std::ostringstream out;
|
||||||
|
|
||||||
out << "#include <cstddef>\n";
|
out << "#include <cstddef>\n";
|
||||||
out << "#include <cstdint>\n\n";
|
out << "#include <cstdint>\n\n";
|
||||||
out << "size_t " << builtinName << "BinarySize_" << platform << " = " << size << ";\n";
|
out << "size_t " << builtinName << "BinarySize_" << platform << "_" << revisionId << " = " << size << ";\n";
|
||||||
out << "uint32_t " << builtinName << "Binary_" << platform << "[" << (size + 3) / 4 << "] = {"
|
out << "uint32_t " << builtinName << "Binary_" << platform << "_" << revisionId << "[" << (size + 3) / 4 << "] = {"
|
||||||
<< std::endl
|
<< std::endl
|
||||||
<< " ";
|
<< " ";
|
||||||
uint32_t *binaryUint = reinterpret_cast<uint32_t *>(binary.get());
|
uint32_t *binaryUint = reinterpret_cast<uint32_t *>(binary.get());
|
||||||
|
@ -60,11 +60,11 @@ std::string parseToCharArray(std::unique_ptr<uint8_t[]> binary, size_t size, std
|
||||||
isSpirV ? out << "Ir(" : out << "Bin(";
|
isSpirV ? out << "Ir(" : out << "Bin(";
|
||||||
out << std::endl;
|
out << std::endl;
|
||||||
out << " \"";
|
out << " \"";
|
||||||
platform != "" ? out << platform << "_0_" << builtinName : out << builtinName;
|
platform != "" ? out << platform << "_" << revisionId << "_" << builtinName : out << builtinName;
|
||||||
isSpirV ? out << ".builtin_kernel.bc\"," : out << ".builtin_kernel.bin\",";
|
isSpirV ? out << ".builtin_kernel.bc\"," : out << ".builtin_kernel.bin\",";
|
||||||
out << std::endl;
|
out << std::endl;
|
||||||
out << " (const char *)" << builtinName << "Binary_" << platform << "," << std::endl;
|
out << " (const char *)" << builtinName << "Binary_" << platform << "_" << revisionId << "," << std::endl;
|
||||||
out << " " << builtinName << "BinarySize_" << platform << ");" << std::endl;
|
out << " " << builtinName << "BinarySize_" << platform << "_" << revisionId << ");" << std::endl;
|
||||||
out << "}" << std::endl;
|
out << "}" << std::endl;
|
||||||
|
|
||||||
return out.str();
|
return out.str();
|
||||||
|
@ -79,6 +79,7 @@ int main(int argc, char *argv[]) {
|
||||||
std::string cppOutputName;
|
std::string cppOutputName;
|
||||||
std::string arrayName;
|
std::string arrayName;
|
||||||
std::string platform = "";
|
std::string platform = "";
|
||||||
|
std::string revisionId = "0";
|
||||||
size_t size = 0;
|
size_t size = 0;
|
||||||
std::fstream inputFile;
|
std::fstream inputFile;
|
||||||
bool isSpirV;
|
bool isSpirV;
|
||||||
|
@ -92,6 +93,8 @@ int main(int argc, char *argv[]) {
|
||||||
arrayName = argv[++i];
|
arrayName = argv[++i];
|
||||||
} else if ((arg == "-p") || (arg == "--platform")) {
|
} else if ((arg == "-p") || (arg == "--platform")) {
|
||||||
platform = argv[++i];
|
platform = argv[++i];
|
||||||
|
} else if ((arg == "-r") || (arg == "--revision_id")) {
|
||||||
|
revisionId = argv[++i];
|
||||||
} else {
|
} else {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -110,7 +113,7 @@ int main(int argc, char *argv[]) {
|
||||||
inputFile.read(reinterpret_cast<char *>(memblock.get()), size);
|
inputFile.read(reinterpret_cast<char *>(memblock.get()), size);
|
||||||
inputFile.close();
|
inputFile.close();
|
||||||
isSpirV = fileName.find(".spv") != std::string::npos;
|
isSpirV = fileName.find(".spv") != std::string::npos;
|
||||||
std::string cpp = parseToCharArray(move(memblock), size, arrayName, platform, isSpirV);
|
std::string cpp = parseToCharArray(move(memblock), size, arrayName, platform, revisionId, isSpirV);
|
||||||
std::fstream(cppOutputName.c_str(), std::ios::out | std::ios::binary).write(cpp.c_str(), cpp.size());
|
std::fstream(cppOutputName.c_str(), std::ios::out | std::ios::binary).write(cpp.c_str(), cpp.size());
|
||||||
} else {
|
} else {
|
||||||
std::cerr << "File cannot be opened!" << std::endl;
|
std::cerr << "File cannot be opened!" << std::endl;
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2017-2020 Intel Corporation
|
* Copyright (C) 2017-2021 Intel Corporation
|
||||||
*
|
*
|
||||||
* SPDX-License-Identifier: MIT
|
* SPDX-License-Identifier: MIT
|
||||||
*
|
*
|
||||||
|
@ -9,6 +9,7 @@
|
||||||
#include "shared/source/debug_settings/debug_settings_manager.h"
|
#include "shared/source/debug_settings/debug_settings_manager.h"
|
||||||
#include "shared/source/device/device.h"
|
#include "shared/source/device/device.h"
|
||||||
#include "shared/source/helpers/api_specific_config.h"
|
#include "shared/source/helpers/api_specific_config.h"
|
||||||
|
#include "shared/source/helpers/hw_helper.h"
|
||||||
|
|
||||||
#include "os_inc.h"
|
#include "os_inc.h"
|
||||||
|
|
||||||
|
@ -186,10 +187,15 @@ BuiltinCode BuiltinsLib::getBuiltinCode(EBuiltInOps::Type builtin, BuiltinCode::
|
||||||
|
|
||||||
BuiltinResourceT BuiltinsLib::getBuiltinResource(EBuiltInOps::Type builtin, BuiltinCode::ECodeType requestedCodeType, Device &device) {
|
BuiltinResourceT BuiltinsLib::getBuiltinResource(EBuiltInOps::Type builtin, BuiltinCode::ECodeType requestedCodeType, Device &device) {
|
||||||
BuiltinResourceT bc;
|
BuiltinResourceT bc;
|
||||||
|
auto &hwInfo = device.getHardwareInfo();
|
||||||
|
auto &hwHelper = HwHelper::get(hwInfo.platform.eRenderCoreFamily);
|
||||||
std::string resourceNameGeneric = createBuiltinResourceName(builtin, BuiltinCode::getExtension(requestedCodeType));
|
std::string resourceNameGeneric = createBuiltinResourceName(builtin, BuiltinCode::getExtension(requestedCodeType));
|
||||||
std::string resourceNameForPlatformType = createBuiltinResourceName(builtin, BuiltinCode::getExtension(requestedCodeType), getFamilyNameWithType(device.getHardwareInfo()));
|
std::string resourceNameForPlatformType = createBuiltinResourceName(builtin, BuiltinCode::getExtension(requestedCodeType),
|
||||||
std::string resourceNameForPlatformTypeAndStepping = createBuiltinResourceName(builtin, BuiltinCode::getExtension(requestedCodeType), getFamilyNameWithType(device.getHardwareInfo()),
|
getFamilyNameWithType(hwInfo),
|
||||||
device.getHardwareInfo().platform.usRevId);
|
hwHelper.getDefaultRevisionId(hwInfo));
|
||||||
|
std::string resourceNameForPlatformTypeAndStepping = createBuiltinResourceName(builtin, BuiltinCode::getExtension(requestedCodeType),
|
||||||
|
getFamilyNameWithType(hwInfo),
|
||||||
|
hwInfo.platform.usRevId);
|
||||||
|
|
||||||
for (auto &rn : {resourceNameForPlatformTypeAndStepping, resourceNameForPlatformType, resourceNameGeneric}) { // first look for dedicated version, only fallback to generic one
|
for (auto &rn : {resourceNameForPlatformTypeAndStepping, resourceNameForPlatformType, resourceNameGeneric}) { // first look for dedicated version, only fallback to generic one
|
||||||
for (auto &s : allStorages) {
|
for (auto &s : allStorages) {
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#
|
#
|
||||||
# Copyright (C) 2018-2020 Intel Corporation
|
# Copyright (C) 2018-2021 Intel Corporation
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
#
|
#
|
||||||
|
@ -50,28 +50,10 @@ if(COMPILE_BUILT_INS)
|
||||||
add_subdirectory(kernels)
|
add_subdirectory(kernels)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
macro(macro_for_each_gen)
|
|
||||||
foreach(MODE ${BIND_MODES})
|
foreach(MODE ${BIND_MODES})
|
||||||
foreach(PLATFORM_TYPE ${PLATFORM_TYPES})
|
get_property(GENERATED_BUILTINS_CPPS_${MODE} GLOBAL PROPERTY GENERATED_BUILTINS_CPPS_${MODE})
|
||||||
get_family_name_with_type(${GEN_TYPE} ${PLATFORM_TYPE})
|
source_group("generated files\\${GEN_TYPE_LOWER}" FILES GENERATED_BUILTINS_CPPS_${MODE})
|
||||||
foreach(GENERATED_BUILTIN_IMAGES ${GENERATED_BUILTINS_IMAGES})
|
|
||||||
list(APPEND GENERATED_BUILTINS_CPPS_${MODE} ${BUILTINS_INCLUDE_DIR}/${RUNTIME_GENERATED_${GENERATED_BUILTIN_IMAGES}_${family_name_with_type}_${MODE}})
|
|
||||||
endforeach()
|
endforeach()
|
||||||
foreach(GENERATED_BUILTIN_IMAGES_STATELESS ${GENERATED_BUILTINS_IMAGES_STATELESS})
|
|
||||||
list(APPEND GENERATED_BUILTINS_CPPS_${MODE} ${BUILTINS_INCLUDE_DIR}/${RUNTIME_GENERATED_${GENERATED_BUILTIN_IMAGES_STATELESS}_${family_name_with_type}_${MODE}})
|
|
||||||
endforeach()
|
|
||||||
foreach(GENERATED_BUILTIN ${GENERATED_BUILTINS})
|
|
||||||
list(APPEND GENERATED_BUILTINS_CPPS_${MODE} ${BUILTINS_INCLUDE_DIR}/${RUNTIME_GENERATED_${GENERATED_BUILTIN}_${family_name_with_type}_${MODE}})
|
|
||||||
endforeach()
|
|
||||||
foreach(GENERATED_BUILTIN_STATELESS ${GENERATED_BUILTINS_STATELESS})
|
|
||||||
list(APPEND GENERATED_BUILTINS_CPPS_${MODE} ${BUILTINS_INCLUDE_DIR}/${RUNTIME_GENERATED_${GENERATED_BUILTIN_STATELESS}_${family_name_with_type}_${MODE}})
|
|
||||||
endforeach()
|
|
||||||
endforeach()
|
|
||||||
source_group("generated files\\${GEN_TYPE_LOWER}" FILES ${GENERATED_BUILTINS_CPPS_${MODE}})
|
|
||||||
endforeach()
|
|
||||||
endmacro()
|
|
||||||
|
|
||||||
apply_macro_for_each_gen("SUPPORTED")
|
|
||||||
|
|
||||||
if(COMPILE_BUILT_INS)
|
if(COMPILE_BUILT_INS)
|
||||||
target_sources(${BUILTINS_BINARIES_BINDFUL_LIB_NAME} PUBLIC ${GENERATED_BUILTINS_CPPS_bindful})
|
target_sources(${BUILTINS_BINARIES_BINDFUL_LIB_NAME} PUBLIC ${GENERATED_BUILTINS_CPPS_bindful})
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#
|
#
|
||||||
# Copyright (C) 2017-2020 Intel Corporation
|
# Copyright (C) 2017-2021 Intel Corporation
|
||||||
#
|
#
|
||||||
# SPDX-License-Identifier: MIT
|
# SPDX-License-Identifier: MIT
|
||||||
#
|
#
|
||||||
|
@ -41,7 +41,7 @@ set(BUILTIN_CPP "")
|
||||||
|
|
||||||
function(get_bits_for_stateless gen_type platform_type)
|
function(get_bits_for_stateless gen_type platform_type)
|
||||||
# Force 32bits compiling on gen9lp for stateless builtins
|
# Force 32bits compiling on gen9lp for stateless builtins
|
||||||
if((${GEN_TYPE} STREQUAL "GEN9") AND (${PLATFORM_TYPE} STREQUAL "LP"))
|
if((${gen_type} STREQUAL "GEN9") AND (${platform_type} STREQUAL "LP"))
|
||||||
set(BITS "32" PARENT_SCOPE)
|
set(BITS "32" PARENT_SCOPE)
|
||||||
else()
|
else()
|
||||||
set(BITS ${NEO_BITS} PARENT_SCOPE)
|
set(BITS ${NEO_BITS} PARENT_SCOPE)
|
||||||
|
@ -64,14 +64,7 @@ function(compile_builtin gen_type platform_type builtin bits builtin_options mod
|
||||||
${OUTPUTPATH_BASE}.bin
|
${OUTPUTPATH_BASE}.bin
|
||||||
${OUTPUTPATH_BASE}.gen
|
${OUTPUTPATH_BASE}.gen
|
||||||
)
|
)
|
||||||
set(OUTPUT_FILE_CPP
|
|
||||||
${OUTPUTPATH_BASE}.cpp
|
|
||||||
)
|
|
||||||
|
|
||||||
# function returns builtin cpp filename
|
|
||||||
unset(BUILTIN_CPP)
|
|
||||||
# set variable outside function
|
|
||||||
set(BUILTIN_CPP built_ins/${NEO_ARCH}/${gen_type_lower}/${mode}_${BASENAME}_${family_name_with_type}.cpp PARENT_SCOPE)
|
|
||||||
if(NOT DEFINED cloc_cmd_prefix)
|
if(NOT DEFINED cloc_cmd_prefix)
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
set(cloc_cmd_prefix ocloc)
|
set(cloc_cmd_prefix ocloc)
|
||||||
|
@ -91,12 +84,19 @@ function(compile_builtin gen_type platform_type builtin bits builtin_options mod
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
DEPENDS ${builtin} 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
|
||||||
|
)
|
||||||
|
list(APPEND BUILTINS_COMMANDS "${OUTPUT_FILE_CPP}")
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT ${OUTPUT_FILE_CPP}
|
OUTPUT ${OUTPUT_FILE_CPP}
|
||||||
COMMAND $<TARGET_FILE:cpp_generate_tool> --file ${OUTPUTPATH_BASE}.gen --output ${OUTPUT_FILE_CPP} --array ${mode}_${BASENAME} --platform ${family_name_with_type}
|
COMMAND $<TARGET_FILE:cpp_generate_tool> --file ${OUTPUTPATH_BASE}.gen --output ${OUTPUT_FILE_CPP} --array ${mode}_${BASENAME} --platform ${family_name_with_type} --revision_id ${REVISION_ID}
|
||||||
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
|
||||||
DEPENDS ${OUTPUTPATH_BASE}.gen $<TARGET_FILE:cpp_generate_tool>
|
DEPENDS ${OUTPUTPATH_BASE}.gen $<TARGET_FILE:cpp_generate_tool>
|
||||||
)
|
)
|
||||||
|
endforeach()
|
||||||
|
set(BUILTINS_COMMANDS ${BUILTINS_COMMANDS} PARENT_SCOPE)
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
function(generate_cpp_spirv builtin)
|
function(generate_cpp_spirv builtin)
|
||||||
|
@ -144,44 +144,40 @@ 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})
|
||||||
|
unset(IMAGE_SUPPORT)
|
||||||
|
GEN_CONTAINS_PLATFORMS("SUPPORTED_IMAGES" ${GEN_TYPE} IMAGE_SUPPORT)
|
||||||
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)
|
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})
|
foreach(MODE ${BIND_MODES})
|
||||||
|
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}" ${MODE})
|
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN}.builtin_kernel ${NEO_BITS} "${BUILTIN_OPTIONS}" ${MODE})
|
||||||
list(APPEND BUILTINS_COMMANDS ${TargetDir}/${BUILTIN_CPP})
|
|
||||||
set(RUNTIME_GENERATED_${GENERATED_BUILTIN}_${family_name_with_type}_${MODE} ${BUILTIN_CPP} PARENT_SCOPE)
|
|
||||||
endforeach()
|
endforeach()
|
||||||
foreach(GENERATED_BUILTINS_IMAGES ${GENERATED_BUILTINS_IMAGES})
|
|
||||||
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTINS_IMAGES}.builtin_kernel ${NEO_BITS} "${BUILTIN_OPTIONS}" ${MODE})
|
|
||||||
set(IMAGE_SUPPORT FALSE)
|
|
||||||
GEN_CONTAINS_PLATFORMS("SUPPORTED_IMAGES" ${GEN_TYPE} IMAGE_SUPPORT)
|
|
||||||
if(${IMAGE_SUPPORT})
|
|
||||||
list(APPEND BUILTINS_COMMANDS ${TargetDir}/${BUILTIN_CPP})
|
|
||||||
set(RUNTIME_GENERATED_${GENERATED_BUILTINS_IMAGES}_${family_name_with_type}_${MODE} ${BUILTIN_CPP} PARENT_SCOPE)
|
|
||||||
endif()
|
|
||||||
endforeach()
|
|
||||||
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}" ${MODE})
|
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN_STATELESS}.builtin_kernel ${BITS} "${BUILTIN_OPTIONS_STATELESS}" ${MODE})
|
||||||
list(APPEND BUILTINS_COMMANDS ${TargetDir}/${BUILTIN_CPP})
|
endforeach()
|
||||||
set(RUNTIME_GENERATED_${GENERATED_BUILTIN_STATELESS}_${family_name_with_type}_${MODE} ${BUILTIN_CPP} PARENT_SCOPE)
|
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()
|
endforeach()
|
||||||
foreach(GENERATED_BUILTIN_IMAGES_STATELESS ${GENERATED_BUILTINS_IMAGES_STATELESS})
|
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})
|
compile_builtin(${GEN_TYPE} ${PLATFORM_TYPE} ${GENERATED_BUILTIN_IMAGES_STATELESS}.builtin_kernel ${BITS} "${BUILTIN_OPTIONS_STATELESS}" ${MODE})
|
||||||
set(IMAGE_SUPPORT FALSE)
|
endforeach()
|
||||||
GEN_CONTAINS_PLATFORMS("SUPPORTED_IMAGES" ${GEN_TYPE} IMAGE_SUPPORT)
|
|
||||||
if(${IMAGE_SUPPORT})
|
|
||||||
list(APPEND BUILTINS_COMMANDS ${TargetDir}/${BUILTIN_CPP})
|
|
||||||
set(RUNTIME_GENERATED_${GENERATED_BUILTIN_IMAGES_STATELESS}_${family_name_with_type}_${MODE} ${BUILTIN_CPP} PARENT_SCOPE)
|
|
||||||
endif()
|
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()
|
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()
|
endforeach()
|
||||||
set(target_name builtins_${family_name_with_type})
|
|
||||||
add_custom_target(${target_name} DEPENDS ${BUILTINS_COMMANDS})
|
|
||||||
add_dependencies(builtins ${target_name})
|
|
||||||
set_target_properties(${target_name} PROPERTIES FOLDER "${SHARED_SOURCE_PROJECTS_FOLDER}/${SHARED_BUIILINS_PROJECTS_FOLDER}/${family_name_with_type}")
|
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
|
@ -11,6 +11,8 @@
|
||||||
#include "shared/source/helpers/hw_helper_bdw_plus.inl"
|
#include "shared/source/helpers/hw_helper_bdw_plus.inl"
|
||||||
#include "shared/source/helpers/hw_helper_bdw_to_icllp.inl"
|
#include "shared/source/helpers/hw_helper_bdw_to_icllp.inl"
|
||||||
|
|
||||||
|
#include <cstring>
|
||||||
|
|
||||||
namespace NEO {
|
namespace NEO {
|
||||||
typedef SKLFamily Family;
|
typedef SKLFamily Family;
|
||||||
|
|
||||||
|
@ -42,6 +44,14 @@ uint32_t HwHelperHw<Family>::getDefaultThreadArbitrationPolicy() const {
|
||||||
return ThreadArbitrationPolicy::RoundRobin;
|
return ThreadArbitrationPolicy::RoundRobin;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <>
|
||||||
|
uint32_t HwHelperHw<Family>::getDefaultRevisionId(const HardwareInfo &hwInfo) const {
|
||||||
|
if (std::strcmp(hwInfo.capabilityTable.platformType, "core") == 0) {
|
||||||
|
return 9u;
|
||||||
|
}
|
||||||
|
return 0u;
|
||||||
|
}
|
||||||
|
|
||||||
template <>
|
template <>
|
||||||
bool MemorySynchronizationCommands<Family>::isPipeControlWArequired(const HardwareInfo &hwInfo) { return true; }
|
bool MemorySynchronizationCommands<Family>::isPipeControlWArequired(const HardwareInfo &hwInfo) { return true; }
|
||||||
|
|
||||||
|
|
|
@ -132,6 +132,7 @@ class HwHelper {
|
||||||
virtual bool isCpuImageTransferPreferred(const HardwareInfo &hwInfo) const = 0;
|
virtual bool isCpuImageTransferPreferred(const HardwareInfo &hwInfo) const = 0;
|
||||||
virtual bool isKmdMigrationSupported(const HardwareInfo &hwInfo) const = 0;
|
virtual bool isKmdMigrationSupported(const HardwareInfo &hwInfo) const = 0;
|
||||||
virtual aub_stream::MMIOList getExtraMmioList(const HardwareInfo &hwInfo) const = 0;
|
virtual aub_stream::MMIOList getExtraMmioList(const HardwareInfo &hwInfo) const = 0;
|
||||||
|
virtual uint32_t getDefaultRevisionId(const HardwareInfo &hwInfo) const = 0;
|
||||||
|
|
||||||
static uint32_t getSubDevicesCount(const HardwareInfo *pHwInfo);
|
static uint32_t getSubDevicesCount(const HardwareInfo *pHwInfo);
|
||||||
static uint32_t getEnginesCount(const HardwareInfo &hwInfo);
|
static uint32_t getEnginesCount(const HardwareInfo &hwInfo);
|
||||||
|
@ -335,6 +336,8 @@ class HwHelperHw : public HwHelper {
|
||||||
|
|
||||||
aub_stream::MMIOList getExtraMmioList(const HardwareInfo &hwInfo) const override;
|
aub_stream::MMIOList getExtraMmioList(const HardwareInfo &hwInfo) const override;
|
||||||
|
|
||||||
|
uint32_t getDefaultRevisionId(const HardwareInfo &hwInfo) const override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
LocalMemoryAccessMode getDefaultLocalMemoryAccessMode(const HardwareInfo &hwInfo) const override;
|
LocalMemoryAccessMode getDefaultLocalMemoryAccessMode(const HardwareInfo &hwInfo) const override;
|
||||||
|
|
||||||
|
|
|
@ -539,4 +539,9 @@ bool HwHelperHw<GfxFamily>::isAdditionalFeatureFlagRequired(const FeatureTable *
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename GfxFamily>
|
||||||
|
uint32_t HwHelperHw<GfxFamily>::getDefaultRevisionId(const HardwareInfo &hwInfo) const {
|
||||||
|
return 0u;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace NEO
|
} // namespace NEO
|
||||||
|
|
Loading…
Reference in New Issue