pwm: imx27: Only enable the clocks once in .get_state()
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Thu, 10 Jan 2019 19:33:53 +0000 (20:33 +0100)
committerThierry Reding <thierry.reding@gmail.com>
Mon, 4 Mar 2019 11:52:48 +0000 (12:52 +0100)
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: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: Thierry Reding <thierry.reding@gmail.com>
drivers/pwm/pwm-imx27.c

index 55666cc..8061306 100644 (file)
@@ -125,14 +125,10 @@ static void pwm_imx27_get_state(struct pwm_chip *chip,
 
        val = readl(imx->mmio_base + MX3_PWMCR);
 
-       if (val & MX3_PWMCR_EN) {
+       if (val & MX3_PWMCR_EN)
                state->enabled = true;
-               ret = pwm_imx27_clk_prepare_enable(chip);
-               if (ret)
-                       return;
-       } else {
+       else
                state->enabled = false;
-       }
 
        switch (FIELD_GET(MX3_PWMCR_POUTC, val)) {
        case MX3_PWMCR_POUTC_NORMAL:
@@ -164,7 +160,8 @@ static void pwm_imx27_get_state(struct pwm_chip *chip,
                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)