aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/pm_domain.h
diff options
context:
space:
mode:
authorThomas Abraham <thomas.abraham@linaro.org>2012-01-27 01:22:07 -0500
committerKukjin Kim <kgene.kim@samsung.com>2012-01-27 01:22:07 -0500
commitc8aa130b74cc5b112cb2b119d3b477abaaf6e5b2 (patch)
tree80ca3b93767b0aec09ed566924c196033ad12b49 /include/linux/pm_domain.h
parentdcd6c92267155e70a94b3927bce681ce74b80d1f (diff)
PM / Domains: Add OF support
A device node pointer is added to generic pm domain structure to associate the domain with a node in the device tree. The platform code parses the device tree to find available nodes representing the generic power domain, instantiates the available domains and initializes them by calling pm_genpd_init(). Nodes representing the devices include a phandle of the power domain to which it belongs. As these devices get instantiated, the driver code checkes for availability of a power domain phandle, converts the phandle to a device node and uses the new pm_genpd_of_add_device() api to associate the device with a power domain. pm_genpd_of_add_device() runs through its list of registered power domains and matches the OF node of the domain with the one specified as the parameter. If a match is found, the device is associated with the matched domain. Cc: Rob Herring <rob.herring@calxeda.com> Cc: Grant Likely <grant.likely@secretlab.ca> Signed-off-by: Thomas Abraham <thomas.abraham@linaro.org> Acked-by: Rafael J. Wysocki <rjw@sisk.pl> Signed-off-by: Kukjin Kim <kgene.kim@samsung.com>
Diffstat (limited to 'include/linux/pm_domain.h')
-rw-r--r--include/linux/pm_domain.h12
1 files changed, 12 insertions, 0 deletions
diff --git a/include/linux/pm_domain.h b/include/linux/pm_domain.h
index a03a0ad998b8..e3ff87550eeb 100644
--- a/include/linux/pm_domain.h
+++ b/include/linux/pm_domain.h
@@ -11,6 +11,7 @@
11 11
12#include <linux/device.h> 12#include <linux/device.h>
13#include <linux/err.h> 13#include <linux/err.h>
14#include <linux/of.h>
14 15
15enum gpd_status { 16enum gpd_status {
16 GPD_STATE_ACTIVE = 0, /* PM domain is active */ 17 GPD_STATE_ACTIVE = 0, /* PM domain is active */
@@ -70,6 +71,7 @@ struct generic_pm_domain {
70 s64 break_even_ns; /* Power break even for the entire domain. */ 71 s64 break_even_ns; /* Power break even for the entire domain. */
71 s64 max_off_time_ns; /* Maximum allowed "suspended" time. */ 72 s64 max_off_time_ns; /* Maximum allowed "suspended" time. */
72 ktime_t power_off_time; 73 ktime_t power_off_time;
74 struct device_node *of_node; /* Node in device tree */
73}; 75};
74 76
75static inline struct generic_pm_domain *pd_to_genpd(struct dev_pm_domain *pd) 77static inline struct generic_pm_domain *pd_to_genpd(struct dev_pm_domain *pd)
@@ -117,12 +119,22 @@ extern int __pm_genpd_add_device(struct generic_pm_domain *genpd,
117 struct device *dev, 119 struct device *dev,
118 struct gpd_timing_data *td); 120 struct gpd_timing_data *td);
119 121
122extern int __pm_genpd_of_add_device(struct device_node *genpd_node,
123 struct device *dev,
124 struct gpd_timing_data *td);
125
120static inline int pm_genpd_add_device(struct generic_pm_domain *genpd, 126static inline int pm_genpd_add_device(struct generic_pm_domain *genpd,
121 struct device *dev) 127 struct device *dev)
122{ 128{
123 return __pm_genpd_add_device(genpd, dev, NULL); 129 return __pm_genpd_add_device(genpd, dev, NULL);
124} 130}
125 131
132static inline int pm_genpd_of_add_device(struct device_node *genpd_node,
133 struct device *dev)
134{
135 return __pm_genpd_of_add_device(genpd_node, dev, NULL);
136}
137
126extern int pm_genpd_remove_device(struct generic_pm_domain *genpd, 138extern int pm_genpd_remove_device(struct generic_pm_domain *genpd,
127 struct device *dev); 139 struct device *dev);
128extern int pm_genpd_add_subdomain(struct generic_pm_domain *genpd, 140extern int pm_genpd_add_subdomain(struct generic_pm_domain *genpd,