diff options
author | Alberto Panizzo <maramaopercheseimorto@gmail.com> | 2009-12-14 12:26:38 -0500 |
---|---|---|
committer | Liam Girdwood <lrg@slimlogic.co.uk> | 2010-03-03 09:49:22 -0500 |
commit | 1bd588fd9d2611d2573066f49477fb5be2aa13de (patch) | |
tree | bf24eb18a4eb47843f19ecd7874bb0f24c6995b7 /drivers/regulator/mc13783-regulator.c | |
parent | 3a5b27bf6f29574d667230c7e76e4b83fe3014e0 (diff) |
regulator: add voltage selection capability to mc13783 regulators v2 .
This patch, complete the mc13783 regulator subsystem driver with
voltage selecting capability.
Main Switches (SW1AB, SW2AB) are not supported yet.
version 2 diffs:
- delete the "Switchers PLL" enable and multiplication factor value
selecting capability because it is not a voltage or current regulator.
This will be a part of Main switcher supporting task.
- Correct many coding style problems pointed me out.
Signed-off-by: Alberto Panizzo <maramaopercheseimorto@gmail.com>
Acked-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Signed-off-by: Liam Girdwood <lrg@slimlogic.co.uk>
Diffstat (limited to 'drivers/regulator/mc13783-regulator.c')
-rw-r--r-- | drivers/regulator/mc13783-regulator.c | 345 |
1 files changed, 315 insertions, 30 deletions
diff --git a/drivers/regulator/mc13783-regulator.c b/drivers/regulator/mc13783-regulator.c index 39c495300045..a40e35ab8555 100644 --- a/drivers/regulator/mc13783-regulator.c +++ b/drivers/regulator/mc13783-regulator.c | |||
@@ -2,6 +2,7 @@ | |||
2 | * Regulator Driver for Freescale MC13783 PMIC | 2 | * Regulator Driver for Freescale MC13783 PMIC |
3 | * | 3 | * |
4 | * Copyright (C) 2008 Sascha Hauer, Pengutronix <s.hauer@pengutronix.de> | 4 | * Copyright (C) 2008 Sascha Hauer, Pengutronix <s.hauer@pengutronix.de> |
5 | * Copyright 2009 Alberto Panizzo <maramaopercheseimorto@gmail.com> | ||
5 | * | 6 | * |
6 | * This program is free software; you can redistribute it and/or modify | 7 | * This program is free software; you can redistribute it and/or modify |
7 | * it under the terms of the GNU General Public License version 2 as | 8 | * it under the terms of the GNU General Public License version 2 as |
@@ -16,11 +17,44 @@ | |||
16 | #include <linux/init.h> | 17 | #include <linux/init.h> |
17 | #include <linux/err.h> | 18 | #include <linux/err.h> |
18 | 19 | ||
19 | #define MC13783_REG_SWITCHERS4 28 | ||
20 | #define MC13783_REG_SWITCHERS4_PLLEN (1 << 18) | ||
21 | |||
22 | #define MC13783_REG_SWITCHERS5 29 | 20 | #define MC13783_REG_SWITCHERS5 29 |
23 | #define MC13783_REG_SWITCHERS5_SW3EN (1 << 20) | 21 | #define MC13783_REG_SWITCHERS5_SW3EN (1 << 20) |
22 | #define MC13783_REG_SWITCHERS5_SW3VSEL 18 | ||
23 | #define MC13783_REG_SWITCHERS5_SW3VSEL_M (3 << 18) | ||
24 | |||
25 | #define MC13783_REG_REGULATORSETTING0 30 | ||
26 | #define MC13783_REG_REGULATORSETTING0_VIOLOVSEL 2 | ||
27 | #define MC13783_REG_REGULATORSETTING0_VDIGVSEL 4 | ||
28 | #define MC13783_REG_REGULATORSETTING0_VGENVSEL 6 | ||
29 | #define MC13783_REG_REGULATORSETTING0_VRFDIGVSEL 9 | ||
30 | #define MC13783_REG_REGULATORSETTING0_VRFREFVSEL 11 | ||
31 | #define MC13783_REG_REGULATORSETTING0_VRFCPVSEL 13 | ||
32 | #define MC13783_REG_REGULATORSETTING0_VSIMVSEL 14 | ||
33 | #define MC13783_REG_REGULATORSETTING0_VESIMVSEL 15 | ||
34 | #define MC13783_REG_REGULATORSETTING0_VCAMVSEL 16 | ||
35 | |||
36 | #define MC13783_REG_REGULATORSETTING0_VIOLOVSEL_M (3 << 2) | ||
37 | #define MC13783_REG_REGULATORSETTING0_VDIGVSEL_M (3 << 4) | ||
38 | #define MC13783_REG_REGULATORSETTING0_VGENVSEL_M (7 << 6) | ||
39 | #define MC13783_REG_REGULATORSETTING0_VRFDIGVSEL_M (3 << 9) | ||
40 | #define MC13783_REG_REGULATORSETTING0_VRFREFVSEL_M (3 << 11) | ||
41 | #define MC13783_REG_REGULATORSETTING0_VRFCPVSEL_M (1 << 13) | ||
42 | #define MC13783_REG_REGULATORSETTING0_VSIMVSEL_M (1 << 14) | ||
43 | #define MC13783_REG_REGULATORSETTING0_VESIMVSEL_M (1 << 15) | ||
44 | #define MC13783_REG_REGULATORSETTING0_VCAMVSEL_M (7 << 16) | ||
45 | |||
46 | #define MC13783_REG_REGULATORSETTING1 31 | ||
47 | #define MC13783_REG_REGULATORSETTING1_VVIBVSEL 0 | ||
48 | #define MC13783_REG_REGULATORSETTING1_VRF1VSEL 2 | ||
49 | #define MC13783_REG_REGULATORSETTING1_VRF2VSEL 4 | ||
50 | #define MC13783_REG_REGULATORSETTING1_VMMC1VSEL 6 | ||
51 | #define MC13783_REG_REGULATORSETTING1_VMMC2VSEL 9 | ||
52 | |||
53 | #define MC13783_REG_REGULATORSETTING1_VVIBVSEL_M (3 << 0) | ||
54 | #define MC13783_REG_REGULATORSETTING1_VRF1VSEL_M (3 << 2) | ||
55 | #define MC13783_REG_REGULATORSETTING1_VRF2VSEL_M (3 << 4) | ||
56 | #define MC13783_REG_REGULATORSETTING1_VMMC1VSEL_M (7 << 6) | ||
57 | #define MC13783_REG_REGULATORSETTING1_VMMC2VSEL_M (7 << 9) | ||
24 | 58 | ||
25 | #define MC13783_REG_REGULATORMODE0 32 | 59 | #define MC13783_REG_REGULATORMODE0 32 |
26 | #define MC13783_REG_REGULATORMODE0_VAUDIOEN (1 << 0) | 60 | #define MC13783_REG_REGULATORMODE0_VAUDIOEN (1 << 0) |
@@ -53,14 +87,88 @@ struct mc13783_regulator { | |||
53 | struct regulator_desc desc; | 87 | struct regulator_desc desc; |
54 | int reg; | 88 | int reg; |
55 | int enable_bit; | 89 | int enable_bit; |
90 | int vsel_reg; | ||
91 | int vsel_shift; | ||
92 | int vsel_mask; | ||
93 | int const *voltages; | ||
94 | }; | ||
95 | |||
96 | /* Voltage Values */ | ||
97 | static const int const mc13783_sw3_val[] = { | ||
98 | 5000000, 5000000, 5000000, 5500000, | ||
99 | }; | ||
100 | |||
101 | static const int const mc13783_vaudio_val[] = { | ||
102 | 2775000, | ||
103 | }; | ||
104 | |||
105 | static const int const mc13783_viohi_val[] = { | ||
106 | 2775000, | ||
107 | }; | ||
108 | |||
109 | static const int const mc13783_violo_val[] = { | ||
110 | 1200000, 1300000, 1500000, 1800000, | ||
111 | }; | ||
112 | |||
113 | static const int const mc13783_vdig_val[] = { | ||
114 | 1200000, 1300000, 1500000, 1800000, | ||
115 | }; | ||
116 | |||
117 | static const int const mc13783_vgen_val[] = { | ||
118 | 1200000, 1300000, 1500000, 1800000, | ||
119 | 1100000, 2000000, 2775000, 2400000, | ||
120 | }; | ||
121 | |||
122 | static const int const mc13783_vrfdig_val[] = { | ||
123 | 1200000, 1500000, 1800000, 1875000, | ||
124 | }; | ||
125 | |||
126 | static const int const mc13783_vrfref_val[] = { | ||
127 | 2475000, 2600000, 2700000, 2775000, | ||
128 | }; | ||
129 | |||
130 | static const int const mc13783_vrfcp_val[] = { | ||
131 | 2700000, 2775000, | ||
132 | }; | ||
133 | |||
134 | static const int const mc13783_vsim_val[] = { | ||
135 | 1800000, 2900000, 3000000, | ||
136 | }; | ||
137 | |||
138 | static const int const mc13783_vesim_val[] = { | ||
139 | 1800000, 2900000, | ||
140 | }; | ||
141 | |||
142 | static const int const mc13783_vcam_val[] = { | ||
143 | 1500000, 1800000, 2500000, 2550000, | ||
144 | 2600000, 2750000, 2800000, 3000000, | ||
145 | }; | ||
146 | |||
147 | static const int const mc13783_vrfbg_val[] = { | ||
148 | 1250000, | ||
149 | }; | ||
150 | |||
151 | static const int const mc13783_vvib_val[] = { | ||
152 | 1300000, 1800000, 2000000, 3000000, | ||
153 | }; | ||
154 | |||
155 | static const int const mc13783_vmmc_val[] = { | ||
156 | 1600000, 1800000, 2000000, 2600000, | ||
157 | 2700000, 2800000, 2900000, 3000000, | ||
158 | }; | ||
159 | |||
160 | static const int const mc13783_vrf_val[] = { | ||
161 | 1500000, 1875000, 2700000, 2775000, | ||
56 | }; | 162 | }; |
57 | 163 | ||
58 | static struct regulator_ops mc13783_regulator_ops; | 164 | static struct regulator_ops mc13783_regulator_ops; |
165 | static struct regulator_ops mc13783_fixed_regulator_ops; | ||
59 | 166 | ||
60 | #define MC13783_DEFINE(prefix, _name, _reg) \ | 167 | #define MC13783_DEFINE(prefix, _name, _reg, _vsel_reg, _voltages) \ |
61 | [MC13783_ ## prefix ## _ ## _name] = { \ | 168 | [MC13783_ ## prefix ## _ ## _name] = { \ |
62 | .desc = { \ | 169 | .desc = { \ |
63 | .name = #prefix "_" #_name, \ | 170 | .name = #prefix "_" #_name, \ |
171 | .n_voltages = ARRAY_SIZE(_voltages), \ | ||
64 | .ops = &mc13783_regulator_ops, \ | 172 | .ops = &mc13783_regulator_ops, \ |
65 | .type = REGULATOR_VOLTAGE, \ | 173 | .type = REGULATOR_VOLTAGE, \ |
66 | .id = MC13783_ ## prefix ## _ ## _name, \ | 174 | .id = MC13783_ ## prefix ## _ ## _name, \ |
@@ -68,36 +176,83 @@ static struct regulator_ops mc13783_regulator_ops; | |||
68 | }, \ | 176 | }, \ |
69 | .reg = MC13783_REG_ ## _reg, \ | 177 | .reg = MC13783_REG_ ## _reg, \ |
70 | .enable_bit = MC13783_REG_ ## _reg ## _ ## _name ## EN, \ | 178 | .enable_bit = MC13783_REG_ ## _reg ## _ ## _name ## EN, \ |
179 | .vsel_reg = MC13783_REG_ ## _vsel_reg, \ | ||
180 | .vsel_shift = MC13783_REG_ ## _vsel_reg ## _ ## _name ## VSEL,\ | ||
181 | .vsel_mask = MC13783_REG_ ## _vsel_reg ## _ ## _name ## VSEL_M,\ | ||
182 | .voltages = _voltages, \ | ||
71 | } | 183 | } |
72 | 184 | ||
73 | #define MC13783_DEFINE_SW(_name, _reg) MC13783_DEFINE(SW, _name, _reg) | 185 | #define MC13783_FIXED_DEFINE(prefix, _name, _reg, _voltages) \ |
74 | #define MC13783_DEFINE_REGU(_name, _reg) MC13783_DEFINE(REGU, _name, _reg) | 186 | [MC13783_ ## prefix ## _ ## _name] = { \ |
187 | .desc = { \ | ||
188 | .name = #prefix "_" #_name, \ | ||
189 | .n_voltages = ARRAY_SIZE(_voltages), \ | ||
190 | .ops = &mc13783_fixed_regulator_ops, \ | ||
191 | .type = REGULATOR_VOLTAGE, \ | ||
192 | .id = MC13783_ ## prefix ## _ ## _name, \ | ||
193 | .owner = THIS_MODULE, \ | ||
194 | }, \ | ||
195 | .reg = MC13783_REG_ ## _reg, \ | ||
196 | .enable_bit = MC13783_REG_ ## _reg ## _ ## _name ## EN, \ | ||
197 | .voltages = _voltages, \ | ||
198 | } | ||
199 | |||
200 | #define MC13783_GPO_DEFINE(prefix, _name, _reg) \ | ||
201 | [MC13783_ ## prefix ## _ ## _name] = { \ | ||
202 | .desc = { \ | ||
203 | .name = #prefix "_" #_name, \ | ||
204 | .ops = &mc13783_regulator_ops, \ | ||
205 | .type = REGULATOR_VOLTAGE, \ | ||
206 | .id = MC13783_ ## prefix ## _ ## _name, \ | ||
207 | .owner = THIS_MODULE, \ | ||
208 | }, \ | ||
209 | .reg = MC13783_REG_ ## _reg, \ | ||
210 | .enable_bit = MC13783_REG_ ## _reg ## _ ## _name ## EN, \ | ||
211 | } | ||
212 | |||
213 | #define MC13783_DEFINE_SW(_name, _reg, _vsel_reg, _voltages) \ | ||
214 | MC13783_DEFINE(SW, _name, _reg, _vsel_reg, _voltages) | ||
215 | #define MC13783_DEFINE_REGU(_name, _reg, _vsel_reg, _voltages) \ | ||
216 | MC13783_DEFINE(REGU, _name, _reg, _vsel_reg, _voltages) | ||
75 | 217 | ||
76 | static struct mc13783_regulator mc13783_regulators[] = { | 218 | static struct mc13783_regulator mc13783_regulators[] = { |
77 | MC13783_DEFINE_SW(SW3, SWITCHERS5), | 219 | MC13783_DEFINE_SW(SW3, SWITCHERS5, SWITCHERS5, mc13783_sw3_val), |
78 | MC13783_DEFINE_SW(PLL, SWITCHERS4), | 220 | |
79 | 221 | MC13783_FIXED_DEFINE(REGU, VAUDIO, REGULATORMODE0, mc13783_vaudio_val), | |
80 | MC13783_DEFINE_REGU(VAUDIO, REGULATORMODE0), | 222 | MC13783_FIXED_DEFINE(REGU, VIOHI, REGULATORMODE0, mc13783_viohi_val), |
81 | MC13783_DEFINE_REGU(VIOHI, REGULATORMODE0), | 223 | MC13783_DEFINE_REGU(VIOLO, REGULATORMODE0, REGULATORSETTING0, \ |
82 | MC13783_DEFINE_REGU(VIOLO, REGULATORMODE0), | 224 | mc13783_violo_val), |
83 | MC13783_DEFINE_REGU(VDIG, REGULATORMODE0), | 225 | MC13783_DEFINE_REGU(VDIG, REGULATORMODE0, REGULATORSETTING0, \ |
84 | MC13783_DEFINE_REGU(VGEN, REGULATORMODE0), | 226 | mc13783_vdig_val), |
85 | MC13783_DEFINE_REGU(VRFDIG, REGULATORMODE0), | 227 | MC13783_DEFINE_REGU(VGEN, REGULATORMODE0, REGULATORSETTING0, \ |
86 | MC13783_DEFINE_REGU(VRFREF, REGULATORMODE0), | 228 | mc13783_vgen_val), |
87 | MC13783_DEFINE_REGU(VRFCP, REGULATORMODE0), | 229 | MC13783_DEFINE_REGU(VRFDIG, REGULATORMODE0, REGULATORSETTING0, \ |
88 | MC13783_DEFINE_REGU(VSIM, REGULATORMODE1), | 230 | mc13783_vrfdig_val), |
89 | MC13783_DEFINE_REGU(VESIM, REGULATORMODE1), | 231 | MC13783_DEFINE_REGU(VRFREF, REGULATORMODE0, REGULATORSETTING0, \ |
90 | MC13783_DEFINE_REGU(VCAM, REGULATORMODE1), | 232 | mc13783_vrfref_val), |
91 | MC13783_DEFINE_REGU(VRFBG, REGULATORMODE1), | 233 | MC13783_DEFINE_REGU(VRFCP, REGULATORMODE0, REGULATORSETTING0, \ |
92 | MC13783_DEFINE_REGU(VVIB, REGULATORMODE1), | 234 | mc13783_vrfcp_val), |
93 | MC13783_DEFINE_REGU(VRF1, REGULATORMODE1), | 235 | MC13783_DEFINE_REGU(VSIM, REGULATORMODE1, REGULATORSETTING0, \ |
94 | MC13783_DEFINE_REGU(VRF2, REGULATORMODE1), | 236 | mc13783_vsim_val), |
95 | MC13783_DEFINE_REGU(VMMC1, REGULATORMODE1), | 237 | MC13783_DEFINE_REGU(VESIM, REGULATORMODE1, REGULATORSETTING0, \ |
96 | MC13783_DEFINE_REGU(VMMC2, REGULATORMODE1), | 238 | mc13783_vesim_val), |
97 | MC13783_DEFINE_REGU(GPO1, POWERMISC), | 239 | MC13783_DEFINE_REGU(VCAM, REGULATORMODE1, REGULATORSETTING0, \ |
98 | MC13783_DEFINE_REGU(GPO2, POWERMISC), | 240 | mc13783_vcam_val), |
99 | MC13783_DEFINE_REGU(GPO3, POWERMISC), | 241 | MC13783_FIXED_DEFINE(REGU, VRFBG, REGULATORMODE1, mc13783_vrfbg_val), |
100 | MC13783_DEFINE_REGU(GPO4, POWERMISC), | 242 | MC13783_DEFINE_REGU(VVIB, REGULATORMODE1, REGULATORSETTING1, \ |
243 | mc13783_vvib_val), | ||
244 | MC13783_DEFINE_REGU(VRF1, REGULATORMODE1, REGULATORSETTING1, \ | ||
245 | mc13783_vrf_val), | ||
246 | MC13783_DEFINE_REGU(VRF2, REGULATORMODE1, REGULATORSETTING1, \ | ||
247 | mc13783_vrf_val), | ||
248 | MC13783_DEFINE_REGU(VMMC1, REGULATORMODE1, REGULATORSETTING1, \ | ||
249 | mc13783_vmmc_val), | ||
250 | MC13783_DEFINE_REGU(VMMC2, REGULATORMODE1, REGULATORSETTING1, \ | ||
251 | mc13783_vmmc_val), | ||
252 | MC13783_GPO_DEFINE(REGU, GPO1, POWERMISC), | ||
253 | MC13783_GPO_DEFINE(REGU, GPO2, POWERMISC), | ||
254 | MC13783_GPO_DEFINE(REGU, GPO3, POWERMISC), | ||
255 | MC13783_GPO_DEFINE(REGU, GPO4, POWERMISC), | ||
101 | }; | 256 | }; |
102 | 257 | ||
103 | struct mc13783_regulator_priv { | 258 | struct mc13783_regulator_priv { |
@@ -154,10 +309,140 @@ static int mc13783_regulator_is_enabled(struct regulator_dev *rdev) | |||
154 | return (val & mc13783_regulators[id].enable_bit) != 0; | 309 | return (val & mc13783_regulators[id].enable_bit) != 0; |
155 | } | 310 | } |
156 | 311 | ||
312 | static int mc13783_regulator_list_voltage(struct regulator_dev *rdev, | ||
313 | unsigned selector) | ||
314 | { | ||
315 | int id = rdev_get_id(rdev); | ||
316 | |||
317 | if (selector >= mc13783_regulators[id].desc.n_voltages) | ||
318 | return -EINVAL; | ||
319 | |||
320 | return mc13783_regulators[id].voltages[selector]; | ||
321 | } | ||
322 | |||
323 | static int mc13783_get_best_voltage_index(struct regulator_dev *rdev, | ||
324 | int min_uV, int max_uV) | ||
325 | { | ||
326 | int reg_id = rdev_get_id(rdev); | ||
327 | int i; | ||
328 | int bestmatch; | ||
329 | int bestindex; | ||
330 | |||
331 | /* | ||
332 | * Locate the minimum voltage fitting the criteria on | ||
333 | * this regulator. The switchable voltages are not | ||
334 | * in strict falling order so we need to check them | ||
335 | * all for the best match. | ||
336 | */ | ||
337 | bestmatch = INT_MAX; | ||
338 | bestindex = -1; | ||
339 | for (i = 0; i < mc13783_regulators[reg_id].desc.n_voltages; i++) { | ||
340 | if (mc13783_regulators[reg_id].voltages[i] >= min_uV && | ||
341 | mc13783_regulators[reg_id].voltages[i] < bestmatch) { | ||
342 | bestmatch = mc13783_regulators[reg_id].voltages[i]; | ||
343 | bestindex = i; | ||
344 | } | ||
345 | } | ||
346 | |||
347 | if (bestindex < 0 || bestmatch > max_uV) { | ||
348 | dev_warn(&rdev->dev, "no possible value for %d<=x<=%d uV\n", | ||
349 | min_uV, max_uV); | ||
350 | return -EINVAL; | ||
351 | } | ||
352 | return bestindex; | ||
353 | } | ||
354 | |||
355 | static int mc13783_regulator_set_voltage(struct regulator_dev *rdev, | ||
356 | int min_uV, int max_uV) | ||
357 | { | ||
358 | struct mc13783_regulator_priv *priv = rdev_get_drvdata(rdev); | ||
359 | int value, id = rdev_get_id(rdev); | ||
360 | int ret; | ||
361 | |||
362 | dev_dbg(rdev_get_dev(rdev), "%s id: %d min_uV: %d max_uV: %d\n", | ||
363 | __func__, id, min_uV, max_uV); | ||
364 | |||
365 | /* Find the best index */ | ||
366 | value = mc13783_get_best_voltage_index(rdev, min_uV, max_uV); | ||
367 | dev_dbg(rdev_get_dev(rdev), "%s best value: %d \n", __func__, value); | ||
368 | if (value < 0) | ||
369 | return value; | ||
370 | |||
371 | mc13783_lock(priv->mc13783); | ||
372 | ret = mc13783_reg_rmw(priv->mc13783, mc13783_regulators[id].vsel_reg, | ||
373 | mc13783_regulators[id].vsel_mask, | ||
374 | value << mc13783_regulators[id].vsel_shift); | ||
375 | mc13783_unlock(priv->mc13783); | ||
376 | |||
377 | return ret; | ||
378 | } | ||
379 | |||
380 | static int mc13783_regulator_get_voltage(struct regulator_dev *rdev) | ||
381 | { | ||
382 | struct mc13783_regulator_priv *priv = rdev_get_drvdata(rdev); | ||
383 | int ret, id = rdev_get_id(rdev); | ||
384 | unsigned int val; | ||
385 | |||
386 | dev_dbg(rdev_get_dev(rdev), "%s id: %d\n", __func__, id); | ||
387 | |||
388 | mc13783_lock(priv->mc13783); | ||
389 | ret = mc13783_reg_read(priv->mc13783, | ||
390 | mc13783_regulators[id].vsel_reg, &val); | ||
391 | mc13783_unlock(priv->mc13783); | ||
392 | |||
393 | if (ret) | ||
394 | return ret; | ||
395 | |||
396 | val = (val & mc13783_regulators[id].vsel_mask) | ||
397 | >> mc13783_regulators[id].vsel_shift; | ||
398 | |||
399 | dev_dbg(rdev_get_dev(rdev), "%s id: %d val: %d\n", __func__, id, val); | ||
400 | |||
401 | BUG_ON(val < 0 || val > mc13783_regulators[id].desc.n_voltages); | ||
402 | |||
403 | return mc13783_regulators[id].voltages[val]; | ||
404 | } | ||
405 | |||
157 | static struct regulator_ops mc13783_regulator_ops = { | 406 | static struct regulator_ops mc13783_regulator_ops = { |
158 | .enable = mc13783_regulator_enable, | 407 | .enable = mc13783_regulator_enable, |
159 | .disable = mc13783_regulator_disable, | 408 | .disable = mc13783_regulator_disable, |
160 | .is_enabled = mc13783_regulator_is_enabled, | 409 | .is_enabled = mc13783_regulator_is_enabled, |
410 | .list_voltage = mc13783_regulator_list_voltage, | ||
411 | .set_voltage = mc13783_regulator_set_voltage, | ||
412 | .get_voltage = mc13783_regulator_get_voltage, | ||
413 | }; | ||
414 | |||
415 | static int mc13783_fixed_regulator_set_voltage(struct regulator_dev *rdev, | ||
416 | int min_uV, int max_uV) | ||
417 | { | ||
418 | int id = rdev_get_id(rdev); | ||
419 | |||
420 | dev_dbg(rdev_get_dev(rdev), "%s id: %d min_uV: %d max_uV: %d\n", | ||
421 | __func__, id, min_uV, max_uV); | ||
422 | |||
423 | if (min_uV > mc13783_regulators[id].voltages[0] && | ||
424 | max_uV < mc13783_regulators[id].voltages[0]) | ||
425 | return 0; | ||
426 | else | ||
427 | return -EINVAL; | ||
428 | } | ||
429 | |||
430 | static int mc13783_fixed_regulator_get_voltage(struct regulator_dev *rdev) | ||
431 | { | ||
432 | int id = rdev_get_id(rdev); | ||
433 | |||
434 | dev_dbg(rdev_get_dev(rdev), "%s id: %d\n", __func__, id); | ||
435 | |||
436 | return mc13783_regulators[id].voltages[0]; | ||
437 | } | ||
438 | |||
439 | static struct regulator_ops mc13783_fixed_regulator_ops = { | ||
440 | .enable = mc13783_regulator_enable, | ||
441 | .disable = mc13783_regulator_disable, | ||
442 | .is_enabled = mc13783_regulator_is_enabled, | ||
443 | .list_voltage = mc13783_regulator_list_voltage, | ||
444 | .set_voltage = mc13783_fixed_regulator_set_voltage, | ||
445 | .get_voltage = mc13783_fixed_regulator_get_voltage, | ||
161 | }; | 446 | }; |
162 | 447 | ||
163 | static int __devinit mc13783_regulator_probe(struct platform_device *pdev) | 448 | static int __devinit mc13783_regulator_probe(struct platform_device *pdev) |