12e36db14SWarner Losh/* 22e36db14SWarner Losh * Copyright (c) 2010 The FreeBSD Foundation 32e36db14SWarner Losh * Copyright (c) 2010-2011 Semihalf 42e36db14SWarner Losh * All rights reserved. 52e36db14SWarner Losh * 62e36db14SWarner Losh * Redistribution and use in source and binary forms, with or without 72e36db14SWarner Losh * modification, are permitted provided that the following conditions 82e36db14SWarner Losh * are met: 92e36db14SWarner Losh * 1. Redistributions of source code must retain the above copyright 102e36db14SWarner Losh * notice, this list of conditions and the following disclaimer. 112e36db14SWarner Losh * 2. Redistributions in binary form must reproduce the above copyright 122e36db14SWarner Losh * notice, this list of conditions and the following disclaimer in the 132e36db14SWarner Losh * documentation and/or other materials provided with the distribution. 142e36db14SWarner Losh * 152e36db14SWarner Losh * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 162e36db14SWarner Losh * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 172e36db14SWarner Losh * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 182e36db14SWarner Losh * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 192e36db14SWarner Losh * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 202e36db14SWarner Losh * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 212e36db14SWarner Losh * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 222e36db14SWarner Losh * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 232e36db14SWarner Losh * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 242e36db14SWarner Losh * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 252e36db14SWarner Losh * SUCH DAMAGE. 262e36db14SWarner Losh * 272e36db14SWarner Losh * Marvell DB-78460 Device Tree Source. 282e36db14SWarner Losh */ 292e36db14SWarner Losh 302e36db14SWarner Losh/dts-v1/; 312e36db14SWarner Losh 322e36db14SWarner Losh/ { 332e36db14SWarner Losh model = "mrvl,DB-78460"; 342e36db14SWarner Losh #address-cells = <1>; 352e36db14SWarner Losh #size-cells = <1>; 362e36db14SWarner Losh 372e36db14SWarner Losh aliases { 382e36db14SWarner Losh serial0 = &serial0; 392e36db14SWarner Losh }; 402e36db14SWarner Losh 412e36db14SWarner Losh cpus { 422e36db14SWarner Losh #address-cells = <1>; 432e36db14SWarner Losh #size-cells = <0>; 442e36db14SWarner Losh 452e36db14SWarner Losh cpu@0 { 462e36db14SWarner Losh device_type = "cpu"; 472e36db14SWarner Losh compatible = "ARM,88VS584"; 482e36db14SWarner Losh reg = <0x0>; 492e36db14SWarner Losh d-cache-line-size = <32>; // 32 bytes 502e36db14SWarner Losh i-cache-line-size = <32>; // 32 bytes 512e36db14SWarner Losh d-cache-size = <0x8000>; // L1, 32K 522e36db14SWarner Losh i-cache-size = <0x8000>; // L1, 32K 532e36db14SWarner Losh timebase-frequency = <0>; 542e36db14SWarner Losh bus-frequency = <200000000>; 552e36db14SWarner Losh clock-frequency = <0>; 562e36db14SWarner Losh }; 572e36db14SWarner Losh }; 582e36db14SWarner Losh 592e36db14SWarner Losh memory { 602e36db14SWarner Losh device_type = "memory"; 612e36db14SWarner Losh reg = <0x0 0x80000000>; // 2G at 0x0 622e36db14SWarner Losh }; 632e36db14SWarner Losh 642e36db14SWarner Losh soc78460@d0000000 { 652e36db14SWarner Losh #address-cells = <1>; 662e36db14SWarner Losh #size-cells = <1>; 672e36db14SWarner Losh compatible = "simple-bus"; 682e36db14SWarner Losh ranges = <0x0 0xd0000000 0x00100000>; 692e36db14SWarner Losh bus-frequency = <0>; 702e36db14SWarner Losh 712e36db14SWarner Losh 722e36db14SWarner Losh MPIC: mpic@20a00 { 732e36db14SWarner Losh interrupt-controller; 742e36db14SWarner Losh #address-cells = <0>; 752e36db14SWarner Losh #interrupt-cells = <1>; 762e36db14SWarner Losh reg = <0x20a00 0x500 0x21870 0x58 0x20400 0x100>; 772e36db14SWarner Losh compatible = "mrvl,mpic"; 782e36db14SWarner Losh }; 792e36db14SWarner Losh 802e36db14SWarner Losh rtc@10300 { 812e36db14SWarner Losh compatible = "mrvl,rtc"; 822e36db14SWarner Losh reg = <0x10300 0x08>; 832e36db14SWarner Losh }; 842e36db14SWarner Losh 852e36db14SWarner Losh timer@21840 { 86*72dbc3acSMarcin Wojtas compatible = "marvell,armada-xp-timer"; 872e36db14SWarner Losh reg = <0x21840 0x30>; 882e36db14SWarner Losh interrupts = <5>; 892e36db14SWarner Losh interrupt-parent = <&MPIC>; 902e36db14SWarner Losh mrvl,has-wdt; 912e36db14SWarner Losh }; 922e36db14SWarner Losh 932e36db14SWarner Losh twsi@11000 { 942e36db14SWarner Losh #address-cells = <1>; 952e36db14SWarner Losh #size-cells = <0>; 962e36db14SWarner Losh compatible = "mrvl,twsi"; 972e36db14SWarner Losh reg = <0x11000 0x20>; 982e36db14SWarner Losh interrupts = <31>; 992e36db14SWarner Losh interrupt-parent = <&MPIC>; 1002e36db14SWarner Losh }; 1012e36db14SWarner Losh 1022e36db14SWarner Losh twsi@11100 { 1032e36db14SWarner Losh #address-cells = <1>; 1042e36db14SWarner Losh #size-cells = <0>; 1052e36db14SWarner Losh compatible = "mrvl,twsi"; 1062e36db14SWarner Losh reg = <0x11100 0x20>; 1072e36db14SWarner Losh interrupts = <32>; 1082e36db14SWarner Losh interrupt-parent = <&MPIC>; 1092e36db14SWarner Losh }; 1102e36db14SWarner Losh 1112e36db14SWarner Losh serial0: serial@12000 { 1122e36db14SWarner Losh compatible = "snps,dw-apb-uart"; 1132e36db14SWarner Losh reg = <0x12000 0x20>; 1142e36db14SWarner Losh reg-shift = <2>; 1152e36db14SWarner Losh current-speed = <115200>; 1162e36db14SWarner Losh clock-frequency = <0>; 1172e36db14SWarner Losh interrupts = <41>; 1182e36db14SWarner Losh interrupt-parent = <&MPIC>; 1192e36db14SWarner Losh }; 1202e36db14SWarner Losh 1212e36db14SWarner Losh serial1: serial@12100 { 1222e36db14SWarner Losh compatible = "snps,dw-apb-uart"; 1232e36db14SWarner Losh reg = <0x12100 0x20>; 1242e36db14SWarner Losh reg-shift = <2>; 1252e36db14SWarner Losh current-speed = <115200>; 1262e36db14SWarner Losh clock-frequency = <0>; 1272e36db14SWarner Losh interrupts = <42>; 1282e36db14SWarner Losh interrupt-parent = <&MPIC>; 1292e36db14SWarner Losh }; 1302e36db14SWarner Losh 1312e36db14SWarner Losh serial2: serial@12200 { 1322e36db14SWarner Losh compatible = "snps,dw-apb-uart"; 1332e36db14SWarner Losh reg = <0x12200 0x20>; 1342e36db14SWarner Losh reg-shift = <2>; 1352e36db14SWarner Losh current-speed = <115200>; 1362e36db14SWarner Losh clock-frequency = <0>; 1372e36db14SWarner Losh interrupts = <43>; 1382e36db14SWarner Losh interrupt-parent = <&MPIC>; 1392e36db14SWarner Losh }; 1402e36db14SWarner Losh 1412e36db14SWarner Losh serial3: serial@12300 { 1422e36db14SWarner Losh compatible = "snps,dw-apb-uart"; 1432e36db14SWarner Losh reg = <0x12300 0x20>; 1442e36db14SWarner Losh reg-shift = <2>; 1452e36db14SWarner Losh current-speed = <115200>; 1462e36db14SWarner Losh clock-frequency = <0>; 1472e36db14SWarner Losh interrupts = <44>; 1482e36db14SWarner Losh interrupt-parent = <&MPIC>; 1492e36db14SWarner Losh }; 1502e36db14SWarner Losh 1512e36db14SWarner Losh MPP: mpp@10000 { 1522e36db14SWarner Losh #pin-cells = <2>; 1532e36db14SWarner Losh compatible = "mrvl,mpp"; 1542e36db14SWarner Losh reg = <0x18000 0x34>; 1552e36db14SWarner Losh pin-count = <68>; 1562e36db14SWarner Losh pin-map = < 1572e36db14SWarner Losh 0 1 /* MPP[0]: GE1_TXCLK */ 1582e36db14SWarner Losh 1 1 /* MPP[1]: GE1_TXCTL */ 1592e36db14SWarner Losh 2 1 /* MPP[2]: GE1_RXCTL */ 1602e36db14SWarner Losh 3 1 /* MPP[3]: GE1_RXCLK */ 1612e36db14SWarner Losh 4 1 /* MPP[4]: GE1_TXD[0] */ 1622e36db14SWarner Losh 5 1 /* MPP[5]: GE1_TXD[1] */ 1632e36db14SWarner Losh 6 1 /* MPP[6]: GE1_TXD[2] */ 1642e36db14SWarner Losh 7 1 /* MPP[7]: GE1_TXD[3] */ 1652e36db14SWarner Losh 8 1 /* MPP[8]: GE1_RXD[0] */ 1662e36db14SWarner Losh 9 1 /* MPP[9]: GE1_RXD[1] */ 1672e36db14SWarner Losh 10 1 /* MPP[10]: GE1_RXD[2] */ 1682e36db14SWarner Losh 11 1 /* MPP[11]: GE1_RXD[3] */ 1692e36db14SWarner Losh 12 2 /* MPP[13]: SYSRST_OUTn */ 1702e36db14SWarner Losh 13 2 /* MPP[13]: SYSRST_OUTn */ 1712e36db14SWarner Losh 14 2 /* MPP[14]: SATA1_ACTn */ 1722e36db14SWarner Losh 15 2 /* MPP[15]: SATA0_ACTn */ 1732e36db14SWarner Losh 16 2 /* MPP[16]: UA2_TXD */ 1742e36db14SWarner Losh 17 2 /* MPP[17]: UA2_RXD */ 1752e36db14SWarner Losh 18 2 /* MPP[18]: <UNKNOWN> */ 1762e36db14SWarner Losh 19 2 /* MPP[19]: <UNKNOWN> */ 1772e36db14SWarner Losh 20 2 /* MPP[20]: <UNKNOWN> */ 1782e36db14SWarner Losh 21 2 /* MPP[21]: <UNKNOWN> */ 1792e36db14SWarner Losh 22 2 /* MPP[22]: UA3_TXD */ 1802e36db14SWarner Losh 23 2 1812e36db14SWarner Losh 24 0 1822e36db14SWarner Losh 25 0 1832e36db14SWarner Losh 26 0 1842e36db14SWarner Losh 27 0 1852e36db14SWarner Losh 28 4 1862e36db14SWarner Losh 29 0 1872e36db14SWarner Losh 30 1 1882e36db14SWarner Losh 31 1 1892e36db14SWarner Losh 32 1 1902e36db14SWarner Losh 33 1 1912e36db14SWarner Losh 34 1 1922e36db14SWarner Losh 35 1 1932e36db14SWarner Losh 36 1 1942e36db14SWarner Losh 37 1 1952e36db14SWarner Losh 38 1 1962e36db14SWarner Losh 39 1 1972e36db14SWarner Losh 40 0 1982e36db14SWarner Losh 41 3 1992e36db14SWarner Losh 42 1 2002e36db14SWarner Losh 43 1 2012e36db14SWarner Losh 44 2 2022e36db14SWarner Losh 45 2 2032e36db14SWarner Losh 46 4 2042e36db14SWarner Losh 47 3 2052e36db14SWarner Losh 48 0 2062e36db14SWarner Losh 49 1 2072e36db14SWarner Losh 50 1 2082e36db14SWarner Losh 51 1 2092e36db14SWarner Losh 52 1 2102e36db14SWarner Losh 53 1 2112e36db14SWarner Losh 54 1 2122e36db14SWarner Losh 55 1 2132e36db14SWarner Losh 56 1 2142e36db14SWarner Losh 57 0 2152e36db14SWarner Losh 58 1 2162e36db14SWarner Losh 59 1 2172e36db14SWarner Losh 60 1 2182e36db14SWarner Losh 61 1 2192e36db14SWarner Losh 62 1 2202e36db14SWarner Losh 63 1 2212e36db14SWarner Losh 64 1 2222e36db14SWarner Losh 65 1 2232e36db14SWarner Losh 66 1 2242e36db14SWarner Losh 67 2 >; 2252e36db14SWarner Losh }; 2262e36db14SWarner Losh 2272e36db14SWarner Losh usb@50000 { 2282e36db14SWarner Losh compatible = "mrvl,usb-ehci", "usb-ehci"; 2292e36db14SWarner Losh reg = <0x50000 0x1000>; 2302e36db14SWarner Losh interrupts = <124 45>; 2312e36db14SWarner Losh interrupt-parent = <&MPIC>; 2322e36db14SWarner Losh }; 2332e36db14SWarner Losh 2342e36db14SWarner Losh usb@51000 { 2352e36db14SWarner Losh compatible = "mrvl,usb-ehci", "usb-ehci"; 2362e36db14SWarner Losh reg = <0x51000 0x1000>; 2372e36db14SWarner Losh interrupts = <124 46>; 2382e36db14SWarner Losh interrupt-parent = <&MPIC>; 2392e36db14SWarner Losh }; 2402e36db14SWarner Losh 2412e36db14SWarner Losh usb@52000 { 2422e36db14SWarner Losh compatible = "mrvl,usb-ehci", "usb-ehci"; 2432e36db14SWarner Losh reg = <0x52000 0x1000>; 2442e36db14SWarner Losh interrupts = <124 47>; 2452e36db14SWarner Losh interrupt-parent = <&MPIC>; 2462e36db14SWarner Losh }; 2472e36db14SWarner Losh 2482e36db14SWarner Losh enet0: ethernet@72000 { 2492e36db14SWarner Losh #address-cells = <1>; 2502e36db14SWarner Losh #size-cells = <1>; 2512e36db14SWarner Losh model = "V2"; 2522e36db14SWarner Losh compatible = "mrvl,ge"; 2532e36db14SWarner Losh reg = <0x72000 0x2000>; 2542e36db14SWarner Losh ranges = <0x0 0x72000 0x2000>; 2552e36db14SWarner Losh local-mac-address = [ 00 04 01 07 84 60 ]; 2562e36db14SWarner Losh interrupts = <67 68 122 >; 2572e36db14SWarner Losh interrupt-parent = <&MPIC>; 2582e36db14SWarner Losh phy-handle = <&phy0>; 2592e36db14SWarner Losh has-neta; 2602e36db14SWarner Losh 2612e36db14SWarner Losh mdio@0 { 2622e36db14SWarner Losh #address-cells = <1>; 2632e36db14SWarner Losh #size-cells = <0>; 2642e36db14SWarner Losh compatible = "mrvl,mdio"; 2652e36db14SWarner Losh 2662e36db14SWarner Losh phy0: ethernet-phy@0 { 2672e36db14SWarner Losh reg = <0x0>; 2682e36db14SWarner Losh }; 2692e36db14SWarner Losh phy1: ethernet-phy@1 { 2702e36db14SWarner Losh reg = <0x1>; 2712e36db14SWarner Losh }; 2722e36db14SWarner Losh phy2: ethernet-phy@2 { 2732e36db14SWarner Losh reg = <0x19>; 2742e36db14SWarner Losh }; 2752e36db14SWarner Losh phy3: ethernet-phy@3 { 2762e36db14SWarner Losh reg = <0x1b>; 2772e36db14SWarner Losh }; 2782e36db14SWarner Losh }; 2792e36db14SWarner Losh }; 2802e36db14SWarner Losh 2812e36db14SWarner Losh sata@A0000 { 2822e36db14SWarner Losh compatible = "mrvl,sata"; 2832e36db14SWarner Losh reg = <0xA0000 0x6000>; 2842e36db14SWarner Losh interrupts = <55>; 2852e36db14SWarner Losh interrupt-parent = <&MPIC>; 2862e36db14SWarner Losh }; 2872e36db14SWarner Losh }; 2882e36db14SWarner Losh 2892e36db14SWarner Losh pci0: pcie@d0040000 { 2902e36db14SWarner Losh compatible = "mrvl,pcie"; 2912e36db14SWarner Losh device_type = "pci"; 2922e36db14SWarner Losh #interrupt-cells = <1>; 2932e36db14SWarner Losh #size-cells = <2>; 2942e36db14SWarner Losh #address-cells = <3>; 2952e36db14SWarner Losh reg = <0xd0040000 0x2000>; 2962e36db14SWarner Losh bus-range = <0 255>; 2972e36db14SWarner Losh ranges = <0x02000000 0x0 0x80000000 0x80000000 0x0 0x20000000 2982e36db14SWarner Losh 0x01000000 0x0 0x00000000 0xa0000000 0x0 0x08000000>; 2992e36db14SWarner Losh clock-frequency = <33333333>; 3002e36db14SWarner Losh interrupt-parent = <&MPIC>; 3012e36db14SWarner Losh interrupts = <120>; 3022e36db14SWarner Losh interrupt-map-mask = <0xf800 0x0 0x0 0x7>; 3032e36db14SWarner Losh interrupt-map = < 3042e36db14SWarner Losh 0x0800 0x0 0x0 0x1 &MPIC 0x3A 3052e36db14SWarner Losh 0x0800 0x0 0x0 0x2 &MPIC 0x3A 3062e36db14SWarner Losh 0x0800 0x0 0x0 0x3 &MPIC 0x3A 3072e36db14SWarner Losh 0x0800 0x0 0x0 0x4 &MPIC 0x3A 3082e36db14SWarner Losh >; 3092e36db14SWarner Losh }; 3102e36db14SWarner Losh 3112e36db14SWarner Losh sram@ffff0000 { 3122e36db14SWarner Losh compatible = "mrvl,cesa-sram"; 3132e36db14SWarner Losh reg = <0xffff0000 0x00010000>; 3142e36db14SWarner Losh }; 3152e36db14SWarner Losh 3162e36db14SWarner Losh chosen { 3172e36db14SWarner Losh stdin = "serial0"; 3182e36db14SWarner Losh stdout = "serial0"; 3192e36db14SWarner Losh stddbg = "serial0"; 3202e36db14SWarner Losh }; 3212e36db14SWarner Losh}; 322