Commit 24478839 authored by Miquel Raynal's avatar Miquel Raynal Committed by Stephen Boyd

clk: core: clarify the check for runtime PM

Currently, the core->dev entry is populated only if runtime PM is
enabled. Doing so prevents accessing the device structure in any
case.

Keep the same logic but instead of using the presence of core->dev as
the only condition, also check the status of
pm_runtime_enabled(). Then, we can set the core->dev pointer at any
time as long as a device structure is available.

This change will help supporting device links in the clock subsystem.
Signed-off-by: default avatarMiquel Raynal <miquel.raynal@bootlin.com>
Cc: Jerome Brunet <jbrunet@baylibre.com>
Cc: Russell King <linux@armlinux.org.uk>
Cc: Michael Turquette <mturquette@baylibre.com>
Cc: Jeffrey Hugo <jhugo@codeaurora.org>
Cc: Chen-Yu Tsai <wens@csie.org>
[sboyd@kernel.org: Change to a boolean flag]
Signed-off-by: default avatarStephen Boyd <sboyd@kernel.org>
parent 1df4046a
...@@ -57,6 +57,7 @@ struct clk_core { ...@@ -57,6 +57,7 @@ struct clk_core {
struct clk_core *new_child; struct clk_core *new_child;
unsigned long flags; unsigned long flags;
bool orphan; bool orphan;
bool rpm_enabled;
unsigned int enable_count; unsigned int enable_count;
unsigned int prepare_count; unsigned int prepare_count;
unsigned int protect_count; unsigned int protect_count;
...@@ -92,9 +93,9 @@ struct clk { ...@@ -92,9 +93,9 @@ struct clk {
/*** runtime pm ***/ /*** runtime pm ***/
static int clk_pm_runtime_get(struct clk_core *core) static int clk_pm_runtime_get(struct clk_core *core)
{ {
int ret = 0; int ret;
if (!core->dev) if (!core->rpm_enabled)
return 0; return 0;
ret = pm_runtime_get_sync(core->dev); ret = pm_runtime_get_sync(core->dev);
...@@ -103,7 +104,7 @@ static int clk_pm_runtime_get(struct clk_core *core) ...@@ -103,7 +104,7 @@ static int clk_pm_runtime_get(struct clk_core *core)
static void clk_pm_runtime_put(struct clk_core *core) static void clk_pm_runtime_put(struct clk_core *core)
{ {
if (!core->dev) if (!core->rpm_enabled)
return; return;
pm_runtime_put_sync(core->dev); pm_runtime_put_sync(core->dev);
...@@ -223,7 +224,7 @@ static bool clk_core_is_enabled(struct clk_core *core) ...@@ -223,7 +224,7 @@ static bool clk_core_is_enabled(struct clk_core *core)
* taking enable spinlock, but the below check is needed if one tries * taking enable spinlock, but the below check is needed if one tries
* to call it from other places. * to call it from other places.
*/ */
if (core->dev) { if (core->rpm_enabled) {
pm_runtime_get_noresume(core->dev); pm_runtime_get_noresume(core->dev);
if (!pm_runtime_active(core->dev)) { if (!pm_runtime_active(core->dev)) {
ret = false; ret = false;
...@@ -233,7 +234,7 @@ static bool clk_core_is_enabled(struct clk_core *core) ...@@ -233,7 +234,7 @@ static bool clk_core_is_enabled(struct clk_core *core)
ret = core->ops->is_enabled(core->hw); ret = core->ops->is_enabled(core->hw);
done: done:
if (core->dev) if (core->rpm_enabled)
pm_runtime_put(core->dev); pm_runtime_put(core->dev);
return ret; return ret;
...@@ -3341,6 +3342,7 @@ struct clk *clk_register(struct device *dev, struct clk_hw *hw) ...@@ -3341,6 +3342,7 @@ struct clk *clk_register(struct device *dev, struct clk_hw *hw)
core->ops = hw->init->ops; core->ops = hw->init->ops;
if (dev && pm_runtime_enabled(dev)) if (dev && pm_runtime_enabled(dev))
core->rpm_enabled = true;
core->dev = dev; core->dev = dev;
if (dev && dev->driver) if (dev && dev->driver)
core->owner = dev->driver->owner; core->owner = dev->driver->owner;
......
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