mirror of
https://github.com/intel/compute-runtime.git
synced 2025-12-20 08:53:55 +08:00
Set windows thread priority to "above normal" on wddm init if flag is set. Related-To: NEO-8215 Signed-off-by: Dominik Dabek <dominik.dabek@intel.com>
48 lines
1.5 KiB
C++
48 lines
1.5 KiB
C++
/*
|
|
* Copyright (C) 2023-2024 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#include "shared/source/os_interface/windows/sys_calls.h"
|
|
#include "shared/source/os_interface/windows/wddm/wddm.h"
|
|
|
|
namespace NEO {
|
|
|
|
void Wddm::setProcessPowerThrottling() {
|
|
SysCalls::ProcessPowerThrottlingState processPowerThrottlingState{};
|
|
bool doSetProcessPowerThrottlingState = false;
|
|
if (debugManager.flags.SetProcessPowerThrottlingState.get() != -1) {
|
|
switch (debugManager.flags.SetProcessPowerThrottlingState.get()) {
|
|
case 0:
|
|
doSetProcessPowerThrottlingState = false;
|
|
break;
|
|
case 1:
|
|
doSetProcessPowerThrottlingState = true;
|
|
processPowerThrottlingState = SysCalls::ProcessPowerThrottlingState::Eco;
|
|
break;
|
|
case 2:
|
|
doSetProcessPowerThrottlingState = true;
|
|
processPowerThrottlingState = SysCalls::ProcessPowerThrottlingState::High;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
if (doSetProcessPowerThrottlingState) {
|
|
SysCalls::setProcessPowerThrottlingState(processPowerThrottlingState);
|
|
}
|
|
}
|
|
|
|
void Wddm::setThreadPriority() {
|
|
bool doSetThreadPriority = false;
|
|
if (debugManager.flags.SetThreadPriority.get() != -1) {
|
|
doSetThreadPriority = !!debugManager.flags.SetThreadPriority.get();
|
|
}
|
|
if (doSetThreadPriority) {
|
|
SysCalls::setThreadPriority(SysCalls::ThreadPriority::AboveNormal);
|
|
}
|
|
}
|
|
|
|
} // namespace NEO
|