diff options
author | Alban Bedel <alban.bedel@avionic-design.de> | 2014-05-20 06:14:02 -0400 |
---|---|---|
committer | Mark Brown <broonie@linaro.org> | 2014-05-26 11:47:40 -0400 |
commit | ad0b40fee4081490676b26ec4fb2205607116eaf (patch) | |
tree | c7bc62aa2c122ab9490c4fd1a6d8f852318a11b9 | |
parent | c9eaa447e77efe77b7fa4c953bd62de8297fd6c5 (diff) |
regulator: tps6586x: Prepare supporting fixed regulators
Add the required definitions and macros to allow easily adding fixed
regulators. This required for the TPS658640 that doesn't allow setting
the LDO_RTC output voltage.
Signed-off-by: Alban Bedel <alban.bedel@avionic-design.de>
Signed-off-by: Mark Brown <broonie@linaro.org>
-rw-r--r-- | drivers/regulator/tps6586x-regulator.c | 27 |
1 files changed, 22 insertions, 5 deletions
diff --git a/drivers/regulator/tps6586x-regulator.c b/drivers/regulator/tps6586x-regulator.c index 32f38a63d944..da8ee0217573 100644 --- a/drivers/regulator/tps6586x-regulator.c +++ b/drivers/regulator/tps6586x-regulator.c | |||
@@ -68,7 +68,7 @@ static inline struct device *to_tps6586x_dev(struct regulator_dev *rdev) | |||
68 | return rdev_get_dev(rdev)->parent; | 68 | return rdev_get_dev(rdev)->parent; |
69 | } | 69 | } |
70 | 70 | ||
71 | static struct regulator_ops tps6586x_regulator_ops = { | 71 | static struct regulator_ops tps6586x_rw_regulator_ops = { |
72 | .list_voltage = regulator_list_voltage_table, | 72 | .list_voltage = regulator_list_voltage_table, |
73 | .map_voltage = regulator_map_voltage_ascend, | 73 | .map_voltage = regulator_map_voltage_ascend, |
74 | .get_voltage_sel = regulator_get_voltage_sel_regmap, | 74 | .get_voltage_sel = regulator_get_voltage_sel_regmap, |
@@ -79,6 +79,16 @@ static struct regulator_ops tps6586x_regulator_ops = { | |||
79 | .disable = regulator_disable_regmap, | 79 | .disable = regulator_disable_regmap, |
80 | }; | 80 | }; |
81 | 81 | ||
82 | static struct regulator_ops tps6586x_ro_regulator_ops = { | ||
83 | .list_voltage = regulator_list_voltage_table, | ||
84 | .map_voltage = regulator_map_voltage_ascend, | ||
85 | .get_voltage_sel = regulator_get_voltage_sel_regmap, | ||
86 | |||
87 | .is_enabled = regulator_is_enabled_regmap, | ||
88 | .enable = regulator_enable_regmap, | ||
89 | .disable = regulator_disable_regmap, | ||
90 | }; | ||
91 | |||
82 | static struct regulator_ops tps6586x_sys_regulator_ops = { | 92 | static struct regulator_ops tps6586x_sys_regulator_ops = { |
83 | }; | 93 | }; |
84 | 94 | ||
@@ -120,12 +130,12 @@ static const unsigned int tps6586x_dvm_voltages[] = { | |||
120 | 1325000, 1350000, 1375000, 1400000, 1425000, 1450000, 1475000, 1500000, | 130 | 1325000, 1350000, 1375000, 1400000, 1425000, 1450000, 1475000, 1500000, |
121 | }; | 131 | }; |
122 | 132 | ||
123 | #define TPS6586X_REGULATOR(_id, _pin_name, vdata, vreg, shift, nbits, \ | 133 | #define TPS6586X_REGULATOR(_id, _ops, _pin_name, vdata, vreg, shift, nbits, \ |
124 | ereg0, ebit0, ereg1, ebit1, goreg, gobit) \ | 134 | ereg0, ebit0, ereg1, ebit1, goreg, gobit) \ |
125 | .desc = { \ | 135 | .desc = { \ |
126 | .supply_name = _pin_name, \ | 136 | .supply_name = _pin_name, \ |
127 | .name = "REG-" #_id, \ | 137 | .name = "REG-" #_id, \ |
128 | .ops = &tps6586x_regulator_ops, \ | 138 | .ops = &tps6586x_## _ops ## _regulator_ops, \ |
129 | .type = REGULATOR_VOLTAGE, \ | 139 | .type = REGULATOR_VOLTAGE, \ |
130 | .id = TPS6586X_ID_##_id, \ | 140 | .id = TPS6586X_ID_##_id, \ |
131 | .n_voltages = ARRAY_SIZE(vdata##_voltages), \ | 141 | .n_voltages = ARRAY_SIZE(vdata##_voltages), \ |
@@ -146,14 +156,21 @@ static const unsigned int tps6586x_dvm_voltages[] = { | |||
146 | #define TPS6586X_LDO(_id, _pname, vdata, vreg, shift, nbits, \ | 156 | #define TPS6586X_LDO(_id, _pname, vdata, vreg, shift, nbits, \ |
147 | ereg0, ebit0, ereg1, ebit1) \ | 157 | ereg0, ebit0, ereg1, ebit1) \ |
148 | { \ | 158 | { \ |
149 | TPS6586X_REGULATOR(_id, _pname, vdata, vreg, shift, nbits, \ | 159 | TPS6586X_REGULATOR(_id, rw, _pname, vdata, vreg, shift, nbits, \ |
160 | ereg0, ebit0, ereg1, ebit1, 0, 0) \ | ||
161 | } | ||
162 | |||
163 | #define TPS6586X_FIXED_LDO(_id, _pname, vdata, vreg, shift, nbits, \ | ||
164 | ereg0, ebit0, ereg1, ebit1) \ | ||
165 | { \ | ||
166 | TPS6586X_REGULATOR(_id, ro, _pname, vdata, vreg, shift, nbits, \ | ||
150 | ereg0, ebit0, ereg1, ebit1, 0, 0) \ | 167 | ereg0, ebit0, ereg1, ebit1, 0, 0) \ |
151 | } | 168 | } |
152 | 169 | ||
153 | #define TPS6586X_DVM(_id, _pname, vdata, vreg, shift, nbits, \ | 170 | #define TPS6586X_DVM(_id, _pname, vdata, vreg, shift, nbits, \ |
154 | ereg0, ebit0, ereg1, ebit1, goreg, gobit) \ | 171 | ereg0, ebit0, ereg1, ebit1, goreg, gobit) \ |
155 | { \ | 172 | { \ |
156 | TPS6586X_REGULATOR(_id, _pname, vdata, vreg, shift, nbits, \ | 173 | TPS6586X_REGULATOR(_id, rw, _pname, vdata, vreg, shift, nbits, \ |
157 | ereg0, ebit0, ereg1, ebit1, goreg, gobit) \ | 174 | ereg0, ebit0, ereg1, ebit1, goreg, gobit) \ |
158 | } | 175 | } |
159 | 176 | ||