/* * Broadcom BCM470X / BCM5301X ARM platform code. * Generic DTS part for all BCM53010, BCM53011, BCM53012, BCM53014, BCM53015, * BCM53016, BCM53017, BCM53018, BCM4707, BCM4708 and BCM4709 SoCs * * Copyright 2013-2014 Hauke Mehrtens * * Licensed under the GNU/GPL. See COPYING for details. */ #include #include #include #include #include "skeleton.dtsi" / { interrupt-parent = <&gic>; chipcommonA { compatible = "simple-bus"; ranges = <0x00000000 0x18000000 0x00001000>; #address-cells = <1>; #size-cells = <1>; uart0: serial@0300 { compatible = "ns16550"; reg = <0x0300 0x100>; interrupts = ; clock-frequency = <100000000>; status = "disabled"; }; uart1: serial@0400 { compatible = "ns16550"; reg = <0x0400 0x100>; interrupts = ; clock-frequency = <100000000>; status = "disabled"; }; }; mpcore { compatible = "simple-bus"; ranges = <0x00000000 0x19020000 0x00003000>; #address-cells = <1>; #size-cells = <1>; scu@0000 { compatible = "arm,cortex-a9-scu"; reg = <0x0000 0x100>; }; timer@0200 { compatible = "arm,cortex-a9-global-timer"; reg = <0x0200 0x100>; interrupts = ; clocks = <&clk_periph>; }; local-timer@0600 { compatible = "arm,cortex-a9-twd-timer"; reg = <0x0600 0x100>; interrupts = ; clocks = <&clk_periph>; }; gic: interrupt-controller@1000 { compatible = "arm,cortex-a9-gic"; #interrupt-cells = <3>; #address-cells = <0>; interrupt-controller; reg = <0x1000 0x1000>, <0x0100 0x100>; }; L2: cache-controller@2000 { compatible = "arm,pl310-cache"; reg = <0x2000 0x1000>; cache-unified; cache-level = <2>; }; }; clocks { #address-cells = <1>; #size-cells = <0>; /* As long as we do not have a real clock driver us this * fixed clock */ clk_periph: periph { compatible = "fixed-clock"; #clock-cells = <0>; clock-frequency = <400000000>; }; }; axi@18000000 { compatible = "brcm,bus-axi"; reg = <0x18000000 0x1000>; ranges = <0x00000000 0x18000000 0x00100000>; #address-cells = <1>; #size-cells = <1>; #interrupt-cells = <1>; interrupt-map-mask = <0x000fffff 0xffff>; interrupt-map = /* ChipCommon */ <0x00000000 0 &gic GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>, /* PCIe Controller 0 */ <0x00012000 0 &gic GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>, <0x00012000 1 &gic GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>, <0x00012000 2 &gic GIC_SPI 128 IRQ_TYPE_LEVEL_HIGH>, <0x00012000 3 &gic GIC_SPI 129 IRQ_TYPE_LEVEL_HIGH>, <0x00012000 4 &gic GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>, <0x00012000 5 &gic GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>, /* PCIe Controller 1 */ <0x00013000 0 &gic GIC_SPI 132 IRQ_TYPE_LEVEL_HIGH>, <0x00013000 1 &gic GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>, <0x00013000 2 &gic GIC_SPI 134 IRQ_TYPE_LEVEL_HIGH>, <0x00013000 3 &gic GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>, <0x00013000 4 &gic GIC_SPI 136 IRQ_TYPE_LEVEL_HIGH>, <0x00013000 5 &gic GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>, /* PCIe Controller 2 */ <0x00014000 0 &gic GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>, <0x00014000 1 &gic GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>, <0x00014000 2 &gic GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>, <0x00014000 3 &gic GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>, <0x00014000 4 &gic GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>, <0x00014000 5 &gic GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>, /* USB 2.0 Controller */ <0x00021000 0 &gic GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>, /* USB 3.0 Controller */ <0x00023000 0 &gic GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>, /* Ethernet Controller 0 */ <0x00024000 0 &gic GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>, /* Ethernet Controller 1 */ <0x00025000 0 &gic GIC_SPI 148 IRQ_TYPE_LEVEL_HIGH>, /* Ethernet Controller 2 */ <0x00026000 0 &gic GIC_SPI 149 IRQ_TYPE_LEVEL_HIGH>, /* Ethernet Controller 3 */ <0x00027000 0 &gic GIC_SPI 150 IRQ_TYPE_LEVEL_HIGH>, /* NAND Controller */ <0x00028000 0 &gic GIC_SPI 64 IRQ_TYPE_LEVEL_HIGH>, <0x00028000 1 &gic GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>, <0x00028000 2 &gic GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>, <0x00028000 3 &gic GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>, <0x00028000 4 &gic GIC_SPI 68 IRQ_TYPE_LEVEL_HIGH>, <0x00028000 5 &gic GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>, <0x00028000 6 &gic GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>, <0x00028000 7 &gic GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>; chipcommon: chipcommon@0 { reg = <0x00000000 0x1000>; gpio-controller; #gpio-cells = <2>; }; }; nand: nand@18028000 { compatible = "brcm,nand-iproc", "brcm,brcmnand-v6.1", "brcm,brcmnand"; reg = <0x18028000 0x600>, <0x1811a408 0x600>, <0x18028f00 0x20>; reg-names = "nand", "iproc-idm", "iproc-ext"; interrupts = ; #address-cells = <1>; #size-cells = <0>; brcm,nand-has-wp; }; };