2012-09-13 17:41:48 +02:00
/*
* Device Tree Include file for Marvell Armada XP family SoC
*
* Copyright (C) 2012 Marvell
*
* Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
*
* This file is licensed under the terms of the GNU General Public
* License version 2. This program is licensed "as is" without any
* warranty of any kind, whether express or implied.
*
* Contains definitions specific to the Armada XP MV78230 SoC that are not
* common to all Armada XP SoCs.
*/
2013-08-07 20:04:21 +00:00
#include "armada-xp.dtsi"
2012-09-13 17:41:48 +02:00
/ {
model = "Marvell Armada XP MV78230 SoC";
compatible = "marvell,armadaxp-mv78230", "marvell,armadaxp", "marvell,armada-370-xp";
2012-09-19 22:53:01 +02:00
aliases {
gpio0 = &gpio0;
gpio1 = &gpio1;
};
2012-11-17 15:22:24 +01:00
cpus {
2013-04-12 16:29:06 +02:00
#address-cells = <1>;
#size-cells = <0>;
2014-04-14 15:54:00 +02:00
enable-method = "marvell,armada-xp-smp";
2012-11-17 15:22:24 +01:00
2013-04-12 16:29:06 +02:00
cpu@0 {
device_type = "cpu";
compatible = "marvell,sheeva-v7";
reg = <0>;
clocks = <&cpuclk 0>;
2014-07-09 17:45:12 +02:00
clock-latency = <1000000>;
2013-04-12 16:29:06 +02:00
};
2013-01-06 11:10:40 +01:00
2013-04-12 16:29:06 +02:00
cpu@1 {
device_type = "cpu";
compatible = "marvell,sheeva-v7";
reg = <1>;
clocks = <&cpuclk 1>;
2014-07-09 17:45:12 +02:00
clock-latency = <1000000>;
2013-04-12 16:29:06 +02:00
};
2013-01-06 11:10:42 +01:00
};
2012-11-17 15:22:24 +01:00
2012-09-13 17:41:48 +02:00
soc {
2013-07-26 10:18:00 -03:00
/*
* MV78230 has 2 PCIe units Gen2.0: One unit can be
* configured as x4 or quad x1 lanes. One unit is
2013-11-05 21:45:48 +01:00
* x1 only.
2013-07-26 10:18:00 -03:00
*/
pcie-controller {
compatible = "marvell,armada-xp-pcie";
status = "disabled";
device_type = "pci";
#address-cells = <3>;
#size-cells = <2>;
2013-08-09 22:27:15 +02:00
msi-parent = <&mpic>;
2013-07-26 10:18:00 -03:00
bus-range = <0x00 0xff>;
ranges =
<0x82000000 0 0x40000 MBUS_ID(0xf0, 0x01) 0x40000 0 0x00002000 /* Port 0.0 registers */
0x82000000 0 0x44000 MBUS_ID(0xf0, 0x01) 0x44000 0 0x00002000 /* Port 0.1 registers */
0x82000000 0 0x48000 MBUS_ID(0xf0, 0x01) 0x48000 0 0x00002000 /* Port 0.2 registers */
0x82000000 0 0x4c000 MBUS_ID(0xf0, 0x01) 0x4c000 0 0x00002000 /* Port 0.3 registers */
2013-11-05 21:45:48 +01:00
0x82000000 0 0x80000 MBUS_ID(0xf0, 0x01) 0x80000 0 0x00002000 /* Port 1.0 registers */
2013-07-26 10:18:00 -03:00
0x82000000 0x1 0 MBUS_ID(0x04, 0xe8) 0 1 0 /* Port 0.0 MEM */
0x81000000 0x1 0 MBUS_ID(0x04, 0xe0) 0 1 0 /* Port 0.0 IO */
0x82000000 0x2 0 MBUS_ID(0x04, 0xd8) 0 1 0 /* Port 0.1 MEM */
0x81000000 0x2 0 MBUS_ID(0x04, 0xd0) 0 1 0 /* Port 0.1 IO */
0x82000000 0x3 0 MBUS_ID(0x04, 0xb8) 0 1 0 /* Port 0.2 MEM */
0x81000000 0x3 0 MBUS_ID(0x04, 0xb0) 0 1 0 /* Port 0.2 IO */
0x82000000 0x4 0 MBUS_ID(0x04, 0x78) 0 1 0 /* Port 0.3 MEM */
0x81000000 0x4 0 MBUS_ID(0x04, 0x70) 0 1 0 /* Port 0.3 IO */
2013-11-05 21:45:48 +01:00
0x82000000 0x5 0 MBUS_ID(0x08, 0xe8) 0 1 0 /* Port 1.0 MEM */
0x81000000 0x5 0 MBUS_ID(0x08, 0xe0) 0 1 0 /* Port 1.0 IO */>;
2013-07-26 10:18:00 -03:00
pcie@1,0 {
device_type = "pci";
assigned-addresses = <0x82000800 0 0x40000 0 0x2000>;
reg = <0x0800 0 0 0 0>;
#address-cells = <3>;
#size-cells = <2>;
#interrupt-cells = <1>;
ranges = <0x82000000 0 0 0x82000000 0x1 0 1 0
0x81000000 0 0 0x81000000 0x1 0 1 0>;
interrupt-map-mask = <0 0 0 0>;
interrupt-map = <0 0 0 0 &mpic 58>;
marvell,pcie-port = <0>;
marvell,pcie-lane = <0>;
clocks = <&gateclk 5>;
status = "disabled";
};
pcie@2,0 {
device_type = "pci";
assigned-addresses = <0x82000800 0 0x44000 0 0x2000>;
reg = <0x1000 0 0 0 0>;
#address-cells = <3>;
#size-cells = <2>;
#interrupt-cells = <1>;
ranges = <0x82000000 0 0 0x82000000 0x2 0 1 0
0x81000000 0 0 0x81000000 0x2 0 1 0>;
interrupt-map-mask = <0 0 0 0>;
interrupt-map = <0 0 0 0 &mpic 59>;
marvell,pcie-port = <0>;
marvell,pcie-lane = <1>;
clocks = <&gateclk 6>;
status = "disabled";
};
pcie@3,0 {
device_type = "pci";
assigned-addresses = <0x82000800 0 0x48000 0 0x2000>;
reg = <0x1800 0 0 0 0>;
#address-cells = <3>;
#size-cells = <2>;
#interrupt-cells = <1>;
ranges = <0x82000000 0 0 0x82000000 0x3 0 1 0
0x81000000 0 0 0x81000000 0x3 0 1 0>;
interrupt-map-mask = <0 0 0 0>;
interrupt-map = <0 0 0 0 &mpic 60>;
marvell,pcie-port = <0>;
marvell,pcie-lane = <2>;
clocks = <&gateclk 7>;
status = "disabled";
};
pcie@4,0 {
device_type = "pci";
assigned-addresses = <0x82000800 0 0x4c000 0 0x2000>;
reg = <0x2000 0 0 0 0>;
#address-cells = <3>;
#size-cells = <2>;
#interrupt-cells = <1>;
ranges = <0x82000000 0 0 0x82000000 0x4 0 1 0
0x81000000 0 0 0x81000000 0x4 0 1 0>;
interrupt-map-mask = <0 0 0 0>;
interrupt-map = <0 0 0 0 &mpic 61>;
marvell,pcie-port = <0>;
marvell,pcie-lane = <3>;
clocks = <&gateclk 8>;
status = "disabled";
};
2013-11-05 21:45:48 +01:00
pcie@5,0 {
2013-07-26 10:18:00 -03:00
device_type = "pci";
2013-11-05 21:45:48 +01:00
assigned-addresses = <0x82000800 0 0x80000 0 0x2000>;
reg = <0x2800 0 0 0 0>;
2013-07-26 10:18:00 -03:00
#address-cells = <3>;
#size-cells = <2>;
#interrupt-cells = <1>;
2013-11-05 21:45:48 +01:00
ranges = <0x82000000 0 0 0x82000000 0x5 0 1 0
0x81000000 0 0 0x81000000 0x5 0 1 0>;
2013-07-26 10:18:00 -03:00
interrupt-map-mask = <0 0 0 0>;
2013-11-05 21:45:48 +01:00
interrupt-map = <0 0 0 0 &mpic 62>;
marvell,pcie-port = <1>;
2013-07-26 10:18:00 -03:00
marvell,pcie-lane = <0>;
2013-11-05 21:45:48 +01:00
clocks = <&gateclk 9>;
2013-07-26 10:18:00 -03:00
status = "disabled";
};
};
2013-04-12 16:29:09 +02:00
internal-regs {
2014-09-19 21:12:00 +02:00
pinctrl: pin-ctrl@18000 {
2013-04-12 16:29:09 +02:00
compatible = "marvell,mv78230-pinctrl";
2012-12-21 15:49:06 +01:00
};
2013-04-09 23:06:34 +02:00
2013-04-12 16:29:09 +02:00
gpio0: gpio@18100 {
compatible = "marvell,orion-gpio";
reg = <0x18100 0x40>;
ngpios = <32>;
gpio-controller;
#gpio-cells = <2>;
interrupt-controller;
2013-07-30 16:59:02 +02:00
#interrupt-cells = <2>;
2013-04-12 16:29:09 +02:00
interrupts = <82>, <83>, <84>, <85>;
2013-04-09 23:06:34 +02:00
};
2013-04-12 16:29:09 +02:00
gpio1: gpio@18140 {
compatible = "marvell,orion-gpio";
reg = <0x18140 0x40>;
ngpios = <17>;
gpio-controller;
#gpio-cells = <2>;
interrupt-controller;
2013-07-30 16:59:02 +02:00
#interrupt-cells = <2>;
2013-04-12 16:29:09 +02:00
interrupts = <87>, <88>, <89>;
2013-04-09 23:06:34 +02:00
};
};
2012-09-13 17:41:48 +02:00
};
};