diff options
author | Gabriel FERNANDEZ <gabriel.fernandez@st.com> | 2014-07-15 11:20:21 -0400 |
---|---|---|
committer | Mike Turquette <mturquette@linaro.org> | 2014-07-29 01:36:23 -0400 |
commit | 3414666d34bb50f91965d16eab98a5fd7c8af08c (patch) | |
tree | 25226bb1db7be433a5fb9f06d17c0648c7fe078b | |
parent | 79bb8aa16fbc7438dae43425c8566d43b6ec49a3 (diff) |
clk: st: Adds Flexgen clock binding
A Flexgen structure is composed by:
- a clock cross bar (represented by a mux element)
- a pre and final dividers (represented by a divider and gate elements)
Signed-off-by: Gabriel Fernandez <gabriel.fernandez@linaro.org>
Acked-by: Peter Griffin <peter.griffin@linaro.org>
Signed-off-by: Mike Turquette <mturquette@linaro.org>
-rw-r--r-- | Documentation/devicetree/bindings/clock/st/st,clkgen.txt | 5 | ||||
-rw-r--r-- | Documentation/devicetree/bindings/clock/st/st,flexgen.txt | 119 |
2 files changed, 124 insertions, 0 deletions
diff --git a/Documentation/devicetree/bindings/clock/st/st,clkgen.txt b/Documentation/devicetree/bindings/clock/st/st,clkgen.txt index 427bad84465c..78978f1f5158 100644 --- a/Documentation/devicetree/bindings/clock/st/st,clkgen.txt +++ b/Documentation/devicetree/bindings/clock/st/st,clkgen.txt | |||
@@ -32,6 +32,10 @@ address is common of all subnode. | |||
32 | vcc_node { | 32 | vcc_node { |
33 | ... | 33 | ... |
34 | }; | 34 | }; |
35 | |||
36 | flexgen_node { | ||
37 | ... | ||
38 | }; | ||
35 | ... | 39 | ... |
36 | }; | 40 | }; |
37 | 41 | ||
@@ -45,6 +49,7 @@ Each subnode should use the binding discribe in [2]..[7] | |||
45 | [5] Documentation/devicetree/bindings/clock/st,clkgen-prediv.txt | 49 | [5] Documentation/devicetree/bindings/clock/st,clkgen-prediv.txt |
46 | [6] Documentation/devicetree/bindings/clock/st,vcc.txt | 50 | [6] Documentation/devicetree/bindings/clock/st,vcc.txt |
47 | [7] Documentation/devicetree/bindings/clock/st,quadfs.txt | 51 | [7] Documentation/devicetree/bindings/clock/st,quadfs.txt |
52 | [8] Documentation/devicetree/bindings/clock/st,flexgen.txt | ||
48 | 53 | ||
49 | 54 | ||
50 | Required properties: | 55 | Required properties: |
diff --git a/Documentation/devicetree/bindings/clock/st/st,flexgen.txt b/Documentation/devicetree/bindings/clock/st/st,flexgen.txt new file mode 100644 index 000000000000..1d3ace088172 --- /dev/null +++ b/Documentation/devicetree/bindings/clock/st/st,flexgen.txt | |||
@@ -0,0 +1,119 @@ | |||
1 | Binding for a type of flexgen structure found on certain | ||
2 | STMicroelectronics consumer electronics SoC devices | ||
3 | |||
4 | This structure includes: | ||
5 | - a clock cross bar (represented by a mux element) | ||
6 | - a pre and final dividers (represented by a divider and gate elements) | ||
7 | |||
8 | Flexgen structure is a part of Clockgen[1]. | ||
9 | |||
10 | Please find an example below: | ||
11 | |||
12 | Clockgen block diagram | ||
13 | ------------------------------------------------------------------- | ||
14 | | Flexgen stucture | | ||
15 | | --------------------------------------------- | | ||
16 | | | ------- -------- -------- | | | ||
17 | clk_sysin | | | | | | | | | | ||
18 | ---|-----------------|-->| | | | | | | | | ||
19 | | | | | | | | | | | | | ||
20 | | | ------- | | | |Pre | |Final | | | | ||
21 | | | |PLL0 | | | | |Dividers| |Dividers| | | | ||
22 | | |->| | | | | | x32 | | x32 | | | | ||
23 | | | | odf_0|----|-->| | | | | | | | | ||
24 | | | | | | | | | | | | | | | ||
25 | | | | | | | | | | | | | | | ||
26 | | | | | | | | | | | | | | | ||
27 | | | | | | | | | | | | | | | ||
28 | | | ------- | | | | | | | | | | ||
29 | | | | | | | | | | | | | ||
30 | | | ------- | | Clock | | | | | | | | ||
31 | | | |PLL1 | | | | | | | | | | | ||
32 | | |->| | | | Cross | | | | | | | | ||
33 | | | | odf_0|----|-->| | | | | | CLK_DIV[31:0] | ||
34 | | | | | | | Bar |====>| |====>| |===|=========> | ||
35 | | | | | | | | | | | | | | | ||
36 | | | | | | | | | | | | | | | ||
37 | | | | | | | | | | | | | | | ||
38 | | | ------- | | | | | | | | | | ||
39 | | | | | | | | | | | | | ||
40 | | | ------- | | | | | | | | | | ||
41 | | | |QUADFS | | | | | | | | | | | ||
42 | | |->| ch0|----|-->| | | | | | | | | ||
43 | | | | | | | | | | | | | | ||
44 | | | ch1|----|-->| | | | | | | | | ||
45 | | | | | | | | | | | | | | ||
46 | | | ch2|----|-->| | | DIV | | DIV | | | | ||
47 | | | | | | | | 1 to | | 1 to | | | | ||
48 | | | ch3|----|-->| | | 1024 | | 64 | | | | ||
49 | | ------- | | | | | | | | | | ||
50 | | | ------- -------- -------- | | | ||
51 | | -------------------------------------------- | | ||
52 | | | | ||
53 | ------------------------------------------------------------------- | ||
54 | |||
55 | This binding uses the common clock binding[2]. | ||
56 | |||
57 | [1] Documentation/devicetree/bindings/clock/st/st,clkgen.txt | ||
58 | [2] Documentation/devicetree/bindings/clock/clock-bindings.txt | ||
59 | |||
60 | Required properties: | ||
61 | - compatible : shall be: | ||
62 | "st,flexgen" | ||
63 | |||
64 | - #clock-cells : from common clock binding; shall be set to 1 (multiple clock | ||
65 | outputs). | ||
66 | |||
67 | - clocks : must be set to the parent's phandle. it's could be output clocks of | ||
68 | a quadsfs or/and a pll or/and clk_sysin (up to 7 clocks) | ||
69 | |||
70 | - clock-output-names : List of strings used to name the clock outputs. | ||
71 | |||
72 | Example: | ||
73 | |||
74 | clk_s_c0_flexgen: clk-s-c0-flexgen { | ||
75 | |||
76 | #clock-cells = <1>; | ||
77 | compatible = "st,flexgen"; | ||
78 | |||
79 | clocks = <&clk_s_c0_pll0 0>, | ||
80 | <&clk_s_c0_pll1 0>, | ||
81 | <&clk_s_c0_quadfs 0>, | ||
82 | <&clk_s_c0_quadfs 1>, | ||
83 | <&clk_s_c0_quadfs 2>, | ||
84 | <&clk_s_c0_quadfs 3>, | ||
85 | <&clk_sysin>; | ||
86 | |||
87 | clock-output-names = "clk-icn-gpu", | ||
88 | "clk-fdma", | ||
89 | "clk-nand", | ||
90 | "clk-hva", | ||
91 | "clk-proc-stfe", | ||
92 | "clk-proc-tp", | ||
93 | "clk-rx-icn-dmu", | ||
94 | "clk-rx-icn-hva", | ||
95 | "clk-icn-cpu", | ||
96 | "clk-tx-icn-dmu", | ||
97 | "clk-mmc-0", | ||
98 | "clk-mmc-1", | ||
99 | "clk-jpegdec", | ||
100 | "clk-ext2fa9", | ||
101 | "clk-ic-bdisp-0", | ||
102 | "clk-ic-bdisp-1", | ||
103 | "clk-pp-dmu", | ||
104 | "clk-vid-dmu", | ||
105 | "clk-dss-lpc", | ||
106 | "clk-st231-aud-0", | ||
107 | "clk-st231-gp-1", | ||
108 | "clk-st231-dmu", | ||
109 | "clk-icn-lmi", | ||
110 | "clk-tx-icn-disp-1", | ||
111 | "clk-icn-sbc", | ||
112 | "clk-stfe-frc2", | ||
113 | "clk-eth-phy", | ||
114 | "clk-eth-ref-phyclk", | ||
115 | "clk-flash-promip", | ||
116 | "clk-main-disp", | ||
117 | "clk-aux-disp", | ||
118 | "clk-compo-dvp"; | ||
119 | }; | ||