Commit 38c20eb2 authored by Axel Lin's avatar Axel Lin Committed by Mark Brown

regulator: wm8400: Use wm8400_ldo_list_voltage instead of open code to verify selected voltage

Call wm8400_ldo_list_voltage() instead of open code to verify selected voltage
falls within specified range.
Use wm8400_ldo_list_voltage() here is less error prone.
Signed-off-by: default avatarAxel Lin <axel.lin@gmail.com>
Signed-off-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
parent 3fe3a182
...@@ -35,27 +35,19 @@ static int wm8400_ldo_map_voltage(struct regulator_dev *dev, ...@@ -35,27 +35,19 @@ static int wm8400_ldo_map_voltage(struct regulator_dev *dev,
int min_uV, int max_uV) int min_uV, int max_uV)
{ {
u16 val; u16 val;
int volt;
if (min_uV < 900000 || min_uV > 3300000) if (min_uV < 900000 || min_uV > 3300000)
return -EINVAL; return -EINVAL;
if (min_uV < 1700000) { if (min_uV < 1700000) /* Steps of 50mV from 900mV; */
/* Steps of 50mV from 900mV; */
val = DIV_ROUND_UP(min_uV - 900000, 50000); val = DIV_ROUND_UP(min_uV - 900000, 50000);
else /* Steps of 100mV from 1700mV */
val = DIV_ROUND_UP(min_uV - 1700000, 100000) + 15;
if ((val * 50000) + 900000 > max_uV) volt = wm8400_ldo_list_voltage(dev, val);
return -EINVAL; if (volt < min_uV || volt > max_uV)
BUG_ON((val * 50000) + 900000 < min_uV); return -EINVAL;
} else {
/* Steps of 100mV from 1700mV */
val = DIV_ROUND_UP(min_uV - 1700000, 100000);
if ((val * 100000) + 1700000 > max_uV)
return -EINVAL;
BUG_ON((val * 100000) + 1700000 < min_uV);
val += 0xf;
}
return val; return val;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment