pm_domain.h 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. /*
  2. * pm_domain.h - Definitions and headers related to device power domains.
  3. *
  4. * Copyright (C) 2011 Rafael J. Wysocki <rjw@sisk.pl>, Renesas Electronics Corp.
  5. *
  6. * This file is released under the GPLv2.
  7. */
  8. #ifndef _LINUX_PM_DOMAIN_H
  9. #define _LINUX_PM_DOMAIN_H
  10. #include <linux/device.h>
  11. enum gpd_status {
  12. GPD_STATE_ACTIVE = 0, /* PM domain is active */
  13. GPD_STATE_WAIT_MASTER, /* PM domain's master is being waited for */
  14. GPD_STATE_BUSY, /* Something is happening to the PM domain */
  15. GPD_STATE_REPEAT, /* Power off in progress, to be repeated */
  16. GPD_STATE_POWER_OFF, /* PM domain is off */
  17. };
  18. struct dev_power_governor {
  19. bool (*power_down_ok)(struct dev_pm_domain *domain);
  20. };
  21. struct generic_pm_domain {
  22. struct dev_pm_domain domain; /* PM domain operations */
  23. struct list_head gpd_list_node; /* Node in the global PM domains list */
  24. struct list_head master_links; /* Links with PM domain as a master */
  25. struct list_head slave_links; /* Links with PM domain as a slave */
  26. struct list_head dev_list; /* List of devices */
  27. struct mutex lock;
  28. struct dev_power_governor *gov;
  29. struct work_struct power_off_work;
  30. unsigned int in_progress; /* Number of devices being suspended now */
  31. atomic_t sd_count; /* Number of subdomains with power "on" */
  32. enum gpd_status status; /* Current state of the domain */
  33. wait_queue_head_t status_wait_queue;
  34. struct task_struct *poweroff_task; /* Powering off task */
  35. unsigned int resume_count; /* Number of devices being resumed */
  36. unsigned int device_count; /* Number of devices */
  37. unsigned int suspended_count; /* System suspend device counter */
  38. unsigned int prepared_count; /* Suspend counter of prepared devices */
  39. bool suspend_power_off; /* Power status before system suspend */
  40. bool dev_irq_safe; /* Device callbacks are IRQ-safe */
  41. int (*power_off)(struct generic_pm_domain *domain);
  42. int (*power_on)(struct generic_pm_domain *domain);
  43. int (*start_device)(struct device *dev);
  44. int (*stop_device)(struct device *dev);
  45. bool (*active_wakeup)(struct device *dev);
  46. };
  47. static inline struct generic_pm_domain *pd_to_genpd(struct dev_pm_domain *pd)
  48. {
  49. return container_of(pd, struct generic_pm_domain, domain);
  50. }
  51. struct gpd_link {
  52. struct generic_pm_domain *master;
  53. struct list_head master_node;
  54. struct generic_pm_domain *slave;
  55. struct list_head slave_node;
  56. };
  57. struct generic_pm_domain_data {
  58. struct pm_domain_data base;
  59. bool need_restore;
  60. };
  61. static inline struct generic_pm_domain_data *to_gpd_data(struct pm_domain_data *pdd)
  62. {
  63. return container_of(pdd, struct generic_pm_domain_data, base);
  64. }
  65. #ifdef CONFIG_PM_GENERIC_DOMAINS
  66. extern int pm_genpd_add_device(struct generic_pm_domain *genpd,
  67. struct device *dev);
  68. extern int pm_genpd_remove_device(struct generic_pm_domain *genpd,
  69. struct device *dev);
  70. extern int pm_genpd_add_subdomain(struct generic_pm_domain *genpd,
  71. struct generic_pm_domain *new_subdomain);
  72. extern int pm_genpd_remove_subdomain(struct generic_pm_domain *genpd,
  73. struct generic_pm_domain *target);
  74. extern void pm_genpd_init(struct generic_pm_domain *genpd,
  75. struct dev_power_governor *gov, bool is_off);
  76. extern int pm_genpd_poweron(struct generic_pm_domain *genpd);
  77. #else
  78. static inline int pm_genpd_add_device(struct generic_pm_domain *genpd,
  79. struct device *dev)
  80. {
  81. return -ENOSYS;
  82. }
  83. static inline int pm_genpd_remove_device(struct generic_pm_domain *genpd,
  84. struct device *dev)
  85. {
  86. return -ENOSYS;
  87. }
  88. static inline int pm_genpd_add_subdomain(struct generic_pm_domain *genpd,
  89. struct generic_pm_domain *new_sd)
  90. {
  91. return -ENOSYS;
  92. }
  93. static inline int pm_genpd_remove_subdomain(struct generic_pm_domain *genpd,
  94. struct generic_pm_domain *target)
  95. {
  96. return -ENOSYS;
  97. }
  98. static inline void pm_genpd_init(struct generic_pm_domain *genpd,
  99. struct dev_power_governor *gov, bool is_off) {}
  100. static inline int pm_genpd_poweron(struct generic_pm_domain *genpd)
  101. {
  102. return -ENOSYS;
  103. }
  104. #endif
  105. #ifdef CONFIG_PM_GENERIC_DOMAINS_RUNTIME
  106. extern void genpd_queue_power_off_work(struct generic_pm_domain *genpd);
  107. extern void pm_genpd_poweroff_unused(void);
  108. #else
  109. static inline void genpd_queue_power_off_work(struct generic_pm_domain *gpd) {}
  110. static inline void pm_genpd_poweroff_unused(void) {}
  111. #endif
  112. #endif /* _LINUX_PM_DOMAIN_H */