* [RFC] dt-bindings: configuration of parent clocks and clock frequency
@ 2014-01-21 12:48 Sylwester Nawrocki
[not found] ` <52DE6CAB.10008-Sze3O3UU22JBDgjK7y7TUQ@public.gmane.org>
0 siblings, 1 reply; 4+ messages in thread
From: Sylwester Nawrocki @ 2014-01-21 12:48 UTC (permalink / raw)
To: linux-arm-kernel, devicetree
Cc: Mike Turquette, Russell King - ARM Linux, Tomasz Figa,
Kyungmin Park, Marek Szyprowski, Rob Herring, Mark Rutland,
Pawel Moll, Ian Campbell, Kumar Gala
Hi All,
During LCE13 there was a discussion regarding initial configuration
of clocks from consumer perspective and the related device tree bindings.
It seems no one started working on this, at least I couldn't see any
related posts/patches on the mailing list, so I thought I'd give a try
the initial binding proposal [1].
As it turns out, by adding only a single property with a list of parent
clock specifiers or clock frequencies corresponding to clocks listed in
the 'clocks' property it is difficult to specify parent clocks or
frequencies only for selected clocks of a device.
So I modified the proposed binding and there are some variants below
it would be nice to get a feedback for.
Let's assume a clock provider and an UART device:
clk {
#clock-cells = <1>;
};
uart: uart {
clocks = <&clk 10>, <&clk 11>, <&clk 12>;
clock-names = "sclk_0", "sclk_1", "gate";
...
};
1. The first version I actually tried in practice is
'assigned-clk-parents' and assigned-clk-rates properties listing
<clk clk_parent> and <clk clk_rate> pairs respectively:
uart {
clocks = <&clk 10>, <&clk 11>, <&clk 12>;
clock-names = "sclk_0", "sclk_1", "gate";
assigned-clk-parents = <&clk_a 10 &clk_a 20>,
<&clk_a 11 &clk_a 100>;
assigned-clk-rates = <&clk_a 10 600000>,
<&clk_a 100 100000>;
};
Parsing assigned-clk-parents is straightforward, only assigned-clk-rates
requires a bit more exercise.
2. A different option would be to list all the required clocks in clock/
clock-names properties and use properties as below to refer to the
clocks by name:
uart {
clocks = <&clk 10>, <&clk 11>, <&clk 12>, &clk 100> /* PLL */;
clock-names = "sclk_0", "sclk_1", "gate", "pll";
assigned-clk-parent-clocks = "sclk_0";
assigned-clk-parent-parents = "pll";
assigned-clk-rate-clocks = "pll";
assigned-clk-rate-values = <600000>;
};
It might be more readable and would allow configuring things more
consciously. However it adds an additional indirection and introduces
specifiers of clocks potentially unrelated to a device in clocks/
clock-names properties.
3. A simplified variant of 2., with indexes to 'clocks' property rather
than values from the clock-names property:
uart: uart {
clocks = <&clk 10>, <&clk 11>, <&clk 12>, &clk 100> /* PLL */;
clock-names = "sclk_0", "sclk_1", "gate", "pll";
assigned-clk-parent-clocks = 0;
assigned-clk-parent-parents = 3;
assigned-clk-rate-clocks = 3;
assigned-clk-rate-values = <600000>;
};
4. With phandle + clock specifier instead of device clock names:
uart: uart {
clocks = <&clk 10>, <&clk 11>, <&clk 12>, &clk 100> /* PLL */;
clock-names = "sclk_0", "sclk_1", "gate", "pll";
assigned-clk-parent-clocks = <&clk 10>;
assigned-clk-parent-parents = <&clk 100>;
assigned-clk-rate-clocks = <&clk 100>;
assigned-clk-rate-values = <600000>;
};
5. Similarly to the regulator bindings the clock names could be appended
to name of a DT property:
[clk_name]-assigned-clock-parent = <...>;
[clk_name]-assigned-clock-rate = <...>;
It has an issue though that length of a DT property name is limited
to 31 characters and there may not be enough room for the clock name.
uart: uart {
clocks = <&clk 10>, <&clk 11>, <&clk 12>;
clock-names = "sclk_0", "sclk_1", "gate";
sclk_0-assigned-clk-parent = <&clk 100>;
pll-assigned-clk-rate = <600000>;
};
Does any of these look reasonable ? Perhaps someone could suggest
a better approach ?
[1] https://lkml.org/lkml/2013/8/22/2
--
Regards,
Sylwester
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [RFC] dt-bindings: configuration of parent clocks and clock frequency
[not found] ` <52DE6CAB.10008-Sze3O3UU22JBDgjK7y7TUQ@public.gmane.org>
@ 2014-02-01 3:06 ` Mike Turquette
2014-02-04 12:16 ` Marek Szyprowski
0 siblings, 1 reply; 4+ messages in thread
From: Mike Turquette @ 2014-02-01 3:06 UTC (permalink / raw)
To: Sylwester Nawrocki, linux-arm-kernel, devicetree
Cc: Russell King - ARM Linux, Tomasz Figa, Kyungmin Park,
Marek Szyprowski, Rob Herring, Mark Rutland, Pawel Moll,
Ian Campbell, Kumar Gala
Quoting Sylwester Nawrocki (2014-01-21 04:48:43)
> 5. Similarly to the regulator bindings the clock names could be appended
> to name of a DT property:
>
> [clk_name]-assigned-clock-parent = <...>;
> [clk_name]-assigned-clock-rate = <...>;
I have always been partial to the way that the reg framework does its
[reg_name]-supply. We could shorten it to something like:
[clk-name]-asn-parent = ....
[clk-name]-asn-rate = ...
This is actually the format that was discussed at the ARM kernel summit
IIRC.
Regards,
Mike
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [RFC] dt-bindings: configuration of parent clocks and clock frequency
2014-02-01 3:06 ` Mike Turquette
@ 2014-02-04 12:16 ` Marek Szyprowski
[not found] ` <52F0DA07.6050903-Sze3O3UU22JBDgjK7y7TUQ@public.gmane.org>
0 siblings, 1 reply; 4+ messages in thread
From: Marek Szyprowski @ 2014-02-04 12:16 UTC (permalink / raw)
To: Mike Turquette, Sylwester Nawrocki, linux-arm-kernel, devicetree
Cc: Russell King - ARM Linux, Tomasz Figa, Kyungmin Park, Rob Herring,
Mark Rutland, Pawel Moll, Ian Campbell, Kumar Gala
Hello,
On 2014-02-01 04:06, Mike Turquette wrote:
> Quoting Sylwester Nawrocki (2014-01-21 04:48:43)
> > 5. Similarly to the regulator bindings the clock names could be appended
> > to name of a DT property:
> >
> > [clk_name]-assigned-clock-parent = <...>;
> > [clk_name]-assigned-clock-rate = <...>;
>
> I have always been partial to the way that the reg framework does its
> [reg_name]-supply. We could shorten it to something like:
>
> [clk-name]-asn-parent = ....
> [clk-name]-asn-rate = ...
>
> This is actually the format that was discussed at the ARM kernel summit
> IIRC.
I think that "[clk-name]-clk-parent" and "[clk-name]-clk-rate" will be a bit
more descriptive names instead of quite ambiguous "asn".
Best regards
--
Marek Szyprowski, PhD
Samsung R&D Institute Poland
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [RFC] dt-bindings: configuration of parent clocks and clock frequency
[not found] ` <52F0DA07.6050903-Sze3O3UU22JBDgjK7y7TUQ@public.gmane.org>
@ 2014-02-06 16:43 ` Mike Turquette
0 siblings, 0 replies; 4+ messages in thread
From: Mike Turquette @ 2014-02-06 16:43 UTC (permalink / raw)
To: Marek Szyprowski, Sylwester Nawrocki, linux-arm-kernel,
devicetree
Cc: Russell King - ARM Linux, Tomasz Figa, Kyungmin Park, Rob Herring,
Mark Rutland, Pawel Moll, Ian Campbell, Kumar Gala
Quoting Marek Szyprowski (2014-02-04 04:16:07)
> Hello,
>
> On 2014-02-01 04:06, Mike Turquette wrote:
> > Quoting Sylwester Nawrocki (2014-01-21 04:48:43)
> > > 5. Similarly to the regulator bindings the clock names could be appended
> > > to name of a DT property:
> > >
> > > [clk_name]-assigned-clock-parent = <...>;
> > > [clk_name]-assigned-clock-rate = <...>;
> >
> > I have always been partial to the way that the reg framework does its
> > [reg_name]-supply. We could shorten it to something like:
> >
> > [clk-name]-asn-parent = ....
> > [clk-name]-asn-rate = ...
> >
> > This is actually the format that was discussed at the ARM kernel summit
> > IIRC.
>
> I think that "[clk-name]-clk-parent" and "[clk-name]-clk-rate" will be a bit
> more descriptive names instead of quite ambiguous "asn".
+1
Regards,
Mike
>
> Best regards
> --
> Marek Szyprowski, PhD
> Samsung R&D Institute Poland
>
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2014-02-06 16:43 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-01-21 12:48 [RFC] dt-bindings: configuration of parent clocks and clock frequency Sylwester Nawrocki
[not found] ` <52DE6CAB.10008-Sze3O3UU22JBDgjK7y7TUQ@public.gmane.org>
2014-02-01 3:06 ` Mike Turquette
2014-02-04 12:16 ` Marek Szyprowski
[not found] ` <52F0DA07.6050903-Sze3O3UU22JBDgjK7y7TUQ@public.gmane.org>
2014-02-06 16:43 ` Mike Turquette
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).