Re: [PATCH V4 07/14] cpufreq: mediatek: Add .get function

From: Rex-BC Chen
Date: Mon Apr 25 2022 - 05:36:59 EST


On Mon, 2022-04-25 at 11:05 +0530, Viresh Kumar wrote:
> On 22-04-22, 15:52, Rex-BC Chen wrote:
> > From: Jia-Wei Chang <jia-wei.chang@xxxxxxxxxxxx>
> >
> > We want to get opp frequency via opp table. Therefore, we add the
> > function
> > "mtk_cpufreq_get()" to do this.
> >
> > Signed-off-by: Jia-Wei Chang <jia-wei.chang@xxxxxxxxxxxx>
> > Signed-off-by: Rex-BC Chen <rex-bc.chen@xxxxxxxxxxxx>
> > ---
> > drivers/cpufreq/mediatek-cpufreq.c | 11 ++++++++++-
> > 1 file changed, 10 insertions(+), 1 deletion(-)
> >
> > diff --git a/drivers/cpufreq/mediatek-cpufreq.c
> > b/drivers/cpufreq/mediatek-cpufreq.c
> > index e070a2619bcb..0b2ca0c8eddc 100644
> > --- a/drivers/cpufreq/mediatek-cpufreq.c
> > +++ b/drivers/cpufreq/mediatek-cpufreq.c
> > @@ -71,6 +71,15 @@ static struct mtk_cpu_dvfs_info
> > *mtk_cpu_dvfs_info_lookup(int cpu)
> > return NULL;
> > }
> >
> > +static unsigned int mtk_cpufreq_get(unsigned int cpu)
> > +{
> > + struct mtk_cpu_dvfs_info *info;
> > +
> > + info = mtk_cpu_dvfs_info_lookup(cpu);
> > +
> > + return !info ? 0 : (info->opp_freq / 1000);
> > +}
> > +
> > static int mtk_cpufreq_voltage_tracking(struct mtk_cpu_dvfs_info
> > *info,
> > int new_vproc)
> > {
> > @@ -588,7 +597,7 @@ static struct cpufreq_driver mtk_cpufreq_driver
> > = {
> > CPUFREQ_IS_COOLING_DEV,
> > .verify = cpufreq_generic_frequency_table_verify,
> > .target_index = mtk_cpufreq_set_target,
> > - .get = cpufreq_generic_get,
> > + .get = mtk_cpufreq_get,
>
> The .get callback should read the real frequency from hardware
> instead of
> fetching a cached freq value.
>

Hello Viresh,

We found that the pulses of cpu voltage could be observed when
frequency is fixed (scaling_max_freq == scaling_min_freq) if using
cpufreq_generic_get as '.get' callback in MT8186.
cpufreq framework will constantly (~ 1 sec) call 'update' if the policy
frequency is NOT equal to hardware frequency in
cpufreq_verify_current_freq.
The problem is that there might be a tiny difference between the policy
frequency and the hardware frequency even they are very close.
e.g. policy frequency is 500,000,000 Hz however, hardware frequency is
499,999,726 Hz for MT8186 opp15.

To prevent the voltage pulses, we currently use the software cached
values as you pointed out.
I wonder is it possible to add a tolerence for checking difference
between policy frequency and hardware frequency in cpufreq framework so
that we can use cpufreq_generic_get as callback without pulse issue.
Or any suggestion would be appreciated.

Thanks.

BRs,
Rex
> > .init = mtk_cpufreq_init,
> > .exit = mtk_cpufreq_exit,
> > .register_em = cpufreq_register_em_with_opp,
> > --
> > 2.18.0
>
>