Re: [PATCH 0/5] Clocklib: generic clocks framework
From: Dmitry
Date: Mon Apr 21 2008 - 04:49:18 EST
Hi, Paul,
2008/4/21, Paul Walmsley <paul@xxxxxxxxx>:
> Hello Dmitry,
>
> By way of introduction, I've been working on the Linux-OMAP clock tree
> over the past several months. I recently had the opportunity to take a
> brief look at these clocklib patches that you're posting, and had a few
> thoughts:
>
> - I understand from the discussions in this thread that the usage of your
> clocklib code will be optional. However, the way you implement various
> parts of the clock interface may effectively become mandatory, and
> clocklib may not be able to handle many of the platform-specific clock
> details that are necessary with more complex clock layouts like OMAP.
> Would you consider the main goal of your clocklib code to be simply the
> removal of several of the simpler ARM clock tree implementations? Or is
> your intention for it to ultimately replace all of the current Linux
> clock implementations? If the latter, your patchset will presumably
> need a higher standard of review, since once it is integrated, any
> changes will affect several architectures, rather than simply one.
Yes, I pretty much understand that. That's why I've posted the
patchserie to the LKML and added such long cc list full of arch.
maintainers. I hope it will be usefull not only to few arm arches, but
to a wide list of linux-supported systems.
I've reviewed the code for most linux/clk.h implementations in the
kernel. The OMAP code was... a bit scary for me. I don't have any deep
knowledge of this platform, and there were lots of structures, lots of
structs embedding struct clk, etc.
Tell me please, what do you need, that can't be done with this framework?
> - As others have mentioned earlier on this thread, it seems difficult to
> construct a good "one-size-fits-all" struct clk. At the very least,
> I would also suggest adding a 'void *' to allow storage of clock-specific
> data.
This was already discussed. It was suggested to use struct embedding
and container_of,
instead of pointers. If you do really need a pointer, you can writes
struct my_clk {
void *data;
struct clk clk;
};
> - Hiroshi DOYU has proposed an alternate debugfs implementation for the
> Linux-OMAP clock tree. I prefer it to yours, as it implements each
> clock as a separate dentry, which makes it easy to implement additional
> debugging functions, such as set_rate/set_parent/round_rate debugging.
> Perhaps you'd consider it, or something similar to it, instead? It is
> proposed here:
> http://www.mail-archive.com/linux-omap@xxxxxxxxxxxxxxx/msg00751.html
I'll look at this. However, if we are going to use such
implementation, may we should
move instead to sysfs?
> - I don't think that I understand the clk_functions part of your code.
> Is this a shorthand to construct aliases to other struct clks?
Yes, that's one of usages for it. E.g. current AT91 code has same
functionality named
at91_clock_associate. Also onece we get to multiple chips
providers/users, we'll see,
that the clock simply can't have just one record in the clocks tree.
It's provided by some
pin (provider_name) and then consumed by several devices (several
consumer_name + consumer_device pairs). That is it.
--
With best wishes
Dmitry
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/