2020-04-22 04:40:21 +08:00
|
|
|
/*
|
2025-02-04 23:17:19 +08:00
|
|
|
* Copyright (C) 2020-2025 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
|
|
|
|
2023-01-21 01:45:04 +08:00
|
|
|
#include "shared/source/command_container/encode_surface_state.h"
|
2025-04-14 20:58:01 +08:00
|
|
|
#include "shared/source/command_stream/stream_properties.h"
|
2022-08-19 09:22:04 +08:00
|
|
|
#include "shared/source/gmm_helper/gmm_helper.h"
|
2024-08-05 22:02:25 +08:00
|
|
|
#include "shared/source/helpers/state_base_address_helper.h"
|
2022-12-07 19:51:44 +08:00
|
|
|
#include "shared/source/memory_manager/allocation_properties.h"
|
2023-02-20 18:27:13 +08:00
|
|
|
#include "shared/test/common/helpers/debug_manager_state_restore.h"
|
2023-01-17 00:40:13 +08:00
|
|
|
#include "shared/test/common/mocks/mock_device.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
|
|
|
|
2022-12-29 20:27:52 +08:00
|
|
|
#include "encode_surface_state_args.h"
|
|
|
|
|
2025-01-22 21:10:44 +08:00
|
|
|
HWTEST2_F(SbaTest, WhenAppendStateBaseAddressParametersIsCalledThenSBACmdHasBindingSurfaceStateProgrammed, IsGen12LP) {
|
2020-04-22 04:40:21 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS stateBaseAddress;
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateSize(0);
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateBaseAddress(0);
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateBaseAddressModifyEnable(false);
|
|
|
|
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&stateBaseAddress, nullptr, &ssh, nullptr, nullptr);
|
2022-08-11 21:36:02 +08:00
|
|
|
|
2023-02-22 04:17:22 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendStateBaseAddressParameters(args);
|
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());
|
|
|
|
}
|
|
|
|
|
2024-09-17 19:32:35 +08:00
|
|
|
HWTEST2_F(SbaTest, WhenProgramStateBaseAddressParametersIsCalledThenSBACmdHasBindingSurfaceStateProgrammed, MatchAny) {
|
2020-04-22 04:40:21 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
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;
|
|
|
|
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(cmd, pDevice->getGmmHelper(), &ssh, nullptr, nullptr);
|
2022-08-11 21:36:02 +08:00
|
|
|
|
|
|
|
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());
|
2022-08-18 06:33:49 +08:00
|
|
|
|
|
|
|
EXPECT_TRUE(cmd->getSurfaceStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(ssh.getHeapGpuBase(), cmd->getSurfaceStateBaseAddress());
|
|
|
|
}
|
|
|
|
|
2022-08-19 09:22:04 +08:00
|
|
|
HWTEST2_F(SbaTest,
|
2024-09-17 19:32:35 +08:00
|
|
|
givenProgramSurfaceStateBaseAddressUsingHeapBaseWhenOverrideSurfaceStateBaseAddressUsedThenSbaDispatchedWithOverrideValue, MatchAny) {
|
2022-08-18 06:33:49 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
constexpr uint64_t surfaceStateBaseAddress = 0xBADA550000;
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS cmd;
|
|
|
|
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&cmd, pDevice->getGmmHelper(), &ssh, nullptr, nullptr);
|
|
|
|
args.surfaceStateBaseAddress = surfaceStateBaseAddress;
|
|
|
|
args.overrideSurfaceStateBaseAddress = true;
|
2022-08-18 06:33:49 +08:00
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_TRUE(cmd.getSurfaceStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(surfaceStateBaseAddress, cmd.getSurfaceStateBaseAddress());
|
2020-04-22 04:40:21 +08:00
|
|
|
}
|
2020-12-04 19:28:18 +08:00
|
|
|
|
2023-02-25 00:55:21 +08:00
|
|
|
using SbaForBindlessTests = SbaTest;
|
2020-12-04 19:28:18 +08:00
|
|
|
|
2024-09-17 19:32:35 +08:00
|
|
|
HWTEST2_F(SbaForBindlessTests, givenGlobalBindlessBaseAddressWhenProgramStateBaseAddressThenSbaProgrammedCorrectly, MatchAny) {
|
2020-12-04 19:28:18 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
2022-08-18 06:33:49 +08:00
|
|
|
constexpr uint64_t globalBindlessHeapsBaseAddress = 0x12340000;
|
2020-12-04 19:28:18 +08:00
|
|
|
|
|
|
|
StackVec<char, 4096> buffer(4096);
|
|
|
|
NEO::LinearStream cmdStream(buffer.begin(), buffer.size());
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS *cmd = reinterpret_cast<STATE_BASE_ADDRESS *>(cmdStream.getSpace(0));
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(cmd, pDevice->getGmmHelper());
|
|
|
|
args.globalHeapsBaseAddress = globalBindlessHeapsBaseAddress;
|
|
|
|
args.useGlobalHeapsBaseAddress = true;
|
2024-04-24 22:08:57 +08:00
|
|
|
args.ssh = &ssh;
|
2022-08-11 21:36:02 +08:00
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
2022-08-03 19:54:08 +08:00
|
|
|
|
2020-12-04 19:28:18 +08:00
|
|
|
EXPECT_TRUE(cmd->getBindlessSurfaceStateBaseAddressModifyEnable());
|
2022-08-18 06:33:49 +08:00
|
|
|
EXPECT_EQ(globalBindlessHeapsBaseAddress, cmd->getBindlessSurfaceStateBaseAddress());
|
|
|
|
|
|
|
|
auto surfaceStateCount = StateBaseAddressHelper<FamilyType>::getMaxBindlessSurfaceStates();
|
|
|
|
EXPECT_EQ(surfaceStateCount, cmd->getBindlessSurfaceStateSize());
|
|
|
|
|
|
|
|
EXPECT_TRUE(cmd->getBindlessSurfaceStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(globalBindlessHeapsBaseAddress, cmd->getBindlessSurfaceStateBaseAddress());
|
|
|
|
|
|
|
|
EXPECT_TRUE(cmd->getDynamicStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_TRUE(cmd->getDynamicStateBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(globalBindlessHeapsBaseAddress, cmd->getDynamicStateBaseAddress());
|
|
|
|
|
|
|
|
EXPECT_TRUE(cmd->getSurfaceStateBaseAddressModifyEnable());
|
2024-04-24 22:08:57 +08:00
|
|
|
EXPECT_NE(globalBindlessHeapsBaseAddress, cmd->getSurfaceStateBaseAddress());
|
|
|
|
EXPECT_EQ(ssh.getHeapGpuBase(), cmd->getSurfaceStateBaseAddress());
|
2022-08-18 06:33:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST2_F(SbaForBindlessTests,
|
2024-09-17 19:32:35 +08:00
|
|
|
givenGlobalBindlessBaseAddressOverridenSurfaceStateBaseAddressWhenProgramStateBaseAddressThenSbaProgrammedCorrectly, MatchAny) {
|
2022-08-18 06:33:49 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
constexpr uint64_t globalBindlessHeapsBaseAddress = 0x12340000;
|
|
|
|
constexpr uint64_t surfaceStateBaseAddress = 0xBADA550000;
|
|
|
|
|
|
|
|
StackVec<char, 4096> buffer(4096);
|
|
|
|
NEO::LinearStream cmdStream(buffer.begin(), buffer.size());
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS *cmd = reinterpret_cast<STATE_BASE_ADDRESS *>(cmdStream.getSpace(0));
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(cmd, pDevice->getGmmHelper());
|
|
|
|
args.globalHeapsBaseAddress = globalBindlessHeapsBaseAddress;
|
|
|
|
args.surfaceStateBaseAddress = surfaceStateBaseAddress;
|
|
|
|
args.useGlobalHeapsBaseAddress = true;
|
|
|
|
args.overrideSurfaceStateBaseAddress = true;
|
2022-08-18 06:33:49 +08:00
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_TRUE(cmd->getBindlessSurfaceStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(globalBindlessHeapsBaseAddress, cmd->getBindlessSurfaceStateBaseAddress());
|
2021-12-01 06:59:19 +08:00
|
|
|
|
|
|
|
auto surfaceStateCount = StateBaseAddressHelper<FamilyType>::getMaxBindlessSurfaceStates();
|
|
|
|
EXPECT_EQ(surfaceStateCount, cmd->getBindlessSurfaceStateSize());
|
2022-08-18 06:33:49 +08:00
|
|
|
|
|
|
|
EXPECT_TRUE(cmd->getBindlessSurfaceStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(globalBindlessHeapsBaseAddress, cmd->getBindlessSurfaceStateBaseAddress());
|
|
|
|
|
|
|
|
EXPECT_TRUE(cmd->getDynamicStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_TRUE(cmd->getDynamicStateBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(globalBindlessHeapsBaseAddress, cmd->getDynamicStateBaseAddress());
|
|
|
|
|
|
|
|
EXPECT_TRUE(cmd->getSurfaceStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(surfaceStateBaseAddress, cmd->getSurfaceStateBaseAddress());
|
2020-12-04 19:28:18 +08:00
|
|
|
}
|
2021-09-28 18:56:22 +08:00
|
|
|
|
2024-09-17 17:55:30 +08:00
|
|
|
using IohSupported = IsGen12LP;
|
2021-09-28 18:56:22 +08:00
|
|
|
|
|
|
|
HWTEST2_F(SbaForBindlessTests, givenGlobalBindlessBaseAddressWhenPassingIndirectBaseAddressThenIndirectBaseAddressIsSet, IohSupported) {
|
2020-12-04 19:28:18 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
2022-08-18 06:33:49 +08:00
|
|
|
constexpr uint64_t globalBindlessHeapsBaseAddress = 0x12340000;
|
|
|
|
constexpr uint64_t indirectObjectBaseAddress = 0x12340000;
|
2020-12-04 19:28:18 +08:00
|
|
|
|
|
|
|
StackVec<char, 4096> buffer(4096);
|
|
|
|
NEO::LinearStream cmdStream(buffer.begin(), buffer.size());
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS *cmd = reinterpret_cast<STATE_BASE_ADDRESS *>(cmdStream.getSpace(0));
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(cmd, pDevice->getGmmHelper());
|
|
|
|
args.globalHeapsBaseAddress = globalBindlessHeapsBaseAddress;
|
|
|
|
args.indirectObjectHeapBaseAddress = indirectObjectBaseAddress;
|
|
|
|
args.useGlobalHeapsBaseAddress = true;
|
2022-08-11 21:36:02 +08:00
|
|
|
|
|
|
|
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
|
|
|
}
|
|
|
|
|
2024-09-17 19:32:35 +08:00
|
|
|
HWTEST2_F(SbaTest, givenSbaWhenOverrideBindlessSurfaceBaseIsFalseThenBindlessSurfaceBaseIsNotSet, MatchAny) {
|
2021-01-26 00:08:33 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS stateBaseAddress;
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateSize(0);
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateBaseAddress(0);
|
|
|
|
stateBaseAddress.setBindlessSurfaceStateBaseAddressModifyEnable(false);
|
|
|
|
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&stateBaseAddress, pDevice->getRootDeviceEnvironment().getGmmHelper());
|
|
|
|
args.useGlobalHeapsBaseAddress = true;
|
2022-08-11 21:36:02 +08:00
|
|
|
|
2023-02-22 04:17:22 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendStateBaseAddressParameters(args);
|
2021-01-26 00:08:33 +08:00
|
|
|
|
|
|
|
EXPECT_EQ(0u, stateBaseAddress.getBindlessSurfaceStateBaseAddress());
|
|
|
|
}
|
|
|
|
|
2024-09-17 19:32:35 +08:00
|
|
|
HWTEST2_F(SbaTest, givenGlobalBindlessBaseAddressWhenSshIsPassedThenBindlessSurfaceBaseIsGlobalHeapBase, MatchAny) {
|
2021-01-26 00:08:33 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
2022-08-18 06:33:49 +08:00
|
|
|
constexpr uint64_t globalBindlessHeapsBaseAddress = 0x12340000;
|
2021-01-26 00:08:33 +08:00
|
|
|
|
|
|
|
StackVec<char, 4096> buffer(4096);
|
|
|
|
NEO::LinearStream cmdStream(buffer.begin(), buffer.size());
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS *cmd = reinterpret_cast<STATE_BASE_ADDRESS *>(cmdStream.getSpace(0));
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(cmd, pDevice->getGmmHelper(), &ssh, nullptr, nullptr);
|
|
|
|
args.globalHeapsBaseAddress = globalBindlessHeapsBaseAddress;
|
|
|
|
args.useGlobalHeapsBaseAddress = true;
|
2022-08-11 21:36:02 +08:00
|
|
|
|
|
|
|
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);
|
|
|
|
}
|
2024-09-17 19:32:35 +08:00
|
|
|
HWTEST2_F(SbaTest, givenSurfaceStateHeapWhenNotUsingGlobalHeapBaseThenBindlessSurfaceBaseIsSshBase, MatchAny) {
|
2021-01-26 00:08:33 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
2022-08-18 06:33:49 +08:00
|
|
|
constexpr uint64_t globalBindlessHeapsBaseAddress = 0x12340000;
|
2021-01-26 00:08:33 +08:00
|
|
|
|
|
|
|
StackVec<char, 4096> buffer(4096);
|
|
|
|
NEO::LinearStream cmdStream(buffer.begin(), buffer.size());
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS *cmd = reinterpret_cast<STATE_BASE_ADDRESS *>(cmdStream.getSpace(0));
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(cmd, pDevice->getGmmHelper(), &ssh, nullptr, nullptr);
|
|
|
|
args.globalHeapsBaseAddress = globalBindlessHeapsBaseAddress;
|
2022-08-11 21:36:02 +08:00
|
|
|
|
|
|
|
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
|
|
|
|
2024-09-17 19:32:35 +08:00
|
|
|
HWTEST2_F(SbaTest, givenNotUsedGlobalHeapBaseAndSshPassedWhenBindlessSurfStateBaseIsPassedThenBindlessSurfaceBaseIsSetToPassedValue, MatchAny) {
|
2023-06-27 01:49:16 +08:00
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
constexpr 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));
|
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(cmd, pDevice->getGmmHelper(), &ssh, nullptr, nullptr);
|
|
|
|
args.bindlessSurfaceStateBaseAddress = globalBindlessHeapsBaseAddress;
|
|
|
|
args.useGlobalHeapsBaseAddress = false;
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_EQ(cmd->getBindlessSurfaceStateBaseAddress(), globalBindlessHeapsBaseAddress);
|
|
|
|
EXPECT_NE(ssh.getHeapGpuBase(), globalBindlessHeapsBaseAddress);
|
|
|
|
}
|
|
|
|
|
2022-08-19 09:22:04 +08:00
|
|
|
HWTEST2_F(SbaTest, givenStateBaseAddressAndDebugFlagSetWhenAppendExtraCacheSettingsThenNothingChanged, IsAtMostXeHpCore) {
|
2022-06-22 19:57:48 +08:00
|
|
|
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
|
|
|
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&stateBaseAddress, pDevice->getGmmHelper(), &ssh, nullptr, nullptr);
|
2022-08-23 19:48:18 +08:00
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
2022-06-22 19:57:48 +08:00
|
|
|
EXPECT_EQ(0, memcmp(&stateBaseAddress, &expectedStateBaseAddress, sizeof(STATE_BASE_ADDRESS)));
|
|
|
|
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForceStatelessL1CachingPolicy.set(2);
|
2022-08-23 19:48:18 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
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
|
|
|
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForceAllResourcesUncached.set(true);
|
2022-08-23 19:48:18 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
2022-08-12 20:23:39 +08:00
|
|
|
EXPECT_EQ(0, memcmp(&stateBaseAddress, &expectedStateBaseAddress, sizeof(STATE_BASE_ADDRESS)));
|
|
|
|
}
|
|
|
|
|
2022-08-19 09:22:04 +08:00
|
|
|
HWTEST2_F(SbaTest, givenStateBaseAddressAndDebugFlagSetWhenAppendExtraCacheSettingsThenProgramCorrectL1CachePolicy, IsAtLeastXeHpgCore) {
|
2022-08-12 20:23:39 +08:00
|
|
|
auto stateBaseAddress = FamilyType::cmdInitStateBaseAddress;
|
|
|
|
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&stateBaseAddress, pDevice->getGmmHelper(), &ssh, nullptr, nullptr);
|
2023-02-25 00:55:21 +08:00
|
|
|
auto &productHelper = getHelper<ProductHelper>();
|
2022-08-23 19:48:18 +08:00
|
|
|
{
|
|
|
|
DebugManagerStateRestore restore;
|
2023-02-25 00:55:21 +08:00
|
|
|
updateSbaHelperArgsL1CachePolicy<FamilyType>(args, productHelper);
|
|
|
|
|
2022-08-23 19:48:18 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_WBP, stateBaseAddress.getL1CacheControlCachePolicy());
|
2022-08-23 19:48:18 +08:00
|
|
|
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForceStatelessL1CachingPolicy.set(2);
|
2023-02-25 00:55:21 +08:00
|
|
|
updateSbaHelperArgsL1CachePolicy<FamilyType>(args, productHelper);
|
|
|
|
|
2022-08-23 19:48:18 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_WB, stateBaseAddress.getL1CacheControlCachePolicy());
|
2022-08-12 20:23:39 +08:00
|
|
|
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForceStatelessL1CachingPolicy.set(3);
|
2023-02-25 00:55:21 +08:00
|
|
|
updateSbaHelperArgsL1CachePolicy<FamilyType>(args, productHelper);
|
|
|
|
|
2022-08-23 19:48:18 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_WT, stateBaseAddress.getL1CacheControlCachePolicy());
|
2022-08-23 19:48:18 +08:00
|
|
|
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForceStatelessL1CachingPolicy.set(4);
|
2023-02-25 00:55:21 +08:00
|
|
|
updateSbaHelperArgsL1CachePolicy<FamilyType>(args, productHelper);
|
|
|
|
|
2022-08-23 19:48:18 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_WS, stateBaseAddress.getL1CacheControlCachePolicy());
|
2022-08-23 19:48:18 +08:00
|
|
|
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForceAllResourcesUncached.set(true);
|
2023-02-25 00:55:21 +08:00
|
|
|
updateSbaHelperArgsL1CachePolicy<FamilyType>(args, productHelper);
|
|
|
|
|
2022-08-23 19:48:18 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_UC, stateBaseAddress.getL1CacheControlCachePolicy());
|
2022-08-23 19:48:18 +08:00
|
|
|
}
|
|
|
|
args.isDebuggerActive = true;
|
|
|
|
{
|
|
|
|
DebugManagerStateRestore restore;
|
2023-02-25 00:55:21 +08:00
|
|
|
updateSbaHelperArgsL1CachePolicy<FamilyType>(args, productHelper);
|
|
|
|
|
2022-08-23 19:48:18 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_WBP, stateBaseAddress.getL1CacheControlCachePolicy());
|
2022-08-23 19:48:18 +08:00
|
|
|
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForceStatelessL1CachingPolicy.set(2);
|
2023-02-25 00:55:21 +08:00
|
|
|
updateSbaHelperArgsL1CachePolicy<FamilyType>(args, productHelper);
|
|
|
|
|
2022-08-23 19:48:18 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_WB, stateBaseAddress.getL1CacheControlCachePolicy());
|
2022-08-23 19:48:18 +08:00
|
|
|
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForceStatelessL1CachingPolicy.set(3);
|
2023-02-25 00:55:21 +08:00
|
|
|
updateSbaHelperArgsL1CachePolicy<FamilyType>(args, productHelper);
|
|
|
|
|
2022-08-23 19:48:18 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_WT, stateBaseAddress.getL1CacheControlCachePolicy());
|
2022-08-23 19:48:18 +08:00
|
|
|
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForceStatelessL1CachingPolicy.set(4);
|
2023-02-25 00:55:21 +08:00
|
|
|
updateSbaHelperArgsL1CachePolicy<FamilyType>(args, productHelper);
|
|
|
|
|
2022-08-23 19:48:18 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_WS, stateBaseAddress.getL1CacheControlCachePolicy());
|
2022-08-23 19:48:18 +08:00
|
|
|
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForceAllResourcesUncached.set(true);
|
2023-02-25 00:55:21 +08:00
|
|
|
updateSbaHelperArgsL1CachePolicy<FamilyType>(args, productHelper);
|
|
|
|
|
2022-08-23 19:48:18 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendExtraCacheSettings(args);
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_UC, stateBaseAddress.getL1CacheControlCachePolicy());
|
2022-08-23 19:48:18 +08:00
|
|
|
}
|
2022-06-22 19:57:48 +08:00
|
|
|
}
|
2022-06-22 21:13:37 +08:00
|
|
|
|
2022-08-19 09:22:04 +08:00
|
|
|
HWTEST2_F(SbaTest, givenDebugFlagSetWhenAppendingSbaThenProgramCorrectL1CachePolicy, IsAtLeastXeHpgCore) {
|
2022-06-22 21:13:37 +08:00
|
|
|
auto sbaCmd = FamilyType::cmdInitStateBaseAddress;
|
|
|
|
|
|
|
|
struct {
|
|
|
|
uint32_t option;
|
2024-11-29 00:31:41 +08:00
|
|
|
typename FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL cachePolicy;
|
2022-06-22 21:13:37 +08:00
|
|
|
} testInputs[] = {
|
2024-11-29 00:31:41 +08:00
|
|
|
{0, FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_WBP},
|
|
|
|
{2, FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_WB},
|
|
|
|
{3, FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_WT},
|
|
|
|
{4, FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_WS}};
|
2022-06-22 21:13:37 +08:00
|
|
|
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&sbaCmd, pDevice->getRootDeviceEnvironment().getGmmHelper(), &ssh, nullptr, nullptr);
|
|
|
|
args.setGeneralStateBaseAddress = true;
|
2022-08-11 21:36:02 +08:00
|
|
|
|
2023-02-25 00:55:21 +08:00
|
|
|
auto &productHelper = getHelper<ProductHelper>();
|
|
|
|
|
2022-06-22 21:13:37 +08:00
|
|
|
for (const auto &input : testInputs) {
|
2022-08-12 20:23:39 +08:00
|
|
|
DebugManagerStateRestore restore;
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.OverrideL1CachePolicyInSurfaceStateAndStateless.set(input.option);
|
2023-02-25 00:55:21 +08:00
|
|
|
updateSbaHelperArgsL1CachePolicy<FamilyType>(args, productHelper);
|
|
|
|
|
2023-02-22 04:17:22 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendStateBaseAddressParameters(args);
|
2022-06-22 21:13:37 +08:00
|
|
|
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(input.cachePolicy, sbaCmd.getL1CacheControlCachePolicy());
|
2022-08-12 20:23:39 +08:00
|
|
|
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForceAllResourcesUncached.set(true);
|
2023-02-25 00:55:21 +08:00
|
|
|
updateSbaHelperArgsL1CachePolicy<FamilyType>(args, productHelper);
|
|
|
|
|
2023-02-22 04:17:22 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendStateBaseAddressParameters(args);
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(FamilyType::STATE_BASE_ADDRESS::L1_CACHE_CONTROL_UC, sbaCmd.getL1CacheControlCachePolicy());
|
2022-06-22 21:13:37 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-08-19 09:22:04 +08:00
|
|
|
HWTEST2_F(SbaTest, givenDebugFlagSetWhenAppendingRssThenProgramCorrectL1CachePolicy, IsAtLeastXeHpgCore) {
|
2022-06-22 21:13:37 +08:00
|
|
|
auto memoryManager = pDevice->getExecutionEnvironment()->memoryManager.get();
|
|
|
|
size_t allocationSize = MemoryConstants::pageSize;
|
2023-12-11 22:24:36 +08:00
|
|
|
AllocationProperties properties(pDevice->getRootDeviceIndex(), allocationSize, AllocationType::buffer, pDevice->getDeviceBitfield());
|
2022-06-22 21:13:37 +08:00
|
|
|
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;
|
2024-11-29 00:31:41 +08:00
|
|
|
typename FamilyType::RENDER_SURFACE_STATE::L1_CACHE_CONTROL cachePolicy;
|
2022-06-22 21:13:37 +08:00
|
|
|
} testInputs[] = {
|
2024-11-29 00:31:41 +08:00
|
|
|
{0, FamilyType::RENDER_SURFACE_STATE::L1_CACHE_CONTROL_WBP},
|
|
|
|
{2, FamilyType::RENDER_SURFACE_STATE::L1_CACHE_CONTROL_WB},
|
|
|
|
{3, FamilyType::RENDER_SURFACE_STATE::L1_CACHE_CONTROL_WT},
|
|
|
|
{4, FamilyType::RENDER_SURFACE_STATE::L1_CACHE_CONTROL_WS}};
|
2022-06-22 21:13:37 +08:00
|
|
|
|
|
|
|
for (const auto &input : testInputs) {
|
2022-08-12 20:23:39 +08:00
|
|
|
DebugManagerStateRestore restore;
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.OverrideL1CachePolicyInSurfaceStateAndStateless.set(input.option);
|
2022-06-22 21:13:37 +08:00
|
|
|
EncodeSurfaceState<FamilyType>::encodeBuffer(args);
|
2024-11-29 00:31:41 +08:00
|
|
|
EXPECT_EQ(input.cachePolicy, rssCmd.getL1CacheControlCachePolicy());
|
2022-06-22 21:13:37 +08:00
|
|
|
}
|
|
|
|
memoryManager->freeGraphicsMemory(allocation);
|
2022-08-18 06:33:49 +08:00
|
|
|
}
|
2022-08-19 09:22:04 +08:00
|
|
|
|
2024-09-19 21:06:41 +08:00
|
|
|
HWCMDTEST_F(IGFX_GEN12LP_CORE, SbaTest, whenGeneralStateBaseAddressIsProgrammedThenDecanonizedAddressIsWritten) {
|
2022-08-19 09:22:04 +08:00
|
|
|
constexpr uint64_t generalStateBaseAddress = 0xffff800400010000ull;
|
|
|
|
|
|
|
|
auto gmmHelper = pDevice->getGmmHelper();
|
|
|
|
|
|
|
|
typename FamilyType::STATE_BASE_ADDRESS sbaCmd;
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&sbaCmd, gmmHelper, &ssh, &dsh, &ioh);
|
|
|
|
args.generalStateBaseAddress = generalStateBaseAddress;
|
|
|
|
args.instructionHeapBaseAddress = generalStateBaseAddress;
|
|
|
|
args.setInstructionStateBaseAddress = true;
|
|
|
|
args.setGeneralStateBaseAddress = true;
|
|
|
|
|
2022-08-19 09:22:04 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_NE(generalStateBaseAddress, sbaCmd.getGeneralStateBaseAddress());
|
|
|
|
EXPECT_EQ(gmmHelper->decanonize(generalStateBaseAddress), sbaCmd.getGeneralStateBaseAddress());
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_F(SbaTest, givenNonZeroGeneralStateBaseAddressWhenProgrammingIsDisabledThenExpectCommandValueZero) {
|
|
|
|
constexpr uint64_t generalStateBaseAddress = 0x80010000ull;
|
|
|
|
|
|
|
|
typename FamilyType::STATE_BASE_ADDRESS sbaCmd;
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&sbaCmd, pDevice->getGmmHelper(), &ssh, &dsh, &ioh);
|
|
|
|
args.generalStateBaseAddress = generalStateBaseAddress;
|
|
|
|
args.instructionHeapBaseAddress = generalStateBaseAddress;
|
|
|
|
args.setInstructionStateBaseAddress = true;
|
|
|
|
|
2022-08-19 09:22:04 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_EQ(0ull, sbaCmd.getGeneralStateBaseAddress());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getGeneralStateBufferSize());
|
|
|
|
EXPECT_FALSE(sbaCmd.getGeneralStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_FALSE(sbaCmd.getGeneralStateBufferSizeModifyEnable());
|
|
|
|
}
|
|
|
|
|
|
|
|
HWTEST_F(SbaTest, givenNonZeroInternalHeapBaseAddressWhenProgrammingIsDisabledThenExpectCommandValueZero) {
|
|
|
|
constexpr uint64_t internalHeapBaseAddress = 0x80010000ull;
|
|
|
|
|
|
|
|
typename FamilyType::STATE_BASE_ADDRESS sbaCmd;
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&sbaCmd, pDevice->getGmmHelper(), &ssh, &dsh, &ioh);
|
|
|
|
args.generalStateBaseAddress = internalHeapBaseAddress;
|
|
|
|
args.indirectObjectHeapBaseAddress = internalHeapBaseAddress;
|
|
|
|
args.setGeneralStateBaseAddress = true;
|
|
|
|
|
2022-08-19 09:22:04 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_FALSE(sbaCmd.getInstructionBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(0ull, sbaCmd.getInstructionBaseAddress());
|
|
|
|
EXPECT_FALSE(sbaCmd.getInstructionBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getInstructionBufferSize());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getInstructionMemoryObjectControlState());
|
|
|
|
}
|
|
|
|
|
2024-09-19 21:06:41 +08:00
|
|
|
HWCMDTEST_F(IGFX_GEN12LP_CORE, SbaTest, givenSbaProgrammingWhenHeapsAreNotProvidedThenDontProgram) {
|
2022-08-19 09:22:04 +08:00
|
|
|
auto gmmHelper = pDevice->getGmmHelper();
|
|
|
|
|
|
|
|
constexpr uint64_t internalHeapBase = 0x10000;
|
|
|
|
constexpr uint64_t instructionHeapBase = 0x10000;
|
|
|
|
constexpr uint64_t generalStateBase = 0x30000;
|
|
|
|
|
|
|
|
typename FamilyType::STATE_BASE_ADDRESS sbaCmd;
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&sbaCmd, pDevice->getGmmHelper());
|
|
|
|
args.generalStateBaseAddress = generalStateBase;
|
|
|
|
args.indirectObjectHeapBaseAddress = internalHeapBase;
|
|
|
|
args.instructionHeapBaseAddress = instructionHeapBase;
|
|
|
|
args.setGeneralStateBaseAddress = true;
|
|
|
|
args.setInstructionStateBaseAddress = true;
|
2022-08-19 09:22:04 +08:00
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_FALSE(sbaCmd.getDynamicStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_FALSE(sbaCmd.getDynamicStateBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getDynamicStateBaseAddress());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getDynamicStateBufferSize());
|
|
|
|
|
|
|
|
EXPECT_FALSE(sbaCmd.getIndirectObjectBaseAddressModifyEnable());
|
|
|
|
EXPECT_FALSE(sbaCmd.getIndirectObjectBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getIndirectObjectBaseAddress());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getIndirectObjectBufferSize());
|
|
|
|
|
|
|
|
EXPECT_FALSE(sbaCmd.getSurfaceStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getSurfaceStateBaseAddress());
|
|
|
|
|
|
|
|
EXPECT_TRUE(sbaCmd.getInstructionBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(instructionHeapBase, sbaCmd.getInstructionBaseAddress());
|
|
|
|
EXPECT_TRUE(sbaCmd.getInstructionBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(MemoryConstants::sizeOf4GBinPageEntities, sbaCmd.getInstructionBufferSize());
|
|
|
|
|
|
|
|
EXPECT_TRUE(sbaCmd.getGeneralStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_TRUE(sbaCmd.getGeneralStateBufferSizeModifyEnable());
|
|
|
|
|
|
|
|
EXPECT_EQ(gmmHelper->decanonize(generalStateBase), sbaCmd.getGeneralStateBaseAddress());
|
|
|
|
EXPECT_EQ(0xfffffu, sbaCmd.getGeneralStateBufferSize());
|
|
|
|
}
|
|
|
|
|
|
|
|
HWCMDTEST_F(IGFX_XE_HP_CORE, SbaTest,
|
|
|
|
givenNoHeapsProvidedWhenSBAIsProgrammedThenBaseAddressesAreNotSetAndBindlessSurfaceStateSizeSetToMax) {
|
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
auto gmmHelper = pDevice->getGmmHelper();
|
|
|
|
|
|
|
|
constexpr uint64_t instructionHeapBase = 0x10000;
|
|
|
|
constexpr uint64_t internalHeapBase = 0x10000;
|
|
|
|
constexpr uint64_t generalStateBase = 0x30000;
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS sbaCmd;
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&sbaCmd, gmmHelper);
|
|
|
|
args.generalStateBaseAddress = generalStateBase;
|
|
|
|
args.indirectObjectHeapBaseAddress = internalHeapBase;
|
|
|
|
args.instructionHeapBaseAddress = instructionHeapBase;
|
|
|
|
args.setGeneralStateBaseAddress = true;
|
|
|
|
args.setInstructionStateBaseAddress = true;
|
|
|
|
|
2022-08-19 09:22:04 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_FALSE(sbaCmd.getDynamicStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_FALSE(sbaCmd.getDynamicStateBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getDynamicStateBaseAddress());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getDynamicStateBufferSize());
|
|
|
|
|
|
|
|
EXPECT_FALSE(sbaCmd.getSurfaceStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getSurfaceStateBaseAddress());
|
|
|
|
|
|
|
|
EXPECT_TRUE(sbaCmd.getInstructionBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(instructionHeapBase, sbaCmd.getInstructionBaseAddress());
|
|
|
|
EXPECT_TRUE(sbaCmd.getInstructionBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(MemoryConstants::sizeOf4GBinPageEntities, sbaCmd.getInstructionBufferSize());
|
|
|
|
|
|
|
|
EXPECT_TRUE(sbaCmd.getGeneralStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_TRUE(sbaCmd.getGeneralStateBufferSizeModifyEnable());
|
|
|
|
if constexpr (is64bit) {
|
|
|
|
EXPECT_EQ(gmmHelper->decanonize(internalHeapBase), sbaCmd.getGeneralStateBaseAddress());
|
|
|
|
} else {
|
|
|
|
EXPECT_EQ(generalStateBase, sbaCmd.getGeneralStateBaseAddress());
|
|
|
|
}
|
|
|
|
EXPECT_EQ(0xfffffu, sbaCmd.getGeneralStateBufferSize());
|
|
|
|
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getBindlessSurfaceStateBaseAddress());
|
|
|
|
EXPECT_FALSE(sbaCmd.getBindlessSurfaceStateBaseAddressModifyEnable());
|
2023-08-17 16:17:57 +08:00
|
|
|
uint32_t defaultBindlessSurfaceStateSize = StateBaseAddressHelper<FamilyType>::getMaxBindlessSurfaceStates();
|
|
|
|
EXPECT_EQ(defaultBindlessSurfaceStateSize, sbaCmd.getBindlessSurfaceStateSize());
|
|
|
|
}
|
|
|
|
|
|
|
|
HWCMDTEST_F(IGFX_XE_HP_CORE, SbaTest,
|
|
|
|
givenNoHeapsProvidedAndBindlessBaseSetWhenSBAIsProgrammedThenBindlessSurfaceStateSizeSetToZeroAndBaseAddressSetToPassedValue) {
|
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
auto gmmHelper = pDevice->getGmmHelper();
|
|
|
|
|
|
|
|
constexpr uint64_t instructionHeapBase = 0x10000;
|
|
|
|
constexpr uint64_t internalHeapBase = 0x10000;
|
|
|
|
constexpr uint64_t generalStateBase = 0x30000;
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS sbaCmd;
|
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&sbaCmd, gmmHelper);
|
|
|
|
args.generalStateBaseAddress = generalStateBase;
|
|
|
|
args.indirectObjectHeapBaseAddress = internalHeapBase;
|
|
|
|
args.instructionHeapBaseAddress = instructionHeapBase;
|
|
|
|
args.setGeneralStateBaseAddress = true;
|
|
|
|
args.setInstructionStateBaseAddress = true;
|
|
|
|
args.bindlessSurfaceStateBaseAddress = 0x90004000;
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_FALSE(sbaCmd.getDynamicStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_FALSE(sbaCmd.getDynamicStateBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getDynamicStateBaseAddress());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getDynamicStateBufferSize());
|
|
|
|
|
|
|
|
EXPECT_FALSE(sbaCmd.getSurfaceStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getSurfaceStateBaseAddress());
|
|
|
|
|
|
|
|
EXPECT_TRUE(sbaCmd.getInstructionBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(instructionHeapBase, sbaCmd.getInstructionBaseAddress());
|
|
|
|
EXPECT_TRUE(sbaCmd.getInstructionBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(MemoryConstants::sizeOf4GBinPageEntities, sbaCmd.getInstructionBufferSize());
|
|
|
|
|
|
|
|
EXPECT_TRUE(sbaCmd.getGeneralStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_TRUE(sbaCmd.getGeneralStateBufferSizeModifyEnable());
|
|
|
|
if constexpr (is64bit) {
|
|
|
|
EXPECT_EQ(gmmHelper->decanonize(internalHeapBase), sbaCmd.getGeneralStateBaseAddress());
|
|
|
|
} else {
|
|
|
|
EXPECT_EQ(generalStateBase, sbaCmd.getGeneralStateBaseAddress());
|
|
|
|
}
|
|
|
|
EXPECT_EQ(0xfffffu, sbaCmd.getGeneralStateBufferSize());
|
2022-08-19 09:22:04 +08:00
|
|
|
|
|
|
|
auto surfaceStateCount = StateBaseAddressHelper<FamilyType>::getMaxBindlessSurfaceStates();
|
2023-08-17 16:17:57 +08:00
|
|
|
EXPECT_EQ(0x90004000u, sbaCmd.getBindlessSurfaceStateBaseAddress());
|
|
|
|
EXPECT_TRUE(sbaCmd.getBindlessSurfaceStateBaseAddressModifyEnable());
|
2022-08-19 09:22:04 +08:00
|
|
|
EXPECT_EQ(surfaceStateCount, sbaCmd.getBindlessSurfaceStateSize());
|
|
|
|
}
|
2023-02-22 04:17:22 +08:00
|
|
|
|
|
|
|
HWTEST2_F(SbaTest, GivenPlatformNotSupportingIndirectHeapBaseWhenProgramIndirectHeapThenNothingHappens, IsAtLeastXeHpCore) {
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(nullptr, nullptr);
|
2023-02-22 04:17:22 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::appendIohParameters(args);
|
|
|
|
}
|
2023-02-20 18:27:13 +08:00
|
|
|
|
|
|
|
HWTEST_F(SbaTest, givenStateBaseAddressPropertiesWhenSettingDynamicStateSurfaceStateMocsPropertiesThenCommandDispatchedCorrectly) {
|
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
DebugManagerStateRestore restore;
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForceL1Caching.set(0);
|
2023-02-20 18:27:13 +08:00
|
|
|
|
|
|
|
constexpr uint64_t surfaceHeapBase = 0x10000;
|
|
|
|
constexpr uint64_t dynamicHeapBase = 0x20000;
|
|
|
|
constexpr uint32_t surfaceHeapSize = 0x10;
|
|
|
|
constexpr uint32_t dynamicHeapSize = 0x20;
|
|
|
|
constexpr uint32_t mocsIndex = 0x8;
|
|
|
|
|
|
|
|
auto gmmHelper = pDevice->getGmmHelper();
|
|
|
|
StateBaseAddressProperties sbaProperties;
|
2023-03-10 07:12:09 +08:00
|
|
|
sbaProperties.initSupport(pDevice->getRootDeviceEnvironment());
|
2023-02-20 18:27:13 +08:00
|
|
|
|
|
|
|
STATE_BASE_ADDRESS sbaCmd;
|
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&sbaCmd, gmmHelper, &sbaProperties);
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_FALSE(sbaCmd.getDynamicStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_FALSE(sbaCmd.getDynamicStateBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getDynamicStateBaseAddress());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getDynamicStateBufferSize());
|
|
|
|
|
|
|
|
EXPECT_FALSE(sbaCmd.getSurfaceStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getSurfaceStateBaseAddress());
|
|
|
|
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getStatelessDataPortAccessMemoryObjectControlState());
|
|
|
|
|
2023-03-11 02:36:22 +08:00
|
|
|
sbaProperties.setPropertiesBindingTableSurfaceState(surfaceHeapBase, surfaceHeapSize, surfaceHeapBase, surfaceHeapSize);
|
2023-02-20 18:27:13 +08:00
|
|
|
sbaProperties.setPropertiesDynamicState(dynamicHeapBase, dynamicHeapSize);
|
|
|
|
sbaProperties.setPropertyStatelessMocs(mocsIndex);
|
|
|
|
|
|
|
|
sbaCmd = FamilyType::cmdInitStateBaseAddress;
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_TRUE(sbaCmd.getDynamicStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_TRUE(sbaCmd.getDynamicStateBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(dynamicHeapBase, sbaCmd.getDynamicStateBaseAddress());
|
|
|
|
EXPECT_EQ(dynamicHeapSize, sbaCmd.getDynamicStateBufferSize());
|
|
|
|
|
|
|
|
EXPECT_TRUE(sbaCmd.getSurfaceStateBaseAddressModifyEnable());
|
|
|
|
EXPECT_EQ(surfaceHeapBase, sbaCmd.getSurfaceStateBaseAddress());
|
|
|
|
|
|
|
|
EXPECT_EQ((mocsIndex << 1), sbaCmd.getStatelessDataPortAccessMemoryObjectControlState());
|
|
|
|
}
|
|
|
|
|
2024-09-17 19:32:35 +08:00
|
|
|
using IndirectBaseAddressPlatforms = IsGen12LP;
|
2023-02-20 18:27:13 +08:00
|
|
|
|
|
|
|
HWTEST2_F(SbaTest, givenStateBaseAddressPropertiesWhenSettingIndirectStatePropertyThenCommandDispatchedCorrectlyIndirectBaseAddress, IndirectBaseAddressPlatforms) {
|
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
|
|
|
|
|
|
|
constexpr uint64_t indirectHeapBase = 0x10000;
|
|
|
|
constexpr uint32_t indirectHeapSize = 0x10;
|
|
|
|
|
|
|
|
auto gmmHelper = pDevice->getGmmHelper();
|
|
|
|
StateBaseAddressProperties sbaProperties;
|
|
|
|
|
|
|
|
STATE_BASE_ADDRESS sbaCmd;
|
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&sbaCmd, gmmHelper, &sbaProperties);
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_FALSE(sbaCmd.getIndirectObjectBaseAddressModifyEnable());
|
|
|
|
EXPECT_FALSE(sbaCmd.getIndirectObjectBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getIndirectObjectBaseAddress());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getIndirectObjectBufferSize());
|
|
|
|
|
|
|
|
sbaProperties.setPropertiesIndirectState(indirectHeapBase, indirectHeapSize);
|
|
|
|
|
|
|
|
sbaCmd = FamilyType::cmdInitStateBaseAddress;
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_TRUE(sbaCmd.getIndirectObjectBaseAddressModifyEnable());
|
|
|
|
EXPECT_TRUE(sbaCmd.getIndirectObjectBufferSizeModifyEnable());
|
|
|
|
EXPECT_EQ(indirectHeapBase, sbaCmd.getIndirectObjectBaseAddress());
|
|
|
|
EXPECT_EQ(indirectHeapSize, sbaCmd.getIndirectObjectBufferSize());
|
|
|
|
}
|
|
|
|
|
|
|
|
using GlobalBaseAddressPlatforms = IsAtLeastXeHpCore;
|
|
|
|
|
2024-09-17 19:32:35 +08:00
|
|
|
using BindlessSurfaceAddressPlatforms = MatchAny;
|
2023-02-20 18:27:13 +08:00
|
|
|
|
|
|
|
HWTEST2_F(SbaTest, givenStateBaseAddressPropertiesWhenSettingBindlessSurfaceStatePropertyThenCommandDispatchedCorrectlyBindlessBaseAddress, BindlessSurfaceAddressPlatforms) {
|
|
|
|
using STATE_BASE_ADDRESS = typename FamilyType::STATE_BASE_ADDRESS;
|
2023-11-07 22:51:26 +08:00
|
|
|
using RENDER_SURFACE_STATE = typename FamilyType::RENDER_SURFACE_STATE;
|
2023-02-20 18:27:13 +08:00
|
|
|
|
|
|
|
constexpr uint64_t surfaceHeapBase = 0x10000;
|
|
|
|
constexpr uint32_t surfaceHeapSize = 0x10;
|
|
|
|
|
|
|
|
uint32_t defaultBindlessSurfaceStateSize = StateBaseAddressHelper<FamilyType>::getMaxBindlessSurfaceStates();
|
|
|
|
|
|
|
|
auto gmmHelper = pDevice->getGmmHelper();
|
|
|
|
StateBaseAddressProperties sbaProperties;
|
2023-03-10 07:12:09 +08:00
|
|
|
sbaProperties.initSupport(pDevice->getRootDeviceEnvironment());
|
2023-02-20 18:27:13 +08:00
|
|
|
|
|
|
|
STATE_BASE_ADDRESS sbaCmd;
|
|
|
|
StateBaseAddressHelperArgs<FamilyType> args = createSbaHelperArgs<FamilyType>(&sbaCmd, gmmHelper, &sbaProperties);
|
|
|
|
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
EXPECT_EQ(defaultBindlessSurfaceStateSize, sbaCmd.getBindlessSurfaceStateSize());
|
|
|
|
EXPECT_EQ(0u, sbaCmd.getBindlessSurfaceStateBaseAddress());
|
|
|
|
EXPECT_FALSE(sbaCmd.getBindlessSurfaceStateBaseAddressModifyEnable());
|
|
|
|
|
2023-08-17 16:17:57 +08:00
|
|
|
sbaCmd = FamilyType::cmdInitStateBaseAddress;
|
|
|
|
args.bindlessSurfaceStateBaseAddress = 0x80004000;
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
|
|
|
EXPECT_EQ(defaultBindlessSurfaceStateSize, sbaCmd.getBindlessSurfaceStateSize());
|
|
|
|
EXPECT_EQ(0x80004000u, sbaCmd.getBindlessSurfaceStateBaseAddress());
|
|
|
|
EXPECT_TRUE(sbaCmd.getBindlessSurfaceStateBaseAddressModifyEnable());
|
|
|
|
|
2023-03-11 02:36:22 +08:00
|
|
|
sbaProperties.setPropertiesBindingTableSurfaceState(surfaceHeapBase, surfaceHeapSize, surfaceHeapBase, surfaceHeapSize);
|
2023-02-20 18:27:13 +08:00
|
|
|
|
|
|
|
sbaCmd = FamilyType::cmdInitStateBaseAddress;
|
2023-08-17 16:17:57 +08:00
|
|
|
args.bindlessSurfaceStateBaseAddress = 0;
|
2023-02-20 18:27:13 +08:00
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(args);
|
|
|
|
|
2023-11-07 22:51:26 +08:00
|
|
|
EXPECT_EQ(surfaceHeapSize * MemoryConstants::pageSize / sizeof(RENDER_SURFACE_STATE), sbaCmd.getBindlessSurfaceStateSize());
|
2023-02-20 18:27:13 +08:00
|
|
|
EXPECT_EQ(surfaceHeapBase, sbaCmd.getBindlessSurfaceStateBaseAddress());
|
|
|
|
EXPECT_TRUE(sbaCmd.getBindlessSurfaceStateBaseAddressModifyEnable());
|
|
|
|
}
|
2024-08-05 22:02:25 +08:00
|
|
|
|
2024-09-19 22:35:03 +08:00
|
|
|
TEST(SbaHelperTest, givenIndirectHeapWhenGetStateBaseAddressAndGetStateSizeThenReturnValuesBasedOnGlobalHeapsPresence) {
|
2024-08-05 22:02:25 +08:00
|
|
|
auto cpuBaseAddress = reinterpret_cast<void *>(0x3000);
|
|
|
|
MockGraphicsAllocation graphicsAllocation(cpuBaseAddress, 4096u);
|
|
|
|
graphicsAllocation.setGpuBaseAddress(4096u);
|
|
|
|
|
|
|
|
IndirectHeap heap(&graphicsAllocation, false);
|
|
|
|
|
|
|
|
auto gpuAddress = heap.getGraphicsAllocation()->getGpuAddress();
|
|
|
|
auto gpuBaseAddress = heap.getGraphicsAllocation()->getGpuBaseAddress();
|
|
|
|
auto heapSize = (static_cast<uint32_t>(heap.getMaxAvailableSpace()) + MemoryConstants::pageMask) / MemoryConstants::pageSize;
|
|
|
|
|
|
|
|
bool useGlobalHeaps = false;
|
|
|
|
|
|
|
|
{
|
|
|
|
useGlobalHeaps = false;
|
|
|
|
EXPECT_EQ(gpuAddress, NEO::getStateBaseAddress(heap, useGlobalHeaps));
|
|
|
|
EXPECT_EQ(heapSize, NEO::getStateSize(heap, useGlobalHeaps));
|
|
|
|
}
|
|
|
|
{
|
|
|
|
useGlobalHeaps = true;
|
|
|
|
EXPECT_EQ(gpuBaseAddress, NEO::getStateBaseAddress(heap, useGlobalHeaps));
|
|
|
|
EXPECT_EQ(MemoryConstants::sizeOf4GBinPageEntities, NEO::getStateSize(heap, useGlobalHeaps));
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
useGlobalHeaps = true;
|
2024-09-19 22:35:03 +08:00
|
|
|
EXPECT_EQ(gpuAddress, NEO::getStateBaseAddressForSsh(heap, useGlobalHeaps));
|
|
|
|
EXPECT_EQ(heapSize, NEO::getStateSizeForSsh(heap, useGlobalHeaps));
|
2024-08-05 22:02:25 +08:00
|
|
|
}
|
|
|
|
{
|
2024-09-19 22:35:03 +08:00
|
|
|
useGlobalHeaps = false;
|
|
|
|
EXPECT_EQ(gpuAddress, NEO::getStateBaseAddressForSsh(heap, useGlobalHeaps));
|
|
|
|
EXPECT_EQ(heapSize, NEO::getStateSizeForSsh(heap, useGlobalHeaps));
|
2024-08-05 22:02:25 +08:00
|
|
|
}
|
2024-09-17 17:55:30 +08:00
|
|
|
}
|