On 21 January 2014 08:35, lizhuangzhi <zhuangzhi.li@xxxxxxxxx> wrote: > Some SMP systems want to make all the possible CPUs share the clock, > if the CPUs init frequencies aren't the same, we need to align all the > CPUs to the same frequency while CPUs registing to avoid mismatched > CPU's P-states. > > Signed-off-by: lizhuangzhi <zhuangzhi.li@xxxxxxxxx> > --- > drivers/cpufreq/cpufreq.c | 2 ++ > 1 file changed, 2 insertions(+) > > diff --git a/drivers/cpufreq/cpufreq.c b/drivers/cpufreq/cpufreq.c > index 8d19f7c..d00abb5 100644 > --- a/drivers/cpufreq/cpufreq.c > +++ b/drivers/cpufreq/cpufreq.c > @@ -991,6 +991,8 @@ static int __cpufreq_add_dev(struct device *dev, struct subsys_interface *sif, > * CPU because it is in the same boat. */ > policy = cpufreq_cpu_get(cpu); > if (unlikely(policy)) { > + /* according present policy to align all the cpus frequencies */ > + cpufreq_driver->target(policy, policy->cur, CPUFREQ_RELATION_H); I don't really understand why is this required? CPUs sharing clocks means that CPUs runs on the same clock line and so all of them must be running on same frequency. So, why do we need to call this routine? policy->cur must be the current freq here for CPU in question. -- viresh -- To unsubscribe from this list: send the line "unsubscribe cpufreq" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html