]> git.baikalelectronics.ru Git - kernel.git/commit
i2c-omap: fix static suspend vs. runtime suspend
authorKevin Hilman <khilman@ti.com>
Fri, 28 Jan 2011 00:18:41 +0000 (16:18 -0800)
committerBen Dooks <ben-linux@fluff.org>
Tue, 22 Feb 2011 23:53:44 +0000 (23:53 +0000)
commitf0be0249b5d52b2a86b57da86340b07121bfcbb6
tree5aeee4e126ee83567e12e437084766602eae942d
parentebd23b40a979014fe1cb8875f34ce209cdea90cd
i2c-omap: fix static suspend vs. runtime suspend

When runtime PM is enabled, each OMAP i2c device is suspended after
each i2c xfer.  However, there are two cases when the static suspend
methods must be used to ensure the devices are suspended:

1) runtime PM is disabled, either at compile time or dynamically
    via /sys/devices/.../power/control.
2) an i2c client driver uses i2c during it's suspend callback, thus
   leaving the i2c driver active (NOTE: runtime suspend transitions are
   disabled during system suspend, so i2c activity during system
   suspend will runtime resume the device, but not runtime (re)suspend it.)

Since the actual work to suspend the device is handled by the
subsytem, call the bus methods to take care of it.

NOTE: This takes care of a known suspend problem on OMAP3 where the
TWL RTC driver does i2c xfers during its suspend path leaving the i2c
driver in an active state (since runtime suspend transistions are
disabled.)

Signed-off-by: Kevin Hilman <khilman@ti.com>
Signed-off-by: Ben Dooks <ben-linux@fluff.org>
drivers/i2c/busses/i2c-omap.c