Commit 519ef9b5 authored by Uwe Kleine-König's avatar Uwe Kleine-König Committed by Thierry Reding

pwm: imx27: Only enable the clocks once in .get_state()

Currently the function pwm_imx27_get_state() of enables the clocks once
unconditionally at the start, a second time if the PWM is enabled and
disables unconditionally at the end.

Simplify that to enable once at the start and disable conditionally at
the end.
Signed-off-by: default avatarUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: default avatarThierry Reding <thierry.reding@gmail.com>
parent b4f9a726
...@@ -125,14 +125,10 @@ static void pwm_imx27_get_state(struct pwm_chip *chip, ...@@ -125,14 +125,10 @@ static void pwm_imx27_get_state(struct pwm_chip *chip,
val = readl(imx->mmio_base + MX3_PWMCR); val = readl(imx->mmio_base + MX3_PWMCR);
if (val & MX3_PWMCR_EN) { if (val & MX3_PWMCR_EN)
state->enabled = true; state->enabled = true;
ret = pwm_imx27_clk_prepare_enable(chip); else
if (ret)
return;
} else {
state->enabled = false; state->enabled = false;
}
switch (FIELD_GET(MX3_PWMCR_POUTC, val)) { switch (FIELD_GET(MX3_PWMCR_POUTC, val)) {
case MX3_PWMCR_POUTC_NORMAL: case MX3_PWMCR_POUTC_NORMAL:
...@@ -164,7 +160,8 @@ static void pwm_imx27_get_state(struct pwm_chip *chip, ...@@ -164,7 +160,8 @@ static void pwm_imx27_get_state(struct pwm_chip *chip,
state->duty_cycle = 0; state->duty_cycle = 0;
} }
pwm_imx27_clk_disable_unprepare(chip); if (!state->enabled)
pwm_imx27_clk_disable_unprepare(chip);
} }
static void pwm_imx27_sw_reset(struct pwm_chip *chip) static void pwm_imx27_sw_reset(struct pwm_chip *chip)
......
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