1a62f48deSStefan Roese/* 2a62f48deSStefan Roese * Device Tree Source for AMCC Kilauea (405EX) 3a62f48deSStefan Roese * 4a62f48deSStefan Roese * Copyright 2007 DENX Software Engineering, Stefan Roese <sr@denx.de> 5a62f48deSStefan Roese * 6a62f48deSStefan Roese * This file is licensed under the terms of the GNU General Public 7a62f48deSStefan Roese * License version 2. This program is licensed "as is" without 8a62f48deSStefan Roese * any warranty of any kind, whether express or implied. 9a62f48deSStefan Roese */ 10a62f48deSStefan Roese 11a62f48deSStefan Roese/ { 12a62f48deSStefan Roese #address-cells = <1>; 13a62f48deSStefan Roese #size-cells = <1>; 14a62f48deSStefan Roese model = "amcc,kilauea"; 15a62f48deSStefan Roese compatible = "amcc,kilauea"; 16a62f48deSStefan Roese dcr-parent = <&/cpus/PowerPC,405EX@0>; 17a62f48deSStefan Roese 18a62f48deSStefan Roese cpus { 19a62f48deSStefan Roese #address-cells = <1>; 20a62f48deSStefan Roese #size-cells = <0>; 21a62f48deSStefan Roese 22a62f48deSStefan Roese PowerPC,405EX@0 { 23a62f48deSStefan Roese device_type = "cpu"; 24a62f48deSStefan Roese reg = <0>; 25a62f48deSStefan Roese clock-frequency = <0>; /* Filled in by U-Boot */ 26a62f48deSStefan Roese timebase-frequency = <0>; /* Filled in by U-Boot */ 27a62f48deSStefan Roese i-cache-line-size = <20>; 28a62f48deSStefan Roese d-cache-line-size = <20>; 29a62f48deSStefan Roese i-cache-size = <4000>; /* 16 kB */ 30a62f48deSStefan Roese d-cache-size = <4000>; /* 16 kB */ 31a62f48deSStefan Roese dcr-controller; 32a62f48deSStefan Roese dcr-access-method = "native"; 33a62f48deSStefan Roese }; 34a62f48deSStefan Roese }; 35a62f48deSStefan Roese 36a62f48deSStefan Roese memory { 37a62f48deSStefan Roese device_type = "memory"; 38a62f48deSStefan Roese reg = <0 0>; /* Filled in by U-Boot */ 39a62f48deSStefan Roese }; 40a62f48deSStefan Roese 41a62f48deSStefan Roese UIC0: interrupt-controller { 42a62f48deSStefan Roese compatible = "ibm,uic-405ex", "ibm,uic"; 43a62f48deSStefan Roese interrupt-controller; 44a62f48deSStefan Roese cell-index = <0>; 45a62f48deSStefan Roese dcr-reg = <0c0 009>; 46a62f48deSStefan Roese #address-cells = <0>; 47a62f48deSStefan Roese #size-cells = <0>; 48a62f48deSStefan Roese #interrupt-cells = <2>; 49a62f48deSStefan Roese }; 50a62f48deSStefan Roese 51a62f48deSStefan Roese UIC1: interrupt-controller1 { 52a62f48deSStefan Roese compatible = "ibm,uic-405ex","ibm,uic"; 53a62f48deSStefan Roese interrupt-controller; 54a62f48deSStefan Roese cell-index = <1>; 55a62f48deSStefan Roese dcr-reg = <0d0 009>; 56a62f48deSStefan Roese #address-cells = <0>; 57a62f48deSStefan Roese #size-cells = <0>; 58a62f48deSStefan Roese #interrupt-cells = <2>; 59a62f48deSStefan Roese interrupts = <1e 4 1f 4>; /* cascade */ 60a62f48deSStefan Roese interrupt-parent = <&UIC0>; 61a62f48deSStefan Roese }; 62a62f48deSStefan Roese 63a62f48deSStefan Roese UIC2: interrupt-controller2 { 64a62f48deSStefan Roese compatible = "ibm,uic-405ex","ibm,uic"; 65a62f48deSStefan Roese interrupt-controller; 66a62f48deSStefan Roese cell-index = <2>; 67a62f48deSStefan Roese dcr-reg = <0e0 009>; 68a62f48deSStefan Roese #address-cells = <0>; 69a62f48deSStefan Roese #size-cells = <0>; 70a62f48deSStefan Roese #interrupt-cells = <2>; 71a62f48deSStefan Roese interrupts = <1c 4 1d 4>; /* cascade */ 72a62f48deSStefan Roese interrupt-parent = <&UIC0>; 73a62f48deSStefan Roese }; 74a62f48deSStefan Roese 75a62f48deSStefan Roese plb { 76a62f48deSStefan Roese compatible = "ibm,plb-405ex", "ibm,plb4"; 77a62f48deSStefan Roese #address-cells = <1>; 78a62f48deSStefan Roese #size-cells = <1>; 79a62f48deSStefan Roese ranges; 80a62f48deSStefan Roese clock-frequency = <0>; /* Filled in by U-Boot */ 81a62f48deSStefan Roese 82a62f48deSStefan Roese SDRAM0: memory-controller { 83a62f48deSStefan Roese compatible = "ibm,sdram-405ex"; 84a62f48deSStefan Roese dcr-reg = <010 2>; 85a62f48deSStefan Roese }; 86a62f48deSStefan Roese 87a62f48deSStefan Roese MAL0: mcmal { 88a62f48deSStefan Roese compatible = "ibm,mcmal-405ex", "ibm,mcmal2"; 89a62f48deSStefan Roese dcr-reg = <180 62>; 90a62f48deSStefan Roese num-tx-chans = <2>; 91a62f48deSStefan Roese num-rx-chans = <2>; 92a62f48deSStefan Roese interrupt-parent = <&MAL0>; 93a62f48deSStefan Roese interrupts = <0 1 2 3 4>; 94a62f48deSStefan Roese #interrupt-cells = <1>; 95a62f48deSStefan Roese #address-cells = <0>; 96a62f48deSStefan Roese #size-cells = <0>; 97a62f48deSStefan Roese interrupt-map = </*TXEOB*/ 0 &UIC0 a 4 98a62f48deSStefan Roese /*RXEOB*/ 1 &UIC0 b 4 99a62f48deSStefan Roese /*SERR*/ 2 &UIC1 0 4 100a62f48deSStefan Roese /*TXDE*/ 3 &UIC1 1 4 101a62f48deSStefan Roese /*RXDE*/ 4 &UIC1 2 4>; 102a62f48deSStefan Roese interrupt-map-mask = <ffffffff>; 103a62f48deSStefan Roese }; 104a62f48deSStefan Roese 105a62f48deSStefan Roese POB0: opb { 106a62f48deSStefan Roese compatible = "ibm,opb-405ex", "ibm,opb"; 107a62f48deSStefan Roese #address-cells = <1>; 108a62f48deSStefan Roese #size-cells = <1>; 109a62f48deSStefan Roese ranges = <80000000 80000000 10000000 110a62f48deSStefan Roese ef600000 ef600000 a00000 111a62f48deSStefan Roese f0000000 f0000000 10000000>; 112a62f48deSStefan Roese dcr-reg = <0a0 5>; 113a62f48deSStefan Roese clock-frequency = <0>; /* Filled in by U-Boot */ 114a62f48deSStefan Roese 115a62f48deSStefan Roese EBC0: ebc { 116a62f48deSStefan Roese compatible = "ibm,ebc-405ex", "ibm,ebc"; 117a62f48deSStefan Roese dcr-reg = <012 2>; 118a62f48deSStefan Roese #address-cells = <2>; 119a62f48deSStefan Roese #size-cells = <1>; 120a62f48deSStefan Roese clock-frequency = <0>; /* Filled in by U-Boot */ 121a62f48deSStefan Roese /* ranges property is supplied by U-Boot */ 122a62f48deSStefan Roese interrupts = <5 1>; 123a62f48deSStefan Roese interrupt-parent = <&UIC1>; 124a62f48deSStefan Roese 125a62f48deSStefan Roese nor_flash@0,0 { 126a62f48deSStefan Roese compatible = "amd,s29gl512n", "cfi-flash"; 127a62f48deSStefan Roese bank-width = <2>; 128a62f48deSStefan Roese reg = <0 000000 4000000>; 129a62f48deSStefan Roese #address-cells = <1>; 130a62f48deSStefan Roese #size-cells = <1>; 131a62f48deSStefan Roese partition@0 { 132a62f48deSStefan Roese label = "kernel"; 133a62f48deSStefan Roese reg = <0 200000>; 134a62f48deSStefan Roese }; 135a62f48deSStefan Roese partition@200000 { 136a62f48deSStefan Roese label = "root"; 137a62f48deSStefan Roese reg = <200000 200000>; 138a62f48deSStefan Roese }; 139a62f48deSStefan Roese partition@400000 { 140a62f48deSStefan Roese label = "user"; 141a62f48deSStefan Roese reg = <400000 3b60000>; 142a62f48deSStefan Roese }; 143a62f48deSStefan Roese partition@3f60000 { 144a62f48deSStefan Roese label = "env"; 145a62f48deSStefan Roese reg = <3f60000 40000>; 146a62f48deSStefan Roese }; 147a62f48deSStefan Roese partition@3fa0000 { 148a62f48deSStefan Roese label = "u-boot"; 149a62f48deSStefan Roese reg = <3fa0000 60000>; 150a62f48deSStefan Roese }; 151a62f48deSStefan Roese }; 152a62f48deSStefan Roese }; 153a62f48deSStefan Roese 154a62f48deSStefan Roese UART0: serial@ef600200 { 155a62f48deSStefan Roese device_type = "serial"; 156a62f48deSStefan Roese compatible = "ns16550"; 157a62f48deSStefan Roese reg = <ef600200 8>; 158a62f48deSStefan Roese virtual-reg = <ef600200>; 159a62f48deSStefan Roese clock-frequency = <0>; /* Filled in by U-Boot */ 160a62f48deSStefan Roese current-speed = <0>; 161a62f48deSStefan Roese interrupt-parent = <&UIC0>; 162a62f48deSStefan Roese interrupts = <1a 4>; 163a62f48deSStefan Roese }; 164a62f48deSStefan Roese 165a62f48deSStefan Roese UART1: serial@ef600300 { 166a62f48deSStefan Roese device_type = "serial"; 167a62f48deSStefan Roese compatible = "ns16550"; 168a62f48deSStefan Roese reg = <ef600300 8>; 169a62f48deSStefan Roese virtual-reg = <ef600300>; 170a62f48deSStefan Roese clock-frequency = <0>; /* Filled in by U-Boot */ 171a62f48deSStefan Roese current-speed = <0>; 172a62f48deSStefan Roese interrupt-parent = <&UIC0>; 173a62f48deSStefan Roese interrupts = <1 4>; 174a62f48deSStefan Roese }; 175a62f48deSStefan Roese 176a62f48deSStefan Roese IIC0: i2c@ef600400 { 177a62f48deSStefan Roese device_type = "i2c"; 178a62f48deSStefan Roese compatible = "ibm,iic-405ex", "ibm,iic"; 179a62f48deSStefan Roese reg = <ef600400 14>; 180a62f48deSStefan Roese interrupt-parent = <&UIC0>; 181a62f48deSStefan Roese interrupts = <2 4>; 182a62f48deSStefan Roese }; 183a62f48deSStefan Roese 184a62f48deSStefan Roese IIC1: i2c@ef600500 { 185a62f48deSStefan Roese device_type = "i2c"; 186a62f48deSStefan Roese compatible = "ibm,iic-405ex", "ibm,iic"; 187a62f48deSStefan Roese reg = <ef600500 14>; 188a62f48deSStefan Roese interrupt-parent = <&UIC0>; 189a62f48deSStefan Roese interrupts = <7 4>; 190a62f48deSStefan Roese }; 191a62f48deSStefan Roese 192a62f48deSStefan Roese 193a62f48deSStefan Roese RGMII0: emac-rgmii@ef600b00 { 194a62f48deSStefan Roese device_type = "rgmii-interface"; 195a62f48deSStefan Roese compatible = "ibm,rgmii-405ex", "ibm,rgmii"; 196a62f48deSStefan Roese reg = <ef600b00 104>; 1970a6ea8beSStefan Roese has-mdio; 198a62f48deSStefan Roese }; 199a62f48deSStefan Roese 200a62f48deSStefan Roese EMAC0: ethernet@ef600900 { 201a62f48deSStefan Roese linux,network-index = <0>; 202a62f48deSStefan Roese device_type = "network"; 203a62f48deSStefan Roese compatible = "ibm,emac-405ex", "ibm,emac4"; 204a62f48deSStefan Roese interrupt-parent = <&EMAC0>; 205a62f48deSStefan Roese interrupts = <0 1>; 206a62f48deSStefan Roese #interrupt-cells = <1>; 207a62f48deSStefan Roese #address-cells = <0>; 208a62f48deSStefan Roese #size-cells = <0>; 209a62f48deSStefan Roese interrupt-map = </*Status*/ 0 &UIC0 18 4 210a62f48deSStefan Roese /*Wake*/ 1 &UIC1 1d 4>; 211a62f48deSStefan Roese reg = <ef600900 70>; 212a62f48deSStefan Roese local-mac-address = [000000000000]; /* Filled in by U-Boot */ 213a62f48deSStefan Roese mal-device = <&MAL0>; 214a62f48deSStefan Roese mal-tx-channel = <0>; 215a62f48deSStefan Roese mal-rx-channel = <0>; 216a62f48deSStefan Roese cell-index = <0>; 217a62f48deSStefan Roese max-frame-size = <5dc>; 218a62f48deSStefan Roese rx-fifo-size = <1000>; 219a62f48deSStefan Roese tx-fifo-size = <800>; 220a62f48deSStefan Roese phy-mode = "rgmii"; 221a62f48deSStefan Roese phy-map = <00000000>; 222a62f48deSStefan Roese rgmii-device = <&RGMII0>; 223a62f48deSStefan Roese rgmii-channel = <0>; 2240a6ea8beSStefan Roese has-inverted-stacr-oc; 2250a6ea8beSStefan Roese has-new-stacr-staopc; 226a62f48deSStefan Roese }; 227a62f48deSStefan Roese 228a62f48deSStefan Roese EMAC1: ethernet@ef600a00 { 229a62f48deSStefan Roese linux,network-index = <1>; 230a62f48deSStefan Roese device_type = "network"; 231a62f48deSStefan Roese compatible = "ibm,emac-405ex", "ibm,emac4"; 232a62f48deSStefan Roese interrupt-parent = <&EMAC1>; 233a62f48deSStefan Roese interrupts = <0 1>; 234a62f48deSStefan Roese #interrupt-cells = <1>; 235a62f48deSStefan Roese #address-cells = <0>; 236a62f48deSStefan Roese #size-cells = <0>; 237a62f48deSStefan Roese interrupt-map = </*Status*/ 0 &UIC0 19 4 238a62f48deSStefan Roese /*Wake*/ 1 &UIC1 1f 4>; 239a62f48deSStefan Roese reg = <ef600a00 70>; 240a62f48deSStefan Roese local-mac-address = [000000000000]; /* Filled in by U-Boot */ 241a62f48deSStefan Roese mal-device = <&MAL0>; 242a62f48deSStefan Roese mal-tx-channel = <1>; 243a62f48deSStefan Roese mal-rx-channel = <1>; 244a62f48deSStefan Roese cell-index = <1>; 245a62f48deSStefan Roese max-frame-size = <5dc>; 246a62f48deSStefan Roese rx-fifo-size = <1000>; 247a62f48deSStefan Roese tx-fifo-size = <800>; 248a62f48deSStefan Roese phy-mode = "rgmii"; 249a62f48deSStefan Roese phy-map = <00000000>; 250a62f48deSStefan Roese rgmii-device = <&RGMII0>; 251a62f48deSStefan Roese rgmii-channel = <1>; 2520a6ea8beSStefan Roese has-inverted-stacr-oc; 2530a6ea8beSStefan Roese has-new-stacr-staopc; 254a62f48deSStefan Roese }; 255a62f48deSStefan Roese }; 256*151161c6SStefan Roese 257*151161c6SStefan Roese PCIE0: pciex@0a0000000 { 258*151161c6SStefan Roese device_type = "pci"; 259*151161c6SStefan Roese #interrupt-cells = <1>; 260*151161c6SStefan Roese #size-cells = <2>; 261*151161c6SStefan Roese #address-cells = <3>; 262*151161c6SStefan Roese compatible = "ibm,plb-pciex-405ex", "ibm,plb-pciex"; 263*151161c6SStefan Roese primary; 264*151161c6SStefan Roese port = <0>; /* port number */ 265*151161c6SStefan Roese reg = <a0000000 20000000 /* Config space access */ 266*151161c6SStefan Roese ef000000 00001000>; /* Registers */ 267*151161c6SStefan Roese dcr-reg = <040 020>; 268*151161c6SStefan Roese sdr-base = <400>; 269*151161c6SStefan Roese 270*151161c6SStefan Roese /* Outbound ranges, one memory and one IO, 271*151161c6SStefan Roese * later cannot be changed 272*151161c6SStefan Roese */ 273*151161c6SStefan Roese ranges = <02000000 0 80000000 90000000 0 08000000 274*151161c6SStefan Roese 01000000 0 00000000 e0000000 0 00010000>; 275*151161c6SStefan Roese 276*151161c6SStefan Roese /* Inbound 2GB range starting at 0 */ 277*151161c6SStefan Roese dma-ranges = <42000000 0 0 0 0 80000000>; 278*151161c6SStefan Roese 279*151161c6SStefan Roese /* This drives busses 0x00 to 0x0f */ 280*151161c6SStefan Roese bus-range = <00 0f>; 281*151161c6SStefan Roese 282*151161c6SStefan Roese /* Legacy interrupts (note the weird polarity, the bridge seems 283*151161c6SStefan Roese * to invert PCIe legacy interrupts). 284*151161c6SStefan Roese * We are de-swizzling here because the numbers are actually for 285*151161c6SStefan Roese * port of the root complex virtual P2P bridge. But I want 286*151161c6SStefan Roese * to avoid putting a node for it in the tree, so the numbers 287*151161c6SStefan Roese * below are basically de-swizzled numbers. 288*151161c6SStefan Roese * The real slot is on idsel 0, so the swizzling is 1:1 289*151161c6SStefan Roese */ 290*151161c6SStefan Roese interrupt-map-mask = <0000 0 0 7>; 291*151161c6SStefan Roese interrupt-map = < 292*151161c6SStefan Roese 0000 0 0 1 &UIC2 0 4 /* swizzled int A */ 293*151161c6SStefan Roese 0000 0 0 2 &UIC2 1 4 /* swizzled int B */ 294*151161c6SStefan Roese 0000 0 0 3 &UIC2 2 4 /* swizzled int C */ 295*151161c6SStefan Roese 0000 0 0 4 &UIC2 3 4 /* swizzled int D */>; 296*151161c6SStefan Roese }; 297*151161c6SStefan Roese 298*151161c6SStefan Roese PCIE1: pciex@0c0000000 { 299*151161c6SStefan Roese device_type = "pci"; 300*151161c6SStefan Roese #interrupt-cells = <1>; 301*151161c6SStefan Roese #size-cells = <2>; 302*151161c6SStefan Roese #address-cells = <3>; 303*151161c6SStefan Roese compatible = "ibm,plb-pciex-405ex", "ibm,plb-pciex"; 304*151161c6SStefan Roese primary; 305*151161c6SStefan Roese port = <1>; /* port number */ 306*151161c6SStefan Roese reg = <c0000000 20000000 /* Config space access */ 307*151161c6SStefan Roese ef001000 00001000>; /* Registers */ 308*151161c6SStefan Roese dcr-reg = <060 020>; 309*151161c6SStefan Roese sdr-base = <440>; 310*151161c6SStefan Roese 311*151161c6SStefan Roese /* Outbound ranges, one memory and one IO, 312*151161c6SStefan Roese * later cannot be changed 313*151161c6SStefan Roese */ 314*151161c6SStefan Roese ranges = <02000000 0 80000000 98000000 0 08000000 315*151161c6SStefan Roese 01000000 0 00000000 e0010000 0 00010000>; 316*151161c6SStefan Roese 317*151161c6SStefan Roese /* Inbound 2GB range starting at 0 */ 318*151161c6SStefan Roese dma-ranges = <42000000 0 0 0 0 80000000>; 319*151161c6SStefan Roese 320*151161c6SStefan Roese /* This drives busses 0x10 to 0x1f */ 321*151161c6SStefan Roese bus-range = <10 1f>; 322*151161c6SStefan Roese 323*151161c6SStefan Roese /* Legacy interrupts (note the weird polarity, the bridge seems 324*151161c6SStefan Roese * to invert PCIe legacy interrupts). 325*151161c6SStefan Roese * We are de-swizzling here because the numbers are actually for 326*151161c6SStefan Roese * port of the root complex virtual P2P bridge. But I want 327*151161c6SStefan Roese * to avoid putting a node for it in the tree, so the numbers 328*151161c6SStefan Roese * below are basically de-swizzled numbers. 329*151161c6SStefan Roese * The real slot is on idsel 0, so the swizzling is 1:1 330*151161c6SStefan Roese */ 331*151161c6SStefan Roese interrupt-map-mask = <0000 0 0 7>; 332*151161c6SStefan Roese interrupt-map = < 333*151161c6SStefan Roese 0000 0 0 1 &UIC2 b 4 /* swizzled int A */ 334*151161c6SStefan Roese 0000 0 0 2 &UIC2 c 4 /* swizzled int B */ 335*151161c6SStefan Roese 0000 0 0 3 &UIC2 d 4 /* swizzled int C */ 336*151161c6SStefan Roese 0000 0 0 4 &UIC2 e 4 /* swizzled int D */>; 337*151161c6SStefan Roese }; 338a62f48deSStefan Roese }; 339a62f48deSStefan Roese}; 340