blob: bd5c6a3b8c55792460316af56432a6a0f2a5775a [file] [log] [blame]
Magnus Dammf14c4f12010-07-27 08:14:35 +00001/*
2 * arch/arm/mach-shmobile/pm_runtime.c
3 *
4 * Runtime PM support code for SuperH Mobile ARM
5 *
6 * Copyright (C) 2009-2010 Magnus Damm
7 *
8 * This file is subject to the terms and conditions of the GNU General Public
9 * License. See the file "COPYING" in the main directory of this archive
10 * for more details.
11 */
12
13#include <linux/init.h>
14#include <linux/kernel.h>
15#include <linux/io.h>
16#include <linux/pm_runtime.h>
Rafael J. Wysocki79620412011-07-13 12:32:07 +020017#include <linux/pm_domain.h>
Rafael J. Wysockib5e8d262011-08-25 15:34:19 +020018#include <linux/pm_clock.h>
Magnus Dammf14c4f12010-07-27 08:14:35 +000019#include <linux/platform_device.h>
20#include <linux/clk.h>
21#include <linux/sh_clk.h>
22#include <linux/bitmap.h>
Rafael J. Wysocki1d2b71f2011-04-29 00:36:53 +020023#include <linux/slab.h>
Magnus Dammf14c4f12010-07-27 08:14:35 +000024
25#ifdef CONFIG_PM_RUNTIME
Magnus Dammf14c4f12010-07-27 08:14:35 +000026
Rafael J. Wysocki38ade3a2011-04-29 00:36:21 +020027static int default_platform_runtime_idle(struct device *dev)
Magnus Dammf14c4f12010-07-27 08:14:35 +000028{
29 /* suspend synchronously to disable clocks immediately */
30 return pm_runtime_suspend(dev);
31}
32
Rafael J. Wysocki564b9052011-06-23 01:52:55 +020033static struct dev_pm_domain default_pm_domain = {
Rafael J. Wysocki38ade3a2011-04-29 00:36:21 +020034 .ops = {
Rafael J. Wysocki3d5c3032011-07-01 22:13:44 +020035 .runtime_suspend = pm_clk_suspend,
36 .runtime_resume = pm_clk_resume,
Rafael J. Wysocki38ade3a2011-04-29 00:36:21 +020037 .runtime_idle = default_platform_runtime_idle,
38 USE_PLATFORM_PM_SLEEP_OPS
39 },
40};
41
Rafael J. Wysocki564b9052011-06-23 01:52:55 +020042#define DEFAULT_PM_DOMAIN_PTR (&default_pm_domain)
Magnus Dammf14c4f12010-07-27 08:14:35 +000043
Rafael J. Wysocki85eb8c82011-04-30 00:25:44 +020044#else
Magnus Dammf14c4f12010-07-27 08:14:35 +000045
Rafael J. Wysocki564b9052011-06-23 01:52:55 +020046#define DEFAULT_PM_DOMAIN_PTR NULL
Magnus Dammf14c4f12010-07-27 08:14:35 +000047
48#endif /* CONFIG_PM_RUNTIME */
49
Rafael J. Wysocki85eb8c82011-04-30 00:25:44 +020050static struct pm_clk_notifier_block platform_bus_notifier = {
Rafael J. Wysocki564b9052011-06-23 01:52:55 +020051 .pm_domain = DEFAULT_PM_DOMAIN_PTR,
Rafael J. Wysocki85eb8c82011-04-30 00:25:44 +020052 .con_ids = { NULL, },
Magnus Dammf14c4f12010-07-27 08:14:35 +000053};
54
55static int __init sh_pm_runtime_init(void)
56{
Rafael J. Wysocki3d5c3032011-07-01 22:13:44 +020057 pm_clk_add_notifier(&platform_bus_type, &platform_bus_notifier);
Magnus Dammf14c4f12010-07-27 08:14:35 +000058 return 0;
59}
60core_initcall(sh_pm_runtime_init);
Magnus Damm999a4d22011-07-10 10:38:34 +020061
Magnus Damm999a4d22011-07-10 10:38:34 +020062static int __init sh_pm_runtime_late_init(void)
63{
Rafael J. Wysocki79620412011-07-13 12:32:07 +020064 pm_genpd_poweroff_unused();
Magnus Damm999a4d22011-07-10 10:38:34 +020065 return 0;
66}
67late_initcall(sh_pm_runtime_late_init);