Thread (33 messages) 33 messages, 5 authors, 2013-01-03
STALE4911d

[PATCH V3 5/5] ARM: tegra20: cpuidle: apply coupled cpuidle for powered-down mode

From: pdeschrijver@nvidia.com (Peter De Schrijver)
Date: 2012-12-18 10:18:19
Also in: linux-tegra

On Tue, Dec 18, 2012 at 03:31:01AM +0100, Joseph Lo wrote:
The "powered-down" cpuidle mode of Tegra20 needs the CPU0 be the last one
core to go into this mode before other core. The coupled cpuidle framework
can help to sync the MPCore to coupled state then go into "powered-down"
idle mode together. The driver can just assume the MPCore come into
"powered-down" mode at the same time. No need to take care if the CPU_0
goes into this mode along and only can put it into safe idle mode (WFI).

The powered-down state of Tegra20 requires power gating both CPU cores.
When the secondary CPU requests to enter powered-down state, it saves
its own contexts and then enters WFI for waiting CPU0 in the same state.
When the CPU0 requests powered-down state, it attempts to put the secondary
CPU into reset to prevent it from waking up. Then power down both CPUs
together and power off the cpu rail.

Be aware of that, you may see the legacy power state "LP2" in the code
which is exactly the same meaning of "CPU power down".

Based on the work by:
Colin Cross [off-list ref]
Gary King [off-list ref]

Signed-off-by: Joseph Lo <redacted>
---
V3:
* sqash last two patch in previous version to support coupled cpuidle
  directly
nitpick - it should be 'squash'.

Cheers,

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