1// SPDX-License-Identifier: (GPL-2.0+ OR MIT) 2/* 3 * Device Tree Include file for Marvell Armada 385 SoC. 4 * 5 * Copyright (C) 2014 Marvell 6 * 7 * Lior Amsalem <alior@marvell.com> 8 * Gregory CLEMENT <gregory.clement@free-electrons.com> 9 * Thomas Petazzoni <thomas.petazzoni@free-electrons.com> 10 */ 11 12#include "armada-38x.dtsi" 13 14/ { 15 model = "Marvell Armada 385 family SoC"; 16 compatible = "marvell,armada385", "marvell,armada380"; 17 18 cpus { 19 #address-cells = <1>; 20 #size-cells = <0>; 21 enable-method = "marvell,armada-380-smp"; 22 23 cpu@0 { 24 device_type = "cpu"; 25 compatible = "arm,cortex-a9"; 26 reg = <0>; 27 }; 28 cpu@1 { 29 device_type = "cpu"; 30 compatible = "arm,cortex-a9"; 31 reg = <1>; 32 }; 33 }; 34 35 soc { 36 pciec: pcie { 37 compatible = "marvell,armada-370-pcie"; 38 status = "disabled"; 39 device_type = "pci"; 40 41 #address-cells = <3>; 42 #size-cells = <2>; 43 44 msi-parent = <&mpic>; 45 bus-range = <0x00 0xff>; 46 47 ranges = 48 <0x82000000 0 0x80000 MBUS_ID(0xf0, 0x01) 0x80000 0 0x00002000 49 0x82000000 0 0x40000 MBUS_ID(0xf0, 0x01) 0x40000 0 0x00002000 50 0x82000000 0 0x44000 MBUS_ID(0xf0, 0x01) 0x44000 0 0x00002000 51 0x82000000 0 0x48000 MBUS_ID(0xf0, 0x01) 0x48000 0 0x00002000 52 0x82000000 0x1 0 MBUS_ID(0x08, 0xe8) 0 1 0 /* Port 0 MEM */ 53 0x81000000 0x1 0 MBUS_ID(0x08, 0xe0) 0 1 0 /* Port 0 IO */ 54 0x82000000 0x2 0 MBUS_ID(0x04, 0xe8) 0 1 0 /* Port 1 MEM */ 55 0x81000000 0x2 0 MBUS_ID(0x04, 0xe0) 0 1 0 /* Port 1 IO */ 56 0x82000000 0x3 0 MBUS_ID(0x04, 0xd8) 0 1 0 /* Port 2 MEM */ 57 0x81000000 0x3 0 MBUS_ID(0x04, 0xd0) 0 1 0 /* Port 2 IO */ 58 0x82000000 0x4 0 MBUS_ID(0x04, 0xb8) 0 1 0 /* Port 3 MEM */ 59 0x81000000 0x4 0 MBUS_ID(0x04, 0xb0) 0 1 0 /* Port 3 IO */>; 60 61 /* 62 * This port can be either x4 or x1. When 63 * configured in x4 by the bootloader, then 64 * pcie@4,0 is not available. 65 */ 66 pcie1: pcie@1,0 { 67 device_type = "pci"; 68 assigned-addresses = <0x82000800 0 0x80000 0 0x2000>; 69 reg = <0x0800 0 0 0 0>; 70 #address-cells = <3>; 71 #size-cells = <2>; 72 interrupt-names = "intx"; 73 interrupts-extended = <&gic GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>; 74 #interrupt-cells = <1>; 75 ranges = <0x82000000 0 0 0x82000000 0x1 0 1 0 76 0x81000000 0 0 0x81000000 0x1 0 1 0>; 77 bus-range = <0x00 0xff>; 78 interrupt-map-mask = <0 0 0 7>; 79 interrupt-map = <0 0 0 1 &pcie1_intc 0>, 80 <0 0 0 2 &pcie1_intc 1>, 81 <0 0 0 3 &pcie1_intc 2>, 82 <0 0 0 4 &pcie1_intc 3>; 83 marvell,pcie-port = <0>; 84 marvell,pcie-lane = <0>; 85 clocks = <&gateclk 8>; 86 status = "disabled"; 87 pcie1_intc: interrupt-controller { 88 interrupt-controller; 89 #interrupt-cells = <1>; 90 }; 91 }; 92 93 /* x1 port */ 94 pcie2: pcie@2,0 { 95 device_type = "pci"; 96 assigned-addresses = <0x82000800 0 0x40000 0 0x2000>; 97 reg = <0x1000 0 0 0 0>; 98 #address-cells = <3>; 99 #size-cells = <2>; 100 interrupt-names = "intx"; 101 interrupts-extended = <&gic GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>; 102 #interrupt-cells = <1>; 103 ranges = <0x82000000 0 0 0x82000000 0x2 0 1 0 104 0x81000000 0 0 0x81000000 0x2 0 1 0>; 105 bus-range = <0x00 0xff>; 106 interrupt-map-mask = <0 0 0 7>; 107 interrupt-map = <0 0 0 1 &pcie2_intc 0>, 108 <0 0 0 2 &pcie2_intc 1>, 109 <0 0 0 3 &pcie2_intc 2>, 110 <0 0 0 4 &pcie2_intc 3>; 111 marvell,pcie-port = <1>; 112 marvell,pcie-lane = <0>; 113 clocks = <&gateclk 5>; 114 status = "disabled"; 115 pcie2_intc: interrupt-controller { 116 interrupt-controller; 117 #interrupt-cells = <1>; 118 }; 119 }; 120 121 /* x1 port */ 122 pcie3: pcie@3,0 { 123 device_type = "pci"; 124 assigned-addresses = <0x82000800 0 0x44000 0 0x2000>; 125 reg = <0x1800 0 0 0 0>; 126 #address-cells = <3>; 127 #size-cells = <2>; 128 interrupt-names = "intx"; 129 interrupts-extended = <&gic GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>; 130 #interrupt-cells = <1>; 131 ranges = <0x82000000 0 0 0x82000000 0x3 0 1 0 132 0x81000000 0 0 0x81000000 0x3 0 1 0>; 133 bus-range = <0x00 0xff>; 134 interrupt-map-mask = <0 0 0 7>; 135 interrupt-map = <0 0 0 1 &pcie3_intc 0>, 136 <0 0 0 2 &pcie3_intc 1>, 137 <0 0 0 3 &pcie3_intc 2>, 138 <0 0 0 4 &pcie3_intc 3>; 139 marvell,pcie-port = <2>; 140 marvell,pcie-lane = <0>; 141 clocks = <&gateclk 6>; 142 status = "disabled"; 143 pcie3_intc: interrupt-controller { 144 interrupt-controller; 145 #interrupt-cells = <1>; 146 }; 147 }; 148 149 /* 150 * x1 port only available when pcie@1,0 is 151 * configured as a x1 port 152 */ 153 pcie4: pcie@4,0 { 154 device_type = "pci"; 155 assigned-addresses = <0x82000800 0 0x48000 0 0x2000>; 156 reg = <0x2000 0 0 0 0>; 157 #address-cells = <3>; 158 #size-cells = <2>; 159 interrupt-names = "intx"; 160 interrupts-extended = <&gic GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>; 161 #interrupt-cells = <1>; 162 ranges = <0x82000000 0 0 0x82000000 0x4 0 1 0 163 0x81000000 0 0 0x81000000 0x4 0 1 0>; 164 bus-range = <0x00 0xff>; 165 interrupt-map-mask = <0 0 0 7>; 166 interrupt-map = <0 0 0 1 &pcie4_intc 0>, 167 <0 0 0 2 &pcie4_intc 1>, 168 <0 0 0 3 &pcie4_intc 2>, 169 <0 0 0 4 &pcie4_intc 3>; 170 marvell,pcie-port = <3>; 171 marvell,pcie-lane = <0>; 172 clocks = <&gateclk 7>; 173 status = "disabled"; 174 pcie4_intc: interrupt-controller { 175 interrupt-controller; 176 #interrupt-cells = <1>; 177 }; 178 }; 179 }; 180 }; 181}; 182 183&pinctrl { 184 compatible = "marvell,mv88f6820-pinctrl"; 185}; 186