aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/regulator/s5m8767.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/regulator/s5m8767.c')
-rw-r--r--drivers/regulator/s5m8767.c33
1 files changed, 10 insertions, 23 deletions
diff --git a/drivers/regulator/s5m8767.c b/drivers/regulator/s5m8767.c
index 33b65c9ad5d5..94b8e484ef90 100644
--- a/drivers/regulator/s5m8767.c
+++ b/drivers/regulator/s5m8767.c
@@ -323,16 +323,15 @@ static int s5m8767_get_voltage_sel(struct regulator_dev *rdev)
323 return val; 323 return val;
324} 324}
325 325
326static int s5m8767_convert_voltage_to_sel( 326static int s5m8767_convert_voltage_to_sel(const struct sec_voltage_desc *desc,
327 const struct sec_voltage_desc *desc, 327 int min_vol)
328 int min_vol, int max_vol)
329{ 328{
330 int selector = 0; 329 int selector = 0;
331 330
332 if (desc == NULL) 331 if (desc == NULL)
333 return -EINVAL; 332 return -EINVAL;
334 333
335 if (max_vol < desc->min || min_vol > desc->max) 334 if (min_vol > desc->max)
336 return -EINVAL; 335 return -EINVAL;
337 336
338 if (min_vol < desc->min) 337 if (min_vol < desc->min)
@@ -340,7 +339,7 @@ static int s5m8767_convert_voltage_to_sel(
340 339
341 selector = DIV_ROUND_UP(min_vol - desc->min, desc->step); 340 selector = DIV_ROUND_UP(min_vol - desc->min, desc->step);
342 341
343 if (desc->min + desc->step * selector > max_vol) 342 if (desc->min + desc->step * selector > desc->max)
344 return -EINVAL; 343 return -EINVAL;
345 344
346 return selector; 345 return selector;
@@ -577,23 +576,17 @@ static int s5m8767_pmic_probe(struct platform_device *pdev)
577 s5m8767->opmode = pdata->opmode; 576 s5m8767->opmode = pdata->opmode;
578 577
579 buck_init = s5m8767_convert_voltage_to_sel(&buck_voltage_val2, 578 buck_init = s5m8767_convert_voltage_to_sel(&buck_voltage_val2,
580 pdata->buck2_init, 579 pdata->buck2_init);
581 pdata->buck2_init +
582 buck_voltage_val2.step);
583 580
584 sec_reg_write(s5m8767->iodev, S5M8767_REG_BUCK2DVS2, buck_init); 581 sec_reg_write(s5m8767->iodev, S5M8767_REG_BUCK2DVS2, buck_init);
585 582
586 buck_init = s5m8767_convert_voltage_to_sel(&buck_voltage_val2, 583 buck_init = s5m8767_convert_voltage_to_sel(&buck_voltage_val2,
587 pdata->buck3_init, 584 pdata->buck3_init);
588 pdata->buck3_init +
589 buck_voltage_val2.step);
590 585
591 sec_reg_write(s5m8767->iodev, S5M8767_REG_BUCK3DVS2, buck_init); 586 sec_reg_write(s5m8767->iodev, S5M8767_REG_BUCK3DVS2, buck_init);
592 587
593 buck_init = s5m8767_convert_voltage_to_sel(&buck_voltage_val2, 588 buck_init = s5m8767_convert_voltage_to_sel(&buck_voltage_val2,
594 pdata->buck4_init, 589 pdata->buck4_init);
595 pdata->buck4_init +
596 buck_voltage_val2.step);
597 590
598 sec_reg_write(s5m8767->iodev, S5M8767_REG_BUCK4DVS2, buck_init); 591 sec_reg_write(s5m8767->iodev, S5M8767_REG_BUCK4DVS2, buck_init);
599 592
@@ -602,27 +595,21 @@ static int s5m8767_pmic_probe(struct platform_device *pdev)
602 s5m8767->buck2_vol[i] = 595 s5m8767->buck2_vol[i] =
603 s5m8767_convert_voltage_to_sel( 596 s5m8767_convert_voltage_to_sel(
604 &buck_voltage_val2, 597 &buck_voltage_val2,
605 pdata->buck2_voltage[i], 598 pdata->buck2_voltage[i]);
606 pdata->buck2_voltage[i] +
607 buck_voltage_val2.step);
608 } 599 }
609 600
610 if (s5m8767->buck3_gpiodvs) { 601 if (s5m8767->buck3_gpiodvs) {
611 s5m8767->buck3_vol[i] = 602 s5m8767->buck3_vol[i] =
612 s5m8767_convert_voltage_to_sel( 603 s5m8767_convert_voltage_to_sel(
613 &buck_voltage_val2, 604 &buck_voltage_val2,
614 pdata->buck3_voltage[i], 605 pdata->buck3_voltage[i]);
615 pdata->buck3_voltage[i] +
616 buck_voltage_val2.step);
617 } 606 }
618 607
619 if (s5m8767->buck4_gpiodvs) { 608 if (s5m8767->buck4_gpiodvs) {
620 s5m8767->buck4_vol[i] = 609 s5m8767->buck4_vol[i] =
621 s5m8767_convert_voltage_to_sel( 610 s5m8767_convert_voltage_to_sel(
622 &buck_voltage_val2, 611 &buck_voltage_val2,
623 pdata->buck4_voltage[i], 612 pdata->buck4_voltage[i]);
624 pdata->buck4_voltage[i] +
625 buck_voltage_val2.step);
626 } 613 }
627 } 614 }
628 615