mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-06 13:55:08 +08:00
08488e20cc
Patch adds DT entries for clockgen A0/1/10/11/12 Signed-off-by: Pankaj Dev <pankaj.dev@st.com> Signed-off-by: Gabriel Fernandez <gabriel.fernandez@linaro.org> Signed-off-by: Maxime Coquelin <maxime.coquelin@st.com>
532 lines
13 KiB
Plaintext
532 lines
13 KiB
Plaintext
/*
|
|
* Copyright (C) 2013 STMicroelectronics R&D Limited
|
|
* <stlinux-devel@stlinux.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* published by the Free Software Foundation.
|
|
*/
|
|
|
|
#include <dt-bindings/clock/stih416-clks.h>
|
|
|
|
/ {
|
|
clocks {
|
|
#address-cells = <1>;
|
|
#size-cells = <1>;
|
|
ranges;
|
|
|
|
/*
|
|
* Fixed 30MHz oscillator inputs to SoC
|
|
*/
|
|
clk_sysin: clk-sysin {
|
|
#clock-cells = <0>;
|
|
compatible = "fixed-clock";
|
|
clock-frequency = <30000000>;
|
|
};
|
|
|
|
/*
|
|
* ARM Peripheral clock for timers
|
|
*/
|
|
arm_periph_clk: arm_periph_clk {
|
|
#clock-cells = <0>;
|
|
compatible = "fixed-clock";
|
|
clock-frequency = <600000000>;
|
|
};
|
|
|
|
/*
|
|
* Bootloader initialized system infrastructure clock for
|
|
* serial devices.
|
|
*/
|
|
CLK_S_ICN_REG_0: clockgenA0@4 {
|
|
#clock-cells = <0>;
|
|
compatible = "fixed-clock";
|
|
clock-frequency = <100000000>;
|
|
clock-output-names = "CLK_S_ICN_REG_0";
|
|
};
|
|
|
|
CLK_S_GMAC0_PHY: clockgenA1@7 {
|
|
#clock-cells = <0>;
|
|
compatible = "fixed-clock";
|
|
clock-frequency = <25000000>;
|
|
clock-output-names = "CLK_S_GMAC0_PHY";
|
|
};
|
|
|
|
CLK_S_ETH1_PHY: clockgenA0@7 {
|
|
#clock-cells = <0>;
|
|
compatible = "fixed-clock";
|
|
clock-frequency = <25000000>;
|
|
clock-output-names = "CLK_S_ETH1_PHY";
|
|
};
|
|
|
|
/*
|
|
* ClockGenAs on SASG2
|
|
*/
|
|
clockgen-a@fee62000 {
|
|
reg = <0xfee62000 0xb48>;
|
|
|
|
clk_s_a0_pll: clk-s-a0-pll {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-plls-c65";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-s-a0-pll0-hs",
|
|
"clk-s-a0-pll0-ls",
|
|
"clk-s-a0-pll1";
|
|
};
|
|
|
|
clk_s_a0_osc_prediv: clk-s-a0-osc-prediv {
|
|
#clock-cells = <0>;
|
|
compatible = "st,clkgena-prediv-c65",
|
|
"st,clkgena-prediv";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-s-a0-osc-prediv";
|
|
};
|
|
|
|
clk_s_a0_hs: clk-s-a0-hs {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c65-hs",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_s_a0_osc_prediv>,
|
|
<&clk_s_a0_pll 0>, /* PLL0 HS */
|
|
<&clk_s_a0_pll 2>; /* PLL1 */
|
|
|
|
clock-output-names = "clk-s-fdma-0",
|
|
"clk-s-fdma-1",
|
|
""; /* clk-s-jit-sense */
|
|
/* Fourth output unused */
|
|
};
|
|
|
|
clk_s_a0_ls: clk-s-a0-ls {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c65-ls",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_s_a0_osc_prediv>,
|
|
<&clk_s_a0_pll 1>, /* PLL0 LS */
|
|
<&clk_s_a0_pll 2>; /* PLL1 */
|
|
|
|
clock-output-names = "clk-s-icn-reg-0",
|
|
"clk-s-icn-if-0",
|
|
"clk-s-icn-reg-lp-0",
|
|
"clk-s-emiss",
|
|
"clk-s-eth1-phy",
|
|
"clk-s-mii-ref-out";
|
|
/* Remaining outputs unused */
|
|
};
|
|
};
|
|
|
|
clockgen-a@fee81000 {
|
|
reg = <0xfee81000 0xb48>;
|
|
|
|
clk_s_a1_pll: clk-s-a1-pll {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-plls-c65";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-s-a1-pll0-hs",
|
|
"clk-s-a1-pll0-ls",
|
|
"clk-s-a1-pll1";
|
|
};
|
|
|
|
clk_s_a1_osc_prediv: clk-s-a1-osc-prediv {
|
|
#clock-cells = <0>;
|
|
compatible = "st,clkgena-prediv-c65",
|
|
"st,clkgena-prediv";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-s-a1-osc-prediv";
|
|
};
|
|
|
|
clk_s_a1_hs: clk-s-a1-hs {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c65-hs",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_s_a1_osc_prediv>,
|
|
<&clk_s_a1_pll 0>, /* PLL0 HS */
|
|
<&clk_s_a1_pll 2>; /* PLL1 */
|
|
|
|
clock-output-names = "", /* Reserved */
|
|
"", /* Reserved */
|
|
"clk-s-stac-phy",
|
|
"clk-s-vtac-tx-phy";
|
|
};
|
|
|
|
clk_s_a1_ls: clk-s-a1-ls {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c65-ls",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_s_a1_osc_prediv>,
|
|
<&clk_s_a1_pll 1>, /* PLL0 LS */
|
|
<&clk_s_a1_pll 2>; /* PLL1 */
|
|
|
|
clock-output-names = "clk-s-icn-if-2",
|
|
"clk-s-card-mmc-0",
|
|
"clk-s-icn-if-1",
|
|
"clk-s-gmac0-phy",
|
|
"clk-s-nand-ctrl",
|
|
"", /* Reserved */
|
|
"clk-s-mii0-ref-out",
|
|
"clk-s-stac-sys",
|
|
"clk-s-card-mmc-1";
|
|
/* Remaining outputs unused */
|
|
};
|
|
};
|
|
|
|
/*
|
|
* ClockGenAs on MPE42
|
|
*/
|
|
clockgen-a@fde12000 {
|
|
reg = <0xfde12000 0xb50>;
|
|
|
|
clk_m_a0_pll0: clk-m-a0-pll0 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,plls-c32-a1x-0", "st,clkgen-plls-c32";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-m-a0-pll0-phi0",
|
|
"clk-m-a0-pll0-phi1",
|
|
"clk-m-a0-pll0-phi2",
|
|
"clk-m-a0-pll0-phi3";
|
|
};
|
|
|
|
clk_m_a0_pll1: clk-m-a0-pll1 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,plls-c32-a1x-1", "st,clkgen-plls-c32";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-m-a0-pll1-phi0",
|
|
"clk-m-a0-pll1-phi1",
|
|
"clk-m-a0-pll1-phi2",
|
|
"clk-m-a0-pll1-phi3";
|
|
};
|
|
|
|
clk_m_a0_osc_prediv: clk-m-a0-osc-prediv {
|
|
#clock-cells = <0>;
|
|
compatible = "st,clkgena-prediv-c32",
|
|
"st,clkgena-prediv";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-m-a0-osc-prediv";
|
|
};
|
|
|
|
clk_m_a0_div0: clk-m-a0-div0 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c32-odf0",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_m_a0_osc_prediv>,
|
|
<&clk_m_a0_pll0 0>, /* PLL0 PHI0 */
|
|
<&clk_m_a0_pll1 0>; /* PLL1 PHI0 */
|
|
|
|
clock-output-names = "", /* Unused */
|
|
"", /* Unused */
|
|
"clk-m-fdma-12",
|
|
"", /* Unused */
|
|
"clk-m-pp-dmu-0",
|
|
"clk-m-pp-dmu-1",
|
|
"clk-m-icm-lmi",
|
|
"clk-m-vid-dmu-0";
|
|
};
|
|
|
|
clk_m_a0_div1: clk-m-a0-div1 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c32-odf1",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_m_a0_osc_prediv>,
|
|
<&clk_m_a0_pll0 1>, /* PLL0 PHI1 */
|
|
<&clk_m_a0_pll1 1>; /* PLL1 PHI1 */
|
|
|
|
clock-output-names = "clk-m-vid-dmu-1",
|
|
"", /* Unused */
|
|
"clk-m-a9-ext2f",
|
|
"clk-m-st40rt",
|
|
"clk-m-st231-dmu-0",
|
|
"clk-m-st231-dmu-1",
|
|
"clk-m-st231-aud",
|
|
"clk-m-st231-gp-0";
|
|
};
|
|
|
|
clk_m_a0_div2: clk-m-a0-div2 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c32-odf2",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_m_a0_osc_prediv>,
|
|
<&clk_m_a0_pll0 2>, /* PLL0 PHI2 */
|
|
<&clk_m_a0_pll1 2>; /* PLL1 PHI2 */
|
|
|
|
clock-output-names = "clk-m-st231-gp-1",
|
|
"clk-m-icn-cpu",
|
|
"clk-m-icn-stac",
|
|
"clk-m-tx-icn-dmu-0",
|
|
"clk-m-tx-icn-dmu-1",
|
|
"clk-m-tx-icn-ts",
|
|
"clk-m-icn-vdp-0",
|
|
"clk-m-icn-vdp-1";
|
|
};
|
|
|
|
clk_m_a0_div3: clk-m-a0-div3 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c32-odf3",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_m_a0_osc_prediv>,
|
|
<&clk_m_a0_pll0 3>, /* PLL0 PHI3 */
|
|
<&clk_m_a0_pll1 3>; /* PLL1 PHI3 */
|
|
|
|
clock-output-names = "", /* Unused */
|
|
"", /* Unused */
|
|
"", /* Unused */
|
|
"", /* Unused */
|
|
"clk-m-icn-vp8",
|
|
"", /* Unused */
|
|
"clk-m-icn-reg-11",
|
|
"clk-m-a9-trace";
|
|
};
|
|
};
|
|
|
|
clockgen-a@fd6db000 {
|
|
reg = <0xfd6db000 0xb50>;
|
|
|
|
clk_m_a1_pll0: clk-m-a1-pll0 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,plls-c32-a1x-0", "st,clkgen-plls-c32";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-m-a1-pll0-phi0",
|
|
"clk-m-a1-pll0-phi1",
|
|
"clk-m-a1-pll0-phi2",
|
|
"clk-m-a1-pll0-phi3";
|
|
};
|
|
|
|
clk_m_a1_pll1: clk-m-a1-pll1 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,plls-c32-a1x-1", "st,clkgen-plls-c32";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-m-a1-pll1-phi0",
|
|
"clk-m-a1-pll1-phi1",
|
|
"clk-m-a1-pll1-phi2",
|
|
"clk-m-a1-pll1-phi3";
|
|
};
|
|
|
|
clk_m_a1_osc_prediv: clk-m-a1-osc-prediv {
|
|
#clock-cells = <0>;
|
|
compatible = "st,clkgena-prediv-c32",
|
|
"st,clkgena-prediv";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-m-a1-osc-prediv";
|
|
};
|
|
|
|
clk_m_a1_div0: clk-m-a1-div0 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c32-odf0",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_m_a1_osc_prediv>,
|
|
<&clk_m_a1_pll0 0>, /* PLL0 PHI0 */
|
|
<&clk_m_a1_pll1 0>; /* PLL1 PHI0 */
|
|
|
|
clock-output-names = "", /* Unused */
|
|
"clk-m-fdma-10",
|
|
"clk-m-fdma-11",
|
|
"clk-m-hva-alt",
|
|
"clk-m-proc-sc",
|
|
"clk-m-tp",
|
|
"clk-m-rx-icn-dmu-0",
|
|
"clk-m-rx-icn-dmu-1";
|
|
};
|
|
|
|
clk_m_a1_div1: clk-m-a1-div1 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c32-odf1",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_m_a1_osc_prediv>,
|
|
<&clk_m_a1_pll0 1>, /* PLL0 PHI1 */
|
|
<&clk_m_a1_pll1 1>; /* PLL1 PHI1 */
|
|
|
|
clock-output-names = "clk-m-rx-icn-ts",
|
|
"clk-m-rx-icn-vdp-0",
|
|
"", /* Unused */
|
|
"clk-m-prv-t1-bus",
|
|
"clk-m-icn-reg-12",
|
|
"clk-m-icn-reg-10",
|
|
"", /* Unused */
|
|
"clk-m-icn-st231";
|
|
};
|
|
|
|
clk_m_a1_div2: clk-m-a1-div2 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c32-odf2",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_m_a1_osc_prediv>,
|
|
<&clk_m_a1_pll0 2>, /* PLL0 PHI2 */
|
|
<&clk_m_a1_pll1 2>; /* PLL1 PHI2 */
|
|
|
|
clock-output-names = "clk-m-fvdp-proc-alt",
|
|
"clk-m-icn-reg-13",
|
|
"clk-m-tx-icn-gpu",
|
|
"clk-m-rx-icn-gpu",
|
|
"", /* Unused */
|
|
"", /* Unused */
|
|
"", /* clk-m-apb-pm-12 */
|
|
""; /* Unused */
|
|
};
|
|
|
|
clk_m_a1_div3: clk-m-a1-div3 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c32-odf3",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_m_a1_osc_prediv>,
|
|
<&clk_m_a1_pll0 3>, /* PLL0 PHI3 */
|
|
<&clk_m_a1_pll1 3>; /* PLL1 PHI3 */
|
|
|
|
clock-output-names = "", /* Unused */
|
|
"", /* Unused */
|
|
"", /* Unused */
|
|
"", /* Unused */
|
|
"", /* Unused */
|
|
"", /* Unused */
|
|
"", /* Unused */
|
|
""; /* clk-m-gpu-alt */
|
|
};
|
|
};
|
|
|
|
clk_m_a9_ext2f_div2: clk-m-a9-ext2f-div2 {
|
|
#clock-cells = <0>;
|
|
compatible = "fixed-factor-clock";
|
|
clocks = <&clk_m_a0_div1 2>;
|
|
clock-div = <2>;
|
|
clock-mult = <1>;
|
|
};
|
|
|
|
clockgen-a@fd345000 {
|
|
reg = <0xfd345000 0xb50>;
|
|
|
|
clk_m_a2_pll0: clk-m-a2-pll0 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,plls-c32-a1x-0", "st,clkgen-plls-c32";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-m-a2-pll0-phi0",
|
|
"clk-m-a2-pll0-phi1",
|
|
"clk-m-a2-pll0-phi2",
|
|
"clk-m-a2-pll0-phi3";
|
|
};
|
|
|
|
clk_m_a2_pll1: clk-m-a2-pll1 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,plls-c32-a1x-1", "st,clkgen-plls-c32";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-m-a2-pll1-phi0",
|
|
"clk-m-a2-pll1-phi1",
|
|
"clk-m-a2-pll1-phi2",
|
|
"clk-m-a2-pll1-phi3";
|
|
};
|
|
|
|
clk_m_a2_osc_prediv: clk-m-a2-osc-prediv {
|
|
#clock-cells = <0>;
|
|
compatible = "st,clkgena-prediv-c32",
|
|
"st,clkgena-prediv";
|
|
|
|
clocks = <&clk_sysin>;
|
|
|
|
clock-output-names = "clk-m-a2-osc-prediv";
|
|
};
|
|
|
|
clk_m_a2_div0: clk-m-a2-div0 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c32-odf0",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_m_a2_osc_prediv>,
|
|
<&clk_m_a2_pll0 0>, /* PLL0 PHI0 */
|
|
<&clk_m_a2_pll1 0>; /* PLL1 PHI0 */
|
|
|
|
clock-output-names = "clk-m-vtac-main-phy",
|
|
"clk-m-vtac-aux-phy",
|
|
"clk-m-stac-phy",
|
|
"clk-m-stac-sys",
|
|
"", /* clk-m-mpestac-pg */
|
|
"", /* clk-m-mpestac-wc */
|
|
"", /* clk-m-mpevtacaux-pg*/
|
|
""; /* clk-m-mpevtacmain-pg*/
|
|
};
|
|
|
|
clk_m_a2_div1: clk-m-a2-div1 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c32-odf1",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_m_a2_osc_prediv>,
|
|
<&clk_m_a2_pll0 1>, /* PLL0 PHI1 */
|
|
<&clk_m_a2_pll1 1>; /* PLL1 PHI1 */
|
|
|
|
clock-output-names = "", /* clk-m-mpevtacrx0-wc */
|
|
"", /* clk-m-mpevtacrx1-wc */
|
|
"clk-m-compo-main",
|
|
"clk-m-compo-aux",
|
|
"clk-m-bdisp-0",
|
|
"clk-m-bdisp-1",
|
|
"clk-m-icn-bdisp",
|
|
"clk-m-icn-compo";
|
|
};
|
|
|
|
clk_m_a2_div2: clk-m-a2-div2 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c32-odf2",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_m_a2_osc_prediv>,
|
|
<&clk_m_a2_pll0 2>, /* PLL0 PHI2 */
|
|
<&clk_m_a2_pll1 2>; /* PLL1 PHI2 */
|
|
|
|
clock-output-names = "clk-m-icn-vdp-2",
|
|
"", /* Unused */
|
|
"clk-m-icn-reg-14",
|
|
"clk-m-mdtp",
|
|
"clk-m-jpegdec",
|
|
"", /* Unused */
|
|
"clk-m-dcephy-impctrl",
|
|
""; /* Unused */
|
|
};
|
|
|
|
clk_m_a2_div3: clk-m-a2-div3 {
|
|
#clock-cells = <1>;
|
|
compatible = "st,clkgena-divmux-c32-odf3",
|
|
"st,clkgena-divmux";
|
|
|
|
clocks = <&clk_m_a2_osc_prediv>,
|
|
<&clk_m_a2_pll0 3>, /* PLL0 PHI3 */
|
|
<&clk_m_a2_pll1 3>; /* PLL1 PHI3 */
|
|
|
|
clock-output-names = "", /* Unused */
|
|
""; /* clk-m-apb-pm-11 */
|
|
/* Remaining outputs unused */
|
|
};
|
|
};
|
|
};
|
|
};
|