2013-02-25 14:44:26 +00:00
|
|
|
Device Tree Clock bindings for arch-sunxi
|
|
|
|
|
|
|
|
This binding uses the common clock binding[1].
|
|
|
|
|
|
|
|
[1] Documentation/devicetree/bindings/clock/clock-bindings.txt
|
|
|
|
|
|
|
|
Required properties:
|
|
|
|
- compatible : shall be one of the following:
|
2013-03-27 02:39:17 +00:00
|
|
|
"allwinner,sun4i-osc-clk" - for a gatable oscillator
|
2013-12-23 03:32:34 +00:00
|
|
|
"allwinner,sun4i-pll1-clk" - for the main PLL clock and PLL4
|
2013-07-23 21:34:10 +00:00
|
|
|
"allwinner,sun6i-a31-pll1-clk" - for the main PLL clock on A31
|
2013-12-23 03:32:37 +00:00
|
|
|
"allwinner,sun4i-pll5-clk" - for the PLL5 clock
|
|
|
|
"allwinner,sun4i-pll6-clk" - for the PLL6 clock
|
2013-03-27 02:39:17 +00:00
|
|
|
"allwinner,sun4i-cpu-clk" - for the CPU multiplexer clock
|
|
|
|
"allwinner,sun4i-axi-clk" - for the AXI clock
|
2013-03-27 21:20:37 +00:00
|
|
|
"allwinner,sun4i-axi-gates-clk" - for the AXI gates
|
2013-03-27 02:39:17 +00:00
|
|
|
"allwinner,sun4i-ahb-clk" - for the AHB clock
|
2013-04-30 09:56:22 +00:00
|
|
|
"allwinner,sun4i-ahb-gates-clk" - for the AHB gates on A10
|
|
|
|
"allwinner,sun5i-a13-ahb-gates-clk" - for the AHB gates on A13
|
2013-07-16 09:21:59 +00:00
|
|
|
"allwinner,sun5i-a10s-ahb-gates-clk" - for the AHB gates on A10s
|
2013-07-25 19:06:56 +00:00
|
|
|
"allwinner,sun7i-a20-ahb-gates-clk" - for the AHB gates on A20
|
2013-07-23 21:34:10 +00:00
|
|
|
"allwinner,sun6i-a31-ahb1-mux-clk" - for the AHB1 multiplexer on A31
|
|
|
|
"allwinner,sun6i-a31-ahb1-gates-clk" - for the AHB1 gates on A31
|
2013-03-27 02:39:17 +00:00
|
|
|
"allwinner,sun4i-apb0-clk" - for the APB0 clock
|
2013-04-30 09:56:22 +00:00
|
|
|
"allwinner,sun4i-apb0-gates-clk" - for the APB0 gates on A10
|
|
|
|
"allwinner,sun5i-a13-apb0-gates-clk" - for the APB0 gates on A13
|
2013-07-16 09:21:59 +00:00
|
|
|
"allwinner,sun5i-a10s-apb0-gates-clk" - for the APB0 gates on A10s
|
2013-07-25 19:06:56 +00:00
|
|
|
"allwinner,sun7i-a20-apb0-gates-clk" - for the APB0 gates on A20
|
2013-03-27 02:39:17 +00:00
|
|
|
"allwinner,sun4i-apb1-clk" - for the APB1 clock
|
|
|
|
"allwinner,sun4i-apb1-mux-clk" - for the APB1 clock muxing
|
2013-04-30 09:56:22 +00:00
|
|
|
"allwinner,sun4i-apb1-gates-clk" - for the APB1 gates on A10
|
|
|
|
"allwinner,sun5i-a13-apb1-gates-clk" - for the APB1 gates on A13
|
2013-07-16 09:21:59 +00:00
|
|
|
"allwinner,sun5i-a10s-apb1-gates-clk" - for the APB1 gates on A10s
|
2013-07-23 21:34:10 +00:00
|
|
|
"allwinner,sun6i-a31-apb1-gates-clk" - for the APB1 gates on A31
|
2013-07-25 19:06:56 +00:00
|
|
|
"allwinner,sun7i-a20-apb1-gates-clk" - for the APB1 gates on A20
|
2013-07-23 21:34:10 +00:00
|
|
|
"allwinner,sun6i-a31-apb2-div-clk" - for the APB2 gates on A31
|
|
|
|
"allwinner,sun6i-a31-apb2-gates-clk" - for the APB2 gates on A31
|
2013-12-23 03:32:39 +00:00
|
|
|
"allwinner,sun4i-mod0-clk" - for the module 0 family of clocks
|
2013-12-24 13:26:17 +00:00
|
|
|
"allwinner,sun7i-a20-out-clk" - for the external output clocks
|
2014-02-07 15:21:50 +00:00
|
|
|
"allwinner,sun4i-a10-usb-clk" - for usb gates + resets on A10 / A20
|
|
|
|
"allwinner,sun5i-a13-usb-clk" - for usb gates + resets on A13
|
2013-02-25 14:44:26 +00:00
|
|
|
|
|
|
|
Required properties for all clocks:
|
|
|
|
- reg : shall be the control register address for the clock.
|
2013-12-23 03:32:39 +00:00
|
|
|
- clocks : shall be the input parent clock(s) phandle for the clock. For
|
|
|
|
multiplexed clocks, the list order must match the hardware
|
|
|
|
programming order.
|
2013-03-27 21:20:37 +00:00
|
|
|
- #clock-cells : from common clock binding; shall be set to 0 except for
|
2014-02-03 01:51:38 +00:00
|
|
|
"allwinner,*-gates-clk", "allwinner,sun4i-pll5-clk" and
|
|
|
|
"allwinner,sun4i-pll6-clk" where it shall be set to 1
|
|
|
|
- clock-output-names : shall be the corresponding names of the outputs.
|
|
|
|
If the clock module only has one output, the name shall be the
|
|
|
|
module name.
|
2013-02-25 14:44:26 +00:00
|
|
|
|
2014-02-07 15:21:50 +00:00
|
|
|
And "allwinner,*-usb-clk" clocks also require:
|
|
|
|
- reset-cells : shall be set to 1
|
|
|
|
|
2013-04-30 09:56:22 +00:00
|
|
|
Clock consumers should specify the desired clocks they use with a
|
|
|
|
"clocks" phandle cell. Consumers that are using a gated clock should
|
2013-10-04 21:19:54 +00:00
|
|
|
provide an additional ID in their clock property. This ID is the
|
|
|
|
offset of the bit controlling this particular gate in the register.
|
2013-04-30 09:56:22 +00:00
|
|
|
|
2013-02-25 14:44:26 +00:00
|
|
|
For example:
|
|
|
|
|
2014-02-03 01:51:38 +00:00
|
|
|
osc24M: clk@01c20050 {
|
2013-02-25 14:44:26 +00:00
|
|
|
#clock-cells = <0>;
|
2013-03-27 02:39:17 +00:00
|
|
|
compatible = "allwinner,sun4i-osc-clk";
|
2013-02-25 14:44:26 +00:00
|
|
|
reg = <0x01c20050 0x4>;
|
|
|
|
clocks = <&osc24M_fixed>;
|
2014-02-03 01:51:38 +00:00
|
|
|
clock-output-names = "osc24M";
|
2013-02-25 14:44:26 +00:00
|
|
|
};
|
|
|
|
|
2014-02-03 01:51:38 +00:00
|
|
|
pll1: clk@01c20000 {
|
2013-02-25 14:44:26 +00:00
|
|
|
#clock-cells = <0>;
|
2013-03-27 02:39:17 +00:00
|
|
|
compatible = "allwinner,sun4i-pll1-clk";
|
2013-02-25 14:44:26 +00:00
|
|
|
reg = <0x01c20000 0x4>;
|
|
|
|
clocks = <&osc24M>;
|
2014-02-03 01:51:38 +00:00
|
|
|
clock-output-names = "pll1";
|
|
|
|
};
|
|
|
|
|
|
|
|
pll5: clk@01c20020 {
|
|
|
|
#clock-cells = <1>;
|
|
|
|
compatible = "allwinner,sun4i-pll5-clk";
|
|
|
|
reg = <0x01c20020 0x4>;
|
|
|
|
clocks = <&osc24M>;
|
|
|
|
clock-output-names = "pll5_ddr", "pll5_other";
|
2013-02-25 14:44:26 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
cpu: cpu@01c20054 {
|
|
|
|
#clock-cells = <0>;
|
2013-03-27 02:39:17 +00:00
|
|
|
compatible = "allwinner,sun4i-cpu-clk";
|
2013-02-25 14:44:26 +00:00
|
|
|
reg = <0x01c20054 0x4>;
|
|
|
|
clocks = <&osc32k>, <&osc24M>, <&pll1>;
|
2014-02-03 01:51:38 +00:00
|
|
|
clock-output-names = "cpu";
|
|
|
|
};
|
|
|
|
|
|
|
|
mmc0_clk: clk@01c20088 {
|
|
|
|
#clock-cells = <0>;
|
|
|
|
compatible = "allwinner,sun4i-mod0-clk";
|
|
|
|
reg = <0x01c20088 0x4>;
|
|
|
|
clocks = <&osc24M>, <&pll6 1>, <&pll5 1>;
|
|
|
|
clock-output-names = "mmc0";
|
2013-02-25 14:44:26 +00:00
|
|
|
};
|