PM: runtime: add might_sleep to PM runtime functions
authorColin Cross <ccross@android.com>
Wed, 10 Aug 2011 16:41:59 +0000 (11:41 -0500)
committermgross <mark.gross@intel.com>
Wed, 9 Nov 2011 20:24:30 +0000 (12:24 -0800)
commit6202c2789c401f3b8e4aa1fd61e78277b4574fea
tree90871d817e5e23ffce41efe2f0517d3757c32177
parentba121e2c85a8daab10bd394a5a1e28f1fad41233
PM: runtime: add might_sleep to PM runtime functions

The list of functions that can be called in atomic context is
non-intuitive (pm_runtime_put_sync can not, but
pm_runtime_put_sync_suspend can, if pm_runtime_irq_safe has
been called?).  The code is actively misleading - the entry
points all start with spin_lock_irqsave, suggesting they
are safe to call in atomic context, but may later
enable interrupts.

Add might_sleep_if to all the __pm_runtime_* entry points
to enforce correct usage.

Also add pm_runtime_put_sync_autosuspend to the list of
functions that can be called in atomic context.

Change-Id: Icac17a10d77c64d44bd2761a91a588dfd1d0c6f0
Signed-off-by: Colin Cross <ccross@android.com>
Documentation/power/runtime_pm.txt
drivers/base/power/runtime.c