[PATCH v7 2/3] clk: introduce the common clock framework
mturquette at ti.com
Fri Mar 23 23:28:16 UTC 2012
On Fri, Mar 23, 2012 at 4:04 PM, Saravana Kannan <skannan at codeaurora.org> wrote:
> On 03/23/2012 03:32 PM, Turquette, Mike wrote:
>> .recalc_rate serves two purposes: first it recalculates the rate after
>> the rate has changed and you pass in a new parent_rate argument. The
>> second purpose is to "speculate" a rate change. You can pass in any
>> rate for the parent_rate parameter when you call .recalc_rates. This
>> is what __speculate_rates does before the rate changes. For
>> clk_set_parent we call,
>> __clk_speculate_rates(clk, parent->rate);
>> Where parent above is the *new* parent. So this will let us propagate
>> pre-rate change notifiers with the new rate.
>> Your .recalc_rate callback doesn't need to differentiate between the
>> two calls to .recalc_rate. It should just take in the parent_rate
>> value and do the calculation required of it.
> Yeah, this is generally true. But, in this specific case, the clock is a mux
> that can literally measure the real rate. I would like the rate of this mux
> clock to be the real measured rate and not just the parent rate.
That's pretty cool hardware. Do you find that software-only tracking
doesn't match up with sampling the frequency in hardware? If software
tracking of the rate changes is correct then you could just skip using
this hardware feature.
> I could actually measure the current rate and return that for recalc_rate(),
> but then the reported rate change during the pre-change notification would
> be wrong. Having the "msg" will let us at least fake the rate correctly for
> pre change notifiers.
In previous series I had separate .recalc_rate and .speculate_rate
callbacks. I merged them since they were almost identical. I'd
prefer not to reintroduce them since it creates a burden on others to
support seperate callbacks, and passing in the message is one way to
solve that... I'll think on this a bit more.
> How does a child (or grand child) clock (not a driver using the clock)
> reject a rate change if it know it can't handle that freq from the parent? I
> won't claim to know this part of the code thoroughly, but I can't find an
> easy way to do this.
Technically you could subscribe a notifier to your grand-child clock,
even if there is no driver for it. The same code that implements your
platform's clock operations could register the notifier handler.
You can see how this works in clk_propagate_rate_change. That usage
is certainly targeted more at drivers but could be made to work for
your case. Let me know what you think; this is an interesting issue.
> Reason for rejection could be things like the counter (for division, etc)
> has an upper limit on how fast it can run.
Are you hitting this in practice today? The clock framework shouldn't
be a perfect piece of code that can validate every possible
combination imaginable. Some burden falls on the code calling the clk
api (especially if that code is platform code) to make sure that it
doesn't do stupid things.
>>> Also, I noticed that clk_set_parent() is treating a NULL as an invalid
>>> clock. Should that be fixed? set_parent(NULL) could be treated as a
>>> grounding the clock. Should we let the ops->set_parent determine if NULL
>>> valid option?
>> We must be looking at different code. clk_set_parent doesn't return
>> any error if parent == NULL. Bringing this to my attention does show
>> that we do deref the parent pointer without a check though...
>> Do you have a real use case for this? Due to the way that we match
>> the parent pointer with the cached clk->parents member it would be
>> painful to support NULL parents as valid.
> I don't have a real use case for MSM. We just have a ground_clock.
I'm electing to ignore the issue until we have a real use-case for it.
More information about the linaro-dev