mirror of
https://github.com/intel/compute-runtime.git
synced 2025-09-15 13:01:45 +08:00
Always set DisableGpuTimeout.
Reg key for preemption may not be available, this doesn't mean that preemption is off. Change-Id: If7c8a8228fbfa9f01f95d61d4134bd398e4079f6
This commit is contained in:

committed by
sys_ocldev

parent
21c1dce943
commit
006d248de6
@ -566,22 +566,52 @@ HWTEST_F(WddmTest, dontCallCreateContextBeforeConfigureDeviceAddressSpace) {
|
||||
delete mockWddm;
|
||||
}
|
||||
|
||||
HWTEST_F(WddmPreemptionTests, givenEnablePreemptionRegKeySetWhenCreateDeviceThenSetGpuTimeoutFlag) {
|
||||
HWTEST_F(WddmPreemptionTests, givenDevicePreemptionEnabledDebugFlagDontForceWhenPreemptionRegKeySetThenSetGpuTimeoutFlagOn) {
|
||||
DebugManager.flags.ForcePreemptionMode.set(0); // dont force
|
||||
hwInfoTest.capabilityTable.defaultPreemptionMode = PreemptionMode::MidThread;
|
||||
unsigned int expectedVal = 1u;
|
||||
createAndInitWddm<FamilyType>(1u);
|
||||
EXPECT_EQ(getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout, 1u);
|
||||
EXPECT_EQ(expectedVal, getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout);
|
||||
}
|
||||
|
||||
HWTEST_F(WddmPreemptionTests, givenEnablePreemptionRegKeyNotSetWhenCreateDeviceThenDontSetGpuTimeoutFlag) {
|
||||
HWTEST_F(WddmPreemptionTests, givenDevicePreemptionDisabledDebugFlagDontForceWhenPreemptionRegKeySetThenSetGpuTimeoutFlagOff) {
|
||||
DebugManager.flags.ForcePreemptionMode.set(0); // dont force
|
||||
hwInfoTest.capabilityTable.defaultPreemptionMode = PreemptionMode::Disabled;
|
||||
unsigned int expectedVal = 0u;
|
||||
createAndInitWddm<FamilyType>(1u);
|
||||
EXPECT_EQ(expectedVal, getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout);
|
||||
}
|
||||
|
||||
HWTEST_F(WddmPreemptionTests, givenDevicePreemptionEnabledDebugFlagDontForceWhenPreemptionRegKeyNotSetThenSetGpuTimeoutFlagOff) {
|
||||
DebugManager.flags.ForcePreemptionMode.set(0); // dont force
|
||||
hwInfoTest.capabilityTable.defaultPreemptionMode = PreemptionMode::MidThread;
|
||||
unsigned int expectedVal = 0u;
|
||||
createAndInitWddm<FamilyType>(0u);
|
||||
EXPECT_EQ(getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout, 0u);
|
||||
EXPECT_EQ(expectedVal, getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout);
|
||||
}
|
||||
|
||||
HWTEST_F(WddmPreemptionTests, givenForceDisablePreemptionDebugFlagWhenCreateDeviceThenDontSetGpuTimeoutFlag) {
|
||||
DebugManager.flags.ForcePreemptionMode.set(1); // disable
|
||||
HWTEST_F(WddmPreemptionTests, givenDevicePreemptionDisabledDebugFlagDontForceWhenPreemptionRegKeyNotSetThenSetGpuTimeoutFlagOff) {
|
||||
DebugManager.flags.ForcePreemptionMode.set(0); // dont force
|
||||
hwInfoTest.capabilityTable.defaultPreemptionMode = PreemptionMode::Disabled;
|
||||
unsigned int expectedVal = 0u;
|
||||
createAndInitWddm<FamilyType>(0u);
|
||||
EXPECT_EQ(expectedVal, getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout);
|
||||
}
|
||||
|
||||
HWTEST_F(WddmPreemptionTests, givenDevicePreemptionDisabledDebugFlagForcePreemptionWhenPreemptionRegKeySetThenSetGpuTimeoutFlagOn) {
|
||||
DebugManager.flags.ForcePreemptionMode.set(static_cast<int32_t>(PreemptionMode::MidThread)); // force preemption
|
||||
hwInfoTest.capabilityTable.defaultPreemptionMode = PreemptionMode::Disabled;
|
||||
unsigned int expectedVal = 1u;
|
||||
createAndInitWddm<FamilyType>(1u);
|
||||
EXPECT_EQ(getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout, 0u);
|
||||
EXPECT_EQ(expectedVal, getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout);
|
||||
}
|
||||
|
||||
HWTEST_F(WddmPreemptionTests, givenDevicePreemptionDisabledDebugFlagForcePreemptionWhenPreemptionRegKeyNotSetThenSetGpuTimeoutFlagOff) {
|
||||
DebugManager.flags.ForcePreemptionMode.set(static_cast<int32_t>(PreemptionMode::MidThread)); // force preemption
|
||||
hwInfoTest.capabilityTable.defaultPreemptionMode = PreemptionMode::Disabled;
|
||||
unsigned int expectedVal = 0u;
|
||||
createAndInitWddm<FamilyType>(0u);
|
||||
EXPECT_EQ(expectedVal, getMockCreateDeviceParamsFcn().Flags.DisableGpuTimeout);
|
||||
}
|
||||
|
||||
HWTEST_F(WddmWithMockGdiTest, makeResidentMultipleHandles) {
|
||||
|
@ -23,6 +23,7 @@
|
||||
#pragma once
|
||||
|
||||
#include "unit_tests/os_interface/windows/wddm_fixture.h"
|
||||
#include "runtime/command_stream/preemption.h"
|
||||
|
||||
#include "test.h"
|
||||
|
||||
@ -40,6 +41,8 @@ class WddmPreemptionTests : public WddmTest {
|
||||
public:
|
||||
void SetUp() override {
|
||||
WddmTest::SetUp();
|
||||
const HardwareInfo hwInfo = *platformDevices[0];
|
||||
memcpy(&hwInfoTest, &hwInfo, sizeof(hwInfoTest));
|
||||
dbgRestorer = new DebugManagerStateRestore();
|
||||
}
|
||||
|
||||
@ -57,11 +60,14 @@ class WddmPreemptionTests : public WddmTest {
|
||||
auto regReader = new RegistryReaderMock();
|
||||
mockWddm->registryReader.reset(regReader);
|
||||
regReader->forceRetValue = forceReturnPreemptionRegKeyValue;
|
||||
PreemptionMode preemptionMode = PreemptionHelper::getDefaultPreemptionMode(hwInfoTest);
|
||||
mockWddm->setPreemptionMode(preemptionMode);
|
||||
mockWddm->init<GfxFamily>();
|
||||
}
|
||||
|
||||
WddmMock *mockWddm = nullptr;
|
||||
DebugManagerStateRestore *dbgRestorer = nullptr;
|
||||
HardwareInfo hwInfoTest;
|
||||
};
|
||||
|
||||
class WddmGmmMockGdiFixture : public GmmFixture, public WddmFixture {
|
||||
|
Reference in New Issue
Block a user