aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/regulator/da9055-regulator.c
diff options
context:
space:
mode:
authorAxel Lin <axel.lin@ingics.com>2012-11-26 21:26:14 -0500
committerMark Brown <broonie@opensource.wolfsonmicro.com>2012-11-27 15:11:19 -0500
commit6b1f8a45666877d4885c03d9472657fd73edfa8b (patch)
tree10706af5a7600cae428ba0cf4e18889a934bf60d /drivers/regulator/da9055-regulator.c
parent5979b2a35f0d67c09b385424674ece6ae9e3bda6 (diff)
regulator: da9055: Use linear_min_sel and regulator_[map|list]_voltage_linear
Signed-off-by: Axel Lin <axel.lin@ingics.com> Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'drivers/regulator/da9055-regulator.c')
-rw-r--r--drivers/regulator/da9055-regulator.c55
1 files changed, 8 insertions, 47 deletions
diff --git a/drivers/regulator/da9055-regulator.c b/drivers/regulator/da9055-regulator.c
index 121564bb5415..2253559703ce 100644
--- a/drivers/regulator/da9055-regulator.c
+++ b/drivers/regulator/da9055-regulator.c
@@ -57,7 +57,6 @@ struct da9055_volt_reg {
57 int reg_a; 57 int reg_a;
58 int reg_b; 58 int reg_b;
59 int sl_shift; 59 int sl_shift;
60 int v_offset;
61 int v_mask; 60 int v_mask;
62 int v_shift; 61 int v_shift;
63}; 62};
@@ -204,41 +203,6 @@ static int da9055_buck_set_current_limit(struct regulator_dev *rdev, int min_uA,
204 info->mode.mask, val << info->mode.shift); 203 info->mode.mask, val << info->mode.shift);
205} 204}
206 205
207static int da9055_list_voltage(struct regulator_dev *rdev, unsigned selector)
208{
209 struct da9055_regulator *regulator = rdev_get_drvdata(rdev);
210 struct da9055_regulator_info *info = regulator->info;
211
212 if (selector >= rdev->desc->n_voltages)
213 return -EINVAL;
214
215 if (selector < info->volt.v_offset)
216 return 0;
217
218 selector -= info->volt.v_offset;
219 return rdev->desc->min_uV + (rdev->desc->uV_step * selector);
220}
221
222static int da9055_map_voltage(struct regulator_dev *rdev, int min_uV,
223 int max_uV)
224{
225 struct da9055_regulator *regulator = rdev_get_drvdata(rdev);
226 struct da9055_regulator_info *info = regulator->info;
227 int sel, voltage;
228
229 if (min_uV < rdev->desc->min_uV)
230 min_uV = rdev->desc->min_uV;
231
232 sel = DIV_ROUND_UP(min_uV - rdev->desc->min_uV, rdev->desc->uV_step);
233 sel += info->volt.v_offset;
234
235 voltage = da9055_list_voltage(rdev, sel);
236 if (voltage < min_uV || voltage > max_uV)
237 return -EINVAL;
238
239 return sel;
240}
241
242static int da9055_regulator_get_voltage_sel(struct regulator_dev *rdev) 206static int da9055_regulator_get_voltage_sel(struct regulator_dev *rdev)
243{ 207{
244 struct da9055_regulator *regulator = rdev_get_drvdata(rdev); 208 struct da9055_regulator *regulator = rdev_get_drvdata(rdev);
@@ -267,10 +231,7 @@ static int da9055_regulator_get_voltage_sel(struct regulator_dev *rdev)
267 return ret; 231 return ret;
268 232
269 sel = (ret & volt.v_mask); 233 sel = (ret & volt.v_mask);
270 if (sel <= volt.v_offset) 234 return sel;
271 return 0;
272 else
273 return sel;
274} 235}
275 236
276static int da9055_regulator_set_voltage_sel(struct regulator_dev *rdev, 237static int da9055_regulator_set_voltage_sel(struct regulator_dev *rdev,
@@ -331,7 +292,7 @@ static int da9055_regulator_set_suspend_voltage(struct regulator_dev *rdev,
331 return ret; 292 return ret;
332 } 293 }
333 294
334 ret = da9055_map_voltage(rdev, uV, uV); 295 ret = regulator_map_voltage_linear(rdev, uV, uV);
335 if (ret < 0) 296 if (ret < 0)
336 return ret; 297 return ret;
337 298
@@ -374,8 +335,8 @@ static struct regulator_ops da9055_buck_ops = {
374 335
375 .get_voltage_sel = da9055_regulator_get_voltage_sel, 336 .get_voltage_sel = da9055_regulator_get_voltage_sel,
376 .set_voltage_sel = da9055_regulator_set_voltage_sel, 337 .set_voltage_sel = da9055_regulator_set_voltage_sel,
377 .list_voltage = da9055_list_voltage, 338 .list_voltage = regulator_list_voltage_linear,
378 .map_voltage = da9055_map_voltage, 339 .map_voltage = regulator_map_voltage_linear,
379 .is_enabled = regulator_is_enabled_regmap, 340 .is_enabled = regulator_is_enabled_regmap,
380 .enable = regulator_enable_regmap, 341 .enable = regulator_enable_regmap,
381 .disable = regulator_disable_regmap, 342 .disable = regulator_disable_regmap,
@@ -392,8 +353,8 @@ static struct regulator_ops da9055_ldo_ops = {
392 353
393 .get_voltage_sel = da9055_regulator_get_voltage_sel, 354 .get_voltage_sel = da9055_regulator_get_voltage_sel,
394 .set_voltage_sel = da9055_regulator_set_voltage_sel, 355 .set_voltage_sel = da9055_regulator_set_voltage_sel,
395 .list_voltage = da9055_list_voltage, 356 .list_voltage = regulator_list_voltage_linear,
396 .map_voltage = da9055_map_voltage, 357 .map_voltage = regulator_map_voltage_linear,
397 .is_enabled = regulator_is_enabled_regmap, 358 .is_enabled = regulator_is_enabled_regmap,
398 .enable = regulator_enable_regmap, 359 .enable = regulator_enable_regmap,
399 .disable = regulator_disable_regmap, 360 .disable = regulator_disable_regmap,
@@ -417,6 +378,7 @@ static struct regulator_ops da9055_ldo_ops = {
417 .enable_mask = 1, \ 378 .enable_mask = 1, \
418 .min_uV = (min) * 1000,\ 379 .min_uV = (min) * 1000,\
419 .uV_step = (step) * 1000,\ 380 .uV_step = (step) * 1000,\
381 .linear_min_sel = (voffset),\
420 .owner = THIS_MODULE,\ 382 .owner = THIS_MODULE,\
421 },\ 383 },\
422 .conf = {\ 384 .conf = {\
@@ -428,7 +390,6 @@ static struct regulator_ops da9055_ldo_ops = {
428 .reg_a = DA9055_REG_VBCORE_A + DA9055_ID_##_id, \ 390 .reg_a = DA9055_REG_VBCORE_A + DA9055_ID_##_id, \
429 .reg_b = DA9055_REG_VBCORE_B + DA9055_ID_##_id, \ 391 .reg_b = DA9055_REG_VBCORE_B + DA9055_ID_##_id, \
430 .sl_shift = 7,\ 392 .sl_shift = 7,\
431 .v_offset = (voffset),\
432 .v_mask = (1 << (vbits)) - 1,\ 393 .v_mask = (1 << (vbits)) - 1,\
433 .v_shift = (vbits),\ 394 .v_shift = (vbits),\
434 },\ 395 },\
@@ -446,6 +407,7 @@ static struct regulator_ops da9055_ldo_ops = {
446 .enable_mask = 1,\ 407 .enable_mask = 1,\
447 .min_uV = (min) * 1000,\ 408 .min_uV = (min) * 1000,\
448 .uV_step = (step) * 1000,\ 409 .uV_step = (step) * 1000,\
410 .linear_min_sel = (voffset),\
449 .owner = THIS_MODULE,\ 411 .owner = THIS_MODULE,\
450 },\ 412 },\
451 .conf = {\ 413 .conf = {\
@@ -457,7 +419,6 @@ static struct regulator_ops da9055_ldo_ops = {
457 .reg_a = DA9055_REG_VBCORE_A + DA9055_ID_##_id, \ 419 .reg_a = DA9055_REG_VBCORE_A + DA9055_ID_##_id, \
458 .reg_b = DA9055_REG_VBCORE_B + DA9055_ID_##_id, \ 420 .reg_b = DA9055_REG_VBCORE_B + DA9055_ID_##_id, \
459 .sl_shift = 7,\ 421 .sl_shift = 7,\
460 .v_offset = (voffset),\
461 .v_mask = (1 << (vbits)) - 1,\ 422 .v_mask = (1 << (vbits)) - 1,\
462 .v_shift = (vbits),\ 423 .v_shift = (vbits),\
463 },\ 424 },\