aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm
diff options
context:
space:
mode:
authorKevin Hilman <khilman@ti.com>2011-03-16 19:13:15 -0400
committerKevin Hilman <khilman@ti.com>2011-09-15 14:39:10 -0400
commite69c22b1459068f15e56e48b4b6953cc3f566c79 (patch)
treedd800481a50885786f00d9d7cc3537efad939629 /arch/arm
parent048a7034f1044e69868df70bff32d8d67974e1b8 (diff)
OMAP2+: voltage: keep track of powerdomains in each voltagedomain
When a powerdomain is registered and it has an associated voltage domain, add the powerdomain to the voltagedomain using voltdm_add_pwrdm(). Also add voltagedomain iterator helper functions to iterate over all registered voltagedomains and all powerdomains associated with a voltagedomain. Modeled after a similar relationship between clockdomains and powerdomains. Signed-off-by: Kevin Hilman <khilman@ti.com>
Diffstat (limited to 'arch/arm')
-rw-r--r--arch/arm/mach-omap2/powerdomain.c2
-rw-r--r--arch/arm/mach-omap2/powerdomain.h2
-rw-r--r--arch/arm/mach-omap2/voltage.c80
-rw-r--r--arch/arm/mach-omap2/voltage.h9
4 files changed, 93 insertions, 0 deletions
diff --git a/arch/arm/mach-omap2/powerdomain.c b/arch/arm/mach-omap2/powerdomain.c
index 984457d612b7..5164d587ef52 100644
--- a/arch/arm/mach-omap2/powerdomain.c
+++ b/arch/arm/mach-omap2/powerdomain.c
@@ -99,6 +99,8 @@ static int _pwrdm_register(struct powerdomain *pwrdm)
99 return -EINVAL; 99 return -EINVAL;
100 } 100 }
101 pwrdm->voltdm.ptr = voltdm; 101 pwrdm->voltdm.ptr = voltdm;
102 INIT_LIST_HEAD(&pwrdm->voltdm_node);
103 voltdm_add_pwrdm(voltdm, pwrdm);
102 104
103 list_add(&pwrdm->node, &pwrdm_list); 105 list_add(&pwrdm->node, &pwrdm_list);
104 106
diff --git a/arch/arm/mach-omap2/powerdomain.h b/arch/arm/mach-omap2/powerdomain.h
index d8a7f914d9b3..42e6dd8f2a78 100644
--- a/arch/arm/mach-omap2/powerdomain.h
+++ b/arch/arm/mach-omap2/powerdomain.h
@@ -91,6 +91,7 @@ struct powerdomain;
91 * @pwrsts_mem_on: Possible memory bank pwrstates when pwrdm in ON 91 * @pwrsts_mem_on: Possible memory bank pwrstates when pwrdm in ON
92 * @pwrdm_clkdms: Clockdomains in this powerdomain 92 * @pwrdm_clkdms: Clockdomains in this powerdomain
93 * @node: list_head linking all powerdomains 93 * @node: list_head linking all powerdomains
94 * @voltdm_node: list_head linking all powerdomains in a voltagedomain
94 * @state: 95 * @state:
95 * @state_counter: 96 * @state_counter:
96 * @timer: 97 * @timer:
@@ -114,6 +115,7 @@ struct powerdomain {
114 const u8 prcm_partition; 115 const u8 prcm_partition;
115 struct clockdomain *pwrdm_clkdms[PWRDM_MAX_CLKDMS]; 116 struct clockdomain *pwrdm_clkdms[PWRDM_MAX_CLKDMS];
116 struct list_head node; 117 struct list_head node;
118 struct list_head voltdm_node;
117 int state; 119 int state;
118 unsigned state_counter[PWRDM_MAX_PWRSTS]; 120 unsigned state_counter[PWRDM_MAX_PWRSTS];
119 unsigned ret_logic_off_counter; 121 unsigned ret_logic_off_counter;
diff --git a/arch/arm/mach-omap2/voltage.c b/arch/arm/mach-omap2/voltage.c
index 48a2593878c6..1e5c1225e2be 100644
--- a/arch/arm/mach-omap2/voltage.c
+++ b/arch/arm/mach-omap2/voltage.c
@@ -36,6 +36,7 @@
36#include "control.h" 36#include "control.h"
37 37
38#include "voltage.h" 38#include "voltage.h"
39#include "powerdomain.h"
39 40
40#include "vc.h" 41#include "vc.h"
41#include "vp.h" 42#include "vp.h"
@@ -1085,11 +1086,90 @@ static struct voltagedomain *_voltdm_lookup(const char *name)
1085 return voltdm; 1086 return voltdm;
1086} 1087}
1087 1088
1089/**
1090 * voltdm_add_pwrdm - add a powerdomain to a voltagedomain
1091 * @voltdm: struct voltagedomain * to add the powerdomain to
1092 * @pwrdm: struct powerdomain * to associate with a voltagedomain
1093 *
1094 * Associate the powerdomain @pwrdm with a voltagedomain @voltdm. This
1095 * enables the use of voltdm_for_each_pwrdm(). Returns -EINVAL if
1096 * presented with invalid pointers; -ENOMEM if memory could not be allocated;
1097 * or 0 upon success.
1098 */
1099int voltdm_add_pwrdm(struct voltagedomain *voltdm, struct powerdomain *pwrdm)
1100{
1101 if (!voltdm || !pwrdm)
1102 return -EINVAL;
1103
1104 pr_debug("voltagedomain: associating powerdomain %s with voltagedomain "
1105 "%s\n", pwrdm->name, voltdm->name);
1106
1107 list_add(&pwrdm->voltdm_node, &voltdm->pwrdm_list);
1108
1109 return 0;
1110}
1111
1112/**
1113 * voltdm_for_each_pwrdm - call function for each pwrdm in a voltdm
1114 * @voltdm: struct voltagedomain * to iterate over
1115 * @fn: callback function *
1116 *
1117 * Call the supplied function @fn for each powerdomain in the
1118 * voltagedomain @voltdm. Returns -EINVAL if presented with invalid
1119 * pointers; or passes along the last return value of the callback
1120 * function, which should be 0 for success or anything else to
1121 * indicate failure.
1122 */
1123int voltdm_for_each_pwrdm(struct voltagedomain *voltdm,
1124 int (*fn)(struct voltagedomain *voltdm,
1125 struct powerdomain *pwrdm))
1126{
1127 struct powerdomain *pwrdm;
1128 int ret = 0;
1129
1130 if (!fn)
1131 return -EINVAL;
1132
1133 list_for_each_entry(pwrdm, &voltdm->pwrdm_list, voltdm_node)
1134 ret = (*fn)(voltdm, pwrdm);
1135
1136 return ret;
1137}
1138
1139/**
1140 * voltdm_for_each - call function on each registered voltagedomain
1141 * @fn: callback function *
1142 *
1143 * Call the supplied function @fn for each registered voltagedomain.
1144 * The callback function @fn can return anything but 0 to bail out
1145 * early from the iterator. Returns the last return value of the
1146 * callback function, which should be 0 for success or anything else
1147 * to indicate failure; or -EINVAL if the function pointer is null.
1148 */
1149int voltdm_for_each(int (*fn)(struct voltagedomain *voltdm, void *user),
1150 void *user)
1151{
1152 struct voltagedomain *temp_voltdm;
1153 int ret = 0;
1154
1155 if (!fn)
1156 return -EINVAL;
1157
1158 list_for_each_entry(temp_voltdm, &voltdm_list, node) {
1159 ret = (*fn)(temp_voltdm, user);
1160 if (ret)
1161 break;
1162 }
1163
1164 return ret;
1165}
1166
1088static int _voltdm_register(struct voltagedomain *voltdm) 1167static int _voltdm_register(struct voltagedomain *voltdm)
1089{ 1168{
1090 if (!voltdm || !voltdm->name) 1169 if (!voltdm || !voltdm->name)
1091 return -EINVAL; 1170 return -EINVAL;
1092 1171
1172 INIT_LIST_HEAD(&voltdm->pwrdm_list);
1093 list_add(&voltdm->node, &voltdm_list); 1173 list_add(&voltdm->node, &voltdm_list);
1094 1174
1095 pr_debug("voltagedomain: registered %s\n", voltdm->name); 1175 pr_debug("voltagedomain: registered %s\n", voltdm->name);
diff --git a/arch/arm/mach-omap2/voltage.h b/arch/arm/mach-omap2/voltage.h
index 966aa8880345..5063ab33af7b 100644
--- a/arch/arm/mach-omap2/voltage.h
+++ b/arch/arm/mach-omap2/voltage.h
@@ -19,6 +19,8 @@
19#include "vc.h" 19#include "vc.h"
20#include "vp.h" 20#include "vp.h"
21 21
22struct powerdomain;
23
22/* XXX document */ 24/* XXX document */
23#define VOLTSCALE_VPFORCEUPDATE 1 25#define VOLTSCALE_VPFORCEUPDATE 1
24#define VOLTSCALE_VCBYPASS 2 26#define VOLTSCALE_VCBYPASS 2
@@ -55,12 +57,14 @@ struct omap_vfsm_instance_data {
55 * @name: Name of the voltage domain which can be used as a unique identifier. 57 * @name: Name of the voltage domain which can be used as a unique identifier.
56 * @scalable: Whether or not this voltage domain is scalable 58 * @scalable: Whether or not this voltage domain is scalable
57 * @node: list_head linking all voltage domains 59 * @node: list_head linking all voltage domains
60 * @pwrdm_list: list_head linking all powerdomains in this voltagedomain
58 * @vdd: to be removed 61 * @vdd: to be removed
59 */ 62 */
60struct voltagedomain { 63struct voltagedomain {
61 char *name; 64 char *name;
62 bool scalable; 65 bool scalable;
63 struct list_head node; 66 struct list_head node;
67 struct list_head pwrdm_list;
64 struct omap_vdd_info *vdd; 68 struct omap_vdd_info *vdd;
65}; 69};
66 70
@@ -187,4 +191,9 @@ extern void omap44xx_voltagedomains_init(void);
187struct voltagedomain *voltdm_lookup(const char *name); 191struct voltagedomain *voltdm_lookup(const char *name);
188void voltdm_init(struct voltagedomain **voltdm_list); 192void voltdm_init(struct voltagedomain **voltdm_list);
189int voltdm_add_pwrdm(struct voltagedomain *voltdm, struct powerdomain *pwrdm); 193int voltdm_add_pwrdm(struct voltagedomain *voltdm, struct powerdomain *pwrdm);
194int voltdm_for_each(int (*fn)(struct voltagedomain *voltdm, void *user),
195 void *user);
196int voltdm_for_each_pwrdm(struct voltagedomain *voltdm,
197 int (*fn)(struct voltagedomain *voltdm,
198 struct powerdomain *pwrdm));
190#endif 199#endif