Thread (32 messages) 32 messages, 10 authors, 2012-01-14

[PATCH v4 5/6] clk: basic gateable and fixed-rate clks

From: Turquette, Mike <hidden>
Date: 2011-12-17 00:58:21
Also in: linux-omap, lkml

On Tue, Dec 13, 2011 at 9:15 PM, Ryan Mallon [off-list ref] wrote:
On 14/12/11 14:53, Mike Turquette wrote:
quoted
Many platforms support simple gateable clks and fixed-rate clks that
should not be re-implemented by every platform.

This patch introduces a gateable clk with a common programming model of
gate control via a write of 1 bit to a register. ?Both set-to-enable and
clear-to-enable are supported.

Also introduced is a fixed-rate clk which has no reprogrammable aspects.

The purpose of both types of clks is documented in drivers/clk/basic.c.

TODO: add support for a simple divider, simple mux and a dummy clk for
stubbing out platform support.

Based on original patch by Jeremy Kerr and contribution by Jamie Iles.

Signed-off-by: Mike Turquette <redacted>
Cc: Jeremy Kerr <redacted>
Cc: Jamie Iles <redacted>
<snip>
quoted
+int clk_register_gate(struct device *dev, const char *name, unsigned long flags,
+ ? ? ? ? ? ? struct clk *fixed_parent, void __iomem *reg, u8 bit_idx,
+ ? ? ? ? ? ? int set_to_enable)
+{
+ ? ? struct clk_hw_gate *gclk;
+ ? ? struct clk *clk;
+
+ ? ? gclk = kmalloc(sizeof(struct clk_hw_gate), GFP_KERNEL);
+
+ ? ? if (!gclk) {
+ ? ? ? ? ? ? pr_err("%s: could not allocate gated clk\n", __func__);
+ ? ? ? ? ? ? return -ENOMEM;
+ ? ? }
+
+ ? ? clk = &gclk->clk;
+
+ ? ? /* struct clk_hw_gate assignments */
+ ? ? gclk->fixed_parent = fixed_parent;
+ ? ? gclk->reg = reg;
+ ? ? gclk->bit_idx = bit_idx;
+
+ ? ? /* struct clk assignments */
+ ? ? clk->name = name;
+ ? ? clk->flags = flags;
+
+ ? ? if (set_to_enable)
+ ? ? ? ? ? ? clk->ops = &clk_hw_gate_set_enable_ops;
+ ? ? else
+ ? ? ? ? ? ? clk->ops = &clk_hw_gate_set_disable_ops;

You could avoid having two sets of operations if you stored the
set_to_enable value in struct clk_hw_gate. It might be useful to store
additional information in struct clk_hw_gate if you also want to extend
to supporting non-32bit registers (readb, etc), clocks with write only
registers, or support clocks which require more than one bit to be set
or cleared to enable them, etc. See the basic mmio gpio driver for a
similar case.
I haven't given the basic clks enough attention, mostly because I
haven't started using them yet in my own platform's conversion to
common struct clk :-/

I think the original reason for the extra operations is to avoid the
conditional in the enable/disable path, but if we're going to end up
adding other conditionals anyways (such as the register locking in the
iMX platform implementation) then we should probably forget about that
approach and just deal with the complexity in one set of common
enable/disable functions.

Thanks for the review,
Mike
~Ryan
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help