|
@@ -36,9 +36,9 @@ static DEFINE_PER_CPU(struct cs_cpu_dbs_info_s, cs_cpu_dbs_info);
|
|
|
|
|
|
/*
|
|
|
* Every sampling_rate, we check, if current idle time is less than 20%
|
|
|
- * (default), then we try to increase frequency Every sampling_rate *
|
|
|
- * sampling_down_factor, we check, if current idle time is more than 80%, then
|
|
|
- * we try to decrease frequency
|
|
|
+ * (default), then we try to increase frequency. Every sampling_rate *
|
|
|
+ * sampling_down_factor, we check, if current idle time is more than 80%
|
|
|
+ * (default), then we try to decrease frequency
|
|
|
*
|
|
|
* Any frequency increase takes it to the maximum frequency. Frequency reduction
|
|
|
* happens at minimum steps of 5% (default) of maximum frequency
|
|
@@ -81,6 +81,11 @@ static void cs_check_cpu(int cpu, unsigned int load)
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
+ /* if sampling_down_factor is active break out early */
|
|
|
+ if (++dbs_info->down_skip < cs_tuners->sampling_down_factor)
|
|
|
+ return;
|
|
|
+ dbs_info->down_skip = 0;
|
|
|
+
|
|
|
/*
|
|
|
* The optimal frequency is the frequency that is the lowest that can
|
|
|
* support the current CPU usage without triggering the up policy. To be
|