From: Viresh Kumar <viresh.kumar@linaro.org>
To: "Rafael J. Wysocki" <rjw@rjwysocki.net>
Cc: Dominik Brodowski <linux@dominikbrodowski.net>,
"Rafael J. Wysocki" <rafael@kernel.org>,
Linux PM <linux-pm@vger.kernel.org>,
Vincent Guittot <vincent.guittot@linaro.org>,
Linux Kernel Mailing List <linux-kernel@vger.kernel.org>
Subject: Re: [RFC V2 1/6] cpufreq: Replace "max_transition_latency" with "dynamic_switching"
Date: Mon, 17 Jul 2017 17:28:51 +0530 [thread overview]
Message-ID: <20170717115851.GR352@vireshk-i7> (raw)
In-Reply-To: <3209820.qRRISZfneG@aspire.rjw.lan>
On 15-07-17, 14:26, Rafael J. Wysocki wrote:
> On Saturday, July 15, 2017 07:08:28 AM Dominik Brodowski wrote:
> > Exactly. But lets take a quick look at the drivers ussing CPUFREQ_ETERNAL:
> >
> > Using CPUFREQ_ETERNAL, as policy-setting drivers:
> >
> > - intel_pstate.c - for the intel_pstate driver, which defers to the hardware
> > to do frequency selection.
> >
> > - longrun.c - hardware-based frequency selection.
>
> That may or may not be hardware-based, but if the ->setpolicy callback is
> present, transition_latency doesn't matter anyway.
Right and to avoid confusion its probably better to avoid setting
transition_latency completely from them. I will try to include that in
my series.
> > => Those drivers are not interested in kernel-based dynamic frequency
> > selection anyway.
>
> Right.
>
> >
> > Using CPUFREQ_ETERNAL as a fallback if transition_latency is unknown:
> > - arm_big_little.c
> > - arm_big_little_dt.c
> > - cpufreq-dt.c
> > - imx6q-cpufreq.c
> > - spear_cpufreq.c
> >
> > => As it seems to be an error case, it seems best to bail out on the
> > safe side and disallow dynamic frequency scaling. Platform experts might
> > know better, though.
> >
>
> Well, Viresh should know what to do for some of them at least. :-)
Yeah, they just don't know how much time it takes to change the
frequency. We shouldn't disallow DVFS for them.
> > Using CPUFREQ_ETERNAL unconditionally:
> > - cpufreq-nforce2.c - over a decade old driver; has a commented-out hack
> > to mdelay(10ms) after each frequency transition. This smells like it might
> > be unsafe to do dynamic switching more often than that.
> >
> > - elanfreq.c - Has udelay(1ms+10ms) in transition path, so the same terms
> > and conditions seem to apply.
> >
> > - gx-suspmod.c - works by a mechanism which reminds me of CPU frequency
> > throttling, but chipset- and not CPU-based.
> >
> > - pmac32-cpufreq.c - for some models, it sets latency to ETERNAL. In some
> > frequency switchign code, it has mdelay(10ms) calls.
> >
> > - speedsstep-smi.c - this case was discussed previously.
> >
> > => For those drivers, dynamic frequency scaling should not be enabled IMO.
>
> Agreed.
+1 and these are the drivers which should have this new variable set
to avoid DVFS.
Anyone who is setting CPUFREQ_ETERNAL unconditionally should be
setting the new flag.
> > To summarize: At first, I'd propose a *complete* switch-over from
> > CPUFREQ_ETERNAL to setting the flag "no DVFS" you have proposed.
>
> So we seem to be in agreement over this.
The usage of CPUFREQ_ETERNAL had been confusing over the years, i.e.
some use it to not allow ondemand/conservative, while others use it as
they don't know their transition latencies.
A complete switch over may not be good for the later.
I would suggest we only move the platforms which set latency to
CPUFREQ_ETERNAL unconditionally to the "no DVFS" list. And everyone
else can still continue with CPUFREQ_ETERNAL. I have earlier proposed
finding their latencies dynamically and will try to include that for
them.
--
viresh
next prev parent reply other threads:[~2017-07-17 11:58 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-07-13 5:40 [RFC V2 0/6] cpufreq: transition-latency cleanups Viresh Kumar
2017-07-13 5:40 ` [RFC V2 1/6] cpufreq: Replace "max_transition_latency" with "dynamic_switching" Viresh Kumar
2017-07-13 16:19 ` Rafael J. Wysocki
2017-07-14 7:01 ` Dominik Brodowski
2017-07-14 11:11 ` Rafael J. Wysocki
2017-07-14 22:06 ` Rafael J. Wysocki
2017-07-15 5:08 ` Dominik Brodowski
2017-07-15 12:26 ` Rafael J. Wysocki
2017-07-17 11:58 ` Viresh Kumar [this message]
2017-07-17 12:18 ` Rafael J. Wysocki
2017-07-13 5:40 ` [RFC V2 2/6] cpufreq: schedutil: Set dynamic_switching to true Viresh Kumar
2017-07-13 5:40 ` [RFC V2 3/6] cpufreq: governor: Drop min_sampling_rate Viresh Kumar
2017-07-13 5:40 ` [RFC V2 4/6] cpufreq: Use transition_delay_us for legacy governors as well Viresh Kumar
2017-07-13 16:31 ` Rafael J. Wysocki
2017-07-13 5:40 ` [RFC V2 5/6] cpufreq: Cap the default transition delay value to 10 ms Viresh Kumar
2017-07-13 5:40 ` [RFC V2 6/6] cpufreq: arm_big_little: Make ->get_transition_latency() mandatory Viresh Kumar
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20170717115851.GR352@vireshk-i7 \
--to=viresh.kumar@linaro.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pm@vger.kernel.org \
--cc=linux@dominikbrodowski.net \
--cc=rafael@kernel.org \
--cc=rjw@rjwysocki.net \
--cc=vincent.guittot@linaro.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox