2020-04-22 04:40:21 +08:00
|
|
|
/*
|
2022-06-22 19:57:48 +08:00
|
|
|
* Copyright (C) 2020-2022 Intel Corporation
|
2020-04-22 04:40:21 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2022-08-10 19:24:38 +08:00
|
|
|
#include "shared/test/unit_test/helpers/state_base_address_tests.h"
|
2020-04-22 04:40:21 +08:00
|
|
|
|
2022-06-22 21:13:37 +08:00
|
|
|
#include "shared/source/command_container/command_encoder.h"
|
2022-06-30 03:17:47 +08:00
|
|
|
#include "shared/test/common/test_macros/hw_test.h"
|
2022-06-22 21:13:37 +08:00
|
|
|
|
2020-04-22 04:40:21 +08:00
|
|
|
using IsBetweenSklAndTgllp = IsWithinProducts<IGFX_SKYLAKE, IGFX_TIGERLAKE_LP>;
|
|
|
|
|
2020-07-29 22:04:23 +08:00
|
|
|
HWTEST2_F(SBATest, WhenAppendStateBaseAddressParametersIsCalledThenSBACmdHasBindingSurfaceStateProgrammed, IsBetweenSklAndTgllp) {
|
2020-04-22 04:40:21 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
EXPECT_NE(IGFX_BROADWELL, ::productFamily);
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS stateBaseAddress;
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateSize(0);
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateBaseAddress(0);
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateBaseAddressModifyEnable(false);
|
|
|
|
|
2022-08-11 21:36:02 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = {
|
|
|
|
0, // generalStateBase
|
|
|
|
0, // indirectObjectHeapBaseAddress
|
|
|
|
0, // instructionHeapBaseAddress
|
|
|
|
0, // globalHeapsBaseAddress
|
|
|
|
&stateBaseAddress, // stateBaseAddressCmd
|
|
|
|
nullptr, // dsh
|
|
|
|
nullptr, // ioh
|
|
|
|
&ssh, // ssh
|
|
|
|
nullptr, // gmmHelper
|
|
|
|
0, // statelessMocsIndex
|
|
|
|
MemoryCompressionState::NotApplicable, // memoryCompressionState
|
|
|
|
false, // setInstructionStateBaseAddress
|
|
|
|
false, // setGeneralStateBaseAddress
|
|
|
|
false, // useGlobalHeapsBaseAddress
|
|
|
|
false, // isMultiOsContextCapable
|
|
|
|
false, // useGlobalAtomics
|
|
|
|
false // areMultipleSubDevicesInContext
|
|
|
|
};
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::appendStateBaseAddressParameters(args, true);
|
2020-04-22 04:40:21 +08:00
|
|
|
|
|
|
|
EXPECT_EQ(ssh.getMaxAvailableSpace() / 64 - 1, stateBaseAddress.getBindlessSurfaceStateSize());
|
|
|
|
EXPECT_EQ(ssh.getHeapGpuBase(), stateBaseAddress.getBindlessSurfaceStateBaseAddress());
|
|
|
|
EXPECT_TRUE(stateBaseAddress.getBindlessSurfaceStateBaseAddressModifyEnable());
|
|
|
|
}
|
|
|
|
|
2021-12-16 01:45:30 +08:00
|
|
|
HWTEST2_F(SBATest, WhenProgramStateBaseAddressParametersIsCalledThenSBACmdHasBindingSurfaceStateProgrammed, IsAtLeastSkl) {
|
2020-04-22 04:40:21 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
EXPECT_NE(IGFX_BROADWELL, ::productFamily);
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS stateBaseAddress;
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateSize(0);
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateBaseAddress(0);
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateBaseAddressModifyEnable(false);
|
|
|
|
|
2020-07-29 22:04:23 +08:00
|
|
|
STATE_BASE_ADDRESS *cmd = reinterpret_cast<STATE_BASE_ADDRESS *>(commandStream.getSpace(0));
|
|
|
|
*cmd = stateBaseAddress;
|
|
|
|
|
2022-08-11 21:36:02 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = {
|
|
|
|
0, // generalStateBase
|
|
|
|
0, // indirectObjectHeapBaseAddress
|
|
|
|
0, // instructionHeapBaseAddress
|
|
|
|
0, // globalHeapsBaseAddress
|
|
|
|
cmd, // stateBaseAddressCmd
|
|
|
|
nullptr, // dsh
|
|
|
|
nullptr, // ioh
|
|
|
|
&ssh, // ssh
|
|
|
|
pDevice->getGmmHelper(), // gmmHelper
|
|
|
|
0, // statelessMocsIndex
|
|
|
|
MemoryCompressionState::NotApplicable, // memoryCompressionState
|
|
|
|
false, // setInstructionStateBaseAddress
|
|
|
|
false, // setGeneralStateBaseAddress
|
|
|
|
false, // useGlobalHeapsBaseAddress
|
|
|
|
false, // isMultiOsContextCapable
|
|
|
|
false, // useGlobalAtomics
|
|
|
|
false // areMultipleSubDevicesInContext
|
|
|
|
};
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
2020-04-22 04:40:21 +08:00
|
|
|
|
2020-07-29 22:04:23 +08:00
|
|
|
EXPECT_EQ(ssh.getMaxAvailableSpace() / 64 - 1, cmd->getBindlessSurfaceStateSize());
|
|
|
|
EXPECT_EQ(ssh.getHeapGpuBase(), cmd->getBindlessSurfaceStateBaseAddress());
|
|
|
|
EXPECT_TRUE(cmd->getBindlessSurfaceStateBaseAddressModifyEnable());
|
2020-04-22 04:40:21 +08:00
|
|
|
}
|
2020-12-04 19:28:18 +08:00
|
|
|
|
2022-08-11 22:01:11 +08:00
|
|
|
using SbaForBindlessTests = Test<DeviceFixture>;
|
2020-12-04 19:28:18 +08:00
|
|
|
|
2021-12-16 01:45:30 +08:00
|
|
|
HWTEST2_F(SbaForBindlessTests, givenGlobalBindlessBaseAddressWhenProgramStateBaseAddressThenSbaProgrammedCorrectly, IsAtLeastSkl) {
|
2020-12-04 19:28:18 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
EXPECT_NE(IGFX_BROADWELL, ::productFamily);
|
|
|
|
|
|
|
|
uint64_t globalBindlessHeapsBaseAddress = 0x12340000;
|
|
|
|
|
|
|
|
StackVec<char, 4096> buffer(4096);
|
|
|
|
NEO::LinearStream cmdStream(buffer.begin(), buffer.size());
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS *cmd = reinterpret_cast<STATE_BASE_ADDRESS *>(cmdStream.getSpace(0));
|
2022-08-11 21:36:02 +08:00
|
|
|
|
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = {
|
|
|
|
0, // generalStateBase
|
|
|
|
0, // indirectObjectHeapBaseAddress
|
|
|
|
0, // instructionHeapBaseAddress
|
|
|
|
globalBindlessHeapsBaseAddress, // globalHeapsBaseAddress
|
|
|
|
cmd, // stateBaseAddressCmd
|
|
|
|
nullptr, // dsh
|
|
|
|
nullptr, // ioh
|
|
|
|
nullptr, // ssh
|
|
|
|
pDevice->getGmmHelper(), // gmmHelper
|
|
|
|
0, // statelessMocsIndex
|
|
|
|
MemoryCompressionState::NotApplicable, // memoryCompressionState
|
|
|
|
false, // setInstructionStateBaseAddress
|
|
|
|
false, // setGeneralStateBaseAddress
|
|
|
|
true, // useGlobalHeapsBaseAddress
|
|
|
|
false, // isMultiOsContextCapable
|
|
|
|
false, // useGlobalAtomics
|
|
|
|
false // areMultipleSubDevicesInContext
|
|
|
|
};
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
2022-08-03 19:54:08 +08:00
|
|
|
|
2020-12-04 19:28:18 +08:00
|
|
|
EXPECT_TRUE(cmd->getBindlessSurfaceStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(cmd->getBindlessSurfaceStateBaseAddress(), globalBindlessHeapsBaseAddress);
|
2021-12-01 06:59:19 +08:00
|
|
|
|
|
|
|
auto surfaceStateCount = StateBaseAddressHelper<FamilyType>::getMaxBindlessSurfaceStates();
|
|
|
|
EXPECT_EQ(surfaceStateCount, cmd->getBindlessSurfaceStateSize());
|
2020-12-04 19:28:18 +08:00
|
|
|
}
|
2021-09-28 18:56:22 +08:00
|
|
|
|
|
|
|
using IohSupported = IsWithinGfxCore<GFXCORE_FAMILY::IGFX_GEN9_CORE, GFXCORE_FAMILY::IGFX_GEN12LP_CORE>;
|
|
|
|
|
|
|
|
HWTEST2_F(SbaForBindlessTests, givenGlobalBindlessBaseAddressWhenPassingIndirectBaseAddressThenIndirectBaseAddressIsSet, IohSupported) {
|
2020-12-04 19:28:18 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
EXPECT_NE(IGFX_BROADWELL, ::productFamily);
|
|
|
|
|
|
|
|
uint64_t globalBindlessHeapsBaseAddress = 0x12340000;
|
|
|
|
uint64_t indirectObjectBaseAddress = 0x12340000;
|
|
|
|
|
|
|
|
StackVec<char, 4096> buffer(4096);
|
|
|
|
NEO::LinearStream cmdStream(buffer.begin(), buffer.size());
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS *cmd = reinterpret_cast<STATE_BASE_ADDRESS *>(cmdStream.getSpace(0));
|
2022-08-11 21:36:02 +08:00
|
|
|
|
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = {
|
|
|
|
0, // generalStateBase
|
|
|
|
indirectObjectBaseAddress, // indirectObjectHeapBaseAddress
|
|
|
|
0, // instructionHeapBaseAddress
|
|
|
|
globalBindlessHeapsBaseAddress, // globalHeapsBaseAddress
|
|
|
|
cmd, // stateBaseAddressCmd
|
|
|
|
nullptr, // dsh
|
|
|
|
nullptr, // ioh
|
|
|
|
nullptr, // ssh
|
|
|
|
pDevice->getGmmHelper(), // gmmHelper
|
|
|
|
0, // statelessMocsIndex
|
|
|
|
MemoryCompressionState::NotApplicable, // memoryCompressionState
|
|
|
|
false, // setInstructionStateBaseAddress
|
|
|
|
false, // setGeneralStateBaseAddress
|
|
|
|
true, // useGlobalHeapsBaseAddress
|
|
|
|
false, // isMultiOsContextCapable
|
|
|
|
false, // useGlobalAtomics
|
|
|
|
false // areMultipleSubDevicesInContext
|
|
|
|
};
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
2020-12-04 19:28:18 +08:00
|
|
|
|
|
|
|
EXPECT_EQ(cmd->getIndirectObjectBaseAddress(), indirectObjectBaseAddress);
|
2021-01-26 00:08:33 +08:00
|
|
|
}
|
|
|
|
|
2021-12-16 01:45:30 +08:00
|
|
|
HWTEST2_F(SBATest, givenSbaWhenOverrideBindlessSurfaceBaseIsFalseThenBindlessSurfaceBaseIsNotSet, IsAtLeastSkl) {
|
2021-01-26 00:08:33 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
EXPECT_NE(IGFX_BROADWELL, ::productFamily);
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS stateBaseAddress;
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateSize(0);
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateBaseAddress(0);
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateBaseAddressModifyEnable(false);
|
|
|
|
|
2022-08-11 21:36:02 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = {
|
|
|
|
0, // generalStateBase
|
|
|
|
0, // indirectObjectHeapBaseAddress
|
|
|
|
0, // instructionHeapBaseAddress
|
|
|
|
0, // globalHeapsBaseAddress
|
|
|
|
&stateBaseAddress, // stateBaseAddressCmd
|
|
|
|
nullptr, // dsh
|
|
|
|
nullptr, // ioh
|
|
|
|
nullptr, // ssh
|
|
|
|
pDevice->getRootDeviceEnvironment().getGmmHelper(), // gmmHelper
|
|
|
|
0, // statelessMocsIndex
|
|
|
|
MemoryCompressionState::NotApplicable, // memoryCompressionState
|
|
|
|
false, // setInstructionStateBaseAddress
|
|
|
|
false, // setGeneralStateBaseAddress
|
|
|
|
true, // useGlobalHeapsBaseAddress
|
|
|
|
false, // isMultiOsContextCapable
|
|
|
|
false, // useGlobalAtomics
|
|
|
|
false // areMultipleSubDevicesInContext
|
|
|
|
};
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::appendStateBaseAddressParameters(args, false);
|
2021-01-26 00:08:33 +08:00
|
|
|
|
|
|
|
EXPECT_EQ(0u, stateBaseAddress.getBindlessSurfaceStateBaseAddress());
|
|
|
|
}
|
|
|
|
|
2021-12-16 01:45:30 +08:00
|
|
|
HWTEST2_F(SBATest, givenGlobalBindlessBaseAddressWhenSshIsPassedThenBindlessSurfaceBaseIsGlobalHeapBase, IsAtLeastSkl) {
|
2021-01-26 00:08:33 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
EXPECT_NE(IGFX_BROADWELL, ::productFamily);
|
|
|
|
|
|
|
|
uint64_t globalBindlessHeapsBaseAddress = 0x12340000;
|
|
|
|
|
|
|
|
StackVec<char, 4096> buffer(4096);
|
|
|
|
NEO::LinearStream cmdStream(buffer.begin(), buffer.size());
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS *cmd = reinterpret_cast<STATE_BASE_ADDRESS *>(cmdStream.getSpace(0));
|
2022-08-11 21:36:02 +08:00
|
|
|
|
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = {
|
|
|
|
0, // generalStateBase
|
|
|
|
0, // indirectObjectHeapBaseAddress
|
|
|
|
0, // instructionHeapBaseAddress
|
|
|
|
globalBindlessHeapsBaseAddress, // globalHeapsBaseAddress
|
|
|
|
cmd, // stateBaseAddressCmd
|
|
|
|
nullptr, // dsh
|
|
|
|
nullptr, // ioh
|
|
|
|
&ssh, // ssh
|
|
|
|
pDevice->getGmmHelper(), // gmmHelper
|
|
|
|
0, // statelessMocsIndex
|
|
|
|
MemoryCompressionState::NotApplicable, // memoryCompressionState
|
|
|
|
false, // setInstructionStateBaseAddress
|
|
|
|
false, // setGeneralStateBaseAddress
|
|
|
|
true, // useGlobalHeapsBaseAddress
|
|
|
|
false, // isMultiOsContextCapable
|
|
|
|
false, // useGlobalAtomics
|
|
|
|
false // areMultipleSubDevicesInContext
|
|
|
|
};
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
2022-08-03 19:54:08 +08:00
|
|
|
|
2021-01-26 00:08:33 +08:00
|
|
|
EXPECT_EQ(cmd->getBindlessSurfaceStateBaseAddress(), globalBindlessHeapsBaseAddress);
|
|
|
|
}
|
2021-12-16 01:45:30 +08:00
|
|
|
HWTEST2_F(SBATest, givenSurfaceStateHeapWhenNotUsingGlobalHeapBaseThenBindlessSurfaceBaseIsSshBase, IsAtLeastSkl) {
|
2021-01-26 00:08:33 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
EXPECT_NE(IGFX_BROADWELL, ::productFamily);
|
|
|
|
|
|
|
|
uint64_t globalBindlessHeapsBaseAddress = 0x12340000;
|
|
|
|
|
|
|
|
StackVec<char, 4096> buffer(4096);
|
|
|
|
NEO::LinearStream cmdStream(buffer.begin(), buffer.size());
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS *cmd = reinterpret_cast<STATE_BASE_ADDRESS *>(cmdStream.getSpace(0));
|
2022-08-11 21:36:02 +08:00
|
|
|
|
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = {
|
|
|
|
0, // generalStateBase
|
|
|
|
0, // indirectObjectHeapBaseAddress
|
|
|
|
0, // instructionHeapBaseAddress
|
|
|
|
globalBindlessHeapsBaseAddress, // globalHeapsBaseAddress
|
|
|
|
cmd, // stateBaseAddressCmd
|
|
|
|
nullptr, // dsh
|
|
|
|
nullptr, // ioh
|
|
|
|
&ssh, // ssh
|
|
|
|
pDevice->getGmmHelper(), // gmmHelper
|
|
|
|
0, // statelessMocsIndex
|
|
|
|
MemoryCompressionState::NotApplicable, // memoryCompressionState
|
|
|
|
false, // setInstructionStateBaseAddress
|
|
|
|
false, // setGeneralStateBaseAddress
|
|
|
|
false, // useGlobalHeapsBaseAddress
|
|
|
|
false, // isMultiOsContextCapable
|
|
|
|
false, // useGlobalAtomics
|
|
|
|
false // areMultipleSubDevicesInContext
|
|
|
|
};
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
2022-08-03 19:54:08 +08:00
|
|
|
|
2021-01-26 00:08:33 +08:00
|
|
|
EXPECT_EQ(ssh.getHeapGpuBase(), cmd->getBindlessSurfaceStateBaseAddress());
|
2021-01-26 22:05:22 +08:00
|
|
|
}
|
2022-06-22 19:57:48 +08:00
|
|
|
|
|
|
|
HWTEST2_F(SBATest, givenStateBaseAddressAndDebugFlagSetWhenAppendExtraCacheSettingsThenNothingChanged, IsAtMostXeHpCore) {
|
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
auto stateBaseAddress = FamilyType::cmdInitStateBaseAddress;
|
|
|
|
auto expectedStateBaseAddress = FamilyType::cmdInitStateBaseAddress;
|
2022-08-12 20:23:39 +08:00
|
|
|
DebugManagerStateRestore restore;
|
2022-06-22 19:57:48 +08:00
|
|
|
|
2022-06-22 21:13:37 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(&stateBaseAddress, &hardwareInfo);
|
2022-06-22 19:57:48 +08:00
|
|
|
EXPECT_EQ(0, memcmp(&stateBaseAddress, &expectedStateBaseAddress, sizeof(STATE_BASE_ADDRESS)));
|
|
|
|
|
|
|
|
DebugManager.flags.ForceStatelessL1CachingPolicy.set(2);
|
2022-06-22 21:13:37 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(&stateBaseAddress, &hardwareInfo);
|
2022-06-22 19:57:48 +08:00
|
|
|
EXPECT_EQ(0, memcmp(&stateBaseAddress, &expectedStateBaseAddress, sizeof(STATE_BASE_ADDRESS)));
|
2022-08-12 20:23:39 +08:00
|
|
|
|
|
|
|
DebugManager.flags.ForceAllResourcesUncached.set(true);
|
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(&stateBaseAddress, &hardwareInfo);
|
|
|
|
EXPECT_EQ(0, memcmp(&stateBaseAddress, &expectedStateBaseAddress, sizeof(STATE_BASE_ADDRESS)));
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST2_F(SBATest, givenStateBaseAddressAndDebugFlagSetWhenAppendExtraCacheSettingsThenProgramCorrectL1CachePolicy, IsAtLeastXeHpgCore) {
|
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
auto stateBaseAddress = FamilyType::cmdInitStateBaseAddress;
|
|
|
|
DebugManagerStateRestore restore;
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(&stateBaseAddress, &hardwareInfo);
|
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WBP, stateBaseAddress.getL1CachePolicyL1CacheControl());
|
|
|
|
|
|
|
|
DebugManager.flags.ForceStatelessL1CachingPolicy.set(2);
|
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(&stateBaseAddress, &hardwareInfo);
|
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WB, stateBaseAddress.getL1CachePolicyL1CacheControl());
|
|
|
|
|
|
|
|
DebugManager.flags.ForceStatelessL1CachingPolicy.set(3);
|
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(&stateBaseAddress, &hardwareInfo);
|
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WT, stateBaseAddress.getL1CachePolicyL1CacheControl());
|
|
|
|
|
|
|
|
DebugManager.flags.ForceStatelessL1CachingPolicy.set(4);
|
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(&stateBaseAddress, &hardwareInfo);
|
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WS, stateBaseAddress.getL1CachePolicyL1CacheControl());
|
|
|
|
|
|
|
|
DebugManager.flags.ForceAllResourcesUncached.set(true);
|
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(&stateBaseAddress, &hardwareInfo);
|
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_UC, stateBaseAddress.getL1CachePolicyL1CacheControl());
|
2022-06-22 19:57:48 +08:00
|
|
|
}
|
2022-06-22 21:13:37 +08:00
|
|
|
|
|
|
|
HWTEST2_F(SBATest, givenDebugFlagSetWhenAppendingSbaThenProgramCorrectL1CachePolicy, IsAtLeastXeHpgCore) {
|
|
|
|
auto memoryManager = pDevice->getExecutionEnvironment()->memoryManager.get();
|
|
|
|
AllocationProperties properties(pDevice->getRootDeviceIndex(), 1, AllocationType::BUFFER, pDevice->getDeviceBitfield());
|
|
|
|
auto allocation = memoryManager->allocateGraphicsMemoryWithProperties(properties);
|
|
|
|
|
|
|
|
IndirectHeap indirectHeap(allocation, 1);
|
|
|
|
auto sbaCmd = FamilyType::cmdInitStateBaseAddress;
|
|
|
|
|
|
|
|
struct {
|
|
|
|
uint32_t option;
|
|
|
|
typename FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY cachePolicy;
|
|
|
|
} testInputs[] = {
|
|
|
|
{0, FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WBP},
|
|
|
|
{2, FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WB},
|
|
|
|
{3, FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WT},
|
|
|
|
{4, FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_WS}};
|
|
|
|
|
2022-08-11 21:36:02 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = {
|
|
|
|
0, // generalStateBase
|
|
|
|
0, // indirectObjectHeapBaseAddress
|
|
|
|
0, // instructionHeapBaseAddress
|
|
|
|
0, // globalHeapsBaseAddress
|
|
|
|
&sbaCmd, // stateBaseAddressCmd
|
|
|
|
nullptr, // dsh
|
|
|
|
nullptr, // ioh
|
|
|
|
&indirectHeap, // ssh
|
|
|
|
pDevice->getRootDeviceEnvironment().getGmmHelper(), // gmmHelper
|
|
|
|
0, // statelessMocsIndex
|
|
|
|
MemoryCompressionState::NotApplicable, // memoryCompressionState
|
|
|
|
false, // setInstructionStateBaseAddress
|
|
|
|
true, // setGeneralStateBaseAddress
|
|
|
|
false, // useGlobalHeapsBaseAddress
|
|
|
|
false, // isMultiOsContextCapable
|
|
|
|
false, // useGlobalAtomics
|
|
|
|
false // areMultipleSubDevicesInContext
|
|
|
|
};
|
|
|
|
|
2022-06-22 21:13:37 +08:00
|
|
|
for (const auto &input : testInputs) {
|
2022-08-12 20:23:39 +08:00
|
|
|
DebugManagerStateRestore restore;
|
2022-06-22 21:13:37 +08:00
|
|
|
DebugManager.flags.OverrideL1CachePolicyInSurfaceStateAndStateless.set(input.option);
|
2022-08-11 21:36:02 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendStateBaseAddressParameters(args, true);
|
2022-06-22 21:13:37 +08:00
|
|
|
|
|
|
|
EXPECT_EQ(input.cachePolicy, sbaCmd.getL1CachePolicyL1CacheControl());
|
2022-08-12 20:23:39 +08:00
|
|
|
|
|
|
|
DebugManager.flags.ForceAllResourcesUncached.set(true);
|
|
|
|
StateBaseAddressHelper<FamilyType>::appendStateBaseAddressParameters(args, true);
|
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_POLICY_UC, sbaCmd.getL1CachePolicyL1CacheControl());
|
2022-06-22 21:13:37 +08:00
|
|
|
}
|
|
|
|
memoryManager->freeGraphicsMemory(allocation);
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST2_F(SBATest, givenDebugFlagSetWhenAppendingRssThenProgramCorrectL1CachePolicy, IsAtLeastXeHpgCore) {
|
|
|
|
auto memoryManager = pDevice->getExecutionEnvironment()->memoryManager.get();
|
|
|
|
size_t allocationSize = MemoryConstants::pageSize;
|
|
|
|
AllocationProperties properties(pDevice->getRootDeviceIndex(), allocationSize, AllocationType::BUFFER, pDevice->getDeviceBitfield());
|
|
|
|
auto allocation = memoryManager->allocateGraphicsMemoryWithProperties(properties);
|
|
|
|
|
|
|
|
auto rssCmd = FamilyType::cmdInitRenderSurfaceState;
|
|
|
|
|
|
|
|
auto multiGraphicsAllocation = MultiGraphicsAllocation(pDevice->getRootDeviceIndex());
|
|
|
|
multiGraphicsAllocation.addAllocation(allocation);
|
|
|
|
|
|
|
|
EncodeSurfaceStateArgs args;
|
|
|
|
args.outMemory = &rssCmd;
|
|
|
|
args.graphicsAddress = allocation->getGpuAddress();
|
|
|
|
args.size = allocation->getUnderlyingBufferSize();
|
|
|
|
args.mocs = 0;
|
|
|
|
args.numAvailableDevices = pDevice->getNumGenericSubDevices();
|
|
|
|
args.allocation = allocation;
|
|
|
|
args.gmmHelper = pDevice->getGmmHelper();
|
|
|
|
args.areMultipleSubDevicesInContext = true;
|
|
|
|
|
|
|
|
struct {
|
|
|
|
uint32_t option;
|
|
|
|
typename FamilyType::RENDER_SURFACE_STATE::L1_CACHE_POLICY cachePolicy;
|
|
|
|
} testInputs[] = {
|
|
|
|
{0, FamilyType::RENDER_SURFACE_STATE::L1_CACHE_POLICY_WBP},
|
|
|
|
{2, FamilyType::RENDER_SURFACE_STATE::L1_CACHE_POLICY_WB},
|
|
|
|
{3, FamilyType::RENDER_SURFACE_STATE::L1_CACHE_POLICY_WT},
|
|
|
|
{4, FamilyType::RENDER_SURFACE_STATE::L1_CACHE_POLICY_WS}};
|
|
|
|
|
|
|
|
for (const auto &input : testInputs) {
|
2022-08-12 20:23:39 +08:00
|
|
|
DebugManagerStateRestore restore;
|
2022-06-22 21:13:37 +08:00
|
|
|
DebugManager.flags.OverrideL1CachePolicyInSurfaceStateAndStateless.set(input.option);
|
|
|
|
EncodeSurfaceState<FamilyType>::encodeBuffer(args);
|
|
|
|
EXPECT_EQ(input.cachePolicy, rssCmd.getL1CachePolicyL1CacheControl());
|
|
|
|
}
|
|
|
|
memoryManager->freeGraphicsMemory(allocation);
|
|
|
|
}
|