Commit b0cde62e authored by Uwe Kleine-König's avatar Uwe Kleine-König Committed by Stephen Boyd

clk: Add a devm variant of clk_rate_exclusive_get()

This allows to simplify drivers that use clk_rate_exclusive_get()
in their probe routine as calling clk_rate_exclusive_put() is cared for
automatically.
Signed-off-by: default avatarUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Link: https://lore.kernel.org/r/20240104225512.1124519-2-u.kleine-koenig@pengutronix.deAcked-by: default avatarRussell King (Oracle) <rmk+kernel@armlinux.org.uk>
Signed-off-by: default avatarStephen Boyd <sboyd@kernel.org>
parent 6613476e
......@@ -939,6 +939,25 @@ int clk_rate_exclusive_get(struct clk *clk)
}
EXPORT_SYMBOL_GPL(clk_rate_exclusive_get);
static void devm_clk_rate_exclusive_put(void *data)
{
struct clk *clk = data;
clk_rate_exclusive_put(clk);
}
int devm_clk_rate_exclusive_get(struct device *dev, struct clk *clk)
{
int ret;
ret = clk_rate_exclusive_get(clk);
if (ret)
return ret;
return devm_add_action_or_reset(dev, devm_clk_rate_exclusive_put, clk);
}
EXPORT_SYMBOL_GPL(devm_clk_rate_exclusive_get);
static void clk_core_unprepare(struct clk_core *core)
{
lockdep_assert_held(&prepare_lock);
......
......@@ -201,6 +201,18 @@ bool clk_is_match(const struct clk *p, const struct clk *q);
*/
int clk_rate_exclusive_get(struct clk *clk);
/**
* devm_clk_rate_exclusive_get - devm variant of clk_rate_exclusive_get
* @dev: device the exclusivity is bound to
* @clk: clock source
*
* Calls clk_rate_exclusive_get() on @clk and registers a devm cleanup handler
* on @dev to call clk_rate_exclusive_put().
*
* Must not be called from within atomic context.
*/
int devm_clk_rate_exclusive_get(struct device *dev, struct clk *clk);
/**
* clk_rate_exclusive_put - release exclusivity over the rate control of a
* producer
......
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