Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mason/btrfs...
[pandora-kernel.git] / arch / arm / mach-omap1 / pm_bus.c
1 /*
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
25 static int omap1_pm_runtime_suspend(struct device *dev)
26 {
27         int ret;
28
29         dev_dbg(dev, "%s\n", __func__);
30
31         ret = pm_generic_runtime_suspend(dev);
32         if (ret)
33                 return ret;
34
35         ret = pm_runtime_clk_suspend(dev);
36         if (ret) {
37                 pm_generic_runtime_resume(dev);
38                 return ret;
39         }
40
41         return 0;
42 }
43
44 static int omap1_pm_runtime_resume(struct device *dev)
45 {
46         dev_dbg(dev, "%s\n", __func__);
47
48         pm_runtime_clk_resume(dev);
49         return pm_generic_runtime_resume(dev);
50 }
51
52 static 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 };
59
60 static struct pm_clk_notifier_block platform_bus_notifier = {
61         .pwr_domain = &default_power_domain,
62         .con_ids = { "ick", "fck", NULL, },
63 };
64
65 static int __init omap1_pm_runtime_init(void)
66 {
67         if (!cpu_class_is_omap1())
68                 return -ENODEV;
69
70         pm_runtime_clk_add_notifier(&platform_bus_type, &platform_bus_notifier);
71
72         return 0;
73 }
74 core_initcall(omap1_pm_runtime_init);
75 #endif /* CONFIG_PM_RUNTIME */