No need to check we're highest performance level when throttling GPU engine speed.
diff --git a/adl.c b/adl.c
index 4d0e65e..e2434e2 100644
--- a/adl.c
+++ b/adl.c
@@ -1062,12 +1062,11 @@ void gpu_autotune(int gpu, bool *enable)
} else if (temp > ga->overtemp && engine > ga->minspeed) {
applog(LOG_WARNING, "Overheat detected, decreasing GPU %d clock speed", gpu);
newengine = ga->minspeed;
- /* Only try to tune engine speed if the current performance level is at max */
- } else if ((ga->lpActivity.iCurrentPerformanceLevel == ga->lpOdParameters.iNumberOfPerformanceLevels - 1) &&
- (temp > ga->targettemp + opt_hysteresis && engine > ga->minspeed && fan_optimal)) {
+ } else if (temp > ga->targettemp + opt_hysteresis && engine > ga->minspeed && fan_optimal) {
if (opt_debug)
applog(LOG_DEBUG, "Temperature %d degrees over target, decreasing clock speed", opt_hysteresis);
newengine = engine - ga->lpOdParameters.sEngineClock.iStep;
+ /* Only try to tune engine speed if the current performance level is at max */
} else if ((ga->lpActivity.iCurrentPerformanceLevel == ga->lpOdParameters.iNumberOfPerformanceLevels - 1) &&
(temp < ga->targettemp && engine < ga->maxspeed)) {
if (opt_debug)