pwm: atmel-hlcdc: Don't use pwm consumer API
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Fri, 26 Jan 2024 12:04:34 +0000 (13:04 +0100)
committerUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Thu, 15 Feb 2024 11:28:02 +0000 (12:28 +0100)
Lowlevel driver callbacks are not supposed to use the consumer API
functions. Currently this works, but with the upcoming locking changes
this probably results in dead locks.

Reviewed-by: Claudiu Beznea <claudiu.beznea@tuxon.dev>
Link: https://lore.kernel.org/r/6e34607828b290cd64ca9f82df40872853069f07.1706269232.git.u.kleine-koenig@pengutronix.de
Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
drivers/pwm/pwm-atmel-hlcdc.c

index 1f6fc9a9fcf3ece292a530005388965e749afe9f..2d64af045fc5ab77baa99f1644ff257ab976d153 100644 (file)
@@ -183,9 +183,10 @@ static const struct atmel_hlcdc_pwm_errata atmel_hlcdc_pwm_sama5d3_errata = {
 static int atmel_hlcdc_pwm_suspend(struct device *dev)
 {
        struct atmel_hlcdc_pwm *atmel = dev_get_drvdata(dev);
+       struct pwm_device *pwm = &atmel->chip.pwms[0];
 
        /* Keep the periph clock enabled if the PWM is still running. */
-       if (!pwm_is_enabled(&atmel->chip.pwms[0]))
+       if (!pwm->state.enabled)
                clk_disable_unprepare(atmel->hlcdc->periph_clk);
 
        return 0;
@@ -194,20 +195,17 @@ static int atmel_hlcdc_pwm_suspend(struct device *dev)
 static int atmel_hlcdc_pwm_resume(struct device *dev)
 {
        struct atmel_hlcdc_pwm *atmel = dev_get_drvdata(dev);
-       struct pwm_state state;
+       struct pwm_device *pwm = &atmel->chip.pwms[0];
        int ret;
 
-       pwm_get_state(&atmel->chip.pwms[0], &state);
-
        /* Re-enable the periph clock it was stopped during suspend. */
-       if (!state.enabled) {
+       if (!pwm->state.enabled) {
                ret = clk_prepare_enable(atmel->hlcdc->periph_clk);
                if (ret)
                        return ret;
        }
 
-       return atmel_hlcdc_pwm_apply(&atmel->chip, &atmel->chip.pwms[0],
-                                    &state);
+       return atmel_hlcdc_pwm_apply(&atmel->chip, pwm, &pwm->state);
 }
 
 static DEFINE_SIMPLE_DEV_PM_OPS(atmel_hlcdc_pwm_pm_ops,