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 * Thomas Petazzoni <thomas.petazzoni@free-electrons.com> 862306a36Sopenharmony_ci * 962306a36Sopenharmony_ci * Contains definitions specific to the Armada XP MV78230 SoC that are not 1062306a36Sopenharmony_ci * common to all Armada XP SoCs. 1162306a36Sopenharmony_ci */ 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci#include "armada-xp.dtsi" 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci/ { 1662306a36Sopenharmony_ci model = "Marvell Armada XP MV78230 SoC"; 1762306a36Sopenharmony_ci compatible = "marvell,armadaxp-mv78230", "marvell,armadaxp", "marvell,armada-370-xp"; 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci aliases { 2062306a36Sopenharmony_ci gpio0 = &gpio0; 2162306a36Sopenharmony_ci gpio1 = &gpio1; 2262306a36Sopenharmony_ci }; 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_ci cpus { 2562306a36Sopenharmony_ci #address-cells = <1>; 2662306a36Sopenharmony_ci #size-cells = <0>; 2762306a36Sopenharmony_ci enable-method = "marvell,armada-xp-smp"; 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_ci cpu@0 { 3062306a36Sopenharmony_ci device_type = "cpu"; 3162306a36Sopenharmony_ci compatible = "marvell,sheeva-v7"; 3262306a36Sopenharmony_ci reg = <0>; 3362306a36Sopenharmony_ci clocks = <&cpuclk 0>; 3462306a36Sopenharmony_ci clock-latency = <1000000>; 3562306a36Sopenharmony_ci }; 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci cpu@1 { 3862306a36Sopenharmony_ci device_type = "cpu"; 3962306a36Sopenharmony_ci compatible = "marvell,sheeva-v7"; 4062306a36Sopenharmony_ci reg = <1>; 4162306a36Sopenharmony_ci clocks = <&cpuclk 1>; 4262306a36Sopenharmony_ci clock-latency = <1000000>; 4362306a36Sopenharmony_ci }; 4462306a36Sopenharmony_ci }; 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci soc { 4762306a36Sopenharmony_ci /* 4862306a36Sopenharmony_ci * MV78230 has 2 PCIe units Gen2.0: One unit can be 4962306a36Sopenharmony_ci * configured as x4 or quad x1 lanes. One unit is 5062306a36Sopenharmony_ci * x1 only. 5162306a36Sopenharmony_ci */ 5262306a36Sopenharmony_ci pciec: pcie@82000000 { 5362306a36Sopenharmony_ci compatible = "marvell,armada-xp-pcie"; 5462306a36Sopenharmony_ci status = "disabled"; 5562306a36Sopenharmony_ci device_type = "pci"; 5662306a36Sopenharmony_ci 5762306a36Sopenharmony_ci #address-cells = <3>; 5862306a36Sopenharmony_ci #size-cells = <2>; 5962306a36Sopenharmony_ci 6062306a36Sopenharmony_ci msi-parent = <&mpic>; 6162306a36Sopenharmony_ci bus-range = <0x00 0xff>; 6262306a36Sopenharmony_ci 6362306a36Sopenharmony_ci ranges = 6462306a36Sopenharmony_ci <0x82000000 0 0x40000 MBUS_ID(0xf0, 0x01) 0x40000 0 0x00002000 /* Port 0.0 registers */ 6562306a36Sopenharmony_ci 0x82000000 0 0x44000 MBUS_ID(0xf0, 0x01) 0x44000 0 0x00002000 /* Port 0.1 registers */ 6662306a36Sopenharmony_ci 0x82000000 0 0x48000 MBUS_ID(0xf0, 0x01) 0x48000 0 0x00002000 /* Port 0.2 registers */ 6762306a36Sopenharmony_ci 0x82000000 0 0x4c000 MBUS_ID(0xf0, 0x01) 0x4c000 0 0x00002000 /* Port 0.3 registers */ 6862306a36Sopenharmony_ci 0x82000000 0 0x80000 MBUS_ID(0xf0, 0x01) 0x80000 0 0x00002000 /* Port 1.0 registers */ 6962306a36Sopenharmony_ci 0x82000000 0x1 0 MBUS_ID(0x04, 0xe8) 0 1 0 /* Port 0.0 MEM */ 7062306a36Sopenharmony_ci 0x81000000 0x1 0 MBUS_ID(0x04, 0xe0) 0 1 0 /* Port 0.0 IO */ 7162306a36Sopenharmony_ci 0x82000000 0x2 0 MBUS_ID(0x04, 0xd8) 0 1 0 /* Port 0.1 MEM */ 7262306a36Sopenharmony_ci 0x81000000 0x2 0 MBUS_ID(0x04, 0xd0) 0 1 0 /* Port 0.1 IO */ 7362306a36Sopenharmony_ci 0x82000000 0x3 0 MBUS_ID(0x04, 0xb8) 0 1 0 /* Port 0.2 MEM */ 7462306a36Sopenharmony_ci 0x81000000 0x3 0 MBUS_ID(0x04, 0xb0) 0 1 0 /* Port 0.2 IO */ 7562306a36Sopenharmony_ci 0x82000000 0x4 0 MBUS_ID(0x04, 0x78) 0 1 0 /* Port 0.3 MEM */ 7662306a36Sopenharmony_ci 0x81000000 0x4 0 MBUS_ID(0x04, 0x70) 0 1 0 /* Port 0.3 IO */ 7762306a36Sopenharmony_ci 0x82000000 0x5 0 MBUS_ID(0x08, 0xe8) 0 1 0 /* Port 1.0 MEM */ 7862306a36Sopenharmony_ci 0x81000000 0x5 0 MBUS_ID(0x08, 0xe0) 0 1 0 /* Port 1.0 IO */>; 7962306a36Sopenharmony_ci 8062306a36Sopenharmony_ci pcie1: pcie@1,0 { 8162306a36Sopenharmony_ci device_type = "pci"; 8262306a36Sopenharmony_ci assigned-addresses = <0x82000800 0 0x40000 0 0x2000>; 8362306a36Sopenharmony_ci reg = <0x0800 0 0 0 0>; 8462306a36Sopenharmony_ci #address-cells = <3>; 8562306a36Sopenharmony_ci #size-cells = <2>; 8662306a36Sopenharmony_ci interrupt-names = "intx"; 8762306a36Sopenharmony_ci interrupts-extended = <&mpic 58>; 8862306a36Sopenharmony_ci #interrupt-cells = <1>; 8962306a36Sopenharmony_ci ranges = <0x82000000 0 0 0x82000000 0x1 0 1 0 9062306a36Sopenharmony_ci 0x81000000 0 0 0x81000000 0x1 0 1 0>; 9162306a36Sopenharmony_ci bus-range = <0x00 0xff>; 9262306a36Sopenharmony_ci interrupt-map-mask = <0 0 0 7>; 9362306a36Sopenharmony_ci interrupt-map = <0 0 0 1 &pcie1_intc 0>, 9462306a36Sopenharmony_ci <0 0 0 2 &pcie1_intc 1>, 9562306a36Sopenharmony_ci <0 0 0 3 &pcie1_intc 2>, 9662306a36Sopenharmony_ci <0 0 0 4 &pcie1_intc 3>; 9762306a36Sopenharmony_ci marvell,pcie-port = <0>; 9862306a36Sopenharmony_ci marvell,pcie-lane = <0>; 9962306a36Sopenharmony_ci clocks = <&gateclk 5>; 10062306a36Sopenharmony_ci status = "disabled"; 10162306a36Sopenharmony_ci 10262306a36Sopenharmony_ci pcie1_intc: interrupt-controller { 10362306a36Sopenharmony_ci interrupt-controller; 10462306a36Sopenharmony_ci #interrupt-cells = <1>; 10562306a36Sopenharmony_ci }; 10662306a36Sopenharmony_ci }; 10762306a36Sopenharmony_ci 10862306a36Sopenharmony_ci pcie2: pcie@2,0 { 10962306a36Sopenharmony_ci device_type = "pci"; 11062306a36Sopenharmony_ci assigned-addresses = <0x82001000 0 0x44000 0 0x2000>; 11162306a36Sopenharmony_ci reg = <0x1000 0 0 0 0>; 11262306a36Sopenharmony_ci #address-cells = <3>; 11362306a36Sopenharmony_ci #size-cells = <2>; 11462306a36Sopenharmony_ci interrupt-names = "intx"; 11562306a36Sopenharmony_ci interrupts-extended = <&mpic 59>; 11662306a36Sopenharmony_ci #interrupt-cells = <1>; 11762306a36Sopenharmony_ci ranges = <0x82000000 0 0 0x82000000 0x2 0 1 0 11862306a36Sopenharmony_ci 0x81000000 0 0 0x81000000 0x2 0 1 0>; 11962306a36Sopenharmony_ci bus-range = <0x00 0xff>; 12062306a36Sopenharmony_ci interrupt-map-mask = <0 0 0 7>; 12162306a36Sopenharmony_ci interrupt-map = <0 0 0 1 &pcie2_intc 0>, 12262306a36Sopenharmony_ci <0 0 0 2 &pcie2_intc 1>, 12362306a36Sopenharmony_ci <0 0 0 3 &pcie2_intc 2>, 12462306a36Sopenharmony_ci <0 0 0 4 &pcie2_intc 3>; 12562306a36Sopenharmony_ci marvell,pcie-port = <0>; 12662306a36Sopenharmony_ci marvell,pcie-lane = <1>; 12762306a36Sopenharmony_ci clocks = <&gateclk 6>; 12862306a36Sopenharmony_ci status = "disabled"; 12962306a36Sopenharmony_ci 13062306a36Sopenharmony_ci pcie2_intc: interrupt-controller { 13162306a36Sopenharmony_ci interrupt-controller; 13262306a36Sopenharmony_ci #interrupt-cells = <1>; 13362306a36Sopenharmony_ci }; 13462306a36Sopenharmony_ci }; 13562306a36Sopenharmony_ci 13662306a36Sopenharmony_ci pcie3: pcie@3,0 { 13762306a36Sopenharmony_ci device_type = "pci"; 13862306a36Sopenharmony_ci assigned-addresses = <0x82001800 0 0x48000 0 0x2000>; 13962306a36Sopenharmony_ci reg = <0x1800 0 0 0 0>; 14062306a36Sopenharmony_ci #address-cells = <3>; 14162306a36Sopenharmony_ci #size-cells = <2>; 14262306a36Sopenharmony_ci interrupt-names = "intx"; 14362306a36Sopenharmony_ci interrupts-extended = <&mpic 60>; 14462306a36Sopenharmony_ci #interrupt-cells = <1>; 14562306a36Sopenharmony_ci ranges = <0x82000000 0 0 0x82000000 0x3 0 1 0 14662306a36Sopenharmony_ci 0x81000000 0 0 0x81000000 0x3 0 1 0>; 14762306a36Sopenharmony_ci bus-range = <0x00 0xff>; 14862306a36Sopenharmony_ci interrupt-map-mask = <0 0 0 7>; 14962306a36Sopenharmony_ci interrupt-map = <0 0 0 1 &pcie3_intc 0>, 15062306a36Sopenharmony_ci <0 0 0 2 &pcie3_intc 1>, 15162306a36Sopenharmony_ci <0 0 0 3 &pcie3_intc 2>, 15262306a36Sopenharmony_ci <0 0 0 4 &pcie3_intc 3>; 15362306a36Sopenharmony_ci marvell,pcie-port = <0>; 15462306a36Sopenharmony_ci marvell,pcie-lane = <2>; 15562306a36Sopenharmony_ci clocks = <&gateclk 7>; 15662306a36Sopenharmony_ci status = "disabled"; 15762306a36Sopenharmony_ci 15862306a36Sopenharmony_ci pcie3_intc: interrupt-controller { 15962306a36Sopenharmony_ci interrupt-controller; 16062306a36Sopenharmony_ci #interrupt-cells = <1>; 16162306a36Sopenharmony_ci }; 16262306a36Sopenharmony_ci }; 16362306a36Sopenharmony_ci 16462306a36Sopenharmony_ci pcie4: pcie@4,0 { 16562306a36Sopenharmony_ci device_type = "pci"; 16662306a36Sopenharmony_ci assigned-addresses = <0x82002000 0 0x4c000 0 0x2000>; 16762306a36Sopenharmony_ci reg = <0x2000 0 0 0 0>; 16862306a36Sopenharmony_ci #address-cells = <3>; 16962306a36Sopenharmony_ci #size-cells = <2>; 17062306a36Sopenharmony_ci interrupt-names = "intx"; 17162306a36Sopenharmony_ci interrupts-extended = <&mpic 61>; 17262306a36Sopenharmony_ci #interrupt-cells = <1>; 17362306a36Sopenharmony_ci ranges = <0x82000000 0 0 0x82000000 0x4 0 1 0 17462306a36Sopenharmony_ci 0x81000000 0 0 0x81000000 0x4 0 1 0>; 17562306a36Sopenharmony_ci bus-range = <0x00 0xff>; 17662306a36Sopenharmony_ci interrupt-map-mask = <0 0 0 7>; 17762306a36Sopenharmony_ci interrupt-map = <0 0 0 1 &pcie4_intc 0>, 17862306a36Sopenharmony_ci <0 0 0 2 &pcie4_intc 1>, 17962306a36Sopenharmony_ci <0 0 0 3 &pcie4_intc 2>, 18062306a36Sopenharmony_ci <0 0 0 4 &pcie4_intc 3>; 18162306a36Sopenharmony_ci marvell,pcie-port = <0>; 18262306a36Sopenharmony_ci marvell,pcie-lane = <3>; 18362306a36Sopenharmony_ci clocks = <&gateclk 8>; 18462306a36Sopenharmony_ci status = "disabled"; 18562306a36Sopenharmony_ci 18662306a36Sopenharmony_ci pcie4_intc: interrupt-controller { 18762306a36Sopenharmony_ci interrupt-controller; 18862306a36Sopenharmony_ci #interrupt-cells = <1>; 18962306a36Sopenharmony_ci }; 19062306a36Sopenharmony_ci }; 19162306a36Sopenharmony_ci 19262306a36Sopenharmony_ci pcie5: pcie@5,0 { 19362306a36Sopenharmony_ci device_type = "pci"; 19462306a36Sopenharmony_ci assigned-addresses = <0x82002800 0 0x80000 0 0x2000>; 19562306a36Sopenharmony_ci reg = <0x2800 0 0 0 0>; 19662306a36Sopenharmony_ci #address-cells = <3>; 19762306a36Sopenharmony_ci #size-cells = <2>; 19862306a36Sopenharmony_ci interrupt-names = "intx"; 19962306a36Sopenharmony_ci interrupts-extended = <&mpic 62>; 20062306a36Sopenharmony_ci #interrupt-cells = <1>; 20162306a36Sopenharmony_ci ranges = <0x82000000 0 0 0x82000000 0x5 0 1 0 20262306a36Sopenharmony_ci 0x81000000 0 0 0x81000000 0x5 0 1 0>; 20362306a36Sopenharmony_ci bus-range = <0x00 0xff>; 20462306a36Sopenharmony_ci interrupt-map-mask = <0 0 0 7>; 20562306a36Sopenharmony_ci interrupt-map = <0 0 0 1 &pcie5_intc 0>, 20662306a36Sopenharmony_ci <0 0 0 2 &pcie5_intc 1>, 20762306a36Sopenharmony_ci <0 0 0 3 &pcie5_intc 2>, 20862306a36Sopenharmony_ci <0 0 0 4 &pcie5_intc 3>; 20962306a36Sopenharmony_ci marvell,pcie-port = <1>; 21062306a36Sopenharmony_ci marvell,pcie-lane = <0>; 21162306a36Sopenharmony_ci clocks = <&gateclk 9>; 21262306a36Sopenharmony_ci status = "disabled"; 21362306a36Sopenharmony_ci 21462306a36Sopenharmony_ci pcie5_intc: interrupt-controller { 21562306a36Sopenharmony_ci interrupt-controller; 21662306a36Sopenharmony_ci #interrupt-cells = <1>; 21762306a36Sopenharmony_ci }; 21862306a36Sopenharmony_ci }; 21962306a36Sopenharmony_ci }; 22062306a36Sopenharmony_ci 22162306a36Sopenharmony_ci internal-regs { 22262306a36Sopenharmony_ci gpio0: gpio@18100 { 22362306a36Sopenharmony_ci compatible = "marvell,armada-370-gpio", 22462306a36Sopenharmony_ci "marvell,orion-gpio"; 22562306a36Sopenharmony_ci reg = <0x18100 0x40>, <0x181c0 0x08>; 22662306a36Sopenharmony_ci reg-names = "gpio", "pwm"; 22762306a36Sopenharmony_ci ngpios = <32>; 22862306a36Sopenharmony_ci gpio-controller; 22962306a36Sopenharmony_ci #gpio-cells = <2>; 23062306a36Sopenharmony_ci #pwm-cells = <2>; 23162306a36Sopenharmony_ci interrupt-controller; 23262306a36Sopenharmony_ci #interrupt-cells = <2>; 23362306a36Sopenharmony_ci interrupts = <82>, <83>, <84>, <85>; 23462306a36Sopenharmony_ci clocks = <&coreclk 0>; 23562306a36Sopenharmony_ci }; 23662306a36Sopenharmony_ci 23762306a36Sopenharmony_ci gpio1: gpio@18140 { 23862306a36Sopenharmony_ci compatible = "marvell,armada-370-gpio", 23962306a36Sopenharmony_ci "marvell,orion-gpio"; 24062306a36Sopenharmony_ci reg = <0x18140 0x40>, <0x181c8 0x08>; 24162306a36Sopenharmony_ci reg-names = "gpio", "pwm"; 24262306a36Sopenharmony_ci ngpios = <17>; 24362306a36Sopenharmony_ci gpio-controller; 24462306a36Sopenharmony_ci #gpio-cells = <2>; 24562306a36Sopenharmony_ci #pwm-cells = <2>; 24662306a36Sopenharmony_ci interrupt-controller; 24762306a36Sopenharmony_ci #interrupt-cells = <2>; 24862306a36Sopenharmony_ci interrupts = <87>, <88>, <89>; 24962306a36Sopenharmony_ci clocks = <&coreclk 0>; 25062306a36Sopenharmony_ci }; 25162306a36Sopenharmony_ci }; 25262306a36Sopenharmony_ci }; 25362306a36Sopenharmony_ci}; 25462306a36Sopenharmony_ci 25562306a36Sopenharmony_ci&pinctrl { 25662306a36Sopenharmony_ci compatible = "marvell,mv78230-pinctrl"; 25762306a36Sopenharmony_ci}; 258