2018-04-10 19:49:26 +08:00
|
|
|
/*
|
2023-01-06 00:57:56 +08:00
|
|
|
* Copyright (C) 2018-2023 Intel Corporation
|
2018-04-10 19:49:26 +08:00
|
|
|
*
|
2018-09-18 15:11:08 +08:00
|
|
|
* SPDX-License-Identifier: MIT
|
2018-04-10 19:49:26 +08:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2022-03-26 05:04:08 +08:00
|
|
|
#include "shared/source/command_container/command_encoder.h"
|
2022-08-11 23:58:56 +08:00
|
|
|
#include "shared/test/common/fixtures/preamble_fixture.h"
|
2021-01-21 20:10:13 +08:00
|
|
|
#include "shared/test/common/helpers/debug_manager_state_restore.h"
|
2022-08-11 23:58:56 +08:00
|
|
|
#include "shared/test/common/source_level_debugger/source_level_debugger_preamble_test.h"
|
2019-02-27 18:39:32 +08:00
|
|
|
|
2018-04-10 19:49:26 +08:00
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
using namespace NEO;
|
2022-07-25 23:30:11 +08:00
|
|
|
typedef Gen9Family GfxFamily;
|
2018-04-10 19:49:26 +08:00
|
|
|
|
2022-08-11 23:58:56 +08:00
|
|
|
#include "shared/test/common/source_level_debugger/source_level_debugger_preamble_test.inl"
|
2018-04-10 19:49:26 +08:00
|
|
|
|
|
|
|
using PreambleTestGen9 = ::testing::Test;
|
|
|
|
|
2018-11-05 18:52:19 +08:00
|
|
|
GEN9TEST_F(PreambleTestGen9, givenMidThreadPreemptionAndDebuggingActiveWhenStateSipIsProgrammedThenCorrectSipKernelIsUsed) {
|
|
|
|
SourceLevelDebuggerPreambleTest<FamilyType>::givenMidThreadPreemptionAndDebuggingActiveWhenStateSipIsProgrammedThenCorrectSipKernelIsUsedTest();
|
2018-04-10 19:49:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
GEN9TEST_F(PreambleTestGen9, givenMidThreadPreemptionAndDebuggingActiveWhenPreambleSizeIsQueriedThenCorrecrSizeIsReturned) {
|
|
|
|
SourceLevelDebuggerPreambleTest<FamilyType>::givenMidThreadPreemptionAndDebuggingActiveWhenPreambleSizeIsQueriedThenCorrecrSizeIsReturnedTest();
|
|
|
|
}
|
|
|
|
|
|
|
|
GEN9TEST_F(PreambleTestGen9, givenPreemptionDisabledAndDebuggingActiveWhenPreambleIsProgrammedThenCorrectSipKernelIsUsed) {
|
|
|
|
SourceLevelDebuggerPreambleTest<FamilyType>::givenPreemptionDisabledAndDebuggingActiveWhenPreambleIsProgrammedThenCorrectSipKernelIsUsedTest();
|
|
|
|
}
|
|
|
|
|
|
|
|
GEN9TEST_F(PreambleTestGen9, givenPreemptionDisabledAndDebuggingActiveWhenPreambleSizeIsQueriedThenCorrecrSizeIsReturned) {
|
|
|
|
SourceLevelDebuggerPreambleTest<FamilyType>::givenPreemptionDisabledAndDebuggingActiveWhenPreambleSizeIsQueriedThenCorrecrSizeIsReturnedTest();
|
|
|
|
}
|
|
|
|
|
2018-11-05 18:52:19 +08:00
|
|
|
GEN9TEST_F(PreambleTestGen9, givenMidThreadPreemptionAndDisabledDebuggingWhenPreambleIsProgrammedThenCorrectSipKernelIsUsed) {
|
|
|
|
SourceLevelDebuggerPreambleTest<FamilyType>::givenMidThreadPreemptionAndDisabledDebuggingWhenPreambleIsProgrammedThenCorrectSipKernelIsUsedTest();
|
2018-04-10 19:49:26 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
GEN9TEST_F(PreambleTestGen9, givenMidThreadPreemptionAndDisabledDebuggingWhenPreambleSizeIsQueriedThenCorrecrSizeIsReturned) {
|
|
|
|
SourceLevelDebuggerPreambleTest<FamilyType>::givenMidThreadPreemptionAndDisabledDebuggingWhenPreambleSizeIsQueriedThenCorrecrSizeIsReturnedTest();
|
|
|
|
}
|
|
|
|
|
|
|
|
GEN9TEST_F(PreambleTestGen9, givenDisabledPreemptionAndDisabledDebuggingWhenPreambleSizeIsQueriedThenCorrecrSizeIsReturned) {
|
|
|
|
SourceLevelDebuggerPreambleTest<FamilyType>::givenDisabledPreemptionAndDisabledDebuggingWhenPreambleSizeIsQueriedThenCorrecrSizeIsReturnedTest();
|
|
|
|
}
|
2018-04-13 17:50:57 +08:00
|
|
|
|
2018-11-05 18:52:19 +08:00
|
|
|
GEN9TEST_F(PreambleTestGen9, givenKernelDebuggingActiveAndDisabledPreemptionWhenGetAdditionalCommandsSizeIsCalledThen2MiLoadRegisterImmCmdsAreInlcuded) {
|
|
|
|
SourceLevelDebuggerPreambleTest<FamilyType>::givenKernelDebuggingActiveAndDisabledPreemptionWhenGetAdditionalCommandsSizeIsCalledThen2MiLoadRegisterImmCmdsAreInlcudedTest();
|
2018-06-28 15:03:05 +08:00
|
|
|
}
|
2019-08-06 05:57:15 +08:00
|
|
|
|
2021-12-14 02:29:58 +08:00
|
|
|
using ThreadArbitrationGen9 = PreambleFixture;
|
|
|
|
GEN9TEST_F(ThreadArbitrationGen9, givenPreambleWhenItIsProgrammedThenThreadArbitrationIsNotSet) {
|
|
|
|
DebugManagerStateRestore dbgRestore;
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForcePreemptionMode.set(static_cast<int32_t>(PreemptionMode::Disabled));
|
2022-07-25 23:30:11 +08:00
|
|
|
typedef Gen9Family::MI_LOAD_REGISTER_IMM MI_LOAD_REGISTER_IMM;
|
|
|
|
typedef Gen9Family::PIPE_CONTROL PIPE_CONTROL;
|
2021-12-14 02:29:58 +08:00
|
|
|
LinearStream &cs = linearStream;
|
|
|
|
uint32_t l3Config = PreambleHelper<FamilyType>::getL3Config(*defaultHwInfo, true);
|
|
|
|
MockDevice mockDevice;
|
2023-09-13 01:51:43 +08:00
|
|
|
PreambleHelper<Gen9Family>::programPreamble(&linearStream, mockDevice, l3Config, nullptr);
|
2021-12-14 02:29:58 +08:00
|
|
|
|
2022-07-25 23:30:11 +08:00
|
|
|
parseCommands<Gen9Family>(cs);
|
2021-12-14 02:29:58 +08:00
|
|
|
|
|
|
|
auto ppC = find<PIPE_CONTROL *>(cmdList.begin(), cmdList.end());
|
|
|
|
ASSERT_EQ(cmdList.end(), ppC);
|
|
|
|
|
2022-05-16 22:06:56 +08:00
|
|
|
auto itorLRI = reverseFind<MI_LOAD_REGISTER_IMM *>(cmdList.rbegin(), cmdList.rend());
|
2021-12-14 02:29:58 +08:00
|
|
|
ASSERT_NE(cmdList.rend(), itorLRI);
|
|
|
|
|
|
|
|
const auto &lri = *reinterpret_cast<MI_LOAD_REGISTER_IMM *>(*itorLRI);
|
|
|
|
EXPECT_NE(0xE404u, lri.getRegisterOffset());
|
|
|
|
EXPECT_NE(0x100u, lri.getDataDword());
|
|
|
|
|
|
|
|
MockDevice device;
|
2022-07-25 23:30:11 +08:00
|
|
|
EXPECT_EQ(0u, PreambleHelper<Gen9Family>::getAdditionalCommandsSize(device));
|
2021-12-14 02:29:58 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
GEN9TEST_F(ThreadArbitrationGen9, whenThreadArbitrationPolicyIsProgrammedThenCorrectValuesAreSet) {
|
|
|
|
DebugManagerStateRestore dbgRestore;
|
2023-11-30 16:32:25 +08:00
|
|
|
debugManager.flags.ForcePreemptionMode.set(static_cast<int32_t>(PreemptionMode::Disabled));
|
2022-07-25 23:30:11 +08:00
|
|
|
typedef Gen9Family::MI_LOAD_REGISTER_IMM MI_LOAD_REGISTER_IMM;
|
|
|
|
typedef Gen9Family::PIPE_CONTROL PIPE_CONTROL;
|
2021-12-14 02:29:58 +08:00
|
|
|
LinearStream &cs = linearStream;
|
|
|
|
MockDevice mockDevice;
|
2022-03-08 22:18:31 +08:00
|
|
|
StreamProperties streamProperties{};
|
|
|
|
streamProperties.stateComputeMode.threadArbitrationPolicy.set(ThreadArbitrationPolicy::RoundRobin);
|
2023-09-13 01:51:43 +08:00
|
|
|
EncodeComputeMode<FamilyType>::programComputeModeCommand(linearStream, streamProperties.stateComputeMode, mockDevice.getRootDeviceEnvironment());
|
2021-12-14 02:29:58 +08:00
|
|
|
|
2022-07-25 23:30:11 +08:00
|
|
|
parseCommands<Gen9Family>(cs);
|
2021-12-14 02:29:58 +08:00
|
|
|
|
|
|
|
auto ppC = find<PIPE_CONTROL *>(cmdList.begin(), cmdList.end());
|
|
|
|
ASSERT_NE(ppC, cmdList.end());
|
|
|
|
|
2022-05-16 22:06:56 +08:00
|
|
|
auto itorLRI = reverseFind<MI_LOAD_REGISTER_IMM *>(cmdList.rbegin(), cmdList.rend());
|
2021-12-14 02:29:58 +08:00
|
|
|
ASSERT_NE(cmdList.rend(), itorLRI);
|
|
|
|
|
|
|
|
const auto &lri = *reinterpret_cast<MI_LOAD_REGISTER_IMM *>(*itorLRI);
|
|
|
|
EXPECT_EQ(0xE404u, lri.getRegisterOffset());
|
|
|
|
EXPECT_EQ(0x100u, lri.getDataDword());
|
|
|
|
|
|
|
|
MockDevice device;
|
2022-07-25 23:30:11 +08:00
|
|
|
EXPECT_EQ(0u, PreambleHelper<Gen9Family>::getAdditionalCommandsSize(device));
|
2021-12-14 02:29:58 +08:00
|
|
|
}
|