12874c5fdSThomas Gleixner// SPDX-License-Identifier: GPL-2.0-or-later 20052bc5dSKumar Gala/* 30052bc5dSKumar Gala * TQM 8540 Device Tree Source 40052bc5dSKumar Gala * 50052bc5dSKumar Gala * Copyright 2008 Freescale Semiconductor Inc. 60052bc5dSKumar Gala */ 70052bc5dSKumar Gala 80052bc5dSKumar Gala/dts-v1/; 90052bc5dSKumar Gala 10*c1024320SPali Rohár/include/ "fsl/e500v1_power_isa.dtsi" 11*c1024320SPali Rohár 120052bc5dSKumar Gala/ { 134fb035f6SWolfgang Grandegger model = "tqc,tqm8540"; 144fb035f6SWolfgang Grandegger compatible = "tqc,tqm8540"; 150052bc5dSKumar Gala #address-cells = <1>; 160052bc5dSKumar Gala #size-cells = <1>; 170052bc5dSKumar Gala 180052bc5dSKumar Gala aliases { 190052bc5dSKumar Gala ethernet0 = &enet0; 200052bc5dSKumar Gala ethernet1 = &enet1; 210052bc5dSKumar Gala ethernet2 = &enet2; 220052bc5dSKumar Gala serial0 = &serial0; 230052bc5dSKumar Gala serial1 = &serial1; 240052bc5dSKumar Gala pci0 = &pci0; 250052bc5dSKumar Gala }; 260052bc5dSKumar Gala 270052bc5dSKumar Gala cpus { 280052bc5dSKumar Gala #address-cells = <1>; 290052bc5dSKumar Gala #size-cells = <0>; 300052bc5dSKumar Gala 310052bc5dSKumar Gala PowerPC,8540@0 { 320052bc5dSKumar Gala device_type = "cpu"; 330052bc5dSKumar Gala reg = <0>; 340052bc5dSKumar Gala d-cache-line-size = <32>; 350052bc5dSKumar Gala i-cache-line-size = <32>; 360052bc5dSKumar Gala d-cache-size = <32768>; 370052bc5dSKumar Gala i-cache-size = <32768>; 380052bc5dSKumar Gala timebase-frequency = <0>; 390052bc5dSKumar Gala bus-frequency = <0>; 400052bc5dSKumar Gala clock-frequency = <0>; 41c054065bSKumar Gala next-level-cache = <&L2>; 420052bc5dSKumar Gala }; 430052bc5dSKumar Gala }; 440052bc5dSKumar Gala 450052bc5dSKumar Gala memory { 460052bc5dSKumar Gala device_type = "memory"; 470052bc5dSKumar Gala reg = <0x00000000 0x10000000>; 480052bc5dSKumar Gala }; 490052bc5dSKumar Gala 50f67be814SKumar Gala soc@e0000000 { 510052bc5dSKumar Gala #address-cells = <1>; 520052bc5dSKumar Gala #size-cells = <1>; 530052bc5dSKumar Gala device_type = "soc"; 540052bc5dSKumar Gala ranges = <0x0 0xe0000000 0x100000>; 550052bc5dSKumar Gala bus-frequency = <0>; 560052bc5dSKumar Gala compatible = "fsl,mpc8540-immr", "simple-bus"; 570052bc5dSKumar Gala 58e1a22897SKumar Gala ecm-law@0 { 59e1a22897SKumar Gala compatible = "fsl,ecm-law"; 60e1a22897SKumar Gala reg = <0x0 0x1000>; 61e1a22897SKumar Gala fsl,num-laws = <8>; 62e1a22897SKumar Gala }; 63e1a22897SKumar Gala 64e1a22897SKumar Gala ecm@1000 { 65e1a22897SKumar Gala compatible = "fsl,mpc8540-ecm", "fsl,ecm"; 66e1a22897SKumar Gala reg = <0x1000 0x1000>; 67e1a22897SKumar Gala interrupts = <17 2>; 68e1a22897SKumar Gala interrupt-parent = <&mpic>; 69e1a22897SKumar Gala }; 70e1a22897SKumar Gala 710052bc5dSKumar Gala memory-controller@2000 { 72fe671772SKumar Gala compatible = "fsl,mpc8540-memory-controller"; 730052bc5dSKumar Gala reg = <0x2000 0x1000>; 740052bc5dSKumar Gala interrupt-parent = <&mpic>; 750052bc5dSKumar Gala interrupts = <18 2>; 760052bc5dSKumar Gala }; 770052bc5dSKumar Gala 78c054065bSKumar Gala L2: l2-cache-controller@20000 { 79fe671772SKumar Gala compatible = "fsl,mpc8540-l2-cache-controller"; 800052bc5dSKumar Gala reg = <0x20000 0x1000>; 810052bc5dSKumar Gala cache-line-size = <32>; 820052bc5dSKumar Gala cache-size = <0x40000>; // L2, 256K 830052bc5dSKumar Gala interrupt-parent = <&mpic>; 840052bc5dSKumar Gala interrupts = <16 2>; 850052bc5dSKumar Gala }; 860052bc5dSKumar Gala 870052bc5dSKumar Gala i2c@3000 { 880052bc5dSKumar Gala #address-cells = <1>; 890052bc5dSKumar Gala #size-cells = <0>; 900052bc5dSKumar Gala cell-index = <0>; 910052bc5dSKumar Gala compatible = "fsl-i2c"; 920052bc5dSKumar Gala reg = <0x3000 0x100>; 930052bc5dSKumar Gala interrupts = <43 2>; 940052bc5dSKumar Gala interrupt-parent = <&mpic>; 950052bc5dSKumar Gala dfsrr; 960052bc5dSKumar Gala 976467cae3SWolfgang Grandegger dtt@48 { 980f73a449SWolfgang Grandegger compatible = "national,lm75"; 996467cae3SWolfgang Grandegger reg = <0x48>; 1000f73a449SWolfgang Grandegger }; 1010f73a449SWolfgang Grandegger 1020052bc5dSKumar Gala rtc@68 { 1030052bc5dSKumar Gala compatible = "dallas,ds1337"; 1040052bc5dSKumar Gala reg = <0x68>; 1050052bc5dSKumar Gala }; 1060052bc5dSKumar Gala }; 1070052bc5dSKumar Gala 108dee80553SKumar Gala dma@21300 { 109dee80553SKumar Gala #address-cells = <1>; 110dee80553SKumar Gala #size-cells = <1>; 111dee80553SKumar Gala compatible = "fsl,mpc8540-dma", "fsl,eloplus-dma"; 112dee80553SKumar Gala reg = <0x21300 0x4>; 113dee80553SKumar Gala ranges = <0x0 0x21100 0x200>; 114dee80553SKumar Gala cell-index = <0>; 115dee80553SKumar Gala dma-channel@0 { 116dee80553SKumar Gala compatible = "fsl,mpc8540-dma-channel", 117dee80553SKumar Gala "fsl,eloplus-dma-channel"; 118dee80553SKumar Gala reg = <0x0 0x80>; 119dee80553SKumar Gala cell-index = <0>; 120dee80553SKumar Gala interrupt-parent = <&mpic>; 121dee80553SKumar Gala interrupts = <20 2>; 122dee80553SKumar Gala }; 123dee80553SKumar Gala dma-channel@80 { 124dee80553SKumar Gala compatible = "fsl,mpc8540-dma-channel", 125dee80553SKumar Gala "fsl,eloplus-dma-channel"; 126dee80553SKumar Gala reg = <0x80 0x80>; 127dee80553SKumar Gala cell-index = <1>; 128dee80553SKumar Gala interrupt-parent = <&mpic>; 129dee80553SKumar Gala interrupts = <21 2>; 130dee80553SKumar Gala }; 131dee80553SKumar Gala dma-channel@100 { 132dee80553SKumar Gala compatible = "fsl,mpc8540-dma-channel", 133dee80553SKumar Gala "fsl,eloplus-dma-channel"; 134dee80553SKumar Gala reg = <0x100 0x80>; 135dee80553SKumar Gala cell-index = <2>; 136dee80553SKumar Gala interrupt-parent = <&mpic>; 137dee80553SKumar Gala interrupts = <22 2>; 138dee80553SKumar Gala }; 139dee80553SKumar Gala dma-channel@180 { 140dee80553SKumar Gala compatible = "fsl,mpc8540-dma-channel", 141dee80553SKumar Gala "fsl,eloplus-dma-channel"; 142dee80553SKumar Gala reg = <0x180 0x80>; 143dee80553SKumar Gala cell-index = <3>; 144dee80553SKumar Gala interrupt-parent = <&mpic>; 145dee80553SKumar Gala interrupts = <23 2>; 146dee80553SKumar Gala }; 147dee80553SKumar Gala }; 148dee80553SKumar Gala 14984ba4a58SAnton Vorontsov enet0: ethernet@24000 { 15084ba4a58SAnton Vorontsov #address-cells = <1>; 15184ba4a58SAnton Vorontsov #size-cells = <1>; 15284ba4a58SAnton Vorontsov cell-index = <0>; 15384ba4a58SAnton Vorontsov device_type = "network"; 15484ba4a58SAnton Vorontsov model = "TSEC"; 15584ba4a58SAnton Vorontsov compatible = "gianfar"; 15684ba4a58SAnton Vorontsov reg = <0x24000 0x1000>; 15784ba4a58SAnton Vorontsov ranges = <0x0 0x24000 0x1000>; 15884ba4a58SAnton Vorontsov local-mac-address = [ 00 00 00 00 00 00 ]; 15984ba4a58SAnton Vorontsov interrupts = <29 2 30 2 34 2>; 16084ba4a58SAnton Vorontsov interrupt-parent = <&mpic>; 16184ba4a58SAnton Vorontsov phy-handle = <&phy2>; 16284ba4a58SAnton Vorontsov 16384ba4a58SAnton Vorontsov mdio@520 { 1640052bc5dSKumar Gala #address-cells = <1>; 1650052bc5dSKumar Gala #size-cells = <0>; 1660052bc5dSKumar Gala compatible = "fsl,gianfar-mdio"; 16784ba4a58SAnton Vorontsov reg = <0x520 0x20>; 1680052bc5dSKumar Gala 1690052bc5dSKumar Gala phy1: ethernet-phy@1 { 1700052bc5dSKumar Gala interrupt-parent = <&mpic>; 1710052bc5dSKumar Gala interrupts = <8 1>; 1720052bc5dSKumar Gala reg = <1>; 1730052bc5dSKumar Gala }; 1740052bc5dSKumar Gala phy2: ethernet-phy@2 { 1750052bc5dSKumar Gala interrupt-parent = <&mpic>; 1760052bc5dSKumar Gala interrupts = <8 1>; 1770052bc5dSKumar Gala reg = <2>; 1780052bc5dSKumar Gala }; 1790052bc5dSKumar Gala phy3: ethernet-phy@3 { 1800052bc5dSKumar Gala interrupt-parent = <&mpic>; 1810052bc5dSKumar Gala interrupts = <8 1>; 1820052bc5dSKumar Gala reg = <3>; 1830052bc5dSKumar Gala }; 184b31a1d8bSAndy Fleming tbi0: tbi-phy@11 { 185b31a1d8bSAndy Fleming reg = <0x11>; 186b31a1d8bSAndy Fleming device_type = "tbi-phy"; 187b31a1d8bSAndy Fleming }; 188b31a1d8bSAndy Fleming }; 18984ba4a58SAnton Vorontsov }; 190b31a1d8bSAndy Fleming 19184ba4a58SAnton Vorontsov enet1: ethernet@25000 { 19284ba4a58SAnton Vorontsov #address-cells = <1>; 19384ba4a58SAnton Vorontsov #size-cells = <1>; 19484ba4a58SAnton Vorontsov cell-index = <1>; 19584ba4a58SAnton Vorontsov device_type = "network"; 19684ba4a58SAnton Vorontsov model = "TSEC"; 19784ba4a58SAnton Vorontsov compatible = "gianfar"; 19884ba4a58SAnton Vorontsov reg = <0x25000 0x1000>; 19984ba4a58SAnton Vorontsov ranges = <0x0 0x25000 0x1000>; 20084ba4a58SAnton Vorontsov local-mac-address = [ 00 00 00 00 00 00 ]; 20184ba4a58SAnton Vorontsov interrupts = <35 2 36 2 40 2>; 20284ba4a58SAnton Vorontsov interrupt-parent = <&mpic>; 20384ba4a58SAnton Vorontsov phy-handle = <&phy1>; 20484ba4a58SAnton Vorontsov 20584ba4a58SAnton Vorontsov mdio@520 { 206b31a1d8bSAndy Fleming #address-cells = <1>; 207b31a1d8bSAndy Fleming #size-cells = <0>; 208b31a1d8bSAndy Fleming compatible = "fsl,gianfar-tbi"; 20984ba4a58SAnton Vorontsov reg = <0x520 0x20>; 210b31a1d8bSAndy Fleming 211b31a1d8bSAndy Fleming tbi1: tbi-phy@11 { 212b31a1d8bSAndy Fleming reg = <0x11>; 213b31a1d8bSAndy Fleming device_type = "tbi-phy"; 214b31a1d8bSAndy Fleming }; 215b31a1d8bSAndy Fleming }; 21684ba4a58SAnton Vorontsov }; 217b31a1d8bSAndy Fleming 21884ba4a58SAnton Vorontsov enet2: ethernet@26000 { 21984ba4a58SAnton Vorontsov #address-cells = <1>; 22084ba4a58SAnton Vorontsov #size-cells = <1>; 22184ba4a58SAnton Vorontsov cell-index = <2>; 22284ba4a58SAnton Vorontsov device_type = "network"; 22384ba4a58SAnton Vorontsov model = "FEC"; 22484ba4a58SAnton Vorontsov compatible = "gianfar"; 22584ba4a58SAnton Vorontsov reg = <0x26000 0x1000>; 22684ba4a58SAnton Vorontsov ranges = <0x0 0x26000 0x1000>; 22784ba4a58SAnton Vorontsov local-mac-address = [ 00 00 00 00 00 00 ]; 22884ba4a58SAnton Vorontsov interrupts = <41 2>; 22984ba4a58SAnton Vorontsov interrupt-parent = <&mpic>; 23084ba4a58SAnton Vorontsov phy-handle = <&phy3>; 23184ba4a58SAnton Vorontsov 23284ba4a58SAnton Vorontsov mdio@520 { 233b31a1d8bSAndy Fleming #address-cells = <1>; 234b31a1d8bSAndy Fleming #size-cells = <0>; 235b31a1d8bSAndy Fleming compatible = "fsl,gianfar-tbi"; 23684ba4a58SAnton Vorontsov reg = <0x520 0x20>; 237b31a1d8bSAndy Fleming 238b31a1d8bSAndy Fleming tbi2: tbi-phy@11 { 239b31a1d8bSAndy Fleming reg = <0x11>; 240b31a1d8bSAndy Fleming device_type = "tbi-phy"; 241b31a1d8bSAndy Fleming }; 2420052bc5dSKumar Gala }; 2430052bc5dSKumar Gala }; 2440052bc5dSKumar Gala 2450052bc5dSKumar Gala serial0: serial@4500 { 2460052bc5dSKumar Gala cell-index = <0>; 2470052bc5dSKumar Gala device_type = "serial"; 248f706bed1SKumar Gala compatible = "fsl,ns16550", "ns16550"; 2490052bc5dSKumar Gala reg = <0x4500 0x100>; // reg base, size 2500052bc5dSKumar Gala clock-frequency = <0>; // should we fill in in uboot? 2510052bc5dSKumar Gala interrupts = <42 2>; 2520052bc5dSKumar Gala interrupt-parent = <&mpic>; 2530052bc5dSKumar Gala }; 2540052bc5dSKumar Gala 2550052bc5dSKumar Gala serial1: serial@4600 { 2560052bc5dSKumar Gala cell-index = <1>; 2570052bc5dSKumar Gala device_type = "serial"; 258f706bed1SKumar Gala compatible = "fsl,ns16550", "ns16550"; 2590052bc5dSKumar Gala reg = <0x4600 0x100>; // reg base, size 2600052bc5dSKumar Gala clock-frequency = <0>; // should we fill in in uboot? 2610052bc5dSKumar Gala interrupts = <42 2>; 2620052bc5dSKumar Gala interrupt-parent = <&mpic>; 2630052bc5dSKumar Gala }; 2640052bc5dSKumar Gala 2650052bc5dSKumar Gala mpic: pic@40000 { 2660052bc5dSKumar Gala interrupt-controller; 2670052bc5dSKumar Gala #address-cells = <0>; 2680052bc5dSKumar Gala #interrupt-cells = <2>; 2690052bc5dSKumar Gala reg = <0x40000 0x40000>; 2700052bc5dSKumar Gala device_type = "open-pic"; 271acd4b715SKumar Gala compatible = "chrp,open-pic"; 2720052bc5dSKumar Gala }; 2730052bc5dSKumar Gala }; 2740052bc5dSKumar Gala 27567e64f4aSDmitry Eremin-Solenikov localbus@e0005000 { 27667e64f4aSDmitry Eremin-Solenikov #address-cells = <2>; 27767e64f4aSDmitry Eremin-Solenikov #size-cells = <1>; 27867e64f4aSDmitry Eremin-Solenikov compatible = "fsl,mpc8540-localbus", "fsl,pq3-localbus", 27967e64f4aSDmitry Eremin-Solenikov "simple-bus"; 28067e64f4aSDmitry Eremin-Solenikov reg = <0xe0005000 0x1000>; 281c0f58950SDmitry Eremin-Solenikov interrupt-parent = <&mpic>; 282c0f58950SDmitry Eremin-Solenikov interrupts = <19 2>; 28367e64f4aSDmitry Eremin-Solenikov 28467e64f4aSDmitry Eremin-Solenikov ranges = <0x0 0x0 0xfe000000 0x02000000>; 28567e64f4aSDmitry Eremin-Solenikov 28667e64f4aSDmitry Eremin-Solenikov nor@0,0 { 28767e64f4aSDmitry Eremin-Solenikov #address-cells = <1>; 28867e64f4aSDmitry Eremin-Solenikov #size-cells = <1>; 28967e64f4aSDmitry Eremin-Solenikov compatible = "cfi-flash"; 29067e64f4aSDmitry Eremin-Solenikov reg = <0x0 0x0 0x02000000>; 29167e64f4aSDmitry Eremin-Solenikov bank-width = <4>; 29267e64f4aSDmitry Eremin-Solenikov device-width = <2>; 29367e64f4aSDmitry Eremin-Solenikov partition@0 { 29467e64f4aSDmitry Eremin-Solenikov label = "kernel"; 29567e64f4aSDmitry Eremin-Solenikov reg = <0x00000000 0x00180000>; 29667e64f4aSDmitry Eremin-Solenikov }; 29767e64f4aSDmitry Eremin-Solenikov partition@180000 { 29867e64f4aSDmitry Eremin-Solenikov label = "root"; 29967e64f4aSDmitry Eremin-Solenikov reg = <0x00180000 0x01dc0000>; 30067e64f4aSDmitry Eremin-Solenikov }; 30167e64f4aSDmitry Eremin-Solenikov partition@1f40000 { 30267e64f4aSDmitry Eremin-Solenikov label = "env1"; 30367e64f4aSDmitry Eremin-Solenikov reg = <0x01f40000 0x00040000>; 30467e64f4aSDmitry Eremin-Solenikov }; 30567e64f4aSDmitry Eremin-Solenikov partition@1f80000 { 30667e64f4aSDmitry Eremin-Solenikov label = "env2"; 30767e64f4aSDmitry Eremin-Solenikov reg = <0x01f80000 0x00040000>; 30867e64f4aSDmitry Eremin-Solenikov }; 30967e64f4aSDmitry Eremin-Solenikov partition@1fc0000 { 31067e64f4aSDmitry Eremin-Solenikov label = "u-boot"; 31167e64f4aSDmitry Eremin-Solenikov reg = <0x01fc0000 0x00040000>; 31267e64f4aSDmitry Eremin-Solenikov read-only; 31367e64f4aSDmitry Eremin-Solenikov }; 31467e64f4aSDmitry Eremin-Solenikov }; 31567e64f4aSDmitry Eremin-Solenikov }; 31667e64f4aSDmitry Eremin-Solenikov 3170052bc5dSKumar Gala pci0: pci@e0008000 { 3180052bc5dSKumar Gala #interrupt-cells = <1>; 3190052bc5dSKumar Gala #size-cells = <2>; 3200052bc5dSKumar Gala #address-cells = <3>; 3210052bc5dSKumar Gala compatible = "fsl,mpc8540-pcix", "fsl,mpc8540-pci"; 3220052bc5dSKumar Gala device_type = "pci"; 3230052bc5dSKumar Gala reg = <0xe0008000 0x1000>; 3240052bc5dSKumar Gala clock-frequency = <66666666>; 3250052bc5dSKumar Gala interrupt-map-mask = <0xf800 0x0 0x0 0x7>; 3260052bc5dSKumar Gala interrupt-map = < 3270052bc5dSKumar Gala /* IDSEL 28 */ 3280052bc5dSKumar Gala 0xe000 0 0 1 &mpic 2 1 32907c63839SDmitry Eremin-Solenikov 0xe000 0 0 2 &mpic 3 1 33007c63839SDmitry Eremin-Solenikov 0xe000 0 0 3 &mpic 6 1 33107c63839SDmitry Eremin-Solenikov 0xe000 0 0 4 &mpic 5 1 33207c63839SDmitry Eremin-Solenikov 33307c63839SDmitry Eremin-Solenikov /* IDSEL 11 */ 33407c63839SDmitry Eremin-Solenikov 0x5800 0 0 1 &mpic 6 1 33507c63839SDmitry Eremin-Solenikov 0x5800 0 0 2 &mpic 5 1 33607c63839SDmitry Eremin-Solenikov >; 3370052bc5dSKumar Gala 3380052bc5dSKumar Gala interrupt-parent = <&mpic>; 3390052bc5dSKumar Gala interrupts = <24 2>; 3400052bc5dSKumar Gala bus-range = <0 0>; 3410052bc5dSKumar Gala ranges = <0x02000000 0 0x80000000 0x80000000 0 0x20000000 3420052bc5dSKumar Gala 0x01000000 0 0x00000000 0xe2000000 0 0x01000000>; 3430052bc5dSKumar Gala }; 3440052bc5dSKumar Gala}; 345