Thread (74 messages) 74 messages, 7 authors, 2018-11-20

[PATCH v8 09/26] kernel/cpu_pm: Manage runtime PM in the idle path for CPUs

From: Lina Iyer <hidden>
Date: 2018-08-10 20:36:10
Also in: linux-arm-msm, linux-pm, lkml

On Thu, Aug 09 2018 at 02:16 -0600, Rafael J. Wysocki wrote:
On Wed, Aug 8, 2018 at 8:02 PM, Lina Iyer [off-list ref] wrote:
quoted
On Wed, Aug 08 2018 at 04:56 -0600, Lorenzo Pieralisi wrote:
quoted
On Mon, Aug 06, 2018 at 11:37:55AM +0200, Rafael J. Wysocki wrote:
quoted
On Fri, Aug 3, 2018 at 1:42 PM, Ulf Hansson [off-list ref]
wrote:
quoted
[...]
quoted
quoted
Assuming that I have got that right, there are concerns, mostly
regarding
patch [07/26], but I will reply to that directly.
Well, I haven't got that right, so never mind.

There are a few minor things to address, but apart from that the
general
genpd patches look ready.
Alright, thanks!

I will re-spin the series and post a new version once 4.19 rc1 is out.
Hopefully we can queue it up early in next cycle to get it tested in
next for a while.
quoted
quoted
The $subject patch is fine by me by itself, but it obviously depends
on the
previous ones.  Patches [01-02/26] are fine too, but they don't seem
to be
particularly useful without the rest of the series.

As far as patches [10-26/26] go, I'd like to see some review comments
and/or
tags from the people with vested interest in there, in particular
from Daniel
on patch [12/26] and from Sudeep on the PSCI ones.
But this still holds.
Actually, patch 10 and patch11 is ready to go as well. I ping Daniel
on patch 12.

In regards to the rest of the series, some of the PSCI/ARM changes
have been reviewed by Mark Rutland, however several changes have not
been acked.

On the other hand, one can also interpret the long silence in regards
to PSCI/ARM changes as they are good to go. :-)
Well, in that case giving an ACK to them should not be an issue for
the people with a vested interest I suppose.

Apologies to everyone for the delay in replying.

Side note: cpu_pm_enter()/exit() are also called through syscore ops in
s2RAM/IDLE, you know that but I just wanted to mention it to compound
the discussion.

As for PSCI patches I do not personally think PSCI OSI enablement is
beneficial (and my position has always been the same since PSCI OSI was
added to the specification, I am not even talking about this patchset)
and Arm Trusted Firmware does not currently support it for the same
reason.

We (if Mark and Sudeep agree) will enable PSCI OSI if and when we have a
definitive and constructive answer to *why* we have to do that that is
not a dogmatic "the kernel knows better" but rather a comprehensive
power benchmark evaluation - I thought that was the agreement reached
at OSPM but apparently I was mistaken.
I will not speak to any comparison of benchmarks between OSI and PC.
AFAIK, there are no platforms supporting both.

But, the OSI feature is critical for QCOM mobile platforms. The
last man activities during cpuidle save quite a lot of power. Powering
off the clocks, busses, regulators and even the oscillator is very
important to have a reasonable battery life when using the phone.
Platform coordinated approach falls quite short of the needs of a
powerful processor with a desired battery efficiency.
Even so, you still need firmware (or hardware) to do the right thing
in the concurrent wakeup via an edge-triggered interrupt case AFAICS.
That is, you need the domain to be prevented from being turned off if
one of the CPUs in it has just been woken up and the interrupt is
still pending.
Yes, that is true and we have been doing this on pretty much every QC
SoC there is, for CPU domains. Generally, there is a handshake of sorts
with the power domain controller when the core executes WFI. It
decrements the reference on the controller when going down and
increments when coming up. The controller is only turned off when the
reference count is 0 and is turned back on before the CPU is ready to
exit the WFI.

What we are doing here is hand the domain's ->power_off and ->power_on
over to the platform firmware, which needs to make sure the races are
handled correctly either in h/w or through mechanisms like MCPM or in
the firmware. I would consider what happens during the power on/off of
the domains beyond the realm of the genpd at least for CPU specific PM
domains.

Thanks,
Lina
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help