sh: Runtime PM for SuperH Mobile platform bus devices
authorMagnus Damm <damm@igel.co.jp>
Fri, 14 Aug 2009 10:48:16 +0000 (10:48 +0000)
committerPaul Mundt <lethal@linux-sh.org>
Sun, 23 Aug 2009 09:03:17 +0000 (18:03 +0900)
commit6a93dde1e8216f7af9b2551a60fb1a5eeac4a89f
tree41a36d18a3f9441000f5658772f6263c17925279
parent0858d9c0c591ce9baa1baf72eaf6f67823f3bc25
sh: Runtime PM for SuperH Mobile platform bus devices

This patch is V3 of the SuperH Mobile Runtime PM platform bus
implentation matching Rafael's Runtime PM v16.

The code gets invoked from the SuperH specific Runtime PM
platform bus functions that override the weak symbols for:
 - platform_pm_runtime_suspend()
 - platform_pm_runtime_resume()
 - platform_pm_runtime_idle()

This Runtime PM implementation performs two levels of power
management. At the time of platform bus runtime suspend the
clock to the device is stopped instantly. Later on if all
devices within the power domain has their clocks stopped
then the device driver ->runtime_suspend() callbacks are
used to save hardware register state for each device.

Device driver ->runtime_suspend() calls are scheduled from
cpuidle context using platform_pm_runtime_suspend_idle().
When all devices have been fully suspended the processor
is allowed to enter deep sleep from cpuidle.

The runtime resume operation turns on clocks and also
restores registers if needed. It is worth noting that the
devices start in a suspended state and the device driver
is responsible for calling runtime resume before accessing
the actual hardware.

In this particular platform bus implementation runtime
resume is not allowed from interrupt context. Runtime
suspend is however allowed from interrupt context as
long as the synchronous functions are avoided.

[ updated for v17 -- PFM. ]

Signed-off-by: Magnus Damm <damm@igel.co.jp>
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
arch/sh/include/asm/device.h
arch/sh/include/asm/hwblk.h
arch/sh/kernel/cpu/shmobile/Makefile
arch/sh/kernel/cpu/shmobile/pm_runtime.c [new file with mode: 0644]