1 // SPDX-License-Identifier: GPL-2.0-only
3 * Copyright (C) 2008 Extreme Engineering Solutions, Inc.
4 * Based on MPC8572DS device tree from Freescale Semiconductor, Inc.
6 * XPedite5370 3U VPX single-board computer based on MPC8572E
11 model = "xes,xpedite5370";
12 compatible = "xes,xpedite5370", "xes,MPC8572";
32 d-cache-line-size = <32>; // 32 bytes
33 i-cache-line-size = <32>; // 32 bytes
34 d-cache-size = <0x8000>; // L1, 32K
35 i-cache-size = <0x8000>; // L1, 32K
36 timebase-frequency = <0>;
38 clock-frequency = <0>;
39 next-level-cache = <&L2>;
45 d-cache-line-size = <32>; // 32 bytes
46 i-cache-line-size = <32>; // 32 bytes
47 d-cache-size = <0x8000>; // L1, 32K
48 i-cache-size = <0x8000>; // L1, 32K
49 timebase-frequency = <0>;
51 clock-frequency = <0>;
52 next-level-cache = <&L2>;
57 device_type = "memory";
58 reg = <0x0 0x0 0x0 0x0>; // Filled in by U-Boot
64 compatible = "fsl,mpc8572-elbc", "fsl,elbc", "simple-bus";
65 reg = <0 0xef005000 0 0x1000>;
67 interrupt-parent = <&mpic>;
68 /* Local bus region mappings */
69 ranges = <0 0 0 0xf8000000 0x8000000 /* CS0: Boot flash */
70 1 0 0 0xf0000000 0x8000000 /* CS1: Alternate flash */
71 2 0 0 0xef800000 0x40000 /* CS2: NAND CE1 */
72 3 0 0 0xef840000 0x40000>; /* CS3: NAND CE2 */
75 compatible = "amd,s29gl01gp", "cfi-flash";
77 reg = <0 0 0x8000000>; /* 128MB */
81 label = "Primary user space";
82 reg = <0x00000000 0x6f00000>; /* 111 MB */
85 label = "Primary kernel";
86 reg = <0x6f00000 0x1000000>; /* 16 MB */
89 label = "Primary DTB";
90 reg = <0x7f00000 0x40000>; /* 256 KB */
93 label = "Primary U-Boot environment";
94 reg = <0x7f40000 0x40000>; /* 256 KB */
97 label = "Primary U-Boot";
98 reg = <0x7f80000 0x80000>; /* 512 KB */
104 compatible = "amd,s29gl01gp", "cfi-flash";
106 //reg = <0xf0000000 0x08000000>; /* 128MB */
107 reg = <1 0 0x8000000>; /* 128MB */
108 #address-cells = <1>;
111 label = "Secondary user space";
112 reg = <0x00000000 0x6f00000>; /* 111 MB */
115 label = "Secondary kernel";
116 reg = <0x6f00000 0x1000000>; /* 16 MB */
119 label = "Secondary DTB";
120 reg = <0x7f00000 0x40000>; /* 256 KB */
123 label = "Secondary U-Boot environment";
124 reg = <0x7f40000 0x40000>; /* 256 KB */
127 label = "Secondary U-Boot";
128 reg = <0x7f80000 0x80000>; /* 512 KB */
134 #address-cells = <1>;
137 * Actual part could be ST Micro NAND08GW3B2A (1 GB),
138 * Micron MT29F8G08DAA (2x 512 MB), or Micron
139 * MT29F16G08FAA (2x 1 GB), depending on the build
142 compatible = "fsl,mpc8572-fcm-nand",
145 /* U-Boot should fix this up if chip size > 1 GB */
147 label = "NAND Filesystem";
148 reg = <0 0x40000000>;
155 #address-cells = <1>;
158 compatible = "fsl,mpc8572-immr", "simple-bus";
159 ranges = <0x0 0 0xef000000 0x100000>;
160 bus-frequency = <0>; // Filled out by uboot.
163 compatible = "fsl,ecm-law";
169 compatible = "fsl,mpc8572-ecm", "fsl,ecm";
170 reg = <0x1000 0x1000>;
172 interrupt-parent = <&mpic>;
175 memory-controller@2000 {
176 compatible = "fsl,mpc8572-memory-controller";
177 reg = <0x2000 0x1000>;
178 interrupt-parent = <&mpic>;
182 memory-controller@6000 {
183 compatible = "fsl,mpc8572-memory-controller";
184 reg = <0x6000 0x1000>;
185 interrupt-parent = <&mpic>;
189 L2: l2-cache-controller@20000 {
190 compatible = "fsl,mpc8572-l2-cache-controller";
191 reg = <0x20000 0x1000>;
192 cache-line-size = <32>; // 32 bytes
193 cache-size = <0x100000>; // L2, 1M
194 interrupt-parent = <&mpic>;
199 #address-cells = <1>;
202 compatible = "fsl-i2c";
203 reg = <0x3000 0x100>;
205 interrupt-parent = <&mpic>;
209 compatible = "dallas,ds1631", "dallas,ds1621";
214 compatible = "adi,adt7461";
219 compatible = "dallas,ds4510";
224 compatible = "atmel,at24c128b";
229 compatible = "st,m41t00",
235 compatible = "plx,pex8518";
240 compatible = "nxp,pca9557";
248 compatible = "nxp,pca9557";
256 compatible = "nxp,pca9557";
264 compatible = "nxp,pca9557";
273 #address-cells = <1>;
276 compatible = "fsl-i2c";
277 reg = <0x3100 0x100>;
279 interrupt-parent = <&mpic>;
284 #address-cells = <1>;
286 compatible = "fsl,mpc8572-dma", "fsl,eloplus-dma";
288 ranges = <0x0 0xc100 0x200>;
291 compatible = "fsl,mpc8572-dma-channel",
292 "fsl,eloplus-dma-channel";
295 interrupt-parent = <&mpic>;
299 compatible = "fsl,mpc8572-dma-channel",
300 "fsl,eloplus-dma-channel";
303 interrupt-parent = <&mpic>;
307 compatible = "fsl,mpc8572-dma-channel",
308 "fsl,eloplus-dma-channel";
311 interrupt-parent = <&mpic>;
315 compatible = "fsl,mpc8572-dma-channel",
316 "fsl,eloplus-dma-channel";
319 interrupt-parent = <&mpic>;
325 #address-cells = <1>;
327 compatible = "fsl,mpc8572-dma", "fsl,eloplus-dma";
329 ranges = <0x0 0x21100 0x200>;
332 compatible = "fsl,mpc8572-dma-channel",
333 "fsl,eloplus-dma-channel";
336 interrupt-parent = <&mpic>;
340 compatible = "fsl,mpc8572-dma-channel",
341 "fsl,eloplus-dma-channel";
344 interrupt-parent = <&mpic>;
348 compatible = "fsl,mpc8572-dma-channel",
349 "fsl,eloplus-dma-channel";
352 interrupt-parent = <&mpic>;
356 compatible = "fsl,mpc8572-dma-channel",
357 "fsl,eloplus-dma-channel";
360 interrupt-parent = <&mpic>;
366 enet0: ethernet@24000 {
367 #address-cells = <1>;
370 device_type = "network";
372 compatible = "gianfar";
373 reg = <0x24000 0x1000>;
374 ranges = <0x0 0x24000 0x1000>;
375 local-mac-address = [ 00 00 00 00 00 00 ];
376 interrupts = <29 2 30 2 34 2>;
377 interrupt-parent = <&mpic>;
378 tbi-handle = <&tbi0>;
379 phy-handle = <&phy0>;
380 phy-connection-type = "sgmii";
383 #address-cells = <1>;
385 compatible = "fsl,gianfar-mdio";
388 phy0: ethernet-phy@1 {
389 interrupt-parent = <&mpic>;
393 phy1: ethernet-phy@2 {
394 interrupt-parent = <&mpic>;
400 device_type = "tbi-phy";
406 enet1: ethernet@25000 {
407 #address-cells = <1>;
410 device_type = "network";
412 compatible = "gianfar";
413 reg = <0x25000 0x1000>;
414 ranges = <0x0 0x25000 0x1000>;
415 local-mac-address = [ 00 00 00 00 00 00 ];
416 interrupts = <35 2 36 2 40 2>;
417 interrupt-parent = <&mpic>;
418 tbi-handle = <&tbi1>;
419 phy-handle = <&phy1>;
420 phy-connection-type = "sgmii";
423 #address-cells = <1>;
425 compatible = "fsl,gianfar-tbi";
430 device_type = "tbi-phy";
436 serial0: serial@4500 {
438 device_type = "serial";
439 compatible = "fsl,ns16550", "ns16550";
440 reg = <0x4500 0x100>;
441 clock-frequency = <0>;
443 interrupt-parent = <&mpic>;
447 serial1: serial@4600 {
449 device_type = "serial";
450 compatible = "fsl,ns16550", "ns16550";
451 reg = <0x4600 0x100>;
452 clock-frequency = <0>;
454 interrupt-parent = <&mpic>;
457 global-utilities@e0000 { //global utilities block
458 compatible = "fsl,mpc8572-guts";
459 reg = <0xe0000 0x1000>;
464 compatible = "fsl,mpc8572-msi", "fsl,mpic-msi";
465 reg = <0x41600 0x80>;
466 msi-available-ranges = <0 0x100>;
476 interrupt-parent = <&mpic>;
480 compatible = "fsl,sec3.0", "fsl,sec2.4", "fsl,sec2.2",
481 "fsl,sec2.1", "fsl,sec2.0";
482 reg = <0x30000 0x10000>;
483 interrupts = <45 2 58 2>;
484 interrupt-parent = <&mpic>;
485 fsl,num-channels = <4>;
486 fsl,channel-fifo-len = <24>;
487 fsl,exec-units-mask = <0x9fe>;
488 fsl,descriptor-types-mask = <0x3ab0ebf>;
492 interrupt-controller;
493 #address-cells = <0>;
494 #interrupt-cells = <2>;
495 reg = <0x40000 0x40000>;
496 compatible = "chrp,open-pic";
497 device_type = "open-pic";
501 compatible = "fsl,mpc8572-gpio";
502 reg = <0xf000 0x1000>;
504 interrupt-parent = <&mpic>;
510 compatible = "gpio-leds";
514 gpios = <&gpio0 4 1>;
515 linux,default-trigger = "heartbeat";
520 gpios = <&gpio0 5 1>;
525 gpios = <&gpio0 6 1>;
530 gpios = <&gpio0 7 1>;
534 /* PME (pattern-matcher) */
536 compatible = "fsl,mpc8572-pme", "pme8572";
537 reg = <0x10000 0x5000>;
538 interrupts = <57 2 64 2 65 2 66 2 67 2>;
539 interrupt-parent = <&mpic>;
543 compatible = "fsl,mpc8572-tlu", "fsl_tlu";
544 reg = <0x2f000 0x1000>;
546 interrupt-parent = <&mpic>;
550 compatible = "fsl,mpc8572-tlu", "fsl_tlu";
551 reg = <0x15000 0x1000>;
553 interrupt-parent = <&mpic>;
558 * PCI Express controller 3 @ ef008000 is not used.
559 * This would have been pci0 on other mpc85xx platforms.
562 /* PCI Express controller 2, wired to VPX P1,P2 backplane */
563 pci1: pcie@ef009000 {
564 compatible = "fsl,mpc8548-pcie";
566 #interrupt-cells = <1>;
568 #address-cells = <3>;
569 reg = <0 0xef009000 0 0x1000>;
571 ranges = <0x2000000 0x0 0xc0000000 0 0xc0000000 0x0 0x10000000
572 0x1000000 0x0 0x00000000 0 0xe8800000 0x0 0x00010000>;
573 clock-frequency = <33333333>;
574 interrupt-parent = <&mpic>;
576 interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
579 0x0 0x0 0x0 0x1 &mpic 0x4 0x1
580 0x0 0x0 0x0 0x2 &mpic 0x5 0x1
581 0x0 0x0 0x0 0x3 &mpic 0x6 0x1
582 0x0 0x0 0x0 0x4 &mpic 0x7 0x1
585 reg = <0x00000000 0x00000000 0x00000000 0x00000000 0x00000000>;
587 #address-cells = <3>;
589 ranges = <0x2000000 0x0 0xc0000000
590 0x2000000 0x0 0xc0000000
599 /* PCI Express controller 1, wired to PEX8518 PCIe switch */
600 pci2: pcie@ef00a000 {
601 compatible = "fsl,mpc8548-pcie";
603 #interrupt-cells = <1>;
605 #address-cells = <3>;
606 reg = <0 0xef00a000 0 0x1000>;
608 ranges = <0x2000000 0x0 0x80000000 0 0x80000000 0x0 0x40000000
609 0x1000000 0x0 0x00000000 0 0xe8000000 0x0 0x10000>;
610 clock-frequency = <33333333>;
611 interrupt-parent = <&mpic>;
613 interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
616 0x0 0x0 0x0 0x1 &mpic 0x0 0x1
617 0x0 0x0 0x0 0x2 &mpic 0x1 0x1
618 0x0 0x0 0x0 0x3 &mpic 0x2 0x1
619 0x0 0x0 0x0 0x4 &mpic 0x3 0x1
622 reg = <0x0 0x0 0x0 0x0 0x0>;
624 #address-cells = <3>;
626 ranges = <0x2000000 0x0 0x80000000
627 0x2000000 0x0 0x80000000