On Tue, 27 Jun 2017, Dirk Behme wrote:
On 11.02.2016 01:43, Michael Turquette wrote:
Quoting Lee Jones (2016-01-18 06:28:50)
Signed-off-by: Lee Jones <lee.jones@xxxxxxxxxx>
Looks good to me.
drivers/clk/clk.c | 6 ++++++
1 file changed, 6 insertions(+)
diff --git a/drivers/clk/clk.c b/drivers/clk/clk.c
index 835cb85..178b364 100644
@@ -575,6 +575,9 @@ static void clk_core_unprepare(struct clk_core *core)
if (WARN_ON(core->prepare_count == 0))
+ if (WARN_ON(core->prepare_count == 1 && core->flags & CLK_IS_CRITICAL))
if (--core->prepare_count > 0)
@@ -680,6 +683,9 @@ static void clk_core_disable(struct clk_core *core)
if (WARN_ON(core->enable_count == 0))
+ if (WARN_ON(core->enable_count == 1 && core->flags & CLK_IS_CRITICAL))
if (--core->enable_count > 0)
I have a question regarding this patch, which is mainline meanwhile :
Having the following clock configuration:
|--> child clk '1' (crit)
clk source --> parent clk 'A' (crit) -->|
|--> child clk '2'
Clock '2' might be used, or not. It might be disabled or not. It doesn't
matter. Clock '1' is not allowed to be disabled. Therefore its marked as
Parent clock 'A' is marked as critical because its not allowed to be
disabled, even if the enable_count of all child clocks is 0. To avoid that
by disabling parent clock 'A' the child clock '1' is disabled, too, whats
not allowed as its marked as critical.
Now, child clock '2' is used and enabled & disabled continuously by a (SPI)
driver. What is ok. But:
Disabling child clock '2' results in the attempt to disable parent clock
'A', too, which has correct enable_count 1 (from enabling the child '2').
a) in the WARN_ON output
b) enable_count of 'A' never decreases to 0. Being off by one after the
It sounds like both is wrong for a configuration like above.
Clock A still has one user, Clock 1.
Why is that wrong?
Opinions or proposal how to fix/change this?