162306a36Sopenharmony_ci// SPDX-License-Identifier: (GPL-2.0+ OR MIT) 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Device Tree Include file for Marvell Armada XP family SoC 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright (C) 2012 Marvell 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Lior Amsalem <alior@marvell.com> 862306a36Sopenharmony_ci * Gregory CLEMENT <gregory.clement@free-electrons.com> 962306a36Sopenharmony_ci * Thomas Petazzoni <thomas.petazzoni@free-electrons.com> 1062306a36Sopenharmony_ci * Ben Dooks <ben.dooks@codethink.co.uk> 1162306a36Sopenharmony_ci * 1262306a36Sopenharmony_ci * Contains definitions specific to the Armada XP SoC that are not 1362306a36Sopenharmony_ci * common to all Armada SoCs. 1462306a36Sopenharmony_ci */ 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci#include "armada-370-xp.dtsi" 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_ci/ { 1962306a36Sopenharmony_ci #address-cells = <2>; 2062306a36Sopenharmony_ci #size-cells = <2>; 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_ci model = "Marvell Armada XP family SoC"; 2362306a36Sopenharmony_ci compatible = "marvell,armadaxp", "marvell,armada-370-xp"; 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci aliases { 2662306a36Sopenharmony_ci serial2 = &uart2; 2762306a36Sopenharmony_ci serial3 = &uart3; 2862306a36Sopenharmony_ci }; 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_ci soc { 3162306a36Sopenharmony_ci compatible = "marvell,armadaxp-mbus", "simple-bus"; 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci bootrom { 3462306a36Sopenharmony_ci compatible = "marvell,bootrom"; 3562306a36Sopenharmony_ci reg = <MBUS_ID(0x01, 0x1d) 0 0x100000>; 3662306a36Sopenharmony_ci }; 3762306a36Sopenharmony_ci 3862306a36Sopenharmony_ci internal-regs { 3962306a36Sopenharmony_ci sdramc: sdramc@1400 { 4062306a36Sopenharmony_ci compatible = "marvell,armada-xp-sdram-controller"; 4162306a36Sopenharmony_ci reg = <0x1400 0x500>; 4262306a36Sopenharmony_ci }; 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ci L2: l2-cache@8000 { 4562306a36Sopenharmony_ci compatible = "marvell,aurora-system-cache"; 4662306a36Sopenharmony_ci reg = <0x08000 0x1000>; 4762306a36Sopenharmony_ci cache-id-part = <0x100>; 4862306a36Sopenharmony_ci cache-level = <2>; 4962306a36Sopenharmony_ci cache-unified; 5062306a36Sopenharmony_ci wt-override; 5162306a36Sopenharmony_ci }; 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_ci uart2: serial@12200 { 5462306a36Sopenharmony_ci compatible = "snps,dw-apb-uart"; 5562306a36Sopenharmony_ci pinctrl-0 = <&uart2_pins>; 5662306a36Sopenharmony_ci pinctrl-names = "default"; 5762306a36Sopenharmony_ci reg = <0x12200 0x100>; 5862306a36Sopenharmony_ci reg-shift = <2>; 5962306a36Sopenharmony_ci interrupts = <43>; 6062306a36Sopenharmony_ci reg-io-width = <1>; 6162306a36Sopenharmony_ci clocks = <&coreclk 0>; 6262306a36Sopenharmony_ci status = "disabled"; 6362306a36Sopenharmony_ci }; 6462306a36Sopenharmony_ci 6562306a36Sopenharmony_ci uart3: serial@12300 { 6662306a36Sopenharmony_ci compatible = "snps,dw-apb-uart"; 6762306a36Sopenharmony_ci pinctrl-0 = <&uart3_pins>; 6862306a36Sopenharmony_ci pinctrl-names = "default"; 6962306a36Sopenharmony_ci reg = <0x12300 0x100>; 7062306a36Sopenharmony_ci reg-shift = <2>; 7162306a36Sopenharmony_ci interrupts = <44>; 7262306a36Sopenharmony_ci reg-io-width = <1>; 7362306a36Sopenharmony_ci clocks = <&coreclk 0>; 7462306a36Sopenharmony_ci status = "disabled"; 7562306a36Sopenharmony_ci }; 7662306a36Sopenharmony_ci 7762306a36Sopenharmony_ci systemc: system-controller@18200 { 7862306a36Sopenharmony_ci compatible = "marvell,armada-370-xp-system-controller"; 7962306a36Sopenharmony_ci reg = <0x18200 0x500>; 8062306a36Sopenharmony_ci }; 8162306a36Sopenharmony_ci 8262306a36Sopenharmony_ci gateclk: clock-gating-control@18220 { 8362306a36Sopenharmony_ci compatible = "marvell,armada-xp-gating-clock"; 8462306a36Sopenharmony_ci reg = <0x18220 0x4>; 8562306a36Sopenharmony_ci clocks = <&coreclk 0>; 8662306a36Sopenharmony_ci #clock-cells = <1>; 8762306a36Sopenharmony_ci }; 8862306a36Sopenharmony_ci 8962306a36Sopenharmony_ci coreclk: mvebu-sar@18230 { 9062306a36Sopenharmony_ci compatible = "marvell,armada-xp-core-clock"; 9162306a36Sopenharmony_ci reg = <0x18230 0x08>; 9262306a36Sopenharmony_ci #clock-cells = <1>; 9362306a36Sopenharmony_ci }; 9462306a36Sopenharmony_ci 9562306a36Sopenharmony_ci thermal: thermal@182b0 { 9662306a36Sopenharmony_ci compatible = "marvell,armadaxp-thermal"; 9762306a36Sopenharmony_ci reg = <0x182b0 0x4 9862306a36Sopenharmony_ci 0x184d0 0x4>; 9962306a36Sopenharmony_ci status = "okay"; 10062306a36Sopenharmony_ci }; 10162306a36Sopenharmony_ci 10262306a36Sopenharmony_ci cpuclk: clock-complex@18700 { 10362306a36Sopenharmony_ci #clock-cells = <1>; 10462306a36Sopenharmony_ci compatible = "marvell,armada-xp-cpu-clock"; 10562306a36Sopenharmony_ci reg = <0x18700 0x24>, <0x1c054 0x10>; 10662306a36Sopenharmony_ci clocks = <&coreclk 1>; 10762306a36Sopenharmony_ci }; 10862306a36Sopenharmony_ci 10962306a36Sopenharmony_ci cpu-config@21000 { 11062306a36Sopenharmony_ci compatible = "marvell,armada-xp-cpu-config"; 11162306a36Sopenharmony_ci reg = <0x21000 0x8>; 11262306a36Sopenharmony_ci }; 11362306a36Sopenharmony_ci 11462306a36Sopenharmony_ci eth2: ethernet@30000 { 11562306a36Sopenharmony_ci compatible = "marvell,armada-xp-neta"; 11662306a36Sopenharmony_ci reg = <0x30000 0x4000>; 11762306a36Sopenharmony_ci interrupts = <12>; 11862306a36Sopenharmony_ci clocks = <&gateclk 2>; 11962306a36Sopenharmony_ci status = "disabled"; 12062306a36Sopenharmony_ci }; 12162306a36Sopenharmony_ci 12262306a36Sopenharmony_ci usb2: usb@52000 { 12362306a36Sopenharmony_ci compatible = "marvell,orion-ehci"; 12462306a36Sopenharmony_ci reg = <0x52000 0x500>; 12562306a36Sopenharmony_ci interrupts = <47>; 12662306a36Sopenharmony_ci clocks = <&gateclk 20>; 12762306a36Sopenharmony_ci status = "disabled"; 12862306a36Sopenharmony_ci }; 12962306a36Sopenharmony_ci 13062306a36Sopenharmony_ci xor1: xor@60900 { 13162306a36Sopenharmony_ci compatible = "marvell,orion-xor"; 13262306a36Sopenharmony_ci reg = <0x60900 0x100 13362306a36Sopenharmony_ci 0x60b00 0x100>; 13462306a36Sopenharmony_ci clocks = <&gateclk 22>; 13562306a36Sopenharmony_ci status = "okay"; 13662306a36Sopenharmony_ci 13762306a36Sopenharmony_ci xor10 { 13862306a36Sopenharmony_ci interrupts = <51>; 13962306a36Sopenharmony_ci dmacap,memcpy; 14062306a36Sopenharmony_ci dmacap,xor; 14162306a36Sopenharmony_ci }; 14262306a36Sopenharmony_ci xor11 { 14362306a36Sopenharmony_ci interrupts = <52>; 14462306a36Sopenharmony_ci dmacap,memcpy; 14562306a36Sopenharmony_ci dmacap,xor; 14662306a36Sopenharmony_ci dmacap,memset; 14762306a36Sopenharmony_ci }; 14862306a36Sopenharmony_ci }; 14962306a36Sopenharmony_ci 15062306a36Sopenharmony_ci ethernet@70000 { 15162306a36Sopenharmony_ci compatible = "marvell,armada-xp-neta"; 15262306a36Sopenharmony_ci }; 15362306a36Sopenharmony_ci 15462306a36Sopenharmony_ci ethernet@74000 { 15562306a36Sopenharmony_ci compatible = "marvell,armada-xp-neta"; 15662306a36Sopenharmony_ci }; 15762306a36Sopenharmony_ci 15862306a36Sopenharmony_ci cesa: crypto@90000 { 15962306a36Sopenharmony_ci compatible = "marvell,armada-xp-crypto"; 16062306a36Sopenharmony_ci reg = <0x90000 0x10000>; 16162306a36Sopenharmony_ci reg-names = "regs"; 16262306a36Sopenharmony_ci interrupts = <48>, <49>; 16362306a36Sopenharmony_ci clocks = <&gateclk 23>, <&gateclk 23>; 16462306a36Sopenharmony_ci clock-names = "cesa0", "cesa1"; 16562306a36Sopenharmony_ci marvell,crypto-srams = <&crypto_sram0>, 16662306a36Sopenharmony_ci <&crypto_sram1>; 16762306a36Sopenharmony_ci marvell,crypto-sram-size = <0x800>; 16862306a36Sopenharmony_ci }; 16962306a36Sopenharmony_ci 17062306a36Sopenharmony_ci bm: bm@c0000 { 17162306a36Sopenharmony_ci compatible = "marvell,armada-380-neta-bm"; 17262306a36Sopenharmony_ci reg = <0xc0000 0xac>; 17362306a36Sopenharmony_ci clocks = <&gateclk 13>; 17462306a36Sopenharmony_ci internal-mem = <&bm_bppi>; 17562306a36Sopenharmony_ci status = "disabled"; 17662306a36Sopenharmony_ci }; 17762306a36Sopenharmony_ci 17862306a36Sopenharmony_ci xor0: xor@f0900 { 17962306a36Sopenharmony_ci compatible = "marvell,orion-xor"; 18062306a36Sopenharmony_ci reg = <0xF0900 0x100 18162306a36Sopenharmony_ci 0xF0B00 0x100>; 18262306a36Sopenharmony_ci clocks = <&gateclk 28>; 18362306a36Sopenharmony_ci status = "okay"; 18462306a36Sopenharmony_ci 18562306a36Sopenharmony_ci xor00 { 18662306a36Sopenharmony_ci interrupts = <94>; 18762306a36Sopenharmony_ci dmacap,memcpy; 18862306a36Sopenharmony_ci dmacap,xor; 18962306a36Sopenharmony_ci }; 19062306a36Sopenharmony_ci xor01 { 19162306a36Sopenharmony_ci interrupts = <95>; 19262306a36Sopenharmony_ci dmacap,memcpy; 19362306a36Sopenharmony_ci dmacap,xor; 19462306a36Sopenharmony_ci dmacap,memset; 19562306a36Sopenharmony_ci }; 19662306a36Sopenharmony_ci }; 19762306a36Sopenharmony_ci }; 19862306a36Sopenharmony_ci 19962306a36Sopenharmony_ci crypto_sram0: sa-sram0 { 20062306a36Sopenharmony_ci compatible = "mmio-sram"; 20162306a36Sopenharmony_ci reg = <MBUS_ID(0x09, 0x09) 0 0x800>; 20262306a36Sopenharmony_ci clocks = <&gateclk 23>; 20362306a36Sopenharmony_ci #address-cells = <1>; 20462306a36Sopenharmony_ci #size-cells = <1>; 20562306a36Sopenharmony_ci ranges = <0 MBUS_ID(0x09, 0x09) 0 0x800>; 20662306a36Sopenharmony_ci }; 20762306a36Sopenharmony_ci 20862306a36Sopenharmony_ci crypto_sram1: sa-sram1 { 20962306a36Sopenharmony_ci compatible = "mmio-sram"; 21062306a36Sopenharmony_ci reg = <MBUS_ID(0x09, 0x05) 0 0x800>; 21162306a36Sopenharmony_ci clocks = <&gateclk 23>; 21262306a36Sopenharmony_ci #address-cells = <1>; 21362306a36Sopenharmony_ci #size-cells = <1>; 21462306a36Sopenharmony_ci ranges = <0 MBUS_ID(0x09, 0x05) 0 0x800>; 21562306a36Sopenharmony_ci }; 21662306a36Sopenharmony_ci 21762306a36Sopenharmony_ci bm_bppi: bm-bppi { 21862306a36Sopenharmony_ci compatible = "mmio-sram"; 21962306a36Sopenharmony_ci reg = <MBUS_ID(0x0c, 0x04) 0 0x100000>; 22062306a36Sopenharmony_ci ranges = <0 MBUS_ID(0x0c, 0x04) 0 0x100000>; 22162306a36Sopenharmony_ci #address-cells = <1>; 22262306a36Sopenharmony_ci #size-cells = <1>; 22362306a36Sopenharmony_ci clocks = <&gateclk 13>; 22462306a36Sopenharmony_ci no-memory-wc; 22562306a36Sopenharmony_ci status = "disabled"; 22662306a36Sopenharmony_ci }; 22762306a36Sopenharmony_ci }; 22862306a36Sopenharmony_ci 22962306a36Sopenharmony_ci clocks { 23062306a36Sopenharmony_ci /* 25 MHz reference crystal */ 23162306a36Sopenharmony_ci refclk: oscillator { 23262306a36Sopenharmony_ci compatible = "fixed-clock"; 23362306a36Sopenharmony_ci #clock-cells = <0>; 23462306a36Sopenharmony_ci clock-frequency = <25000000>; 23562306a36Sopenharmony_ci }; 23662306a36Sopenharmony_ci }; 23762306a36Sopenharmony_ci}; 23862306a36Sopenharmony_ci 23962306a36Sopenharmony_ci&i2c0 { 24062306a36Sopenharmony_ci compatible = "marvell,mv78230-i2c", "marvell,mv64xxx-i2c"; 24162306a36Sopenharmony_ci reg = <0x11000 0x100>; 24262306a36Sopenharmony_ci}; 24362306a36Sopenharmony_ci 24462306a36Sopenharmony_ci&i2c1 { 24562306a36Sopenharmony_ci compatible = "marvell,mv78230-i2c", "marvell,mv64xxx-i2c"; 24662306a36Sopenharmony_ci reg = <0x11100 0x100>; 24762306a36Sopenharmony_ci}; 24862306a36Sopenharmony_ci 24962306a36Sopenharmony_ci&mpic { 25062306a36Sopenharmony_ci reg = <0x20a00 0x2d0>, <0x21070 0x58>; 25162306a36Sopenharmony_ci}; 25262306a36Sopenharmony_ci 25362306a36Sopenharmony_ci&timer { 25462306a36Sopenharmony_ci compatible = "marvell,armada-xp-timer"; 25562306a36Sopenharmony_ci clocks = <&coreclk 2>, <&refclk>; 25662306a36Sopenharmony_ci clock-names = "nbclk", "fixed"; 25762306a36Sopenharmony_ci}; 25862306a36Sopenharmony_ci 25962306a36Sopenharmony_ci&watchdog { 26062306a36Sopenharmony_ci compatible = "marvell,armada-xp-wdt"; 26162306a36Sopenharmony_ci clocks = <&coreclk 2>, <&refclk>; 26262306a36Sopenharmony_ci clock-names = "nbclk", "fixed"; 26362306a36Sopenharmony_ci interrupts = <93>, <38>; 26462306a36Sopenharmony_ci}; 26562306a36Sopenharmony_ci 26662306a36Sopenharmony_ci&cpurst { 26762306a36Sopenharmony_ci reg = <0x20800 0x20>; 26862306a36Sopenharmony_ci}; 26962306a36Sopenharmony_ci 27062306a36Sopenharmony_ci&usb0 { 27162306a36Sopenharmony_ci clocks = <&gateclk 18>; 27262306a36Sopenharmony_ci}; 27362306a36Sopenharmony_ci 27462306a36Sopenharmony_ci&usb1 { 27562306a36Sopenharmony_ci clocks = <&gateclk 19>; 27662306a36Sopenharmony_ci}; 27762306a36Sopenharmony_ci 27862306a36Sopenharmony_ci&pinctrl { 27962306a36Sopenharmony_ci ge0_gmii_pins: ge0-gmii-pins { 28062306a36Sopenharmony_ci marvell,pins = 28162306a36Sopenharmony_ci "mpp0", "mpp1", "mpp2", "mpp3", 28262306a36Sopenharmony_ci "mpp4", "mpp5", "mpp6", "mpp7", 28362306a36Sopenharmony_ci "mpp8", "mpp9", "mpp10", "mpp11", 28462306a36Sopenharmony_ci "mpp12", "mpp13", "mpp14", "mpp15", 28562306a36Sopenharmony_ci "mpp16", "mpp17", "mpp18", "mpp19", 28662306a36Sopenharmony_ci "mpp20", "mpp21", "mpp22", "mpp23"; 28762306a36Sopenharmony_ci marvell,function = "ge0"; 28862306a36Sopenharmony_ci }; 28962306a36Sopenharmony_ci 29062306a36Sopenharmony_ci ge0_rgmii_pins: ge0-rgmii-pins { 29162306a36Sopenharmony_ci marvell,pins = 29262306a36Sopenharmony_ci "mpp0", "mpp1", "mpp2", "mpp3", 29362306a36Sopenharmony_ci "mpp4", "mpp5", "mpp6", "mpp7", 29462306a36Sopenharmony_ci "mpp8", "mpp9", "mpp10", "mpp11"; 29562306a36Sopenharmony_ci marvell,function = "ge0"; 29662306a36Sopenharmony_ci }; 29762306a36Sopenharmony_ci 29862306a36Sopenharmony_ci ge1_rgmii_pins: ge1-rgmii-pins { 29962306a36Sopenharmony_ci marvell,pins = 30062306a36Sopenharmony_ci "mpp12", "mpp13", "mpp14", "mpp15", 30162306a36Sopenharmony_ci "mpp16", "mpp17", "mpp18", "mpp19", 30262306a36Sopenharmony_ci "mpp20", "mpp21", "mpp22", "mpp23"; 30362306a36Sopenharmony_ci marvell,function = "ge1"; 30462306a36Sopenharmony_ci }; 30562306a36Sopenharmony_ci 30662306a36Sopenharmony_ci sdio_pins: sdio-pins { 30762306a36Sopenharmony_ci marvell,pins = "mpp30", "mpp31", "mpp32", 30862306a36Sopenharmony_ci "mpp33", "mpp34", "mpp35"; 30962306a36Sopenharmony_ci marvell,function = "sd0"; 31062306a36Sopenharmony_ci }; 31162306a36Sopenharmony_ci 31262306a36Sopenharmony_ci spi0_pins: spi0-pins { 31362306a36Sopenharmony_ci marvell,pins = "mpp36", "mpp37", 31462306a36Sopenharmony_ci "mpp38", "mpp39"; 31562306a36Sopenharmony_ci marvell,function = "spi0"; 31662306a36Sopenharmony_ci }; 31762306a36Sopenharmony_ci 31862306a36Sopenharmony_ci spi1_pins: spi1-pins { 31962306a36Sopenharmony_ci marvell,pins = "mpp13", "mpp14", 32062306a36Sopenharmony_ci "mpp16", "mpp17"; 32162306a36Sopenharmony_ci marvell,function = "spi1"; 32262306a36Sopenharmony_ci }; 32362306a36Sopenharmony_ci 32462306a36Sopenharmony_ci uart2_pins: uart2-pins { 32562306a36Sopenharmony_ci marvell,pins = "mpp42", "mpp43"; 32662306a36Sopenharmony_ci marvell,function = "uart2"; 32762306a36Sopenharmony_ci }; 32862306a36Sopenharmony_ci 32962306a36Sopenharmony_ci uart3_pins: uart3-pins { 33062306a36Sopenharmony_ci marvell,pins = "mpp44", "mpp45"; 33162306a36Sopenharmony_ci marvell,function = "uart3"; 33262306a36Sopenharmony_ci }; 33362306a36Sopenharmony_ci}; 33462306a36Sopenharmony_ci 33562306a36Sopenharmony_ci&spi0 { 33662306a36Sopenharmony_ci compatible = "marvell,armada-xp-spi", "marvell,orion-spi"; 33762306a36Sopenharmony_ci pinctrl-0 = <&spi0_pins>; 33862306a36Sopenharmony_ci pinctrl-names = "default"; 33962306a36Sopenharmony_ci}; 34062306a36Sopenharmony_ci 34162306a36Sopenharmony_ci&spi1 { 34262306a36Sopenharmony_ci compatible = "marvell,armada-xp-spi", "marvell,orion-spi"; 34362306a36Sopenharmony_ci pinctrl-0 = <&spi1_pins>; 34462306a36Sopenharmony_ci pinctrl-names = "default"; 34562306a36Sopenharmony_ci}; 346