/* * Copyright (C) 2018-2019 Intel Corporation * * SPDX-License-Identifier: MIT * */ #include "runtime/command_stream/preemption.h" #include "runtime/helpers/hw_helper.h" #include "test.h" #include "unit_tests/helpers/debug_manager_state_restore.h" #include "unit_tests/os_interface/windows/wddm_fixture.h" using namespace NEO; class WddmPreemptionTests : public Test { public: void SetUp() override { WddmFixtureWithMockGdiDll::SetUp(); const HardwareInfo hwInfo = *platformDevices[0]; memcpy(&hwInfoTest, &hwInfo, sizeof(hwInfoTest)); dbgRestorer = new DebugManagerStateRestore(); wddm->featureTable->ftrGpGpuMidThreadLevelPreempt = true; } void TearDown() override { delete dbgRestorer; WddmFixtureWithMockGdiDll::TearDown(); } void createAndInitWddm(unsigned int forceReturnPreemptionRegKeyValue) { wddm = static_cast(Wddm::createWddm()); executionEnvironment->osInterface = std::make_unique(); executionEnvironment->osInterface->get()->setWddm(wddm); osInterface = executionEnvironment->osInterface.get(); auto regReader = new RegistryReaderMock(); wddm->registryReader.reset(regReader); regReader->forceRetValue = forceReturnPreemptionRegKeyValue; auto preemptionMode = PreemptionHelper::getDefaultPreemptionMode(hwInfoTest); wddm->init(hwInfoTest); osContext = std::make_unique(*wddm, 0u, 1, HwHelper::get(platformDevices[0]->platform.eRenderCoreFamily).getGpgpuEngineInstances()[0], preemptionMode, false); } DebugManagerStateRestore *dbgRestorer = nullptr; HardwareInfo hwInfoTest; }; TEST_F(WddmPreemptionTests, givenDevicePreemptionEnabledDebugFlagDontForceWhenPreemptionRegKeySetThenSetGpuTimeoutFlagOn) { DebugManager.flags.ForcePreemptionMode.set(-1); // dont force hwInfoTest.capabilityTable.defaultPreemptionMode = PreemptionMode::MidThread; unsigned int expectedVal = 1u; createAndInitWddm(1u); EXPECT_EQ(expectedVal, getCreateContextDataFcn()->Flags.DisableGpuTimeout); } TEST_F(WddmPreemptionTests, givenDevicePreemptionDisabledDebugFlagDontForceWhenPreemptionRegKeySetThenSetGpuTimeoutFlagOff) { DebugManager.flags.ForcePreemptionMode.set(-1); // dont force hwInfoTest.capabilityTable.defaultPreemptionMode = PreemptionMode::Disabled; unsigned int expectedVal = 0u; createAndInitWddm(1u); EXPECT_EQ(expectedVal, getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout); EXPECT_EQ(expectedVal, getCreateContextDataFcn()->Flags.DisableGpuTimeout); } TEST_F(WddmPreemptionTests, givenDevicePreemptionEnabledDebugFlagDontForceWhenPreemptionRegKeyNotSetThenSetGpuTimeoutFlagOff) { DebugManager.flags.ForcePreemptionMode.set(-1); // dont force hwInfoTest.capabilityTable.defaultPreemptionMode = PreemptionMode::MidThread; unsigned int expectedVal = 0u; createAndInitWddm(0u); EXPECT_EQ(expectedVal, getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout); EXPECT_EQ(expectedVal, getCreateContextDataFcn()->Flags.DisableGpuTimeout); } TEST_F(WddmPreemptionTests, givenDevicePreemptionDisabledDebugFlagDontForceWhenPreemptionRegKeyNotSetThenSetGpuTimeoutFlagOff) { DebugManager.flags.ForcePreemptionMode.set(-1); // dont force hwInfoTest.capabilityTable.defaultPreemptionMode = PreemptionMode::Disabled; unsigned int expectedVal = 0u; createAndInitWddm(0u); EXPECT_EQ(expectedVal, getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout); EXPECT_EQ(expectedVal, getCreateContextDataFcn()->Flags.DisableGpuTimeout); } TEST_F(WddmPreemptionTests, givenDevicePreemptionDisabledDebugFlagForcePreemptionWhenPreemptionRegKeySetThenSetGpuTimeoutFlagOn) { DebugManager.flags.ForcePreemptionMode.set(static_cast(PreemptionMode::MidThread)); // force preemption hwInfoTest.capabilityTable.defaultPreemptionMode = PreemptionMode::Disabled; unsigned int expectedVal = 1u; createAndInitWddm(1u); EXPECT_EQ(expectedVal, getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout); EXPECT_EQ(expectedVal, getCreateContextDataFcn()->Flags.DisableGpuTimeout); } TEST_F(WddmPreemptionTests, givenDevicePreemptionDisabledDebugFlagForcePreemptionWhenPreemptionRegKeyNotSetThenSetGpuTimeoutFlagOff) { DebugManager.flags.ForcePreemptionMode.set(static_cast(PreemptionMode::MidThread)); // force preemption hwInfoTest.capabilityTable.defaultPreemptionMode = PreemptionMode::Disabled; unsigned int expectedVal = 0u; createAndInitWddm(0u); EXPECT_EQ(expectedVal, getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout); EXPECT_EQ(expectedVal, getCreateContextDataFcn()->Flags.DisableGpuTimeout); }