pm_runtime.c 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /*
  2. * Runtime PM support code
  3. *
  4. * Copyright (C) 2009-2010 Magnus Damm
  5. *
  6. * This file is subject to the terms and conditions of the GNU General Public
  7. * License. See the file "COPYING" in the main directory of this archive
  8. * for more details.
  9. */
  10. #include <linux/init.h>
  11. #include <linux/kernel.h>
  12. #include <linux/io.h>
  13. #include <linux/pm_runtime.h>
  14. #include <linux/pm_domain.h>
  15. #include <linux/pm_clock.h>
  16. #include <linux/platform_device.h>
  17. #include <linux/clk.h>
  18. #include <linux/sh_clk.h>
  19. #include <linux/bitmap.h>
  20. #include <linux/slab.h>
  21. #ifdef CONFIG_PM_RUNTIME
  22. static int default_platform_runtime_idle(struct device *dev)
  23. {
  24. /* suspend synchronously to disable clocks immediately */
  25. return pm_runtime_suspend(dev);
  26. }
  27. static struct dev_pm_domain default_pm_domain = {
  28. .ops = {
  29. .runtime_suspend = pm_clk_suspend,
  30. .runtime_resume = pm_clk_resume,
  31. .runtime_idle = default_platform_runtime_idle,
  32. USE_PLATFORM_PM_SLEEP_OPS
  33. },
  34. };
  35. #define DEFAULT_PM_DOMAIN_PTR (&default_pm_domain)
  36. #else
  37. #define DEFAULT_PM_DOMAIN_PTR NULL
  38. #endif /* CONFIG_PM_RUNTIME */
  39. static struct pm_clk_notifier_block platform_bus_notifier = {
  40. .pm_domain = DEFAULT_PM_DOMAIN_PTR,
  41. .con_ids = { NULL, },
  42. };
  43. static int __init sh_pm_runtime_init(void)
  44. {
  45. pm_clk_add_notifier(&platform_bus_type, &platform_bus_notifier);
  46. return 0;
  47. }
  48. core_initcall(sh_pm_runtime_init);
  49. static int __init sh_pm_runtime_late_init(void)
  50. {
  51. pm_genpd_poweroff_unused();
  52. return 0;
  53. }
  54. late_initcall(sh_pm_runtime_late_init);