Message ID | 20210731195034.979084-3-dmitry.baryshkov@linaro.org |
---|---|
State | Accepted |
Commit | a649136b17af6361355874a10e9219390c266a2c |
Headers | show |
Series | [v3,1/3] PM: runtime: add devm_pm_runtime_enable helper | expand |
Hi Dmitry, Thanks for your patch! On Sat, Jul 31, 2021 at 9:51 PM Dmitry Baryshkov <dmitry.baryshkov@linaro.org> wrote: > A typical code pattern for pm_clk_create() call is to call it in the > _probe function and to call pm_clk_destroy() both from _probe error path > and from _remove function. For some drivers the whole remove function > would consist of the call to pm_remove_disable(). Is it? I could find only one (drivers/clk/mmp/clk-audio.c). All other users call it from their PM Domain .attach_dev() callback, which cannot become managed. > Add helper function to replace this bolierplate piece of code. Calling > devm_pm_clk_create() removes the need for calling pm_clk_destroy() both > in the probe()'s error path and in the remove() function. > > Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> Gr{oetje,eeting}s, Geert
diff --git a/drivers/base/power/clock_ops.c b/drivers/base/power/clock_ops.c index 0251f3e6e61d..4110c19c08dc 100644 --- a/drivers/base/power/clock_ops.c +++ b/drivers/base/power/clock_ops.c @@ -519,6 +519,23 @@ void pm_clk_destroy(struct device *dev) } EXPORT_SYMBOL_GPL(pm_clk_destroy); +static void pm_clk_destroy_action(void *data) +{ + pm_clk_destroy(data); +} + +int devm_pm_clk_create(struct device *dev) +{ + int ret; + + ret = pm_clk_create(dev); + if (ret) + return ret; + + return devm_add_action_or_reset(dev, pm_clk_destroy_action, dev); +} +EXPORT_SYMBOL_GPL(devm_pm_clk_create); + /** * pm_clk_suspend - Disable clocks in a device's PM clock list. * @dev: Device to disable the clocks for. diff --git a/include/linux/pm_clock.h b/include/linux/pm_clock.h index 8ddc7860e131..ada3a0ab10bf 100644 --- a/include/linux/pm_clock.h +++ b/include/linux/pm_clock.h @@ -47,6 +47,7 @@ extern void pm_clk_remove(struct device *dev, const char *con_id); extern void pm_clk_remove_clk(struct device *dev, struct clk *clk); extern int pm_clk_suspend(struct device *dev); extern int pm_clk_resume(struct device *dev); +extern int devm_pm_clk_create(struct device *dev); #else static inline bool pm_clk_no_clocks(struct device *dev) { @@ -83,6 +84,10 @@ static inline void pm_clk_remove(struct device *dev, const char *con_id) static inline void pm_clk_remove_clk(struct device *dev, struct clk *clk) { } +static inline int devm_pm_clk_create(struct device *dev) +{ + return -EINVAL; +} #endif #ifdef CONFIG_HAVE_CLK
A typical code pattern for pm_clk_create() call is to call it in the _probe function and to call pm_clk_destroy() both from _probe error path and from _remove function. For some drivers the whole remove function would consist of the call to pm_remove_disable(). Add helper function to replace this bolierplate piece of code. Calling devm_pm_clk_create() removes the need for calling pm_clk_destroy() both in the probe()'s error path and in the remove() function. Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org> --- drivers/base/power/clock_ops.c | 17 +++++++++++++++++ include/linux/pm_clock.h | 5 +++++ 2 files changed, 22 insertions(+) -- 2.30.2