ARM: dts: stih410-b2260: Sync DT with kernel v5.2

Synchronize U-boot DT with kernel v5.2 for stih410-b2260.
Update stih410-b2260-u-boot.dtsi accordingly.

Signed-off-by: Patrice Chotard <patrice.chotard@st.com>
This commit is contained in:
Patrice Chotard 2019-07-23 15:33:30 +02:00
parent 2e01fcf17c
commit 0203050e57
8 changed files with 380 additions and 571 deletions

View file

@ -1,38 +1,29 @@
// SPDX-License-Identifier: GPL-2.0-only
/* /*
* Copyright (C) 2014 STMicroelectronics R&D Limited * Copyright (C) 2014 STMicroelectronics R&D Limited
*
* 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/stih407-clks.h> #include <dt-bindings/clock/stih407-clks.h>
/ { / {
/*
* Fixed 30MHz oscillator inputs to SoC
*/
clk_sysin: clk-sysin {
#clock-cells = <0>;
compatible = "fixed-clock";
clock-frequency = <30000000>;
};
clk_tmdsout_hdmi: clk-tmdsout-hdmi {
#clock-cells = <0>;
compatible = "fixed-clock";
clock-frequency = <0>;
};
clocks { clocks {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <1>; #size-cells = <1>;
ranges; 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: clk-m-a9-periphs {
#clock-cells = <0>;
compatible = "fixed-factor-clock";
clocks = <&clk_m_a9>;
clock-div = <2>;
clock-mult = <1>;
};
/* /*
* A9 PLL. * A9 PLL.
*/ */
@ -62,35 +53,22 @@
<&clockgen_a9_pll 0>, <&clockgen_a9_pll 0>,
<&clk_s_c0_flexgen 13>, <&clk_s_c0_flexgen 13>,
<&clk_m_a9_ext2f_div2>; <&clk_m_a9_ext2f_div2>;
/*
* ARM Peripheral clock for timers
*/
arm_periph_clk: clk-m-a9-periphs {
#clock-cells = <0>;
compatible = "fixed-factor-clock";
clocks = <&clk_m_a9>;
clock-div = <2>;
clock-mult = <1>;
};
}; };
/* clockgen-a@90ff000 {
* ARM Peripheral clock for timers
*/
clk_m_a9_ext2f_div2: clk-m-a9-ext2f-div2s {
#clock-cells = <0>;
compatible = "fixed-factor-clock";
clocks = <&clk_s_c0_flexgen 13>;
clock-output-names = "clk-m-a9-ext2f-div2";
clock-div = <2>;
clock-mult = <1>;
};
/*
* Bootloader initialized system infrastructure clock for
* serial devices.
*/
clk_ext2f_a9: clockgen-c0@13 {
#clock-cells = <0>;
compatible = "fixed-clock";
clock-frequency = <200000000>;
clock-output-names = "clk-s-icn-reg-0";
};
clockgen-a@090ff000 {
compatible = "st,clkgen-c32"; compatible = "st,clkgen-c32";
reg = <0x90ff000 0x1000>; reg = <0x90ff000 0x1000>;
@ -101,6 +79,7 @@
clocks = <&clk_sysin>; clocks = <&clk_sysin>;
clock-output-names = "clk-s-a0-pll-ofd-0"; clock-output-names = "clk-s-a0-pll-ofd-0";
clock-critical = <0>; /* clk-s-a0-pll-ofd-0 */
}; };
clk_s_a0_flexgen: clk-s-a0-flexgen { clk_s_a0_flexgen: clk-s-a0-flexgen {
@ -112,6 +91,7 @@
<&clk_sysin>; <&clk_sysin>;
clock-output-names = "clk-ic-lmi0"; clock-output-names = "clk-ic-lmi0";
clock-critical = <CLK_IC_LMI0>;
}; };
}; };
@ -126,9 +106,10 @@
"clk-s-c0-fs0-ch1", "clk-s-c0-fs0-ch1",
"clk-s-c0-fs0-ch2", "clk-s-c0-fs0-ch2",
"clk-s-c0-fs0-ch3"; "clk-s-c0-fs0-ch3";
clock-critical = <0>; /* clk-s-c0-fs0-ch0 */
}; };
clk_s_c0: clockgen-c@09103000 { clk_s_c0: clockgen-c@9103000 {
compatible = "st,clkgen-c32"; compatible = "st,clkgen-c32";
reg = <0x9103000 0x1000>; reg = <0x9103000 0x1000>;
@ -139,6 +120,7 @@
clocks = <&clk_sysin>; clocks = <&clk_sysin>;
clock-output-names = "clk-s-c0-pll0-odf-0"; clock-output-names = "clk-s-c0-pll0-odf-0";
clock-critical = <0>; /* clk-s-c0-pll0-odf-0 */
}; };
clk_s_c0_pll1: clk-s-c0-pll1 { clk_s_c0_pll1: clk-s-c0-pll1 {
@ -194,6 +176,27 @@
"clk-main-disp", "clk-main-disp",
"clk-aux-disp", "clk-aux-disp",
"clk-compo-dvp"; "clk-compo-dvp";
clock-critical = <CLK_PROC_STFE>,
<CLK_ICN_CPU>,
<CLK_TX_ICN_DMU>,
<CLK_EXT2F_A9>,
<CLK_ICN_LMI>,
<CLK_ICN_SBC>;
/*
* ARM Peripheral clock for timers
*/
clk_m_a9_ext2f_div2: clk-m-a9-ext2f-div2s {
#clock-cells = <0>;
compatible = "fixed-factor-clock";
clocks = <&clk_s_c0_flexgen 13>;
clock-output-names = "clk-m-a9-ext2f-div2";
clock-div = <2>;
clock-mult = <1>;
};
}; };
}; };
@ -210,7 +213,7 @@
"clk-s-d0-fs0-ch3"; "clk-s-d0-fs0-ch3";
}; };
clockgen-d0@09104000 { clockgen-d0@9104000 {
compatible = "st,clkgen-c32"; compatible = "st,clkgen-c32";
reg = <0x9104000 0x1000>; reg = <0x9104000 0x1000>;
@ -244,13 +247,7 @@
"clk-s-d2-fs0-ch3"; "clk-s-d2-fs0-ch3";
}; };
clk_tmdsout_hdmi: clk-tmdsout-hdmi { clockgen-d2@9106000 {
#clock-cells = <0>;
compatible = "fixed-clock";
clock-frequency = <0>;
};
clockgen-d2@x9106000 {
compatible = "st,clkgen-c32"; compatible = "st,clkgen-c32";
reg = <0x9106000 0x1000>; reg = <0x9106000 0x1000>;

View file

@ -1,10 +1,7 @@
// SPDX-License-Identifier: GPL-2.0-only
/* /*
* Copyright (C) 2014 STMicroelectronics Limited. * Copyright (C) 2014 STMicroelectronics Limited.
* Author: Giuseppe Cavallaro <peppe.cavallaro@st.com> * Author: Giuseppe Cavallaro <peppe.cavallaro@st.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
* publishhed by the Free Software Foundation.
*/ */
#include "stih407-pinctrl.dtsi" #include "stih407-pinctrl.dtsi"
#include <dt-bindings/mfd/st-lpc.h> #include <dt-bindings/mfd/st-lpc.h>
@ -20,7 +17,13 @@
#size-cells = <1>; #size-cells = <1>;
ranges; ranges;
dmu_reserved: rproc@44000000 { gp0_reserved: rproc@45000000 {
compatible = "shared-dma-pool";
reg = <0x45000000 0x00400000>;
no-map;
};
delta_reserved: rproc@44000000 {
compatible = "shared-dma-pool"; compatible = "shared-dma-pool";
reg = <0x44000000 0x01000000>; reg = <0x44000000 0x01000000>;
no-map; no-map;
@ -47,6 +50,7 @@
clocks = <&clk_m_a9>; clocks = <&clk_m_a9>;
clock-names = "cpu"; clock-names = "cpu";
clock-latency = <100000>; clock-latency = <100000>;
cpu0-supply = <&pwm_regulator>;
st,syscfg = <&syscfg_core 0x8e0>; st,syscfg = <&syscfg_core 0x8e0>;
}; };
cpu@1 { cpu@1 {
@ -65,19 +69,19 @@
}; };
}; };
intc: interrupt-controller@08761000 { intc: interrupt-controller@8761000 {
compatible = "arm,cortex-a9-gic"; compatible = "arm,cortex-a9-gic";
#interrupt-cells = <3>; #interrupt-cells = <3>;
interrupt-controller; interrupt-controller;
reg = <0x08761000 0x1000>, <0x08760100 0x100>; reg = <0x08761000 0x1000>, <0x08760100 0x100>;
}; };
scu@08760000 { scu@8760000 {
compatible = "arm,cortex-a9-scu"; compatible = "arm,cortex-a9-scu";
reg = <0x08760000 0x1000>; reg = <0x08760000 0x1000>;
}; };
timer@08760200 { timer@8760200 {
interrupt-parent = <&intc>; interrupt-parent = <&intc>;
compatible = "arm,cortex-a9-global-timer"; compatible = "arm,cortex-a9-global-timer";
reg = <0x08760200 0x100>; reg = <0x08760200 0x100>;
@ -85,7 +89,7 @@
clocks = <&arm_periph_clk>; clocks = <&arm_periph_clk>;
}; };
l2: cache-controller { l2: cache-controller@8762000 {
compatible = "arm,pl310-cache"; compatible = "arm,pl310-cache";
reg = <0x08762000 0x1000>; reg = <0x08762000 0x1000>;
arm,data-latency = <3 3 3>; arm,data-latency = <3 3 3>;
@ -118,24 +122,28 @@
ranges; ranges;
compatible = "simple-bus"; compatible = "simple-bus";
restart { restart: restart-controller@0 {
compatible = "st,stih407-restart"; compatible = "st,stih407-restart";
reg = <0 0>;
st,syscfg = <&syscfg_sbc_reg>; st,syscfg = <&syscfg_sbc_reg>;
status = "okay"; status = "okay";
}; };
powerdown: powerdown-controller { powerdown: powerdown-controller@0 {
compatible = "st,stih407-powerdown"; compatible = "st,stih407-powerdown";
reg = <0 0>;
#reset-cells = <1>; #reset-cells = <1>;
}; };
softreset: softreset-controller { softreset: softreset-controller@0 {
compatible = "st,stih407-softreset"; compatible = "st,stih407-softreset";
reg = <0 0>;
#reset-cells = <1>; #reset-cells = <1>;
}; };
picophyreset: picophyreset-controller { picophyreset: picophyreset-controller@0 {
compatible = "st,stih407-picophyreset"; compatible = "st,stih407-picophyreset";
reg = <0 0>;
#reset-cells = <1>; #reset-cells = <1>;
}; };
@ -167,6 +175,13 @@
syscfg_core: core-syscfg@92b0000 { syscfg_core: core-syscfg@92b0000 {
compatible = "st,stih407-core-syscfg", "syscon"; compatible = "st,stih407-core-syscfg", "syscon";
reg = <0x92b0000 0x1000>; reg = <0x92b0000 0x1000>;
sti_sasg_codec: sti-sasg-codec {
compatible = "st,stih407-sas-codec";
#sound-dai-cells = <1>;
status = "disabled";
st,syscfg = <&syscfg_core>;
};
}; };
syscfg_lpm: lpm-syscfg@94b5100 { syscfg_lpm: lpm-syscfg@94b5100 {
@ -174,8 +189,9 @@
reg = <0x94b5100 0x1000>; reg = <0x94b5100 0x1000>;
}; };
irq-syscfg { irq-syscfg@0 {
compatible = "st,stih407-irq-syscfg"; compatible = "st,stih407-irq-syscfg";
reg = <0 0>;
st,syscfg = <&syscfg_core>; st,syscfg = <&syscfg_core>;
st,irq-device = <ST_IRQ_SYSCFG_PMU_0>, st,irq-device = <ST_IRQ_SYSCFG_PMU_0>,
<ST_IRQ_SYSCFG_PMU_1>; <ST_IRQ_SYSCFG_PMU_1>;
@ -187,22 +203,21 @@
vtg_main: sti-vtg-main@8d02800 { vtg_main: sti-vtg-main@8d02800 {
compatible = "st,vtg"; compatible = "st,vtg";
reg = <0x8d02800 0x200>; reg = <0x8d02800 0x200>;
interrupts = <GIC_SPI 108 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
}; };
vtg_aux: sti-vtg-aux@8d00200 { vtg_aux: sti-vtg-aux@8d00200 {
compatible = "st,vtg"; compatible = "st,vtg";
reg = <0x8d00200 0x100>; reg = <0x8d00200 0x100>;
interrupts = <GIC_SPI 109 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
}; };
serial@9830000 { serial@9830000 {
compatible = "st,asc"; compatible = "st,asc";
reg = <0x9830000 0x2c>; reg = <0x9830000 0x2c>;
interrupts = <GIC_SPI 122 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 122 IRQ_TYPE_LEVEL_HIGH>;
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_serial0>;
clocks = <&clk_s_c0_flexgen CLK_EXT2F_A9>; clocks = <&clk_s_c0_flexgen CLK_EXT2F_A9>;
/* Pinctrl moved out to a per-board configuration */
status = "disabled"; status = "disabled";
}; };
@ -210,7 +225,7 @@
serial@9831000 { serial@9831000 {
compatible = "st,asc"; compatible = "st,asc";
reg = <0x9831000 0x2c>; reg = <0x9831000 0x2c>;
interrupts = <GIC_SPI 123 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 123 IRQ_TYPE_LEVEL_HIGH>;
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_serial1>; pinctrl-0 = <&pinctrl_serial1>;
clocks = <&clk_s_c0_flexgen CLK_EXT2F_A9>; clocks = <&clk_s_c0_flexgen CLK_EXT2F_A9>;
@ -221,7 +236,7 @@
serial@9832000 { serial@9832000 {
compatible = "st,asc"; compatible = "st,asc";
reg = <0x9832000 0x2c>; reg = <0x9832000 0x2c>;
interrupts = <GIC_SPI 124 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 124 IRQ_TYPE_LEVEL_HIGH>;
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_serial2>; pinctrl-0 = <&pinctrl_serial2>;
clocks = <&clk_s_c0_flexgen CLK_EXT2F_A9>; clocks = <&clk_s_c0_flexgen CLK_EXT2F_A9>;
@ -233,7 +248,7 @@
sbc_serial0: serial@9530000 { sbc_serial0: serial@9530000 {
compatible = "st,asc"; compatible = "st,asc";
reg = <0x9530000 0x2c>; reg = <0x9530000 0x2c>;
interrupts = <GIC_SPI 138 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>;
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_sbc_serial0>; pinctrl-0 = <&pinctrl_sbc_serial0>;
clocks = <&clk_sysin>; clocks = <&clk_sysin>;
@ -244,7 +259,7 @@
serial@9531000 { serial@9531000 {
compatible = "st,asc"; compatible = "st,asc";
reg = <0x9531000 0x2c>; reg = <0x9531000 0x2c>;
interrupts = <GIC_SPI 139 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>;
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_sbc_serial1>; pinctrl-0 = <&pinctrl_sbc_serial1>;
clocks = <&clk_sysin>; clocks = <&clk_sysin>;
@ -374,8 +389,9 @@
status = "disabled"; status = "disabled";
}; };
usb2_picophy0: phy1 { usb2_picophy0: phy1@0 {
compatible = "st,stih407-usb2-phy"; compatible = "st,stih407-usb2-phy";
reg = <0 0>;
#phy-cells = <0>; #phy-cells = <0>;
st,syscfg = <&syscfg_core 0x100 0xf4>; st,syscfg = <&syscfg_core 0x100 0xf4>;
resets = <&softreset STIH407_PICOPHY_SOFTRESET>, resets = <&softreset STIH407_PICOPHY_SOFTRESET>,
@ -383,12 +399,13 @@
reset-names = "global", "port"; reset-names = "global", "port";
}; };
miphy28lp_phy: miphy28lp@9b22000 { miphy28lp_phy: miphy28lp@0 {
compatible = "st,miphy28lp-phy"; compatible = "st,miphy28lp-phy";
st,syscfg = <&syscfg_core>; st,syscfg = <&syscfg_core>;
#address-cells = <1>; #address-cells = <1>;
#size-cells = <1>; #size-cells = <1>;
ranges; ranges;
reg = <0 0>;
phy_port0: port@9b22000 { phy_port0: port@9b22000 {
reg = <0x9b22000 0xff>, reg = <0x9b22000 0xff>,
@ -458,6 +475,8 @@
clock-names = "ssc"; clock-names = "ssc";
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_spi1_default>; pinctrl-0 = <&pinctrl_spi1_default>;
#address-cells = <1>;
#size-cells = <0>;
status = "disabled"; status = "disabled";
}; };
@ -470,6 +489,8 @@
clock-names = "ssc"; clock-names = "ssc";
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_spi2_default>; pinctrl-0 = <&pinctrl_spi2_default>;
#address-cells = <1>;
#size-cells = <0>;
status = "disabled"; status = "disabled";
}; };
@ -482,6 +503,8 @@
clock-names = "ssc"; clock-names = "ssc";
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_spi3_default>; pinctrl-0 = <&pinctrl_spi3_default>;
#address-cells = <1>;
#size-cells = <0>;
status = "disabled"; status = "disabled";
}; };
@ -494,6 +517,8 @@
clock-names = "ssc"; clock-names = "ssc";
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_spi4_default>; pinctrl-0 = <&pinctrl_spi4_default>;
#address-cells = <1>;
#size-cells = <0>;
status = "disabled"; status = "disabled";
}; };
@ -507,6 +532,8 @@
clock-names = "ssc"; clock-names = "ssc";
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_spi10_default>; pinctrl-0 = <&pinctrl_spi10_default>;
#address-cells = <1>;
#size-cells = <0>;
status = "disabled"; status = "disabled";
}; };
@ -519,6 +546,8 @@
clock-names = "ssc"; clock-names = "ssc";
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_spi11_default>; pinctrl-0 = <&pinctrl_spi11_default>;
#address-cells = <1>;
#size-cells = <0>;
status = "disabled"; status = "disabled";
}; };
@ -531,16 +560,18 @@
clock-names = "ssc"; clock-names = "ssc";
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_spi12_default>; pinctrl-0 = <&pinctrl_spi12_default>;
#address-cells = <1>;
#size-cells = <0>;
status = "disabled"; status = "disabled";
}; };
mmc0: sdhci@09060000 { mmc0: sdhci@9060000 {
compatible = "st,sdhci-stih407", "st,sdhci"; compatible = "st,sdhci-stih407", "st,sdhci";
status = "disabled"; status = "disabled";
reg = <0x09060000 0x7ff>, <0x9061008 0x20>; reg = <0x09060000 0x7ff>, <0x9061008 0x20>;
reg-names = "mmc", "top-mmc-delay"; reg-names = "mmc", "top-mmc-delay";
interrupts = <GIC_SPI 92 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "mmcirq"; interrupt-names = "mmcirq";
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_mmc0>; pinctrl-0 = <&pinctrl_mmc0>;
@ -550,12 +581,12 @@
bus-width = <8>; bus-width = <8>;
}; };
mmc1: sdhci@09080000 { mmc1: sdhci@9080000 {
compatible = "st,sdhci-stih407", "st,sdhci"; compatible = "st,sdhci-stih407", "st,sdhci";
status = "disabled"; status = "disabled";
reg = <0x09080000 0x7ff>; reg = <0x09080000 0x7ff>;
reg-names = "mmc"; reg-names = "mmc";
interrupts = <GIC_SPI 90 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "mmcirq"; interrupt-names = "mmcirq";
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_sd1>; pinctrl-0 = <&pinctrl_sd1>;
@ -563,7 +594,6 @@
clocks = <&clk_s_c0_flexgen CLK_MMC_1>, clocks = <&clk_s_c0_flexgen CLK_MMC_1>,
<&clk_s_c0_flexgen CLK_RX_ICN_HVA>; <&clk_s_c0_flexgen CLK_RX_ICN_HVA>;
resets = <&softreset STIH407_MMC1_SOFTRESET>; resets = <&softreset STIH407_MMC1_SOFTRESET>;
reset-names = "softreset";
bus-width = <4>; bus-width = <4>;
}; };
@ -590,7 +620,7 @@
compatible = "st,ahci"; compatible = "st,ahci";
reg = <0x9b20000 0x1000>; reg = <0x9b20000 0x1000>;
interrupts = <GIC_SPI 159 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 159 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "hostc"; interrupt-names = "hostc";
phys = <&phy_port0 PHY_TYPE_SATA>; phys = <&phy_port0 PHY_TYPE_SATA>;
@ -613,7 +643,7 @@
compatible = "st,ahci"; compatible = "st,ahci";
reg = <0x9b28000 0x1000>; reg = <0x9b28000 0x1000>;
interrupts = <GIC_SPI 170 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 170 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "hostc"; interrupt-names = "hostc";
phys = <&phy_port1 PHY_TYPE_SATA>; phys = <&phy_port1 PHY_TYPE_SATA>;
@ -654,11 +684,12 @@
dwc3: dwc3@9900000 { dwc3: dwc3@9900000 {
compatible = "snps,dwc3"; compatible = "snps,dwc3";
reg = <0x09900000 0x100000>; reg = <0x09900000 0x100000>;
interrupts = <GIC_SPI 155 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 155 IRQ_TYPE_LEVEL_HIGH>;
dr_mode = "peripheral"; dr_mode = "host";
phy-names = "usb2-phy", "usb3-phy"; phy-names = "usb2-phy", "usb3-phy";
phys = <&usb2_picophy0>, phys = <&usb2_picophy0>,
<&phy_port2 PHY_TYPE_USB3>; <&phy_port2 PHY_TYPE_USB3>;
snps,dis_u3_susphy_quirk;
}; };
}; };
@ -667,7 +698,7 @@
compatible = "st,sti-pwm"; compatible = "st,sti-pwm";
#pwm-cells = <2>; #pwm-cells = <2>;
reg = <0x9810000 0x68>; reg = <0x9810000 0x68>;
interrupts = <GIC_SPI 128 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 128 IRQ_TYPE_LEVEL_HIGH>;
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_pwm0_chan0_default>; pinctrl-0 = <&pinctrl_pwm0_chan0_default>;
clock-names = "pwm"; clock-names = "pwm";
@ -682,6 +713,7 @@
compatible = "st,sti-pwm"; compatible = "st,sti-pwm";
#pwm-cells = <2>; #pwm-cells = <2>;
reg = <0x9510000 0x68>; reg = <0x9510000 0x68>;
interrupts = <GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>;
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_pwm1_chan0_default pinctrl-0 = <&pinctrl_pwm1_chan0_default
&pinctrl_pwm1_chan1_default &pinctrl_pwm1_chan1_default
@ -694,14 +726,14 @@
status = "disabled"; status = "disabled";
}; };
rng10: rng@08a89000 { rng10: rng@8a89000 {
compatible = "st,rng"; compatible = "st,rng";
reg = <0x08a89000 0x1000>; reg = <0x08a89000 0x1000>;
clocks = <&clk_sysin>; clocks = <&clk_sysin>;
status = "okay"; status = "okay";
}; };
rng11: rng@08a8a000 { rng11: rng@8a8a000 {
compatible = "st,rng"; compatible = "st,rng";
reg = <0x08a8a000 0x1000>; reg = <0x08a8a000 0x1000>;
clocks = <&clk_sysin>; clocks = <&clk_sysin>;
@ -720,8 +752,8 @@
resets = <&softreset STIH407_ETH1_SOFTRESET>; resets = <&softreset STIH407_ETH1_SOFTRESET>;
reset-names = "stmmaceth"; reset-names = "stmmaceth";
interrupts = <GIC_SPI 98 IRQ_TYPE_NONE>, interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 99 IRQ_TYPE_NONE>; <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "macirq", "eth_wake_irq"; interrupt-names = "macirq", "eth_wake_irq";
/* DMA Bus Mode */ /* DMA Bus Mode */
@ -735,26 +767,14 @@
<&clk_s_c0_flexgen CLK_ETH_PHY>; <&clk_s_c0_flexgen CLK_ETH_PHY>;
}; };
cec: sti-cec@094a087c { rng10: rng@8a89000 {
compatible = "st,stih-cec";
reg = <0x94a087c 0x64>;
clocks = <&clk_sysin>;
clock-names = "cec-clk";
interrupts = <GIC_SPI 140 IRQ_TYPE_NONE>;
interrupt-names = "cec-irq";
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_cec0_default>;
resets = <&softreset STIH407_LPM_SOFTRESET>;
};
rng10: rng@08a89000 {
compatible = "st,rng"; compatible = "st,rng";
reg = <0x08a89000 0x1000>; reg = <0x08a89000 0x1000>;
clocks = <&clk_sysin>; clocks = <&clk_sysin>;
status = "okay"; status = "okay";
}; };
rng11: rng@08a8a000 { rng11: rng@8a8a000 {
compatible = "st,rng"; compatible = "st,rng";
reg = <0x08a8a000 0x1000>; reg = <0x08a8a000 0x1000>;
clocks = <&clk_sysin>; clocks = <&clk_sysin>;
@ -764,7 +784,7 @@
mailbox0: mailbox@8f00000 { mailbox0: mailbox@8f00000 {
compatible = "st,stih407-mailbox"; compatible = "st,stih407-mailbox";
reg = <0x8f00000 0x1000>; reg = <0x8f00000 0x1000>;
interrupts = <GIC_SPI 1 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
#mbox-cells = <2>; #mbox-cells = <2>;
mbox-name = "a9"; mbox-name = "a9";
status = "okay"; status = "okay";
@ -794,9 +814,24 @@
status = "okay"; status = "okay";
}; };
st231_delta: st231-delta@44000000 { st231_gp0: st231-gp0@0 {
compatible = "st,st231-rproc"; compatible = "st,st231-rproc";
memory-region = <&dmu_reserved>; reg = <0 0>;
memory-region = <&gp0_reserved>;
resets = <&softreset STIH407_ST231_GP0_SOFTRESET>;
reset-names = "sw_reset";
clocks = <&clk_s_c0_flexgen CLK_ST231_GP_0>;
clock-frequency = <600000000>;
st,syscfg = <&syscfg_core 0x22c>;
#mbox-cells = <1>;
mbox-names = "vq0_rx", "vq0_tx", "vq1_rx", "vq1_tx";
mboxes = <&mailbox0 0 2>, <&mailbox2 0 1>, <&mailbox0 0 3>, <&mailbox2 0 0>;
};
st231_delta: st231-delta@0 {
compatible = "st,st231-rproc";
reg = <0 0>;
memory-region = <&delta_reserved>;
resets = <&softreset STIH407_ST231_DMU_SOFTRESET>; resets = <&softreset STIH407_ST231_DMU_SOFTRESET>;
reset-names = "sw_reset"; reset-names = "sw_reset";
clocks = <&clk_s_c0_flexgen CLK_ST231_DMU>; clocks = <&clk_s_c0_flexgen CLK_ST231_DMU>;
@ -819,7 +854,7 @@
<&clk_s_c0_flexgen CLK_EXT2F_A9>, <&clk_s_c0_flexgen CLK_EXT2F_A9>,
<&clk_s_c0_flexgen CLK_EXT2F_A9>, <&clk_s_c0_flexgen CLK_EXT2F_A9>,
<&clk_s_c0_flexgen CLK_EXT2F_A9>; <&clk_s_c0_flexgen CLK_EXT2F_A9>;
interrupts = <GIC_SPI 5 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
dma-channels = <16>; dma-channels = <16>;
#dma-cells = <3>; #dma-cells = <3>;
}; };
@ -837,9 +872,11 @@
<&clk_s_c0_flexgen CLK_TX_ICN_DMU>, <&clk_s_c0_flexgen CLK_TX_ICN_DMU>,
<&clk_s_c0_flexgen CLK_EXT2F_A9>; <&clk_s_c0_flexgen CLK_EXT2F_A9>;
interrupts = <GIC_SPI 7 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
dma-channels = <16>; dma-channels = <16>;
#dma-cells = <3>; #dma-cells = <3>;
status = "disabled";
}; };
/* fdma free running */ /* fdma free running */
@ -850,20 +887,15 @@
<0x8e77000 0x1000>, <0x8e77000 0x1000>,
<0x8e78000 0x8000>; <0x8e78000 0x8000>;
reg-names = "slimcore", "dmem", "peripherals", "imem"; reg-names = "slimcore", "dmem", "peripherals", "imem";
interrupts = <GIC_SPI 9 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
dma-channels = <16>; dma-channels = <16>;
#dma-cells = <3>; #dma-cells = <3>;
clocks = <&clk_s_c0_flexgen CLK_FDMA>, clocks = <&clk_s_c0_flexgen CLK_FDMA>,
<&clk_s_c0_flexgen CLK_EXT2F_A9>, <&clk_s_c0_flexgen CLK_EXT2F_A9>,
<&clk_s_c0_flexgen CLK_TX_ICN_DISP_0>, <&clk_s_c0_flexgen CLK_TX_ICN_DISP_0>,
<&clk_s_c0_flexgen CLK_EXT2F_A9>; <&clk_s_c0_flexgen CLK_EXT2F_A9>;
};
sti_sasg_codec: sti-sasg-codec {
compatible = "st,stih407-sas-codec";
#sound-dai-cells = <1>;
status = "disabled"; status = "disabled";
st,syscfg = <&syscfg_core>;
}; };
sti_uni_player0: sti-uni-player@8d80000 { sti_uni_player0: sti-uni-player@8d80000 {
@ -875,7 +907,7 @@
assigned-clock-parents = <0>, <&clk_s_d0_quadfs 0>; assigned-clock-parents = <0>, <&clk_s_d0_quadfs 0>;
assigned-clock-rates = <50000000>; assigned-clock-rates = <50000000>;
reg = <0x8d80000 0x158>; reg = <0x8d80000 0x158>;
interrupts = <GIC_SPI 84 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
dmas = <&fdma0 2 0 1>; dmas = <&fdma0 2 0 1>;
dma-names = "tx"; dma-names = "tx";
@ -891,7 +923,7 @@
assigned-clock-parents = <0>, <&clk_s_d0_quadfs 1>; assigned-clock-parents = <0>, <&clk_s_d0_quadfs 1>;
assigned-clock-rates = <50000000>; assigned-clock-rates = <50000000>;
reg = <0x8d81000 0x158>; reg = <0x8d81000 0x158>;
interrupts = <GIC_SPI 85 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
dmas = <&fdma0 3 0 1>; dmas = <&fdma0 3 0 1>;
dma-names = "tx"; dma-names = "tx";
@ -907,7 +939,7 @@
assigned-clock-parents = <0>, <&clk_s_d0_quadfs 2>; assigned-clock-parents = <0>, <&clk_s_d0_quadfs 2>;
assigned-clock-rates = <50000000>; assigned-clock-rates = <50000000>;
reg = <0x8d82000 0x158>; reg = <0x8d82000 0x158>;
interrupts = <GIC_SPI 86 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
dmas = <&fdma0 4 0 1>; dmas = <&fdma0 4 0 1>;
dma-names = "tx"; dma-names = "tx";
@ -923,7 +955,7 @@
assigned-clock-parents = <0>, <&clk_s_d0_quadfs 3>; assigned-clock-parents = <0>, <&clk_s_d0_quadfs 3>;
assigned-clock-rates = <50000000>; assigned-clock-rates = <50000000>;
reg = <0x8d85000 0x158>; reg = <0x8d85000 0x158>;
interrupts = <GIC_SPI 89 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
dmas = <&fdma0 7 0 1>; dmas = <&fdma0 7 0 1>;
dma-names = "tx"; dma-names = "tx";
@ -935,7 +967,7 @@
#sound-dai-cells = <0>; #sound-dai-cells = <0>;
st,syscfg = <&syscfg_core>; st,syscfg = <&syscfg_core>;
reg = <0x8d83000 0x158>; reg = <0x8d83000 0x158>;
interrupts = <GIC_SPI 87 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
dmas = <&fdma0 5 0 1>; dmas = <&fdma0 5 0 1>;
dma-names = "rx"; dma-names = "rx";
@ -947,32 +979,22 @@
#sound-dai-cells = <0>; #sound-dai-cells = <0>;
st,syscfg = <&syscfg_core>; st,syscfg = <&syscfg_core>;
reg = <0x8d84000 0x158>; reg = <0x8d84000 0x158>;
interrupts = <GIC_SPI 88 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;
dmas = <&fdma0 6 0 1>; dmas = <&fdma0 6 0 1>;
dma-names = "rx"; dma-names = "rx";
status = "disabled"; status = "disabled";
}; };
rc: rc@09518000 { delta0@0 {
compatible = "st,comms-irb"; compatible = "st,st-delta";
reg = <0x09518000 0x234>; reg = <0 0>;
interrupts = <GIC_SPI 132 IRQ_TYPE_NONE>; clock-names = "delta",
rx-mode = "infrared"; "delta-st231",
pinctrl-names = "default"; "delta-flash-promip";
pinctrl-0 = <&pinctrl_ir clocks = <&clk_s_c0_flexgen CLK_VID_DMU>,
&pinctrl_uhf <&clk_s_c0_flexgen CLK_ST231_DMU>,
&pinctrl_tx <&clk_s_c0_flexgen CLK_FLASH_PROMIP>;
&pinctrl_tx_od>;
clocks = <&clk_sysin>;
resets = <&softreset STIH407_IRB_SOFTRESET>;
status = "disabled";
};
socinfo {
compatible = "st,stih407-socinfo";
st,syscfg = <&syscfg_core>;
}; };
}; };
}; };

View file

@ -1,10 +1,7 @@
// SPDX-License-Identifier: GPL-2.0-only
/* /*
* Copyright (C) 2014 STMicroelectronics Limited. * Copyright (C) 2014 STMicroelectronics Limited.
* Author: Giuseppe Cavallaro <peppe.cavallaro@st.com> * Author: Giuseppe Cavallaro <peppe.cavallaro@st.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
* publishhed by the Free Software Foundation.
*/ */
#include "st-pincfg.h" #include "st-pincfg.h"
#include <dt-bindings/interrupt-controller/arm-gic.h> #include <dt-bindings/interrupt-controller/arm-gic.h>
@ -45,18 +42,18 @@
}; };
soc { soc {
pin-controller-sbc { pin-controller-sbc@961f080 {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <1>; #size-cells = <1>;
compatible = "st,stih407-sbc-pinctrl"; compatible = "st,stih407-sbc-pinctrl";
st,syscfg = <&syscfg_sbc>; st,syscfg = <&syscfg_sbc>;
reg = <0x0961f080 0x4>; reg = <0x0961f080 0x4>;
reg-names = "irqmux"; reg-names = "irqmux";
interrupts = <GIC_SPI 188 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 188 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "irqmux"; interrupt-names = "irqmux";
ranges = <0 0x09610000 0x6000>; ranges = <0 0x09610000 0x6000>;
pio0: gpio@09610000 { pio0: gpio@9610000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -64,7 +61,7 @@
reg = <0x0 0x100>; reg = <0x0 0x100>;
st,bank-name = "PIO0"; st,bank-name = "PIO0";
}; };
pio1: gpio@09611000 { pio1: gpio@9611000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -72,7 +69,7 @@
reg = <0x1000 0x100>; reg = <0x1000 0x100>;
st,bank-name = "PIO1"; st,bank-name = "PIO1";
}; };
pio2: gpio@09612000 { pio2: gpio@9612000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -80,7 +77,7 @@
reg = <0x2000 0x100>; reg = <0x2000 0x100>;
st,bank-name = "PIO2"; st,bank-name = "PIO2";
}; };
pio3: gpio@09613000 { pio3: gpio@9613000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -88,7 +85,7 @@
reg = <0x3000 0x100>; reg = <0x3000 0x100>;
st,bank-name = "PIO3"; st,bank-name = "PIO3";
}; };
pio4: gpio@09614000 { pio4: gpio@9614000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -97,7 +94,7 @@
st,bank-name = "PIO4"; st,bank-name = "PIO4";
}; };
pio5: gpio@09615000 { pio5: gpio@9615000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -369,18 +366,18 @@
}; };
}; };
pin-controller-front0 { pin-controller-front0@920f080 {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <1>; #size-cells = <1>;
compatible = "st,stih407-front-pinctrl"; compatible = "st,stih407-front-pinctrl";
st,syscfg = <&syscfg_front>; st,syscfg = <&syscfg_front>;
reg = <0x0920f080 0x4>; reg = <0x0920f080 0x4>;
reg-names = "irqmux"; reg-names = "irqmux";
interrupts = <GIC_SPI 189 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 189 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "irqmux"; interrupt-names = "irqmux";
ranges = <0 0x09200000 0x10000>; ranges = <0 0x09200000 0x10000>;
pio10: pio@09200000 { pio10: pio@9200000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -388,7 +385,7 @@
reg = <0x0 0x100>; reg = <0x0 0x100>;
st,bank-name = "PIO10"; st,bank-name = "PIO10";
}; };
pio11: pio@09201000 { pio11: pio@9201000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -396,7 +393,7 @@
reg = <0x1000 0x100>; reg = <0x1000 0x100>;
st,bank-name = "PIO11"; st,bank-name = "PIO11";
}; };
pio12: pio@09202000 { pio12: pio@9202000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -404,7 +401,7 @@
reg = <0x2000 0x100>; reg = <0x2000 0x100>;
st,bank-name = "PIO12"; st,bank-name = "PIO12";
}; };
pio13: pio@09203000 { pio13: pio@9203000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -412,7 +409,7 @@
reg = <0x3000 0x100>; reg = <0x3000 0x100>;
st,bank-name = "PIO13"; st,bank-name = "PIO13";
}; };
pio14: pio@09204000 { pio14: pio@9204000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -420,7 +417,7 @@
reg = <0x4000 0x100>; reg = <0x4000 0x100>;
st,bank-name = "PIO14"; st,bank-name = "PIO14";
}; };
pio15: pio@09205000 { pio15: pio@9205000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -428,7 +425,7 @@
reg = <0x5000 0x100>; reg = <0x5000 0x100>;
st,bank-name = "PIO15"; st,bank-name = "PIO15";
}; };
pio16: pio@09206000 { pio16: pio@9206000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -436,7 +433,7 @@
reg = <0x6000 0x100>; reg = <0x6000 0x100>;
st,bank-name = "PIO16"; st,bank-name = "PIO16";
}; };
pio17: pio@09207000 { pio17: pio@9207000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -444,7 +441,7 @@
reg = <0x7000 0x100>; reg = <0x7000 0x100>;
st,bank-name = "PIO17"; st,bank-name = "PIO17";
}; };
pio18: pio@09208000 { pio18: pio@9208000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -452,7 +449,7 @@
reg = <0x8000 0x100>; reg = <0x8000 0x100>;
st,bank-name = "PIO18"; st,bank-name = "PIO18";
}; };
pio19: pio@09209000 { pio19: pio@9209000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -465,19 +462,16 @@
serial0 { serial0 {
pinctrl_serial0: serial0-0 { pinctrl_serial0: serial0-0 {
st,pins { st,pins {
tx = <&pio17 0 ALT1 OUT>; tx = <&pio17 0 ALT1 OUT>;
rx = <&pio17 1 ALT1 IN>; rx = <&pio17 1 ALT1 IN>;
}; };
}; };
pinctrl_serial0_rts: serial0_rts { pinctrl_serial0_hw_flowctrl: serial0-0_hw_flowctrl {
st,pins {
rts = <&pio17 3 ALT1 OUT>;
};
};
pinctrl_serial0_cts: serial0_cts {
st,pins { st,pins {
tx = <&pio17 0 ALT1 OUT>;
rx = <&pio17 1 ALT1 IN>;
cts = <&pio17 2 ALT1 IN>; cts = <&pio17 2 ALT1 IN>;
rts = <&pio17 3 ALT1 OUT>;
}; };
}; };
}; };
@ -932,18 +926,18 @@
}; };
}; };
pin-controller-front1 { pin-controller-front1@921f080 {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <1>; #size-cells = <1>;
compatible = "st,stih407-front-pinctrl"; compatible = "st,stih407-front-pinctrl";
st,syscfg = <&syscfg_front>; st,syscfg = <&syscfg_front>;
reg = <0x0921f080 0x4>; reg = <0x0921f080 0x4>;
reg-names = "irqmux"; reg-names = "irqmux";
interrupts = <GIC_SPI 190 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 190 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "irqmux"; interrupt-names = "irqmux";
ranges = <0 0x09210000 0x10000>; ranges = <0 0x09210000 0x10000>;
pio20: pio@09210000 { pio20: pio@9210000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -965,18 +959,18 @@
}; };
}; };
pin-controller-rear { pin-controller-rear@922f080 {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <1>; #size-cells = <1>;
compatible = "st,stih407-rear-pinctrl"; compatible = "st,stih407-rear-pinctrl";
st,syscfg = <&syscfg_rear>; st,syscfg = <&syscfg_rear>;
reg = <0x0922f080 0x4>; reg = <0x0922f080 0x4>;
reg-names = "irqmux"; reg-names = "irqmux";
interrupts = <GIC_SPI 191 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 191 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "irqmux"; interrupt-names = "irqmux";
ranges = <0 0x09220000 0x6000>; ranges = <0 0x09220000 0x6000>;
pio30: gpio@09220000 { pio30: gpio@9220000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -984,7 +978,7 @@
reg = <0x0 0x100>; reg = <0x0 0x100>;
st,bank-name = "PIO30"; st,bank-name = "PIO30";
}; };
pio31: gpio@09221000 { pio31: gpio@9221000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -992,7 +986,7 @@
reg = <0x1000 0x100>; reg = <0x1000 0x100>;
st,bank-name = "PIO31"; st,bank-name = "PIO31";
}; };
pio32: gpio@09222000 { pio32: gpio@9222000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -1000,7 +994,7 @@
reg = <0x2000 0x100>; reg = <0x2000 0x100>;
st,bank-name = "PIO32"; st,bank-name = "PIO32";
}; };
pio33: gpio@09223000 { pio33: gpio@9223000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -1008,7 +1002,7 @@
reg = <0x3000 0x100>; reg = <0x3000 0x100>;
st,bank-name = "PIO33"; st,bank-name = "PIO33";
}; };
pio34: gpio@09224000 { pio34: gpio@9224000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -1016,7 +1010,7 @@
reg = <0x4000 0x100>; reg = <0x4000 0x100>;
st,bank-name = "PIO34"; st,bank-name = "PIO34";
}; };
pio35: gpio@09225000 { pio35: gpio@9225000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -1026,41 +1020,6 @@
st,retime-pin-mask = <0x7f>; st,retime-pin-mask = <0x7f>;
}; };
dvo {
pinctrl_dvo: dvo {
st,pins {
hs = <&pio30 0 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
vs = <&pio30 1 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
de = <&pio30 2 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
ck = <&pio30 3 ALT2 (OE | CLKNOTDATA) 0>;
d0 = <&pio30 4 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d1 = <&pio30 5 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d2 = <&pio30 6 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d3 = <&pio30 7 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d4 = <&pio31 0 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d5 = <&pio31 1 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d6 = <&pio31 2 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d7 = <&pio31 3 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d8 = <&pio31 4 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d9 = <&pio31 5 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d10 = <&pio31 6 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d11 = <&pio31 7 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d12 = <&pio32 0 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d13 = <&pio32 1 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d14 = <&pio32 2 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d15 = <&pio32 3 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d16 = <&pio32 4 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d17 = <&pio32 5 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d18 = <&pio32 6 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d19 = <&pio32 7 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d20 = <&pio33 0 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d21 = <&pio33 1 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d22 = <&pio33 2 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
d23 = <&pio33 3 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
};
};
};
i2c4 { i2c4 {
pinctrl_i2c4_default: i2c4-default { pinctrl_i2c4_default: i2c4-default {
st,pins { st,pins {
@ -1195,18 +1154,18 @@
}; };
}; };
pin-controller-flash { pin-controller-flash@923f080 {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <1>; #size-cells = <1>;
compatible = "st,stih407-flash-pinctrl"; compatible = "st,stih407-flash-pinctrl";
st,syscfg = <&syscfg_flash>; st,syscfg = <&syscfg_flash>;
reg = <0x0923f080 0x4>; reg = <0x0923f080 0x4>;
reg-names = "irqmux"; reg-names = "irqmux";
interrupts = <GIC_SPI 192 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 192 IRQ_TYPE_LEVEL_HIGH>;
interrupts-names = "irqmux"; interrupt-names = "irqmux";
ranges = <0 0x09230000 0x3000>; ranges = <0 0x09230000 0x3000>;
pio40: gpio@09230000 { pio40: gpio@9230000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -1214,7 +1173,7 @@
reg = <0 0x100>; reg = <0 0x100>;
st,bank-name = "PIO40"; st,bank-name = "PIO40";
}; };
pio41: gpio@09231000 { pio41: gpio@9231000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;
@ -1222,7 +1181,7 @@
reg = <0x1000 0x100>; reg = <0x1000 0x100>;
st,bank-name = "PIO41"; st,bank-name = "PIO41";
}; };
pio42: gpio@09232000 { pio42: gpio@9232000 {
gpio-controller; gpio-controller;
#gpio-cells = <2>; #gpio-cells = <2>;
interrupt-controller; interrupt-controller;

View file

@ -9,8 +9,25 @@
soc { soc {
st_dwc3: dwc3@8f94000 { st_dwc3: dwc3@8f94000 {
dwc3: dwc3@9900000 { dwc3: dwc3@9900000 {
dr_mode = "peripheral";
phys = <&usb2_picophy0>; phys = <&usb2_picophy0>;
}; };
}; };
ohci0: usb@9a03c00 {
compatible = "generic-ohci";
};
ehci0: usb@9a03e00 {
compatible = "generic-ehci";
};
ohci1: usb@9a83c00 {
compatible = "generic-ohci";
};
ehci1: usb@9a83e00 {
compatible = "generic-ehci";
};
}; };
}; };

View file

@ -1,10 +1,7 @@
// SPDX-License-Identifier: GPL-2.0-only
/* /*
* Copyright (C) 2016 STMicroelectronics (R&D) Limited. * Copyright (C) 2016 STMicroelectronics (R&D) Limited.
* Author: Patrice Chotard <patrice.chotard@st.com> * Author: Patrice Chotard <patrice.chotard@st.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.
*/ */
/dts-v1/; /dts-v1/;
#include "stih410.dtsi" #include "stih410.dtsi"
@ -15,68 +12,79 @@
compatible = "st,stih410-b2260", "st,stih410"; compatible = "st,stih410-b2260", "st,stih410";
chosen { chosen {
bootargs = "console=ttyAS1,115200"; bootargs = "clk_ignore_unused";
linux,stdout-path = &uart1;
stdout-path = &uart1; stdout-path = &uart1;
}; };
memory { memory@40000000 {
device_type = "memory"; device_type = "memory";
reg = <0x40000000 0x40000000>; reg = <0x40000000 0x40000000>;
}; };
aliases { aliases {
ttyAS1 = &uart1; serial1 = &uart1;
ethernet0 = &ethernet0; ethernet0 = &ethernet0;
}; };
soc { leds {
compatible = "gpio-leds";
leds { user_green_1 {
compatible = "gpio-leds"; label = "User_green_1";
user_green_1 { gpios = <&pio1 3 GPIO_ACTIVE_LOW>;
label = "User_green_1"; linux,default-trigger = "heartbeat";
gpios = <&pio1 3 GPIO_ACTIVE_LOW>; default-state = "off";
linux,default-trigger = "heartbeat";
default-state = "off";
};
user_green_2 {
label = "User_green_2";
gpios = <&pio4 1 GPIO_ACTIVE_LOW>;
default-state = "off";
};
user_green_3 {
label = "User_green_3";
gpios = <&pio2 1 GPIO_ACTIVE_LOW>;
default-state = "off";
};
user_green_4 {
label = "User_green_4";
gpios = <&pio2 5 GPIO_ACTIVE_LOW>;
default-state = "off";
};
wifi_yellow {
label = "Wifi_yellow";
gpios = <&pio4 0 GPIO_ACTIVE_LOW>;
linux,default-trigger = "wifi-activity";
default-state = "off";
};
bt_blue {
label = "Bluetooth_blue";
gpios = <&pio3 3 GPIO_ACTIVE_LOW>;
linux,default-trigger = "hci0-power";
default-state = "off";
};
}; };
user_green_2 {
label = "User_green_2";
gpios = <&pio4 1 GPIO_ACTIVE_LOW>;
default-state = "off";
};
user_green_3 {
label = "User_green_3";
gpios = <&pio2 1 GPIO_ACTIVE_LOW>;
default-state = "off";
};
user_green_4 {
label = "User_green_4";
gpios = <&pio2 5 GPIO_ACTIVE_LOW>;
default-state = "off";
};
};
sound: sound {
compatible = "simple-audio-card";
simple-audio-card,name = "STI-B2260";
status = "okay";
#address-cells = <1>;
#size-cells = <0>;
simple-audio-card,dai-link@0 {
reg = <0>;
/* DAC */
format = "i2s";
mclk-fs = <128>;
cpu {
sound-dai = <&sti_uni_player0>;
};
codec {
sound-dai = <&sti_hdmi>;
};
};
};
soc {
/* Low speed expansion connector */ /* Low speed expansion connector */
uart0: serial@9830000 { uart0: serial@9830000 {
label = "LS-UART0"; label = "LS-UART0";
pinctrl-names = "default", "no-hw-flowctrl";
pinctrl-0 = <&pinctrl_serial0_hw_flowctrl>;
pinctrl-1 = <&pinctrl_serial0>;
rts-gpios = <&pio17 3 GPIO_ACTIVE_LOW>;
uart-has-rtscts;
status = "okay"; status = "okay";
}; };
@ -119,14 +127,14 @@
status = "okay"; status = "okay";
}; };
mmc0: sdhci@09060000 { mmc0: sdhci@9060000 {
pinctrl-0 = <&pinctrl_sd0>; pinctrl-0 = <&pinctrl_sd0>;
bus-width = <4>; bus-width = <4>;
status = "okay"; status = "okay";
}; };
/* high speed expansion connector */ /* high speed expansion connector */
mmc1: sdhci@09080000 { mmc1: sdhci@9080000 {
status = "okay"; status = "okay";
}; };
@ -138,11 +146,11 @@
status = "okay"; status = "okay";
}; };
usb2_picophy1: phy2 { usb2_picophy1: phy2@0 {
status = "okay"; status = "okay";
}; };
usb2_picophy2: phy3 { usb2_picophy2: phy3@0 {
status = "okay"; status = "okay";
}; };
@ -183,17 +191,17 @@
sti_uni_player0: sti-uni-player@8d80000 { sti_uni_player0: sti-uni-player@8d80000 {
status = "okay"; status = "okay";
}; };
/* SSC11 to HDMI */ /* SSC11 to HDMI */
hdmiddc: i2c@9541000 { hdmiddc: i2c@9541000 {
/* HDMI V1.3a supports Standard mode only */ /* HDMI V1.3a supports Standard mode only */
clock-frequency = <100000>; clock-frequency = <100000>;
st,i2c-min-scl-pulse-width-us = <0>; st,i2c-min-scl-pulse-width-us = <0>;
st,i2c-min-sda-pulse-width-us = <1>; st,i2c-min-sda-pulse-width-us = <5>;
status = "okay"; status = "okay";
}; };
miphy28lp_phy: miphy28lp@9b22000 { miphy28lp_phy: miphy28lp@0 {
phy_port1: port@9b2a000 { phy_port1: port@9b2a000 {
st,osc-force-ext; st,osc-force-ext;
}; };
@ -202,25 +210,5 @@
sata1: sata@9b28000 { sata1: sata@9b28000 {
status = "okay"; status = "okay";
}; };
sound {
compatible = "simple-audio-card";
simple-audio-card,name = "STI-B2260";
status = "okay";
simple-audio-card,dai-link@0 {
/* DAC */
format = "i2s";
mclk-fs = <128>;
cpu {
sound-dai = <&sti_uni_player0>;
};
codec {
sound-dai = <&sti_hdmi>;
};
};
};
}; };
}; };

View file

@ -1,12 +1,25 @@
// SPDX-License-Identifier: GPL-2.0-only
/* /*
* Copyright (C) 2014 STMicroelectronics R&D Limited * Copyright (C) 2014 STMicroelectronics R&D Limited
*
* 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/stih410-clks.h> #include <dt-bindings/clock/stih410-clks.h>
/ { / {
/*
* Fixed 30MHz oscillator inputs to SoC
*/
clk_sysin: clk-sysin {
#clock-cells = <0>;
compatible = "fixed-clock";
clock-frequency = <30000000>;
clock-output-names = "CLK_SYSIN";
};
clk_tmdsout_hdmi: clk-tmdsout-hdmi {
#clock-cells = <0>;
compatible = "fixed-clock";
clock-frequency = <0>;
};
clocks { clocks {
#address-cells = <1>; #address-cells = <1>;
#size-cells = <1>; #size-cells = <1>;
@ -14,27 +27,6 @@
compatible = "st,stih410-clk", "simple-bus"; compatible = "st,stih410-clk", "simple-bus";
/*
* Fixed 30MHz oscillator inputs to SoC
*/
clk_sysin: clk-sysin {
#clock-cells = <0>;
compatible = "fixed-clock";
clock-frequency = <30000000>;
clock-output-names = "CLK_SYSIN";
};
/*
* ARM Peripheral clock for timers
*/
arm_periph_clk: clk-m-a9-periphs {
#clock-cells = <0>;
compatible = "fixed-factor-clock";
clocks = <&clk_m_a9>;
clock-div = <2>;
clock-mult = <1>;
};
/* /*
* A9 PLL. * A9 PLL.
*/ */
@ -64,35 +56,19 @@
<&clockgen_a9_pll 0>, <&clockgen_a9_pll 0>,
<&clk_s_c0_flexgen 13>, <&clk_s_c0_flexgen 13>,
<&clk_m_a9_ext2f_div2>; <&clk_m_a9_ext2f_div2>;
/*
* ARM Peripheral clock for timers
*/
arm_periph_clk: clk-m-a9-periphs {
#clock-cells = <0>;
compatible = "fixed-factor-clock";
clocks = <&clk_m_a9>;
clock-div = <2>;
clock-mult = <1>;
};
}; };
/* clockgen-a@90ff000 {
* ARM Peripheral clock for timers
*/
clk_m_a9_ext2f_div2: clk-m-a9-ext2f-div2s {
#clock-cells = <0>;
compatible = "fixed-factor-clock";
clocks = <&clk_s_c0_flexgen 13>;
clock-output-names = "clk-m-a9-ext2f-div2";
clock-div = <2>;
clock-mult = <1>;
};
/*
* Bootloader initialized system infrastructure clock for
* serial devices.
*/
clk_ext2f_a9: clockgen-c0@13 {
#clock-cells = <0>;
compatible = "fixed-clock";
clock-frequency = <200000000>;
clock-output-names = "clk-s-icn-reg-0";
};
clockgen-a@090ff000 {
compatible = "st,clkgen-c32"; compatible = "st,clkgen-c32";
reg = <0x90ff000 0x1000>; reg = <0x90ff000 0x1000>;
@ -134,7 +110,7 @@
clock-critical = <0>; /* clk-s-c0-fs0-ch0 */ clock-critical = <0>; /* clk-s-c0-fs0-ch0 */
}; };
clk_s_c0: clockgen-c@09103000 { clk_s_c0: clockgen-c@9103000 {
compatible = "st,clkgen-c32"; compatible = "st,clkgen-c32";
reg = <0x9103000 0x1000>; reg = <0x9103000 0x1000>;
@ -208,11 +184,27 @@
"clk-clust-hades", "clk-clust-hades",
"clk-hwpe-hades", "clk-hwpe-hades",
"clk-fc-hades"; "clk-fc-hades";
clock-critical = <CLK_ICN_CPU>, clock-critical = <CLK_PROC_STFE>,
<CLK_ICN_CPU>,
<CLK_TX_ICN_DMU>, <CLK_TX_ICN_DMU>,
<CLK_EXT2F_A9>, <CLK_EXT2F_A9>,
<CLK_ICN_LMI>, <CLK_ICN_LMI>,
<CLK_ICN_SBC>; <CLK_ICN_SBC>;
/*
* ARM Peripheral clock for timers
*/
clk_m_a9_ext2f_div2: clk-m-a9-ext2f-div2s {
#clock-cells = <0>;
compatible = "fixed-factor-clock";
clocks = <&clk_s_c0_flexgen 13>;
clock-output-names = "clk-m-a9-ext2f-div2";
clock-div = <2>;
clock-mult = <1>;
};
}; };
}; };
@ -229,7 +221,7 @@
"clk-s-d0-fs0-ch3"; "clk-s-d0-fs0-ch3";
}; };
clockgen-d0@09104000 { clockgen-d0@9104000 {
compatible = "st,clkgen-c32"; compatible = "st,clkgen-c32";
reg = <0x9104000 0x1000>; reg = <0x9104000 0x1000>;
@ -265,13 +257,7 @@
"clk-s-d2-fs0-ch3"; "clk-s-d2-fs0-ch3";
}; };
clk_tmdsout_hdmi: clk-tmdsout-hdmi { clockgen-d2@9106000 {
#clock-cells = <0>;
compatible = "fixed-clock";
clock-frequency = <0>;
};
clockgen-d2@x9106000 {
compatible = "st,clkgen-c32"; compatible = "st,clkgen-c32";
reg = <0x9106000 0x1000>; reg = <0x9106000 0x1000>;

View file

@ -1,16 +1,13 @@
// SPDX-License-Identifier: GPL-2.0-only
/* /*
* Copyright (C) 2014 STMicroelectronics Limited. * Copyright (C) 2014 STMicroelectronics Limited.
* Author: Peter Griffin <peter.griffin@linaro.org> * Author: Peter Griffin <peter.griffin@linaro.org>
*
* 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
* publishhed by the Free Software Foundation.
*/ */
#include "st-pincfg.h" #include "st-pincfg.h"
/ { / {
soc { soc {
pin-controller-rear { pin-controller-rear@922f080 {
usb0 { usb0 {
pinctrl_usb0: usb2-0 { pinctrl_usb0: usb2-0 {

View file

@ -1,67 +1,21 @@
// SPDX-License-Identifier: GPL-2.0-only
/* /*
* Copyright (C) 2014 STMicroelectronics Limited. * Copyright (C) 2014 STMicroelectronics Limited.
* Author: Peter Griffin <peter.griffin@linaro.org> * Author: Peter Griffin <peter.griffin@linaro.org>
*
* 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
* publishhed by the Free Software Foundation.
*/ */
#include "stih410-clock.dtsi" #include "stih410-clock.dtsi"
#include "stih407-family.dtsi" #include "stih407-family.dtsi"
#include "stih410-pinctrl.dtsi" #include "stih410-pinctrl.dtsi"
#include <dt-bindings/gpio/gpio.h>
/ { / {
aliases { aliases {
bdisp0 = &bdisp0; bdisp0 = &bdisp0;
}; };
cpus {
cpu@0 {
st,syscfg = <&syscfg_core 0x8e0>;
st,syscfg-eng = <&syscfg_opp 0x4 0x0>;
clocks = <&clk_m_a9>;
operating-points-v2 = <&cpu0_opp_table>;
};
cpu@1 {
clocks = <&clk_m_a9>;
operating-points-v2 = <&cpu0_opp_table>;
};
};
cpu0_opp_table: opp_table0 {
compatible = "operating-points-v2";
opp-shared;
opp@1500000000 {
opp-supported-hw = <0xffffffff 0xffffffff 0xffffffff>;
opp-hz = /bits/ 64 <1500000000>;
clock-latency-ns = <10000000>;
opp-suspend;
};
opp@1200000000 {
opp-supported-hw = <0xffffffff 0xffffffff 0xffffffff>;
opp-hz = /bits/ 64 <1200000000>;
clock-latency-ns = <10000000>;
};
opp@800000000 {
opp-supported-hw = <0xffffffff 0xffffffff 0xffffffff>;
opp-hz = /bits/ 64 <800000000>;
clock-latency-ns = <10000000>;
};
opp@400000000 {
opp-supported-hw = <0xffffffff 0xffffffff 0xffffffff>;
opp-hz = /bits/ 64 <400000000>;
clock-latency-ns = <10000000>;
};
};
soc { soc {
syscfg_opp: @08a6583c { usb2_picophy1: phy2@0 {
compatible = "syscon";
reg = <0x08a6583c 0x8>;
};
usb2_picophy1: phy2 {
compatible = "st,stih407-usb2-phy"; compatible = "st,stih407-usb2-phy";
reg = <0 0>;
#phy-cells = <0>; #phy-cells = <0>;
st,syscfg = <&syscfg_core 0xf8 0xf4>; st,syscfg = <&syscfg_core 0xf8 0xf4>;
resets = <&softreset STIH407_PICOPHY_SOFTRESET>, resets = <&softreset STIH407_PICOPHY_SOFTRESET>,
@ -71,8 +25,9 @@
status = "disabled"; status = "disabled";
}; };
usb2_picophy2: phy3 { usb2_picophy2: phy3@0 {
compatible = "st,stih407-usb2-phy"; compatible = "st,stih407-usb2-phy";
reg = <0 0>;
#phy-cells = <0>; #phy-cells = <0>;
st,syscfg = <&syscfg_core 0xfc 0xf4>; st,syscfg = <&syscfg_core 0xfc 0xf4>;
resets = <&softreset STIH407_PICOPHY_SOFTRESET>, resets = <&softreset STIH407_PICOPHY_SOFTRESET>,
@ -83,15 +38,14 @@
}; };
ohci0: usb@9a03c00 { ohci0: usb@9a03c00 {
compatible = "generic-ohci"; compatible = "st,st-ohci-300x";
reg = <0x9a03c00 0x100>; reg = <0x9a03c00 0x100>;
interrupts = <GIC_SPI 180 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 180 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&clk_s_c0_flexgen CLK_TX_ICN_DISP_0>, clocks = <&clk_s_c0_flexgen CLK_TX_ICN_DISP_0>,
<&clk_s_c0_flexgen CLK_RX_ICN_DISP_0>; <&clk_s_c0_flexgen CLK_RX_ICN_DISP_0>;
resets = <&powerdown STIH407_USB2_PORT0_POWERDOWN>, resets = <&powerdown STIH407_USB2_PORT0_POWERDOWN>,
<&softreset STIH407_USB2_PORT0_SOFTRESET>; <&softreset STIH407_USB2_PORT0_SOFTRESET>;
reset-names = "power", "softreset"; reset-names = "power", "softreset";
phys = <&usb2_picophy1>; phys = <&usb2_picophy1>;
phy-names = "usb"; phy-names = "usb";
@ -99,9 +53,9 @@
}; };
ehci0: usb@9a03e00 { ehci0: usb@9a03e00 {
compatible = "generic-ehci"; compatible = "st,st-ehci-300x";
reg = <0x9a03e00 0x100>; reg = <0x9a03e00 0x100>;
interrupts = <GIC_SPI 151 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 151 IRQ_TYPE_LEVEL_HIGH>;
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_usb0>; pinctrl-0 = <&pinctrl_usb0>;
clocks = <&clk_s_c0_flexgen CLK_TX_ICN_DISP_0>, clocks = <&clk_s_c0_flexgen CLK_TX_ICN_DISP_0>,
@ -116,15 +70,14 @@
}; };
ohci1: usb@9a83c00 { ohci1: usb@9a83c00 {
compatible = "generic-ohci"; compatible = "st,st-ohci-300x";
reg = <0x9a83c00 0x100>; reg = <0x9a83c00 0x100>;
interrupts = <GIC_SPI 181 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 181 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&clk_s_c0_flexgen CLK_TX_ICN_DISP_0>, clocks = <&clk_s_c0_flexgen CLK_TX_ICN_DISP_0>,
<&clk_s_c0_flexgen CLK_RX_ICN_DISP_0>; <&clk_s_c0_flexgen CLK_RX_ICN_DISP_0>;
resets = <&powerdown STIH407_USB2_PORT1_POWERDOWN>, resets = <&powerdown STIH407_USB2_PORT1_POWERDOWN>,
<&softreset STIH407_USB2_PORT1_SOFTRESET>; <&softreset STIH407_USB2_PORT1_SOFTRESET>;
reset-names = "power", "softreset"; reset-names = "power", "softreset";
phys = <&usb2_picophy2>; phys = <&usb2_picophy2>;
phy-names = "usb"; phy-names = "usb";
@ -132,9 +85,9 @@
}; };
ehci1: usb@9a83e00 { ehci1: usb@9a83e00 {
compatible = "generic-ehci"; compatible = "st,st-ehci-300x";
reg = <0x9a83e00 0x100>; reg = <0x9a83e00 0x100>;
interrupts = <GIC_SPI 153 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 153 IRQ_TYPE_LEVEL_HIGH>;
pinctrl-names = "default"; pinctrl-names = "default";
pinctrl-0 = <&pinctrl_usb1>; pinctrl-0 = <&pinctrl_usb1>;
clocks = <&clk_s_c0_flexgen CLK_TX_ICN_DISP_0>, clocks = <&clk_s_c0_flexgen CLK_TX_ICN_DISP_0>,
@ -142,18 +95,18 @@
resets = <&powerdown STIH407_USB2_PORT1_POWERDOWN>, resets = <&powerdown STIH407_USB2_PORT1_POWERDOWN>,
<&softreset STIH407_USB2_PORT1_SOFTRESET>; <&softreset STIH407_USB2_PORT1_SOFTRESET>;
reset-names = "power", "softreset"; reset-names = "power", "softreset";
phys = <&usb2_picophy2>; phys = <&usb2_picophy2>;
phy-names = "usb"; phy-names = "usb";
status = "disabled"; status = "disabled";
}; };
sti-display-subsystem { sti-display-subsystem@0 {
compatible = "st,sti-display-subsystem"; compatible = "st,sti-display-subsystem";
#address-cells = <1>; #address-cells = <1>;
#size-cells = <1>; #size-cells = <1>;
reg = <0 0>;
assigned-clocks = <&clk_s_d2_quadfs 0>, assigned-clocks = <&clk_s_d2_quadfs 0>,
<&clk_s_d2_quadfs 1>, <&clk_s_d2_quadfs 1>,
<&clk_s_c0_pll1 0>, <&clk_s_c0_pll1 0>,
@ -243,10 +196,10 @@
sti_hdmi: sti-hdmi@8d04000 { sti_hdmi: sti-hdmi@8d04000 {
compatible = "st,stih407-hdmi"; compatible = "st,stih407-hdmi";
#sound-dai-cells = <0>;
reg = <0x8d04000 0x1000>; reg = <0x8d04000 0x1000>;
reg-names = "hdmi-reg"; reg-names = "hdmi-reg";
interrupts = <GIC_SPI 106 IRQ_TYPE_NONE>; #sound-dai-cells = <0>;
interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
interrupt-names = "irq"; interrupt-names = "irq";
clock-names = "pix", clock-names = "pix",
"tmds", "tmds",
@ -262,7 +215,7 @@
<&clk_s_d2_quadfs 0>, <&clk_s_d2_quadfs 0>,
<&clk_s_d2_quadfs 1>; <&clk_s_d2_quadfs 1>;
hdmi,hpd-gpio = <&pio5 3>; hdmi,hpd-gpio = <&pio5 3 GPIO_ACTIVE_LOW>;
reset-names = "hdmi"; reset-names = "hdmi";
resets = <&softreset STIH407_HDMI_TX_PHY_SOFTRESET>; resets = <&softreset STIH407_HDMI_TX_PHY_SOFTRESET>;
ddc = <&hdmiddc>; ddc = <&hdmiddc>;
@ -283,24 +236,7 @@
<&clk_s_d2_quadfs 1>; <&clk_s_d2_quadfs 1>;
}; };
sti-dvo@8d00400 { sti-hqvdp@9c00000 {
compatible = "st,stih407-dvo";
status = "disabled";
reg = <0x8d00400 0x200>;
reg-names = "dvo-reg";
clock-names = "dvo_pix",
"dvo",
"main_parent",
"aux_parent";
clocks = <&clk_s_d2_flexgen CLK_PIX_DVO>,
<&clk_s_d2_flexgen CLK_DVO>,
<&clk_s_d2_quadfs 0>,
<&clk_s_d2_quadfs 1>;
pinctrl-names = "default";
pinctrl-0 = <&pinctrl_dvo>;
};
sti-hqvdp@9c000000 {
compatible = "st,stih407-hqvdp"; compatible = "st,stih407-hqvdp";
reg = <0x9C00000 0x100000>; reg = <0x9C00000 0x100000>;
clock-names = "hqvdp", "pix_main"; clock-names = "hqvdp", "pix_main";
@ -315,7 +251,7 @@
bdisp0:bdisp@9f10000 { bdisp0:bdisp@9f10000 {
compatible = "st,stih407-bdisp"; compatible = "st,stih407-bdisp";
reg = <0x9f10000 0x1000>; reg = <0x9f10000 0x1000>;
interrupts = <GIC_SPI 38 IRQ_TYPE_NONE>; interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
clock-names = "bdisp"; clock-names = "bdisp";
clocks = <&clk_s_c0_flexgen CLK_IC_BDISP_0>; clocks = <&clk_s_c0_flexgen CLK_IC_BDISP_0>;
}; };
@ -324,8 +260,8 @@
compatible = "st,st-hva"; compatible = "st,st-hva";
reg = <0x8c85000 0x400>, <0x6000000 0x40000>; reg = <0x8c85000 0x400>, <0x6000000 0x40000>;
reg-names = "hva_registers", "hva_esram"; reg-names = "hva_registers", "hva_esram";
interrupts = <GIC_SPI 58 IRQ_TYPE_NONE>, interrupts = <GIC_SPI 58 IRQ_TYPE_LEVEL_HIGH>,
<GIC_SPI 59 IRQ_TYPE_NONE>; <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
clock-names = "clk_hva"; clock-names = "clk_hva";
clocks = <&clk_s_c0_flexgen CLK_HVA>; clocks = <&clk_s_c0_flexgen CLK_HVA>;
}; };
@ -338,66 +274,7 @@
interrupts = <GIC_SPI 205 IRQ_TYPE_EDGE_RISING>; interrupts = <GIC_SPI 205 IRQ_TYPE_EDGE_RISING>;
}; };
g1@8c80000 { delta0@0 {
compatible = "st,g1";
reg = <0x8c80000 0x194>;
interrupts = <GIC_SPI 57 IRQ_TYPE_NONE>;
};
temp0{
compatible = "st,stih407-thermal";
reg = <0x91a0000 0x28>;
clock-names = "thermal";
clocks = <&clk_sysin>;
interrupts = <GIC_SPI 205 IRQ_TYPE_EDGE_RISING>;
};
delta0 {
compatible = "st,delta";
clock-names = "delta", "delta-st231", "delta-flash-promip";
clocks = <&clk_s_c0_flexgen CLK_VID_DMU>,
<&clk_s_c0_flexgen CLK_ST231_DMU>,
<&clk_s_c0_flexgen CLK_FLASH_PROMIP>;
};
h264pp0: h264pp@8c00000 {
compatible = "st,h264pp";
reg = <0x8c00000 0x20000>;
interrupts = <GIC_SPI 53 IRQ_TYPE_NONE>;
clock-names = "clk_h264pp_0";
clocks = <&clk_s_c0_flexgen CLK_PP_DMU>;
};
mali: mali@09f00000 {
compatible = "arm,mali-400";
reg = <0x09f00000 0x10000>;
interrupts = <GIC_SPI 49 IRQ_TYPE_NONE>,
<GIC_SPI 50 IRQ_TYPE_NONE>,
<GIC_SPI 41 IRQ_TYPE_NONE>,
<GIC_SPI 45 IRQ_TYPE_NONE>,
<GIC_SPI 42 IRQ_TYPE_NONE>,
<GIC_SPI 46 IRQ_TYPE_NONE>,
<GIC_SPI 43 IRQ_TYPE_NONE>,
<GIC_SPI 47 IRQ_TYPE_NONE>,
<GIC_SPI 44 IRQ_TYPE_NONE>,
<GIC_SPI 48 IRQ_TYPE_NONE>;
interrupt-names = "IRQGP",
"IRQGPMMU",
"IRQPP0",
"IRQPPMMU0",
"IRQPP1",
"IRQPPMMU1",
"IRQPP2",
"IRQPPMMU2",
"IRQPP3",
"IRQPPMMU3";
clock-names = "gpu-clk";
clocks = <&clk_s_c0_flexgen CLK_ICN_GPU>;
reset-names = "gpu";
resets = <&softreset STIH407_GPU_SOFTRESET>;
};
delta0 {
compatible = "st,st-delta"; compatible = "st,st-delta";
clock-names = "delta", clock-names = "delta",
"delta-st231", "delta-st231",
@ -407,51 +284,17 @@
<&clk_s_c0_flexgen CLK_FLASH_PROMIP>; <&clk_s_c0_flexgen CLK_FLASH_PROMIP>;
}; };
h264pp0: h264pp@8c00000 { sti-cec@94a087c {
compatible = "st,h264pp"; compatible = "st,stih-cec";
reg = <0x8c00000 0x20000>; reg = <0x94a087c 0x64>;
interrupts = <GIC_SPI 53 IRQ_TYPE_NONE>; clocks = <&clk_sysin>;
clock-names = "clk_h264pp_0"; clock-names = "cec-clk";
clocks = <&clk_s_c0_flexgen CLK_PP_DMU>; interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>;
}; interrupt-names = "cec-irq";
pinctrl-names = "default";
mali: mali@09f00000 { pinctrl-0 = <&pinctrl_cec0_default>;
compatible = "arm,mali-400"; resets = <&softreset STIH407_LPM_SOFTRESET>;
reg = <0x09f00000 0x10000>; hdmi-phandle = <&sti_hdmi>;
interrupts = <GIC_SPI 49 IRQ_TYPE_NONE>,
<GIC_SPI 50 IRQ_TYPE_NONE>,
<GIC_SPI 41 IRQ_TYPE_NONE>,
<GIC_SPI 45 IRQ_TYPE_NONE>,
<GIC_SPI 42 IRQ_TYPE_NONE>,
<GIC_SPI 46 IRQ_TYPE_NONE>,
<GIC_SPI 43 IRQ_TYPE_NONE>,
<GIC_SPI 47 IRQ_TYPE_NONE>,
<GIC_SPI 44 IRQ_TYPE_NONE>,
<GIC_SPI 48 IRQ_TYPE_NONE>;
interrupt-names = "IRQGP",
"IRQGPMMU",
"IRQPP0",
"IRQPPMMU0",
"IRQPP1",
"IRQPPMMU1",
"IRQPP2",
"IRQPPMMU2",
"IRQPP3",
"IRQPPMMU3";
clock-names = "gpu-clk";
clocks = <&clk_s_c0_flexgen CLK_ICN_GPU>;
reset-names = "gpu";
resets = <&softreset STIH407_GPU_SOFTRESET>;
};
hva@8c85000{
compatible = "st,st-hva";
reg = <0x8c85000 0x400>, <0x6000000 0x40000>;
reg-names = "hva_registers", "hva_esram";
interrupts = <GIC_SPI 58 IRQ_TYPE_NONE>,
<GIC_SPI 59 IRQ_TYPE_NONE>;
clock-names = "clk_hva";
clocks = <&clk_s_c0_flexgen CLK_HVA>;
}; };
}; };
}; };