/* * Copyright (C) 2020-2023 Intel Corporation * * SPDX-License-Identifier: MIT * */ #include "shared/source/command_container/cmdcontainer.h" #include "shared/source/command_container/command_encoder.h" #include "shared/source/gen9/hw_cmds.h" #include "shared/source/helpers/blit_commands_helper.h" #include "shared/test/common/cmd_parse/gen_cmd_parse.h" #include "shared/test/common/fixtures/device_fixture.h" #include "shared/test/common/mocks/mock_device.h" #include "shared/test/common/test_macros/header/per_product_test_definitions.h" #include "shared/test/common/test_macros/test.h" #include "reg_configs_common.h" using namespace NEO; using CommandEncoderTest = Test; GEN9TEST_F(CommandEncoderTest, WhenProgrammingThenLoadRegisterImmIsUsed) { CommandContainer cmdContainer; cmdContainer.initialize(pDevice, nullptr, true); EncodeL3State::encode(cmdContainer, false); GenCmdList commands; CmdParse::parseCommandBuffer(commands, ptrOffset(cmdContainer.getCommandStream()->getCpuBase(), 0), cmdContainer.getCommandStream()->getUsed()); using MI_LOAD_REGISTER_IMM = typename FamilyType::MI_LOAD_REGISTER_IMM; auto itorLRI = find(commands.begin(), commands.end()); ASSERT_NE(itorLRI, commands.end()); } GEN9TEST_F(CommandEncoderTest, givenNoSlmThenCorrectMmioIsSet) { CommandContainer cmdContainer; cmdContainer.initialize(pDevice, nullptr, true); EncodeL3State::encode(cmdContainer, false); GenCmdList commands; CmdParse::parseCommandBuffer(commands, ptrOffset(cmdContainer.getCommandStream()->getCpuBase(), 0), cmdContainer.getCommandStream()->getUsed()); using MI_LOAD_REGISTER_IMM = typename FamilyType::MI_LOAD_REGISTER_IMM; auto itorLRI = find(commands.begin(), commands.end()); ASSERT_NE(itorLRI, commands.end()); auto cmd = genCmdCast(*itorLRI); auto isL3Configurable = (PreambleHelper::getL3Config(pDevice->getHardwareInfo(), true) != PreambleHelper::getL3Config(pDevice->getHardwareInfo(), false)); auto expectedData = isL3Configurable ? 0x80000340u : 0x60000321u; EXPECT_EQ(cmd->getRegisterOffset(), 0x7034u); EXPECT_EQ(cmd->getDataDword(), expectedData); } GEN9TEST_F(CommandEncoderTest, givenSlmThenCorrectMmioIsSet) { CommandContainer cmdContainer; cmdContainer.initialize(pDevice, nullptr, true); EncodeL3State::encode(cmdContainer, true); GenCmdList commands; CmdParse::parseCommandBuffer(commands, ptrOffset(cmdContainer.getCommandStream()->getCpuBase(), 0), cmdContainer.getCommandStream()->getUsed()); using MI_LOAD_REGISTER_IMM = typename FamilyType::MI_LOAD_REGISTER_IMM; auto itorLRI = find(commands.begin(), commands.end()); ASSERT_NE(itorLRI, commands.end()); auto cmd = genCmdCast(*itorLRI); EXPECT_EQ(cmd->getRegisterOffset(), 0x7034u); EXPECT_EQ(cmd->getDataDword(), 0x60000321u); } using Gen9CommandEncodeTest = testing::Test; GEN9TEST_F(Gen9CommandEncodeTest, givenBcsCommandsHelperWhenMiArbCheckWaRequiredThenReturnTrue) { EXPECT_FALSE(BlitCommandsHelper::miArbCheckWaRequired()); }