• Rafael J. Wysocki's avatar
    i2c: Fix bus-level power management callbacks · 2f60ba70
    Rafael J. Wysocki authored
    There are three issues with the i2c bus type's power management
    callbacks at the moment.  First, they don't include any hibernate
    callbacks, although they should at least include the .restore()
    callback (there's no guarantee that the driver will be present in
    memory before loading the image kernel and we must restore the
    pre-hibernation state of the device).  Second, the "legacy"
    callbacks are not going to be invoked by the PM core since the bus
    type's pm object is not NULL.  Finally, the system sleep PM
    (ie. suspend/resume) callbacks don't check if the device has been
    already suspended at run time, in which case they should skip
    suspending it.  Also, it looks like the i2c bus type can use the
    generic subsystem-level runtime PM callbacks.
    
    For these reasons, rework the system sleep PM callbacks provided by
    the i2c bus type to handle hibernation correctly and to invoke the
    "legacy" callbacks for drivers that provide them.  In addition to
    that make the i2c bus type use the generic subsystem-level runtime
    PM callbacks.
    Signed-off-by: default avatarRafael J. Wysocki <rjw@sisk.pl>
    Acked-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
    Acked-by: default avatarJean Delvare <khali@linux-fr.org>
    2f60ba70
i2c-core.c 53.3 KB