blob: ed116df9c3e769a2ceef9cb4d1dd1eaf44473f38 [file] [log] [blame]
Emilio Lópeze874a662013-02-25 11:44:26 -03001Device Tree Clock bindings for arch-sunxi
2
3This binding uses the common clock binding[1].
4
5[1] Documentation/devicetree/bindings/clock/clock-bindings.txt
6
7Required properties:
8- compatible : shall be one of the following:
Maxime Ripardfd1b22f2014-02-06 09:55:57 +01009 "allwinner,sun4i-a10-osc-clk" - for a gatable oscillator
10 "allwinner,sun4i-a10-pll1-clk" - for the main PLL clock and PLL4
Maxime Ripard6a721db2013-07-23 23:34:10 +020011 "allwinner,sun6i-a31-pll1-clk" - for the main PLL clock on A31
Chen-Yu Tsai515c1a42014-06-26 23:55:43 +080012 "allwinner,sun8i-a23-pll1-clk" - for the main PLL clock on A23
Maxime Ripardfd1b22f2014-02-06 09:55:57 +010013 "allwinner,sun4i-a10-pll5-clk" - for the PLL5 clock
14 "allwinner,sun4i-a10-pll6-clk" - for the PLL6 clock
Maxime Ripard92ef67c2014-02-05 14:05:03 +010015 "allwinner,sun6i-a31-pll6-clk" - for the PLL6 clock on A31
Maxime Ripardfd1b22f2014-02-06 09:55:57 +010016 "allwinner,sun4i-a10-cpu-clk" - for the CPU multiplexer clock
17 "allwinner,sun4i-a10-axi-clk" - for the AXI clock
Chen-Yu Tsai515c1a42014-06-26 23:55:43 +080018 "allwinner,sun8i-a23-axi-clk" - for the AXI clock on A23
Maxime Ripardfd1b22f2014-02-06 09:55:57 +010019 "allwinner,sun4i-a10-axi-gates-clk" - for the AXI gates
20 "allwinner,sun4i-a10-ahb-clk" - for the AHB clock
21 "allwinner,sun4i-a10-ahb-gates-clk" - for the AHB gates on A10
Maxime Ripard4f985b42013-04-30 11:56:22 +020022 "allwinner,sun5i-a13-ahb-gates-clk" - for the AHB gates on A13
Maxime Ripard2371dd82013-07-16 11:21:59 +020023 "allwinner,sun5i-a10s-ahb-gates-clk" - for the AHB gates on A10s
Maxime Ripard1fb2e4a2013-07-25 21:06:56 +020024 "allwinner,sun7i-a20-ahb-gates-clk" - for the AHB gates on A20
Boris BREZILLON5c89a8b2014-05-15 10:55:12 +020025 "allwinner,sun6i-a31-ar100-clk" - for the AR100 on A31
Maxime Ripard6a721db2013-07-23 23:34:10 +020026 "allwinner,sun6i-a31-ahb1-mux-clk" - for the AHB1 multiplexer on A31
27 "allwinner,sun6i-a31-ahb1-gates-clk" - for the AHB1 gates on A31
Chen-Yu Tsai515c1a42014-06-26 23:55:43 +080028 "allwinner,sun8i-a23-ahb1-gates-clk" - for the AHB1 gates on A23
Maxime Ripardfd1b22f2014-02-06 09:55:57 +010029 "allwinner,sun4i-a10-apb0-clk" - for the APB0 clock
Boris BREZILLON5c89a8b2014-05-15 10:55:12 +020030 "allwinner,sun6i-a31-apb0-clk" - for the APB0 clock on A31
Chen-Yu Tsai57a1fbf22014-07-03 22:55:41 +080031 "allwinner,sun8i-a23-apb0-clk" - for the APB0 clock on A23
Maxime Ripardfd1b22f2014-02-06 09:55:57 +010032 "allwinner,sun4i-a10-apb0-gates-clk" - for the APB0 gates on A10
Maxime Ripard4f985b42013-04-30 11:56:22 +020033 "allwinner,sun5i-a13-apb0-gates-clk" - for the APB0 gates on A13
Maxime Ripard2371dd82013-07-16 11:21:59 +020034 "allwinner,sun5i-a10s-apb0-gates-clk" - for the APB0 gates on A10s
Boris BREZILLON5c89a8b2014-05-15 10:55:12 +020035 "allwinner,sun6i-a31-apb0-gates-clk" - for the APB0 gates on A31
Maxime Ripard1fb2e4a2013-07-25 21:06:56 +020036 "allwinner,sun7i-a20-apb0-gates-clk" - for the APB0 gates on A20
Chen-Yu Tsai6c1d66f2014-07-09 15:54:35 +080037 "allwinner,sun8i-a23-apb0-gates-clk" - for the APB0 gates on A23
Maxime Ripardfd1b22f2014-02-06 09:55:57 +010038 "allwinner,sun4i-a10-apb1-clk" - for the APB1 clock
39 "allwinner,sun4i-a10-apb1-mux-clk" - for the APB1 clock muxing
40 "allwinner,sun4i-a10-apb1-gates-clk" - for the APB1 gates on A10
Maxime Ripard4f985b42013-04-30 11:56:22 +020041 "allwinner,sun5i-a13-apb1-gates-clk" - for the APB1 gates on A13
Maxime Ripard2371dd82013-07-16 11:21:59 +020042 "allwinner,sun5i-a10s-apb1-gates-clk" - for the APB1 gates on A10s
Maxime Ripard6a721db2013-07-23 23:34:10 +020043 "allwinner,sun6i-a31-apb1-gates-clk" - for the APB1 gates on A31
Maxime Ripard1fb2e4a2013-07-25 21:06:56 +020044 "allwinner,sun7i-a20-apb1-gates-clk" - for the APB1 gates on A20
Chen-Yu Tsai515c1a42014-06-26 23:55:43 +080045 "allwinner,sun8i-a23-apb1-gates-clk" - for the APB1 gates on A23
Maxime Ripard6a721db2013-07-23 23:34:10 +020046 "allwinner,sun6i-a31-apb2-div-clk" - for the APB2 gates on A31
47 "allwinner,sun6i-a31-apb2-gates-clk" - for the APB2 gates on A31
Chen-Yu Tsai515c1a42014-06-26 23:55:43 +080048 "allwinner,sun8i-a23-apb2-gates-clk" - for the APB2 gates on A23
Maxime Ripard03e29bb2014-07-10 23:53:40 +020049 "allwinner,sun5i-a13-mbus-clk" - for the MBUS clock on A13
Maxime Ripard37e10412014-07-11 18:43:18 +020050 "allwinner,sun4i-a10-mmc-output-clk" - for the MMC output clock on A10
51 "allwinner,sun4i-a10-mmc-sample-clk" - for the MMC sample clock on A10
Maxime Ripardfd1b22f2014-02-06 09:55:57 +010052 "allwinner,sun4i-a10-mod0-clk" - for the module 0 family of clocks
Chen-Yu Tsai9c8176b2014-09-16 18:04:01 +080053 "allwinner,sun8i-a23-mbus-clk" - for the MBUS clock on A23
Chen-Yu Tsai6f863412013-12-24 21:26:17 +080054 "allwinner,sun7i-a20-out-clk" - for the external output clocks
Chen-Yu Tsaie4c6d6c2014-02-10 18:35:47 +080055 "allwinner,sun7i-a20-gmac-clk" - for the GMAC clock module on A20/A31
Roman Byshko5abdbf22014-02-07 16:21:50 +010056 "allwinner,sun4i-a10-usb-clk" - for usb gates + resets on A10 / A20
57 "allwinner,sun5i-a13-usb-clk" - for usb gates + resets on A13
Emilio López6d1d14d2014-05-13 13:29:26 -030058 "allwinner,sun6i-a31-usb-clk" - for usb gates + resets on A31
Emilio Lópeze874a662013-02-25 11:44:26 -030059
60Required properties for all clocks:
61- reg : shall be the control register address for the clock.
Emilio López75517692013-12-23 00:32:39 -030062- clocks : shall be the input parent clock(s) phandle for the clock. For
63 multiplexed clocks, the list order must match the hardware
64 programming order.
Emilio López13569a72013-03-27 18:20:37 -030065- #clock-cells : from common clock binding; shall be set to 0 except for
Chen-Yu Tsai373d4e62014-02-03 09:51:38 +080066 "allwinner,*-gates-clk", "allwinner,sun4i-pll5-clk" and
67 "allwinner,sun4i-pll6-clk" where it shall be set to 1
68- clock-output-names : shall be the corresponding names of the outputs.
69 If the clock module only has one output, the name shall be the
70 module name.
Emilio Lópeze874a662013-02-25 11:44:26 -030071
Roman Byshko5abdbf22014-02-07 16:21:50 +010072And "allwinner,*-usb-clk" clocks also require:
73- reset-cells : shall be set to 1
74
Chen-Yu Tsaie4c6d6c2014-02-10 18:35:47 +080075For "allwinner,sun7i-a20-gmac-clk", the parent clocks shall be fixed rate
76dummy clocks at 25 MHz and 125 MHz, respectively. See example.
77
Maxime Ripard4f985b42013-04-30 11:56:22 +020078Clock consumers should specify the desired clocks they use with a
79"clocks" phandle cell. Consumers that are using a gated clock should
Maxime Ripardfc42ef52013-10-04 23:19:54 +020080provide an additional ID in their clock property. This ID is the
81offset of the bit controlling this particular gate in the register.
Maxime Ripard4f985b42013-04-30 11:56:22 +020082
Emilio Lópeze874a662013-02-25 11:44:26 -030083For example:
84
Chen-Yu Tsai373d4e62014-02-03 09:51:38 +080085osc24M: clk@01c20050 {
Emilio Lópeze874a662013-02-25 11:44:26 -030086 #clock-cells = <0>;
Maxime Ripardfd1b22f2014-02-06 09:55:57 +010087 compatible = "allwinner,sun4i-a10-osc-clk";
Emilio Lópeze874a662013-02-25 11:44:26 -030088 reg = <0x01c20050 0x4>;
89 clocks = <&osc24M_fixed>;
Chen-Yu Tsai373d4e62014-02-03 09:51:38 +080090 clock-output-names = "osc24M";
Emilio Lópeze874a662013-02-25 11:44:26 -030091};
92
Chen-Yu Tsai373d4e62014-02-03 09:51:38 +080093pll1: clk@01c20000 {
Emilio Lópeze874a662013-02-25 11:44:26 -030094 #clock-cells = <0>;
Maxime Ripardfd1b22f2014-02-06 09:55:57 +010095 compatible = "allwinner,sun4i-a10-pll1-clk";
Emilio Lópeze874a662013-02-25 11:44:26 -030096 reg = <0x01c20000 0x4>;
97 clocks = <&osc24M>;
Chen-Yu Tsai373d4e62014-02-03 09:51:38 +080098 clock-output-names = "pll1";
99};
100
101pll5: clk@01c20020 {
102 #clock-cells = <1>;
103 compatible = "allwinner,sun4i-pll5-clk";
104 reg = <0x01c20020 0x4>;
105 clocks = <&osc24M>;
106 clock-output-names = "pll5_ddr", "pll5_other";
Emilio Lópeze874a662013-02-25 11:44:26 -0300107};
108
109cpu: cpu@01c20054 {
110 #clock-cells = <0>;
Maxime Ripardfd1b22f2014-02-06 09:55:57 +0100111 compatible = "allwinner,sun4i-a10-cpu-clk";
Emilio Lópeze874a662013-02-25 11:44:26 -0300112 reg = <0x01c20054 0x4>;
113 clocks = <&osc32k>, <&osc24M>, <&pll1>;
Chen-Yu Tsai373d4e62014-02-03 09:51:38 +0800114 clock-output-names = "cpu";
115};
116
117mmc0_clk: clk@01c20088 {
118 #clock-cells = <0>;
119 compatible = "allwinner,sun4i-mod0-clk";
120 reg = <0x01c20088 0x4>;
121 clocks = <&osc24M>, <&pll6 1>, <&pll5 1>;
122 clock-output-names = "mmc0";
Emilio Lópeze874a662013-02-25 11:44:26 -0300123};
Chen-Yu Tsaie4c6d6c2014-02-10 18:35:47 +0800124
125mii_phy_tx_clk: clk@2 {
126 #clock-cells = <0>;
127 compatible = "fixed-clock";
128 clock-frequency = <25000000>;
129 clock-output-names = "mii_phy_tx";
130};
131
132gmac_int_tx_clk: clk@3 {
133 #clock-cells = <0>;
134 compatible = "fixed-clock";
135 clock-frequency = <125000000>;
136 clock-output-names = "gmac_int_tx";
137};
138
139gmac_clk: clk@01c20164 {
140 #clock-cells = <0>;
141 compatible = "allwinner,sun7i-a20-gmac-clk";
142 reg = <0x01c20164 0x4>;
143 /*
144 * The first clock must be fixed at 25MHz;
145 * the second clock must be fixed at 125MHz
146 */
147 clocks = <&mii_phy_tx_clk>, <&gmac_int_tx_clk>;
148 clock-output-names = "gmac";
149};