|
@@ -584,20 +584,14 @@ static int sugov_start(struct cpufreq_policy *policy)
|
|
|
for_each_cpu(cpu, policy->cpus) {
|
|
|
struct sugov_cpu *sg_cpu = &per_cpu(sugov_cpu, cpu);
|
|
|
|
|
|
+ memset(sg_cpu, 0, sizeof(*sg_cpu));
|
|
|
sg_cpu->sg_policy = sg_policy;
|
|
|
- if (policy_is_shared(policy)) {
|
|
|
- sg_cpu->util = 0;
|
|
|
- sg_cpu->max = 0;
|
|
|
- sg_cpu->flags = SCHED_CPUFREQ_RT;
|
|
|
- sg_cpu->last_update = 0;
|
|
|
- sg_cpu->iowait_boost = 0;
|
|
|
- sg_cpu->iowait_boost_max = policy->cpuinfo.max_freq;
|
|
|
- cpufreq_add_update_util_hook(cpu, &sg_cpu->update_util,
|
|
|
- sugov_update_shared);
|
|
|
- } else {
|
|
|
- cpufreq_add_update_util_hook(cpu, &sg_cpu->update_util,
|
|
|
- sugov_update_single);
|
|
|
- }
|
|
|
+ sg_cpu->flags = SCHED_CPUFREQ_RT;
|
|
|
+ sg_cpu->iowait_boost_max = policy->cpuinfo.max_freq;
|
|
|
+ cpufreq_add_update_util_hook(cpu, &sg_cpu->update_util,
|
|
|
+ policy_is_shared(policy) ?
|
|
|
+ sugov_update_shared :
|
|
|
+ sugov_update_single);
|
|
|
}
|
|
|
return 0;
|
|
|
}
|