233 lines
7.4 KiB
C++
233 lines
7.4 KiB
C++
/*
|
|
* Copyright (C) 2020-2021 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#include "shared/test/common/helpers/state_base_address_tests.h"
|
|
|
|
using IsBetweenSklAndTgllp = IsWithinProducts<IGFX_SKYLAKE, IGFX_TIGERLAKE_LP>;
|
|
|
|
HWTEST2_F(SBATest, WhenAppendStateBaseAddressParametersIsCalledThenSBACmdHasBindingSurfaceStateProgrammed, IsBetweenSklAndTgllp) {
|
|
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);
|
|
|
|
StateBaseAddressHelper<FamilyType>::appendStateBaseAddressParameters(
|
|
&stateBaseAddress,
|
|
&ssh,
|
|
false,
|
|
0,
|
|
nullptr,
|
|
false,
|
|
MemoryCompressionState::NotApplicable,
|
|
true,
|
|
false,
|
|
1u);
|
|
|
|
EXPECT_EQ(ssh.getMaxAvailableSpace() / 64 - 1, stateBaseAddress.getBindlessSurfaceStateSize());
|
|
EXPECT_EQ(ssh.getHeapGpuBase(), stateBaseAddress.getBindlessSurfaceStateBaseAddress());
|
|
EXPECT_TRUE(stateBaseAddress.getBindlessSurfaceStateBaseAddressModifyEnable());
|
|
}
|
|
|
|
using IsSklOrAbove = IsAtLeastProduct<IGFX_SKYLAKE>;
|
|
HWTEST2_F(SBATest, WhenProgramStateBaseAddressParametersIsCalledThenSBACmdHasBindingSurfaceStateProgrammed, IsSklOrAbove) {
|
|
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);
|
|
|
|
STATE_BASE_ADDRESS *cmd = reinterpret_cast<STATE_BASE_ADDRESS *>(commandStream.getSpace(0));
|
|
*cmd = stateBaseAddress;
|
|
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(
|
|
cmd,
|
|
nullptr,
|
|
nullptr,
|
|
&ssh,
|
|
0,
|
|
false,
|
|
0,
|
|
0,
|
|
0,
|
|
0,
|
|
false,
|
|
false,
|
|
pDevice->getGmmHelper(),
|
|
true,
|
|
MemoryCompressionState::NotApplicable,
|
|
false,
|
|
1u);
|
|
|
|
EXPECT_EQ(ssh.getMaxAvailableSpace() / 64 - 1, cmd->getBindlessSurfaceStateSize());
|
|
EXPECT_EQ(ssh.getHeapGpuBase(), cmd->getBindlessSurfaceStateBaseAddress());
|
|
EXPECT_TRUE(cmd->getBindlessSurfaceStateBaseAddressModifyEnable());
|
|
}
|
|
|
|
using SbaForBindlessTests = Test<DeviceFixture>;
|
|
|
|
HWTEST2_F(SbaForBindlessTests, givenGlobalBindlessBaseAddressWhenProgramStateBaseAddressThenSbaProgrammedCorrectly, IsSklOrAbove) {
|
|
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));
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(
|
|
cmd,
|
|
nullptr,
|
|
nullptr,
|
|
nullptr,
|
|
0,
|
|
false,
|
|
0,
|
|
0,
|
|
0,
|
|
globalBindlessHeapsBaseAddress,
|
|
false,
|
|
true,
|
|
pDevice->getGmmHelper(),
|
|
true,
|
|
MemoryCompressionState::NotApplicable,
|
|
false,
|
|
1u);
|
|
EXPECT_TRUE(cmd->getBindlessSurfaceStateBaseAddressModifyEnable());
|
|
EXPECT_EQ(cmd->getBindlessSurfaceStateBaseAddress(), globalBindlessHeapsBaseAddress);
|
|
EXPECT_EQ(cmd->getBindlessSurfaceStateSize(), MemoryConstants::sizeOf4GBinPageEntities);
|
|
}
|
|
HWTEST2_F(SbaForBindlessTests, givenGlobalBindlessBaseAddressWhenPassingIndirectBaseAddressThenIndirectBaseAddressIsSet, IsSklOrAbove) {
|
|
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));
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(
|
|
cmd,
|
|
nullptr,
|
|
nullptr,
|
|
nullptr,
|
|
0,
|
|
false,
|
|
0,
|
|
indirectObjectBaseAddress,
|
|
0,
|
|
globalBindlessHeapsBaseAddress,
|
|
false,
|
|
true,
|
|
pDevice->getGmmHelper(),
|
|
true,
|
|
MemoryCompressionState::NotApplicable,
|
|
false,
|
|
1u);
|
|
|
|
EXPECT_EQ(cmd->getIndirectObjectBaseAddress(), indirectObjectBaseAddress);
|
|
}
|
|
|
|
HWTEST2_F(SBATest, givenSbaWhenOverrideBindlessSurfaceBaseIsFalseThenBindlessSurfaceBaseIsNotSet, IsSklOrAbove) {
|
|
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);
|
|
|
|
StateBaseAddressHelper<FamilyType>::appendStateBaseAddressParameters(
|
|
&stateBaseAddress,
|
|
&ssh,
|
|
false,
|
|
0,
|
|
pDevice->getRootDeviceEnvironment().getGmmHelper(),
|
|
false,
|
|
MemoryCompressionState::NotApplicable,
|
|
false,
|
|
false,
|
|
1u);
|
|
|
|
EXPECT_EQ(0u, stateBaseAddress.getBindlessSurfaceStateBaseAddress());
|
|
}
|
|
|
|
HWTEST2_F(SBATest, givenGlobalBindlessBaseAddressWhenSshIsPassedThenBindlessSurfaceBaseIsGlobalHeapBase, IsSklOrAbove) {
|
|
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));
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(
|
|
cmd,
|
|
nullptr,
|
|
nullptr,
|
|
&ssh,
|
|
0,
|
|
false,
|
|
0,
|
|
0,
|
|
0,
|
|
globalBindlessHeapsBaseAddress,
|
|
false,
|
|
true,
|
|
pDevice->getGmmHelper(),
|
|
true,
|
|
MemoryCompressionState::NotApplicable,
|
|
false,
|
|
1u);
|
|
EXPECT_EQ(cmd->getBindlessSurfaceStateBaseAddress(), globalBindlessHeapsBaseAddress);
|
|
}
|
|
HWTEST2_F(SBATest, givenSurfaceStateHeapWhenNotUsingGlobalHeapBaseThenBindlessSurfaceBaseIsSshBase, IsSklOrAbove) {
|
|
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));
|
|
StateBaseAddressHelper<FamilyType>::programStateBaseAddress(
|
|
cmd,
|
|
nullptr,
|
|
nullptr,
|
|
&ssh,
|
|
0,
|
|
false,
|
|
0,
|
|
0,
|
|
0,
|
|
globalBindlessHeapsBaseAddress,
|
|
false,
|
|
false,
|
|
pDevice->getGmmHelper(),
|
|
true,
|
|
MemoryCompressionState::NotApplicable,
|
|
false,
|
|
1u);
|
|
EXPECT_EQ(ssh.getHeapGpuBase(), cmd->getBindlessSurfaceStateBaseAddress());
|
|
}
|