dt-bindings: clock: Add new bindings for TI Davinci PLL clocks
authorDavid Lechner <david@lechnology.com>
Fri, 16 Mar 2018 02:52:17 +0000 (21:52 -0500)
committerStephen Boyd <sboyd@kernel.org>
Tue, 20 Mar 2018 16:33:08 +0000 (09:33 -0700)
This adds a new binding for the PLL IP blocks in the mach-davinci
family of processors. Currently, only da850 has device tree support
but these bindings can also work for other SoCs in this family just
by adding new compatible strings.

Note: Although these PLL controllers are very similar to the TI Keystone
SoCs, we are not re-using those bindings. The Keystone bindings use a
legacy one-node-per-clock binding. Furthermore, the mach-davinici SoCs
have a slightly different PLL register layout and a number of quirks
that can't be handled by the existing bindings, so the keystone bindings
could not be used as-is anyway.

Signed-off-by: David Lechner <david@lechnology.com>
Reviewed-by: Rob Herring <robh@kernel.org>
Signed-off-by: Stephen Boyd <sboyd@kernel.org>
Documentation/devicetree/bindings/clock/ti/davinci/pll.txt [new file with mode: 0644]

diff --git a/Documentation/devicetree/bindings/clock/ti/davinci/pll.txt b/Documentation/devicetree/bindings/clock/ti/davinci/pll.txt
new file mode 100644 (file)
index 0000000..36998e1
--- /dev/null
@@ -0,0 +1,96 @@
+Binding for TI DaVinci PLL Controllers
+
+The PLL provides clocks to most of the components on the SoC. In addition
+to the PLL itself, this controller also contains bypasses, gates, dividers,
+an multiplexers for various clock signals.
+
+Required properties:
+- compatible: shall be one of:
+       - "ti,da850-pll0" for PLL0 on DA850/OMAP-L138/AM18XX
+       - "ti,da850-pll1" for PLL1 on DA850/OMAP-L138/AM18XX
+- reg: physical base address and size of the controller's register area.
+- clocks: phandles corresponding to the clock names
+- clock-names: names of the clock sources - depends on compatible string
+       - for "ti,da850-pll0", shall be "clksrc", "extclksrc"
+       - for "ti,da850-pll1", shall be "clksrc"
+
+Optional properties:
+- ti,clkmode-square-wave: Indicates that the the board is supplying a square
+       wave input on the OSCIN pin instead of using a crystal oscillator.
+       This property is only valid when compatible = "ti,da850-pll0".
+
+
+Optional child nodes:
+
+pllout
+       Describes the main PLL clock output (before POSTDIV). The node name must
+       be "pllout".
+
+       Required properties:
+       - #clock-cells: shall be 0
+
+sysclk
+       Describes the PLLDIVn divider clocks that provide the SYSCLKn clock
+       domains. The node name must be "sysclk". Consumers of this node should
+       use "n" in "SYSCLKn" as the index parameter for the clock cell.
+
+       Required properties:
+       - #clock-cells: shall be 1
+
+auxclk
+       Describes the AUXCLK output of the PLL. The node name must be "auxclk".
+       This child node is only valid when compatible = "ti,da850-pll0".
+
+       Required properties:
+       - #clock-cells: shall be 0
+
+obsclk
+       Describes the OBSCLK output of the PLL. The node name must be "obsclk".
+
+       Required properties:
+       - #clock-cells: shall be 0
+
+
+Examples:
+
+       pll0: clock-controller@11000 {
+               compatible = "ti,da850-pll0";
+               reg = <0x11000 0x1000>;
+               clocks = <&ref_clk>, <&pll1_sysclk 3>;
+               clock-names = "clksrc", "extclksrc";
+               ti,clkmode-square-wave;
+
+               pll0_pllout: pllout {
+                       #clock-cells = <0>;
+               };
+
+               pll0_sysclk: sysclk {
+                       #clock-cells = <1>;
+               };
+
+               pll0_auxclk: auxclk {
+                       #clock-cells = <0>;
+               };
+
+               pll0_obsclk: obsclk {
+                       #clock-cells = <0>;
+               };
+       };
+
+       pll1: clock-controller@21a000 {
+               compatible = "ti,da850-pll1";
+               reg = <0x21a000 0x1000>;
+               clocks = <&ref_clk>;
+               clock-names = "clksrc";
+
+               pll0_sysclk: sysclk {
+                       #clock-cells = <1>;
+               };
+
+               pll0_obsclk: obsclk {
+                       #clock-cells = <0>;
+               };
+       };
+
+Also see:
+- Documentation/devicetree/bindings/clock/clock-bindings.txt