162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/ { 362306a36Sopenharmony_ci #address-cells = <1>; 462306a36Sopenharmony_ci #size-cells = <1>; 562306a36Sopenharmony_ci compatible = "brcm,bcm7420"; 662306a36Sopenharmony_ci 762306a36Sopenharmony_ci cpus { 862306a36Sopenharmony_ci #address-cells = <1>; 962306a36Sopenharmony_ci #size-cells = <0>; 1062306a36Sopenharmony_ci 1162306a36Sopenharmony_ci mips-hpt-frequency = <93750000>; 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci cpu@0 { 1462306a36Sopenharmony_ci compatible = "brcm,bmips5000"; 1562306a36Sopenharmony_ci device_type = "cpu"; 1662306a36Sopenharmony_ci reg = <0>; 1762306a36Sopenharmony_ci }; 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci cpu@1 { 2062306a36Sopenharmony_ci compatible = "brcm,bmips5000"; 2162306a36Sopenharmony_ci device_type = "cpu"; 2262306a36Sopenharmony_ci reg = <1>; 2362306a36Sopenharmony_ci }; 2462306a36Sopenharmony_ci }; 2562306a36Sopenharmony_ci 2662306a36Sopenharmony_ci aliases { 2762306a36Sopenharmony_ci uart0 = &uart0; 2862306a36Sopenharmony_ci }; 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_ci cpu_intc: interrupt-controller { 3162306a36Sopenharmony_ci #address-cells = <0>; 3262306a36Sopenharmony_ci compatible = "mti,cpu-interrupt-controller"; 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_ci interrupt-controller; 3562306a36Sopenharmony_ci #interrupt-cells = <1>; 3662306a36Sopenharmony_ci }; 3762306a36Sopenharmony_ci 3862306a36Sopenharmony_ci clocks { 3962306a36Sopenharmony_ci uart_clk: uart_clk { 4062306a36Sopenharmony_ci compatible = "fixed-clock"; 4162306a36Sopenharmony_ci #clock-cells = <0>; 4262306a36Sopenharmony_ci clock-frequency = <81000000>; 4362306a36Sopenharmony_ci }; 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_ci upg_clk: upg_clk { 4662306a36Sopenharmony_ci compatible = "fixed-clock"; 4762306a36Sopenharmony_ci #clock-cells = <0>; 4862306a36Sopenharmony_ci clock-frequency = <27000000>; 4962306a36Sopenharmony_ci }; 5062306a36Sopenharmony_ci }; 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_ci rdb { 5362306a36Sopenharmony_ci #address-cells = <1>; 5462306a36Sopenharmony_ci #size-cells = <1>; 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci compatible = "simple-bus"; 5762306a36Sopenharmony_ci ranges = <0 0x10000000 0x01000000>; 5862306a36Sopenharmony_ci 5962306a36Sopenharmony_ci periph_intc: interrupt-controller@441400 { 6062306a36Sopenharmony_ci compatible = "brcm,bcm7038-l1-intc"; 6162306a36Sopenharmony_ci reg = <0x441400 0x30>, <0x441600 0x30>; 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_ci interrupt-controller; 6462306a36Sopenharmony_ci #interrupt-cells = <1>; 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_ci interrupt-parent = <&cpu_intc>; 6762306a36Sopenharmony_ci interrupts = <2>, <3>; 6862306a36Sopenharmony_ci }; 6962306a36Sopenharmony_ci 7062306a36Sopenharmony_ci sun_l2_intc: interrupt-controller@401800 { 7162306a36Sopenharmony_ci compatible = "brcm,l2-intc"; 7262306a36Sopenharmony_ci reg = <0x401800 0x30>; 7362306a36Sopenharmony_ci interrupt-controller; 7462306a36Sopenharmony_ci #interrupt-cells = <1>; 7562306a36Sopenharmony_ci interrupt-parent = <&periph_intc>; 7662306a36Sopenharmony_ci interrupts = <23>; 7762306a36Sopenharmony_ci }; 7862306a36Sopenharmony_ci 7962306a36Sopenharmony_ci gisb-arb@400000 { 8062306a36Sopenharmony_ci compatible = "brcm,bcm7400-gisb-arb"; 8162306a36Sopenharmony_ci reg = <0x400000 0xdc>; 8262306a36Sopenharmony_ci native-endian; 8362306a36Sopenharmony_ci interrupt-parent = <&sun_l2_intc>; 8462306a36Sopenharmony_ci interrupts = <0>, <2>; 8562306a36Sopenharmony_ci brcm,gisb-arb-master-mask = <0x3ff>; 8662306a36Sopenharmony_ci brcm,gisb-arb-master-names = "ssp_0", "cpu_0", "pci_0", 8762306a36Sopenharmony_ci "pcie_0", "bsp_0", "rdc_0", 8862306a36Sopenharmony_ci "rptd_0", "avd_0", "avd_1", 8962306a36Sopenharmony_ci "jtag_0"; 9062306a36Sopenharmony_ci }; 9162306a36Sopenharmony_ci 9262306a36Sopenharmony_ci upg_irq0_intc: interrupt-controller@406780 { 9362306a36Sopenharmony_ci compatible = "brcm,bcm7120-l2-intc"; 9462306a36Sopenharmony_ci reg = <0x406780 0x8>; 9562306a36Sopenharmony_ci 9662306a36Sopenharmony_ci brcm,int-map-mask = <0x44>, <0x1f000000>, <0x100000>; 9762306a36Sopenharmony_ci brcm,int-fwd-mask = <0x70000>; 9862306a36Sopenharmony_ci 9962306a36Sopenharmony_ci interrupt-controller; 10062306a36Sopenharmony_ci #interrupt-cells = <1>; 10162306a36Sopenharmony_ci 10262306a36Sopenharmony_ci interrupt-parent = <&periph_intc>; 10362306a36Sopenharmony_ci interrupts = <18>, <19>, <20>; 10462306a36Sopenharmony_ci interrupt-names = "upg_main", "upg_bsc", "upg_spi"; 10562306a36Sopenharmony_ci }; 10662306a36Sopenharmony_ci 10762306a36Sopenharmony_ci sun_top_ctrl: syscon@404000 { 10862306a36Sopenharmony_ci compatible = "brcm,bcm7420-sun-top-ctrl", "syscon"; 10962306a36Sopenharmony_ci reg = <0x404000 0x60c>; 11062306a36Sopenharmony_ci native-endian; 11162306a36Sopenharmony_ci }; 11262306a36Sopenharmony_ci 11362306a36Sopenharmony_ci reboot { 11462306a36Sopenharmony_ci compatible = "brcm,bcm7038-reboot"; 11562306a36Sopenharmony_ci syscon = <&sun_top_ctrl 0x8 0x14>; 11662306a36Sopenharmony_ci }; 11762306a36Sopenharmony_ci 11862306a36Sopenharmony_ci uart0: serial@406b00 { 11962306a36Sopenharmony_ci compatible = "ns16550a"; 12062306a36Sopenharmony_ci reg = <0x406b00 0x20>; 12162306a36Sopenharmony_ci reg-io-width = <0x4>; 12262306a36Sopenharmony_ci reg-shift = <0x2>; 12362306a36Sopenharmony_ci interrupt-parent = <&periph_intc>; 12462306a36Sopenharmony_ci interrupts = <21>; 12562306a36Sopenharmony_ci clocks = <&uart_clk>; 12662306a36Sopenharmony_ci status = "disabled"; 12762306a36Sopenharmony_ci }; 12862306a36Sopenharmony_ci 12962306a36Sopenharmony_ci uart1: serial@406b40 { 13062306a36Sopenharmony_ci compatible = "ns16550a"; 13162306a36Sopenharmony_ci reg = <0x406b40 0x20>; 13262306a36Sopenharmony_ci reg-io-width = <0x4>; 13362306a36Sopenharmony_ci reg-shift = <0x2>; 13462306a36Sopenharmony_ci interrupt-parent = <&periph_intc>; 13562306a36Sopenharmony_ci interrupts = <64>; 13662306a36Sopenharmony_ci clocks = <&uart_clk>; 13762306a36Sopenharmony_ci status = "disabled"; 13862306a36Sopenharmony_ci }; 13962306a36Sopenharmony_ci 14062306a36Sopenharmony_ci uart2: serial@406b80 { 14162306a36Sopenharmony_ci compatible = "ns16550a"; 14262306a36Sopenharmony_ci reg = <0x406b80 0x20>; 14362306a36Sopenharmony_ci reg-io-width = <0x4>; 14462306a36Sopenharmony_ci reg-shift = <0x2>; 14562306a36Sopenharmony_ci interrupt-parent = <&periph_intc>; 14662306a36Sopenharmony_ci interrupts = <65>; 14762306a36Sopenharmony_ci clocks = <&uart_clk>; 14862306a36Sopenharmony_ci status = "disabled"; 14962306a36Sopenharmony_ci }; 15062306a36Sopenharmony_ci 15162306a36Sopenharmony_ci bsca: i2c@406200 { 15262306a36Sopenharmony_ci clock-frequency = <390000>; 15362306a36Sopenharmony_ci compatible = "brcm,brcmstb-i2c"; 15462306a36Sopenharmony_ci interrupt-parent = <&upg_irq0_intc>; 15562306a36Sopenharmony_ci reg = <0x406200 0x58>; 15662306a36Sopenharmony_ci interrupts = <24>; 15762306a36Sopenharmony_ci interrupt-names = "upg_bsca"; 15862306a36Sopenharmony_ci status = "disabled"; 15962306a36Sopenharmony_ci }; 16062306a36Sopenharmony_ci 16162306a36Sopenharmony_ci bscb: i2c@406280 { 16262306a36Sopenharmony_ci clock-frequency = <390000>; 16362306a36Sopenharmony_ci compatible = "brcm,brcmstb-i2c"; 16462306a36Sopenharmony_ci interrupt-parent = <&upg_irq0_intc>; 16562306a36Sopenharmony_ci reg = <0x406280 0x58>; 16662306a36Sopenharmony_ci interrupts = <25>; 16762306a36Sopenharmony_ci interrupt-names = "upg_bscb"; 16862306a36Sopenharmony_ci status = "disabled"; 16962306a36Sopenharmony_ci }; 17062306a36Sopenharmony_ci 17162306a36Sopenharmony_ci bscc: i2c@406300 { 17262306a36Sopenharmony_ci clock-frequency = <390000>; 17362306a36Sopenharmony_ci compatible = "brcm,brcmstb-i2c"; 17462306a36Sopenharmony_ci interrupt-parent = <&upg_irq0_intc>; 17562306a36Sopenharmony_ci reg = <0x406300 0x58>; 17662306a36Sopenharmony_ci interrupts = <26>; 17762306a36Sopenharmony_ci interrupt-names = "upg_bscc"; 17862306a36Sopenharmony_ci status = "disabled"; 17962306a36Sopenharmony_ci }; 18062306a36Sopenharmony_ci 18162306a36Sopenharmony_ci bscd: i2c@406380 { 18262306a36Sopenharmony_ci clock-frequency = <390000>; 18362306a36Sopenharmony_ci compatible = "brcm,brcmstb-i2c"; 18462306a36Sopenharmony_ci interrupt-parent = <&upg_irq0_intc>; 18562306a36Sopenharmony_ci reg = <0x406380 0x58>; 18662306a36Sopenharmony_ci interrupts = <27>; 18762306a36Sopenharmony_ci interrupt-names = "upg_bscd"; 18862306a36Sopenharmony_ci status = "disabled"; 18962306a36Sopenharmony_ci }; 19062306a36Sopenharmony_ci 19162306a36Sopenharmony_ci bsce: i2c@406800 { 19262306a36Sopenharmony_ci clock-frequency = <390000>; 19362306a36Sopenharmony_ci compatible = "brcm,brcmstb-i2c"; 19462306a36Sopenharmony_ci interrupt-parent = <&upg_irq0_intc>; 19562306a36Sopenharmony_ci reg = <0x406800 0x58>; 19662306a36Sopenharmony_ci interrupts = <28>; 19762306a36Sopenharmony_ci interrupt-names = "upg_bsce"; 19862306a36Sopenharmony_ci status = "disabled"; 19962306a36Sopenharmony_ci }; 20062306a36Sopenharmony_ci 20162306a36Sopenharmony_ci pwma: pwm@406580 { 20262306a36Sopenharmony_ci compatible = "brcm,bcm7038-pwm"; 20362306a36Sopenharmony_ci reg = <0x406580 0x28>; 20462306a36Sopenharmony_ci #pwm-cells = <2>; 20562306a36Sopenharmony_ci clocks = <&upg_clk>; 20662306a36Sopenharmony_ci status = "disabled"; 20762306a36Sopenharmony_ci }; 20862306a36Sopenharmony_ci 20962306a36Sopenharmony_ci pwmb: pwm@406880 { 21062306a36Sopenharmony_ci compatible = "brcm,bcm7038-pwm"; 21162306a36Sopenharmony_ci reg = <0x406880 0x28>; 21262306a36Sopenharmony_ci #pwm-cells = <2>; 21362306a36Sopenharmony_ci clocks = <&upg_clk>; 21462306a36Sopenharmony_ci status = "disabled"; 21562306a36Sopenharmony_ci }; 21662306a36Sopenharmony_ci 21762306a36Sopenharmony_ci watchdog: watchdog@4067e8 { 21862306a36Sopenharmony_ci clocks = <&upg_clk>; 21962306a36Sopenharmony_ci compatible = "brcm,bcm7038-wdt"; 22062306a36Sopenharmony_ci reg = <0x4067e8 0x14>; 22162306a36Sopenharmony_ci status = "disabled"; 22262306a36Sopenharmony_ci }; 22362306a36Sopenharmony_ci 22462306a36Sopenharmony_ci upg_gio: gpio@406700 { 22562306a36Sopenharmony_ci compatible = "brcm,brcmstb-gpio"; 22662306a36Sopenharmony_ci reg = <0x406700 0x80>; 22762306a36Sopenharmony_ci #gpio-cells = <2>; 22862306a36Sopenharmony_ci #interrupt-cells = <2>; 22962306a36Sopenharmony_ci gpio-controller; 23062306a36Sopenharmony_ci interrupt-controller; 23162306a36Sopenharmony_ci interrupt-parent = <&upg_irq0_intc>; 23262306a36Sopenharmony_ci interrupts = <6>; 23362306a36Sopenharmony_ci brcm,gpio-bank-widths = <32 32 32 27>; 23462306a36Sopenharmony_ci }; 23562306a36Sopenharmony_ci 23662306a36Sopenharmony_ci enet0: ethernet@468000 { 23762306a36Sopenharmony_ci phy-mode = "internal"; 23862306a36Sopenharmony_ci phy-handle = <&phy1>; 23962306a36Sopenharmony_ci mac-address = [ 00 10 18 36 23 1a ]; 24062306a36Sopenharmony_ci compatible = "brcm,genet-v1"; 24162306a36Sopenharmony_ci #address-cells = <0x1>; 24262306a36Sopenharmony_ci #size-cells = <0x1>; 24362306a36Sopenharmony_ci reg = <0x468000 0x3c8c>; 24462306a36Sopenharmony_ci interrupts = <69>, <79>; 24562306a36Sopenharmony_ci interrupt-parent = <&periph_intc>; 24662306a36Sopenharmony_ci status = "disabled"; 24762306a36Sopenharmony_ci 24862306a36Sopenharmony_ci mdio@e14 { 24962306a36Sopenharmony_ci compatible = "brcm,genet-mdio-v1"; 25062306a36Sopenharmony_ci #address-cells = <0x1>; 25162306a36Sopenharmony_ci #size-cells = <0x0>; 25262306a36Sopenharmony_ci reg = <0xe14 0x8>; 25362306a36Sopenharmony_ci 25462306a36Sopenharmony_ci phy1: ethernet-phy@1 { 25562306a36Sopenharmony_ci max-speed = <100>; 25662306a36Sopenharmony_ci reg = <0x1>; 25762306a36Sopenharmony_ci compatible = "brcm,65nm-ephy", 25862306a36Sopenharmony_ci "ethernet-phy-ieee802.3-c22"; 25962306a36Sopenharmony_ci }; 26062306a36Sopenharmony_ci }; 26162306a36Sopenharmony_ci }; 26262306a36Sopenharmony_ci 26362306a36Sopenharmony_ci ehci0: usb@488300 { 26462306a36Sopenharmony_ci compatible = "brcm,bcm7420-ehci", "generic-ehci"; 26562306a36Sopenharmony_ci reg = <0x488300 0x100>; 26662306a36Sopenharmony_ci interrupt-parent = <&periph_intc>; 26762306a36Sopenharmony_ci interrupts = <60>; 26862306a36Sopenharmony_ci status = "disabled"; 26962306a36Sopenharmony_ci }; 27062306a36Sopenharmony_ci 27162306a36Sopenharmony_ci ohci0: usb@488400 { 27262306a36Sopenharmony_ci compatible = "brcm,bcm7420-ohci", "generic-ohci"; 27362306a36Sopenharmony_ci reg = <0x488400 0x100>; 27462306a36Sopenharmony_ci native-endian; 27562306a36Sopenharmony_ci no-big-frame-no; 27662306a36Sopenharmony_ci interrupt-parent = <&periph_intc>; 27762306a36Sopenharmony_ci interrupts = <61>; 27862306a36Sopenharmony_ci status = "disabled"; 27962306a36Sopenharmony_ci }; 28062306a36Sopenharmony_ci 28162306a36Sopenharmony_ci ehci1: usb@488500 { 28262306a36Sopenharmony_ci compatible = "brcm,bcm7420-ehci", "generic-ehci"; 28362306a36Sopenharmony_ci reg = <0x488500 0x100>; 28462306a36Sopenharmony_ci interrupt-parent = <&periph_intc>; 28562306a36Sopenharmony_ci interrupts = <55>; 28662306a36Sopenharmony_ci status = "disabled"; 28762306a36Sopenharmony_ci }; 28862306a36Sopenharmony_ci 28962306a36Sopenharmony_ci ohci1: usb@488600 { 29062306a36Sopenharmony_ci compatible = "brcm,bcm7420-ohci", "generic-ohci"; 29162306a36Sopenharmony_ci reg = <0x488600 0x100>; 29262306a36Sopenharmony_ci native-endian; 29362306a36Sopenharmony_ci no-big-frame-no; 29462306a36Sopenharmony_ci interrupt-parent = <&periph_intc>; 29562306a36Sopenharmony_ci interrupts = <62>; 29662306a36Sopenharmony_ci status = "disabled"; 29762306a36Sopenharmony_ci }; 29862306a36Sopenharmony_ci 29962306a36Sopenharmony_ci spi_l2_intc: interrupt-controller@411d00 { 30062306a36Sopenharmony_ci compatible = "brcm,l2-intc"; 30162306a36Sopenharmony_ci reg = <0x411d00 0x30>; 30262306a36Sopenharmony_ci interrupt-controller; 30362306a36Sopenharmony_ci #interrupt-cells = <1>; 30462306a36Sopenharmony_ci interrupt-parent = <&periph_intc>; 30562306a36Sopenharmony_ci interrupts = <78>; 30662306a36Sopenharmony_ci }; 30762306a36Sopenharmony_ci 30862306a36Sopenharmony_ci qspi: spi@443000 { 30962306a36Sopenharmony_ci #address-cells = <0x1>; 31062306a36Sopenharmony_ci #size-cells = <0x0>; 31162306a36Sopenharmony_ci compatible = "brcm,spi-bcm-qspi", 31262306a36Sopenharmony_ci "brcm,spi-brcmstb-qspi"; 31362306a36Sopenharmony_ci clocks = <&upg_clk>; 31462306a36Sopenharmony_ci reg = <0x440920 0x4 0x443200 0x188 0x443000 0x50>; 31562306a36Sopenharmony_ci reg-names = "cs_reg", "hif_mspi", "bspi"; 31662306a36Sopenharmony_ci interrupts = <0x0 0x1 0x2 0x3 0x4 0x5 0x6>; 31762306a36Sopenharmony_ci interrupt-parent = <&spi_l2_intc>; 31862306a36Sopenharmony_ci interrupt-names = "spi_lr_fullness_reached", 31962306a36Sopenharmony_ci "spi_lr_session_aborted", 32062306a36Sopenharmony_ci "spi_lr_impatient", 32162306a36Sopenharmony_ci "spi_lr_session_done", 32262306a36Sopenharmony_ci "spi_lr_overread", 32362306a36Sopenharmony_ci "mspi_done", 32462306a36Sopenharmony_ci "mspi_halted"; 32562306a36Sopenharmony_ci status = "disabled"; 32662306a36Sopenharmony_ci }; 32762306a36Sopenharmony_ci 32862306a36Sopenharmony_ci mspi: spi@406400 { 32962306a36Sopenharmony_ci #address-cells = <1>; 33062306a36Sopenharmony_ci #size-cells = <0>; 33162306a36Sopenharmony_ci compatible = "brcm,spi-bcm-qspi", 33262306a36Sopenharmony_ci "brcm,spi-brcmstb-mspi"; 33362306a36Sopenharmony_ci clocks = <&upg_clk>; 33462306a36Sopenharmony_ci reg = <0x406400 0x180>; 33562306a36Sopenharmony_ci reg-names = "mspi"; 33662306a36Sopenharmony_ci interrupts = <0x14>; 33762306a36Sopenharmony_ci interrupt-parent = <&upg_irq0_intc>; 33862306a36Sopenharmony_ci interrupt-names = "mspi_done"; 33962306a36Sopenharmony_ci status = "disabled"; 34062306a36Sopenharmony_ci }; 34162306a36Sopenharmony_ci }; 34262306a36Sopenharmony_ci}; 343