aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBoris Brezillon <boris.brezillon@free-electrons.com>2016-06-14 05:13:19 -0400
committerThierry Reding <thierry.reding@gmail.com>2016-07-11 02:43:24 -0400
commit87248991a1de28e73dc30057e82d831bc11cdd44 (patch)
tree7084e3d326418f80421fc2f01edcea0bdeffbbfd
parent3f4eb39be9b1402ea01a5c67441d0b0bcb74b4b2 (diff)
regulator: pwm: Properly initialize the ->state field
The ->state field is currently initialized to 0, thus referencing the voltage selector at index 0, which might not reflect the current voltage value. If possible, retrieve the current voltage selector from the PWM state, else return -EINVAL. Signed-off-by: Boris Brezillon <boris.brezillon@free-electrons.com> Tested-by: Brian Norris <briannorris@chromium.org> Tested-by: Heiko Stuebner <heiko@sntech.de> Acked-by: Mark Brown <broonie@kernel.org> Signed-off-by: Thierry Reding <thierry.reding@gmail.com>
-rw-r--r--drivers/regulator/pwm-regulator.c22
1 files changed, 22 insertions, 0 deletions
diff --git a/drivers/regulator/pwm-regulator.c b/drivers/regulator/pwm-regulator.c
index 7920411057af..7d26d3b0eed6 100644
--- a/drivers/regulator/pwm-regulator.c
+++ b/drivers/regulator/pwm-regulator.c
@@ -52,10 +52,31 @@ struct pwm_voltages {
52/** 52/**
53 * Voltage table call-backs 53 * Voltage table call-backs
54 */ 54 */
55static void pwm_regulator_init_state(struct regulator_dev *rdev)
56{
57 struct pwm_regulator_data *drvdata = rdev_get_drvdata(rdev);
58 struct pwm_state pwm_state;
59 unsigned int dutycycle;
60 int i;
61
62 pwm_get_state(drvdata->pwm, &pwm_state);
63 dutycycle = pwm_get_relative_duty_cycle(&pwm_state, 100);
64
65 for (i = 0; i < rdev->desc->n_voltages; i++) {
66 if (dutycycle == drvdata->duty_cycle_table[i].dutycycle) {
67 drvdata->state = i;
68 return;
69 }
70 }
71}
72
55static int pwm_regulator_get_voltage_sel(struct regulator_dev *rdev) 73static int pwm_regulator_get_voltage_sel(struct regulator_dev *rdev)
56{ 74{
57 struct pwm_regulator_data *drvdata = rdev_get_drvdata(rdev); 75 struct pwm_regulator_data *drvdata = rdev_get_drvdata(rdev);
58 76
77 if (drvdata->state < 0)
78 pwm_regulator_init_state(rdev);
79
59 return drvdata->state; 80 return drvdata->state;
60} 81}
61 82
@@ -221,6 +242,7 @@ static int pwm_regulator_init_table(struct platform_device *pdev,
221 return ret; 242 return ret;
222 } 243 }
223 244
245 drvdata->state = -EINVAL;
224 drvdata->duty_cycle_table = duty_cycle_table; 246 drvdata->duty_cycle_table = duty_cycle_table;
225 memcpy(&drvdata->ops, &pwm_regulator_voltage_table_ops, 247 memcpy(&drvdata->ops, &pwm_regulator_voltage_table_ops,
226 sizeof(drvdata->ops)); 248 sizeof(drvdata->ops));