blob: 334fb8871bc319348f9edb152e5d611fb539aa6f [file] [log] [blame]
Kevin Hilmane933ec72010-06-17 15:48:43 -07001/*
2 * Runtime PM support code for OMAP1
3 *
4 * Author: Kevin Hilman, Deep Root Systems, LLC
5 *
6 * Copyright (C) 2010 Texas Instruments, Inc.
7 *
8 * This file is licensed under the terms of the GNU General Public
9 * License version 2. This program is licensed "as is" without any
10 * warranty of any kind, whether express or implied.
11 */
12#include <linux/init.h>
13#include <linux/kernel.h>
14#include <linux/io.h>
15#include <linux/pm_runtime.h>
16#include <linux/platform_device.h>
17#include <linux/mutex.h>
18#include <linux/clk.h>
19#include <linux/err.h>
20
21#include <plat/omap_device.h>
22#include <plat/omap-pm.h>
23
24#ifdef CONFIG_PM_RUNTIME
25static int omap1_pm_runtime_suspend(struct device *dev)
26{
Rafael J. Wysocki600b7762011-05-16 20:15:36 +020027 int ret;
Kevin Hilmane933ec72010-06-17 15:48:43 -070028
29 dev_dbg(dev, "%s\n", __func__);
30
31 ret = pm_generic_runtime_suspend(dev);
Rafael J. Wysocki600b7762011-05-16 20:15:36 +020032 if (ret)
33 return ret;
Kevin Hilmane933ec72010-06-17 15:48:43 -070034
Rafael J. Wysocki600b7762011-05-16 20:15:36 +020035 ret = pm_runtime_clk_suspend(dev);
36 if (ret) {
37 pm_generic_runtime_resume(dev);
38 return ret;
Kevin Hilmane933ec72010-06-17 15:48:43 -070039 }
40
41 return 0;
Rafael J. Wysocki600b7762011-05-16 20:15:36 +020042}
Kevin Hilmane933ec72010-06-17 15:48:43 -070043
44static int omap1_pm_runtime_resume(struct device *dev)
45{
Kevin Hilmane933ec72010-06-17 15:48:43 -070046 dev_dbg(dev, "%s\n", __func__);
47
Rafael J. Wysocki600b7762011-05-16 20:15:36 +020048 pm_runtime_clk_resume(dev);
Kevin Hilmane933ec72010-06-17 15:48:43 -070049 return pm_generic_runtime_resume(dev);
Rafael J. Wysocki600b7762011-05-16 20:15:36 +020050}
51
52static struct dev_power_domain default_power_domain = {
53 .ops = {
54 .runtime_suspend = omap1_pm_runtime_suspend,
55 .runtime_resume = omap1_pm_runtime_resume,
56 USE_PLATFORM_PM_SLEEP_OPS
57 },
58};
Kevin Hilmane9e35c52011-06-14 05:53:18 -070059#define OMAP1_PWR_DOMAIN (&default_power_domain)
60#else
61#define OMAP1_PWR_DOMAIN NULL
62#endif /* CONFIG_PM_RUNTIME */
Rafael J. Wysocki600b7762011-05-16 20:15:36 +020063
64static struct pm_clk_notifier_block platform_bus_notifier = {
Kevin Hilmane9e35c52011-06-14 05:53:18 -070065 .pwr_domain = OMAP1_PWR_DOMAIN,
Rafael J. Wysocki600b7762011-05-16 20:15:36 +020066 .con_ids = { "ick", "fck", NULL, },
Kevin Hilmane933ec72010-06-17 15:48:43 -070067};
68
69static int __init omap1_pm_runtime_init(void)
70{
Tony Lindgren7f9187c2010-12-10 09:46:24 -080071 if (!cpu_class_is_omap1())
72 return -ENODEV;
73
Rafael J. Wysocki600b7762011-05-16 20:15:36 +020074 pm_runtime_clk_add_notifier(&platform_bus_type, &platform_bus_notifier);
Kevin Hilmane933ec72010-06-17 15:48:43 -070075
76 return 0;
77}
78core_initcall(omap1_pm_runtime_init);
Kevin Hilmane9e35c52011-06-14 05:53:18 -070079