Commit 62020f23 authored by Tony Lindgren's avatar Tony Lindgren

bus: ti-sysc: Add suspend and resume handling

This allows us to idle the module on suspend after the children
are suspended.
Signed-off-by: default avatarTony Lindgren <tony@atomide.com>
parent 2c355ff6
......@@ -58,6 +58,7 @@ static const char * const clock_names[] = { "fck", "ick", };
* @cfg: interconnect target module configuration
* @name: name if available
* @revision: interconnect target module revision
* @needs_resume: runtime resume needed on resume from suspend
*/
struct sysc {
struct device *dev;
......@@ -71,6 +72,8 @@ struct sysc {
struct sysc_config cfg;
const char *name;
u32 revision;
bool enabled;
bool needs_resume;
};
static u32 sysc_read(struct sysc *ddata, int offset)
......@@ -497,7 +500,38 @@ static int __maybe_unused sysc_runtime_resume(struct device *dev)
return 0;
}
#ifdef CONFIG_PM_SLEEP
static int sysc_suspend(struct device *dev)
{
struct sysc *ddata;
ddata = dev_get_drvdata(dev);
if (!ddata->enabled)
return 0;
ddata->needs_resume = true;
return sysc_runtime_suspend(dev);
}
static int sysc_resume(struct device *dev)
{
struct sysc *ddata;
ddata = dev_get_drvdata(dev);
if (ddata->needs_resume) {
ddata->needs_resume = false;
return sysc_runtime_resume(dev);
}
return 0;
}
#endif
static const struct dev_pm_ops sysc_pm_ops = {
SET_SYSTEM_SLEEP_PM_OPS(sysc_suspend, sysc_resume)
SET_RUNTIME_PM_OPS(sysc_runtime_suspend,
sysc_runtime_resume,
NULL)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment