2022-03-09 23:39:57 +08:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2022 Intel Corporation
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2022-06-14 07:13:43 +08:00
|
|
|
#include "shared/source/helpers/compiler_hw_info_config.h"
|
2022-03-09 23:39:57 +08:00
|
|
|
#include "shared/source/os_interface/hw_info_config.h"
|
2022-04-29 22:33:41 +08:00
|
|
|
#include "shared/test/common/helpers/debug_manager_state_restore.h"
|
2022-03-09 23:39:57 +08:00
|
|
|
#include "shared/test/common/test_macros/test.h"
|
2022-06-01 22:46:32 +08:00
|
|
|
#include "shared/test/unit_test/os_interface/hw_info_config_tests.h"
|
2022-03-09 23:39:57 +08:00
|
|
|
|
2022-06-20 20:16:05 +08:00
|
|
|
#include "platforms.h"
|
|
|
|
|
2022-03-09 23:39:57 +08:00
|
|
|
using namespace NEO;
|
|
|
|
|
|
|
|
HWTEST_F(HwInfoConfigTest, givenHwInfoConfigWhenIsAdjustProgrammableIdPreferredSlmSizeRequiredThenFalseIsReturned) {
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
EXPECT_FALSE(hwInfoConfig.isAdjustProgrammableIdPreferredSlmSizeRequired(*defaultHwInfo));
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_F(HwInfoConfigTest, givenHwInfoConfigWhenIsComputeDispatchAllWalkerEnableInCfeStateRequiredThenFalseIsReturned) {
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
EXPECT_FALSE(hwInfoConfig.isComputeDispatchAllWalkerEnableInCfeStateRequired(*defaultHwInfo));
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_F(HwInfoConfigTest, givenHwInfoConfigWhenIsComputeDispatchAllWalkerEnableInComputeWalkerRequiredThenFalseIsReturned) {
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
EXPECT_FALSE(hwInfoConfig.isComputeDispatchAllWalkerEnableInComputeWalkerRequired(*defaultHwInfo));
|
|
|
|
}
|
|
|
|
|
2022-03-24 16:59:17 +08:00
|
|
|
HWTEST_F(HwInfoConfigTest, givenHwInfoConfigWhenIsGlobalFenceInCommandStreamRequiredThenFalseIsReturned) {
|
2022-03-09 23:39:57 +08:00
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
2022-03-24 16:59:17 +08:00
|
|
|
EXPECT_FALSE(hwInfoConfig.isGlobalFenceInCommandStreamRequired(*defaultHwInfo));
|
2022-03-09 23:39:57 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_F(HwInfoConfigTest, givenHwInfoConfigWhenIsSpecialPipelineSelectModeChangedThenFalseIsReturned) {
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
EXPECT_FALSE(hwInfoConfig.isSpecialPipelineSelectModeChanged(*defaultHwInfo));
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_F(HwInfoConfigTest, givenHwInfoConfigWhenIsSystolicModeConfigurabledThenFalseIsReturned) {
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
EXPECT_FALSE(hwInfoConfig.isSystolicModeConfigurable(*defaultHwInfo));
|
|
|
|
}
|
|
|
|
|
2022-03-22 01:44:02 +08:00
|
|
|
HWTEST_F(HwInfoConfigTest, givenHwInfoConfigWhenGetThreadEuRatioForScratchThen8IsReturned) {
|
2022-03-09 23:39:57 +08:00
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
2022-03-22 01:44:02 +08:00
|
|
|
EXPECT_EQ(8u, hwInfoConfig.getThreadEuRatioForScratch(*defaultHwInfo));
|
2022-03-09 23:39:57 +08:00
|
|
|
}
|
2022-03-11 01:27:38 +08:00
|
|
|
|
2022-04-29 22:33:41 +08:00
|
|
|
HWTEST_F(HwInfoConfigTest, whenIsGrfNumReportedWithScmIsQueriedThenTrueIsReturned) {
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
EXPECT_TRUE(hwInfoConfig.isGrfNumReportedWithScm());
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_F(HwInfoConfigTest, givenForceGrfNumProgrammingWithScmFlagSetWhenIsGrfNumReportedWithScmIsQueriedThenCorrectValueIsReturned) {
|
|
|
|
DebugManagerStateRestore restorer;
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
|
|
|
|
DebugManager.flags.ForceGrfNumProgrammingWithScm.set(0);
|
|
|
|
EXPECT_FALSE(hwInfoConfig.isGrfNumReportedWithScm());
|
|
|
|
|
|
|
|
DebugManager.flags.ForceGrfNumProgrammingWithScm.set(1);
|
|
|
|
EXPECT_TRUE(hwInfoConfig.isGrfNumReportedWithScm());
|
|
|
|
}
|
2022-05-24 01:03:53 +08:00
|
|
|
|
2022-05-17 04:34:53 +08:00
|
|
|
HWTEST_F(HwInfoConfigTest, whenIsThreadArbitrationPolicyReportedWithScmIsQueriedThenTrueIsReturned) {
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
EXPECT_TRUE(hwInfoConfig.isThreadArbitrationPolicyReportedWithScm());
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_F(HwInfoConfigTest, givenForceThreadArbitrationPolicyProgrammingWithScmFlagSetWhenIsThreadArbitrationPolicyReportedWithScmIsQueriedThenCorrectValueIsReturned) {
|
|
|
|
DebugManagerStateRestore restorer;
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
|
|
|
|
DebugManager.flags.ForceThreadArbitrationPolicyProgrammingWithScm.set(0);
|
|
|
|
EXPECT_FALSE(hwInfoConfig.isThreadArbitrationPolicyReportedWithScm());
|
|
|
|
|
|
|
|
DebugManager.flags.ForceThreadArbitrationPolicyProgrammingWithScm.set(1);
|
|
|
|
EXPECT_TRUE(hwInfoConfig.isThreadArbitrationPolicyReportedWithScm());
|
|
|
|
}
|
|
|
|
|
2022-05-24 01:03:53 +08:00
|
|
|
HWTEST2_F(HwInfoConfigTest, givenHwInfoConfigWhenIsImplicitScalingSupportedThenExpectFalse, isNotXeHpOrXeHpcCore) {
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
EXPECT_FALSE(hwInfoConfig.isImplicitScalingSupported(*defaultHwInfo));
|
|
|
|
}
|
2022-06-14 07:13:43 +08:00
|
|
|
|
|
|
|
HWTEST2_F(HwInfoConfigTest, givenHwInfoConfigWhenGetProductConfigThenCorrectMatchIsFound, IsAtMostXeHpCore) {
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
EXPECT_NE(hwInfoConfig.getProductConfigFromHwInfo(*defaultHwInfo), AOT::UNKNOWN_ISA);
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST2_F(HwInfoConfigTest, givenAotConfigWhenSetHwInfoRevisionIdThenCorrectValueIsSet, IsAtMostXeHpCore) {
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
auto productConfig = hwInfoConfig.getProductConfigFromHwInfo(*defaultHwInfo);
|
|
|
|
AheadOfTimeConfig aotConfig = {0};
|
|
|
|
aotConfig.ProductConfig = productConfig;
|
|
|
|
CompilerHwInfoConfig::get(defaultHwInfo->platform.eProductFamily)->setProductConfigForHwInfo(*defaultHwInfo, aotConfig);
|
|
|
|
EXPECT_EQ(defaultHwInfo->platform.usRevId, aotConfig.ProductConfigID.Revision);
|
2022-06-15 02:17:04 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_F(HwInfoConfigTest, givenHwInfoConfigWhenIsAdjustWalkOrderAvailableCallThenFalseReturn) {
|
|
|
|
const auto &hwInfoConfig = *HwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
EXPECT_FALSE(hwInfoConfig.isAdjustWalkOrderAvailable(*defaultHwInfo));
|
2022-06-20 20:39:11 +08:00
|
|
|
}
|
|
|
|
|
2022-06-27 22:58:29 +08:00
|
|
|
HWTEST2_F(HwInfoConfigTest, givenAtMostXeHPWhenGetCachingPolicyOptionsThenReturnNullptr, IsAtMostXeHpCore) {
|
2022-06-20 20:39:11 +08:00
|
|
|
auto compilerHwInfoConfig = CompilerHwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
EXPECT_EQ(compilerHwInfoConfig->getCachingPolicyOptions(), nullptr);
|
2022-06-22 21:13:37 +08:00
|
|
|
}
|
|
|
|
|
2022-06-27 22:58:29 +08:00
|
|
|
HWTEST2_F(HwInfoConfigTest, givenAtLeastDG2WhenGetCachingPolicyOptionsThenReturnWriteByPassPolicyOption, IsAtLeastXeHpgCore) {
|
|
|
|
auto compilerHwInfoConfig = CompilerHwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
const char *expectedStr = "-cl-store-cache-default=2 -cl-load-cache-default=4";
|
|
|
|
EXPECT_EQ(0, memcmp(compilerHwInfoConfig->getCachingPolicyOptions(), expectedStr, strlen(expectedStr)));
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST2_F(HwInfoConfigTest, givenAtLeastDG2WhenGetCachingPolicyOptionsThenReturnWriteBackPolicyOption, IsAtLeastXeHpgCore) {
|
|
|
|
DebugManagerStateRestore restorer;
|
|
|
|
DebugManager.flags.OverrideL1CachePolicyInSurfaceStateAndStateless.set(2);
|
|
|
|
|
|
|
|
auto compilerHwInfoConfig = CompilerHwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
const char *expectedStr = "-cl-store-cache-default=7 -cl-load-cache-default=4";
|
|
|
|
EXPECT_EQ(0, memcmp(compilerHwInfoConfig->getCachingPolicyOptions(), expectedStr, strlen(expectedStr)));
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST2_F(HwInfoConfigTest, givenCachePolicyWithoutCorrespondingBuildOptionWhenGetCachingPolicyOptionsThenReturnNullptr, IsAtLeastXeHpgCore) {
|
|
|
|
DebugManagerStateRestore restorer;
|
|
|
|
DebugManager.flags.OverrideL1CachePolicyInSurfaceStateAndStateless.set(1);
|
|
|
|
|
|
|
|
auto compilerHwInfoConfig = CompilerHwInfoConfig::get(defaultHwInfo->platform.eProductFamily);
|
|
|
|
EXPECT_EQ(nullptr, compilerHwInfoConfig->getCachingPolicyOptions());
|
|
|
|
}
|
|
|
|
|
2022-06-22 21:13:37 +08:00
|
|
|
HWTEST2_F(HwInfoConfigTest, givenHwInfoConfigAndDebugFlagWhenGetL1CachePolicyThenReturnCorrectPolicy, IsAtLeastXeHpgCore) {
|
|
|
|
DebugManagerStateRestore restorer;
|
|
|
|
auto hwInfo = *defaultHwInfo;
|
|
|
|
auto hwInfoConfig = HwInfoConfig::get(hwInfo.platform.eProductFamily);
|
|
|
|
|
|
|
|
DebugManager.flags.OverrideL1CachePolicyInSurfaceStateAndStateless.set(0);
|
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WBP, hwInfoConfig->getL1CachePolicy());
|
|
|
|
|
|
|
|
DebugManager.flags.OverrideL1CachePolicyInSurfaceStateAndStateless.set(2);
|
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WB, hwInfoConfig->getL1CachePolicy());
|
|
|
|
|
|
|
|
DebugManager.flags.OverrideL1CachePolicyInSurfaceStateAndStateless.set(3);
|
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WT, hwInfoConfig->getL1CachePolicy());
|
|
|
|
|
|
|
|
DebugManager.flags.OverrideL1CachePolicyInSurfaceStateAndStateless.set(4);
|
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WS, hwInfoConfig->getL1CachePolicy());
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST2_F(HwInfoConfigTest, givenHwInfoConfigWhenGetL1CachePolicyThenReturnWriteByPass, IsAtLeastXeHpgCore) {
|
|
|
|
auto hwInfo = *defaultHwInfo;
|
|
|
|
auto hwInfoConfig = HwInfoConfig::get(hwInfo.platform.eProductFamily);
|
|
|
|
|
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WBP, hwInfoConfig->getL1CachePolicy());
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST2_F(HwInfoConfigTest, givenPlatformWithUnsupportedL1CachePoliciesWhenGetL1CachePolicyThenReturnZero, IsAtMostXeHpCore) {
|
|
|
|
auto hwInfo = *defaultHwInfo;
|
|
|
|
auto hwInfoConfig = HwInfoConfig::get(hwInfo.platform.eProductFamily);
|
|
|
|
|
|
|
|
EXPECT_EQ(0u, hwInfoConfig->getL1CachePolicy());
|
2022-06-27 22:58:29 +08:00
|
|
|
}
|