1*4882a593Smuzhiyun// SPDX-License-Identifier: GPL-2.0-only 2*4882a593Smuzhiyun/* 3*4882a593Smuzhiyun * Copyright (C) 2008 Extreme Engineering Solutions, Inc. 4*4882a593Smuzhiyun * Based on MPC8572DS device tree from Freescale Semiconductor, Inc. 5*4882a593Smuzhiyun * 6*4882a593Smuzhiyun * XPedite5301 PMC/XMC module based on MPC8572E 7*4882a593Smuzhiyun */ 8*4882a593Smuzhiyun 9*4882a593Smuzhiyun/dts-v1/; 10*4882a593Smuzhiyun/ { 11*4882a593Smuzhiyun model = "xes,xpedite5301"; 12*4882a593Smuzhiyun compatible = "xes,xpedite5301", "xes,MPC8572"; 13*4882a593Smuzhiyun #address-cells = <2>; 14*4882a593Smuzhiyun #size-cells = <2>; 15*4882a593Smuzhiyun form-factor = "PMC/XMC"; 16*4882a593Smuzhiyun boot-bank = <0x0>; /* 0: Primary flash, 1: Secondary flash */ 17*4882a593Smuzhiyun 18*4882a593Smuzhiyun aliases { 19*4882a593Smuzhiyun ethernet0 = &enet0; 20*4882a593Smuzhiyun ethernet1 = &enet1; 21*4882a593Smuzhiyun serial0 = &serial0; 22*4882a593Smuzhiyun serial1 = &serial1; 23*4882a593Smuzhiyun pci1 = &pci1; 24*4882a593Smuzhiyun pci2 = &pci2; 25*4882a593Smuzhiyun }; 26*4882a593Smuzhiyun 27*4882a593Smuzhiyun cpus { 28*4882a593Smuzhiyun #address-cells = <1>; 29*4882a593Smuzhiyun #size-cells = <0>; 30*4882a593Smuzhiyun 31*4882a593Smuzhiyun PowerPC,8572@0 { 32*4882a593Smuzhiyun device_type = "cpu"; 33*4882a593Smuzhiyun reg = <0x0>; 34*4882a593Smuzhiyun d-cache-line-size = <32>; // 32 bytes 35*4882a593Smuzhiyun i-cache-line-size = <32>; // 32 bytes 36*4882a593Smuzhiyun d-cache-size = <0x8000>; // L1, 32K 37*4882a593Smuzhiyun i-cache-size = <0x8000>; // L1, 32K 38*4882a593Smuzhiyun timebase-frequency = <0>; 39*4882a593Smuzhiyun bus-frequency = <0>; 40*4882a593Smuzhiyun clock-frequency = <0>; 41*4882a593Smuzhiyun next-level-cache = <&L2>; 42*4882a593Smuzhiyun }; 43*4882a593Smuzhiyun 44*4882a593Smuzhiyun PowerPC,8572@1 { 45*4882a593Smuzhiyun device_type = "cpu"; 46*4882a593Smuzhiyun reg = <0x1>; 47*4882a593Smuzhiyun d-cache-line-size = <32>; // 32 bytes 48*4882a593Smuzhiyun i-cache-line-size = <32>; // 32 bytes 49*4882a593Smuzhiyun d-cache-size = <0x8000>; // L1, 32K 50*4882a593Smuzhiyun i-cache-size = <0x8000>; // L1, 32K 51*4882a593Smuzhiyun timebase-frequency = <0>; 52*4882a593Smuzhiyun bus-frequency = <0>; 53*4882a593Smuzhiyun clock-frequency = <0>; 54*4882a593Smuzhiyun next-level-cache = <&L2>; 55*4882a593Smuzhiyun }; 56*4882a593Smuzhiyun }; 57*4882a593Smuzhiyun 58*4882a593Smuzhiyun memory { 59*4882a593Smuzhiyun device_type = "memory"; 60*4882a593Smuzhiyun reg = <0x0 0x0 0x0 0x0>; // Filled in by U-Boot 61*4882a593Smuzhiyun }; 62*4882a593Smuzhiyun 63*4882a593Smuzhiyun localbus@ef005000 { 64*4882a593Smuzhiyun #address-cells = <2>; 65*4882a593Smuzhiyun #size-cells = <1>; 66*4882a593Smuzhiyun compatible = "fsl,mpc8572-elbc", "fsl,elbc", "simple-bus"; 67*4882a593Smuzhiyun reg = <0 0xef005000 0 0x1000>; 68*4882a593Smuzhiyun interrupts = <19 2>; 69*4882a593Smuzhiyun interrupt-parent = <&mpic>; 70*4882a593Smuzhiyun /* Local bus region mappings */ 71*4882a593Smuzhiyun ranges = <0 0 0 0xf8000000 0x8000000 /* CS0: Boot flash */ 72*4882a593Smuzhiyun 1 0 0 0xf0000000 0x8000000 /* CS1: Alternate flash */ 73*4882a593Smuzhiyun 2 0 0 0xef800000 0x40000 /* CS2: NAND CE1 */ 74*4882a593Smuzhiyun 3 0 0 0xef840000 0x40000>; /* CS3: NAND CE2 */ 75*4882a593Smuzhiyun 76*4882a593Smuzhiyun nor-boot@0,0 { 77*4882a593Smuzhiyun compatible = "amd,s29gl01gp", "cfi-flash"; 78*4882a593Smuzhiyun bank-width = <2>; 79*4882a593Smuzhiyun reg = <0 0 0x8000000>; /* 128MB */ 80*4882a593Smuzhiyun #address-cells = <1>; 81*4882a593Smuzhiyun #size-cells = <1>; 82*4882a593Smuzhiyun partition@0 { 83*4882a593Smuzhiyun label = "Primary user space"; 84*4882a593Smuzhiyun reg = <0x00000000 0x6f00000>; /* 111 MB */ 85*4882a593Smuzhiyun }; 86*4882a593Smuzhiyun partition@6f00000 { 87*4882a593Smuzhiyun label = "Primary kernel"; 88*4882a593Smuzhiyun reg = <0x6f00000 0x1000000>; /* 16 MB */ 89*4882a593Smuzhiyun }; 90*4882a593Smuzhiyun partition@7f00000 { 91*4882a593Smuzhiyun label = "Primary DTB"; 92*4882a593Smuzhiyun reg = <0x7f00000 0x40000>; /* 256 KB */ 93*4882a593Smuzhiyun }; 94*4882a593Smuzhiyun partition@7f40000 { 95*4882a593Smuzhiyun label = "Primary U-Boot environment"; 96*4882a593Smuzhiyun reg = <0x7f40000 0x40000>; /* 256 KB */ 97*4882a593Smuzhiyun }; 98*4882a593Smuzhiyun partition@7f80000 { 99*4882a593Smuzhiyun label = "Primary U-Boot"; 100*4882a593Smuzhiyun reg = <0x7f80000 0x80000>; /* 512 KB */ 101*4882a593Smuzhiyun read-only; 102*4882a593Smuzhiyun }; 103*4882a593Smuzhiyun }; 104*4882a593Smuzhiyun 105*4882a593Smuzhiyun nor-alternate@1,0 { 106*4882a593Smuzhiyun compatible = "amd,s29gl01gp", "cfi-flash"; 107*4882a593Smuzhiyun bank-width = <2>; 108*4882a593Smuzhiyun //reg = <0xf0000000 0x08000000>; /* 128MB */ 109*4882a593Smuzhiyun reg = <1 0 0x8000000>; /* 128MB */ 110*4882a593Smuzhiyun #address-cells = <1>; 111*4882a593Smuzhiyun #size-cells = <1>; 112*4882a593Smuzhiyun partition@0 { 113*4882a593Smuzhiyun label = "Secondary user space"; 114*4882a593Smuzhiyun reg = <0x00000000 0x6f00000>; /* 111 MB */ 115*4882a593Smuzhiyun }; 116*4882a593Smuzhiyun partition@6f00000 { 117*4882a593Smuzhiyun label = "Secondary kernel"; 118*4882a593Smuzhiyun reg = <0x6f00000 0x1000000>; /* 16 MB */ 119*4882a593Smuzhiyun }; 120*4882a593Smuzhiyun partition@7f00000 { 121*4882a593Smuzhiyun label = "Secondary DTB"; 122*4882a593Smuzhiyun reg = <0x7f00000 0x40000>; /* 256 KB */ 123*4882a593Smuzhiyun }; 124*4882a593Smuzhiyun partition@7f40000 { 125*4882a593Smuzhiyun label = "Secondary U-Boot environment"; 126*4882a593Smuzhiyun reg = <0x7f40000 0x40000>; /* 256 KB */ 127*4882a593Smuzhiyun }; 128*4882a593Smuzhiyun partition@7f80000 { 129*4882a593Smuzhiyun label = "Secondary U-Boot"; 130*4882a593Smuzhiyun reg = <0x7f80000 0x80000>; /* 512 KB */ 131*4882a593Smuzhiyun read-only; 132*4882a593Smuzhiyun }; 133*4882a593Smuzhiyun }; 134*4882a593Smuzhiyun 135*4882a593Smuzhiyun nand@2,0 { 136*4882a593Smuzhiyun #address-cells = <1>; 137*4882a593Smuzhiyun #size-cells = <1>; 138*4882a593Smuzhiyun /* 139*4882a593Smuzhiyun * Actual part could be ST Micro NAND08GW3B2A (1 GB), 140*4882a593Smuzhiyun * Micron MT29F8G08DAA (2x 512 MB), or Micron 141*4882a593Smuzhiyun * MT29F16G08FAA (2x 1 GB), depending on the build 142*4882a593Smuzhiyun * configuration 143*4882a593Smuzhiyun */ 144*4882a593Smuzhiyun compatible = "fsl,mpc8572-fcm-nand", 145*4882a593Smuzhiyun "fsl,elbc-fcm-nand"; 146*4882a593Smuzhiyun reg = <2 0 0x40000>; 147*4882a593Smuzhiyun /* U-Boot should fix this up if chip size > 1 GB */ 148*4882a593Smuzhiyun partition@0 { 149*4882a593Smuzhiyun label = "NAND Filesystem"; 150*4882a593Smuzhiyun reg = <0 0x40000000>; 151*4882a593Smuzhiyun }; 152*4882a593Smuzhiyun }; 153*4882a593Smuzhiyun 154*4882a593Smuzhiyun }; 155*4882a593Smuzhiyun 156*4882a593Smuzhiyun soc8572@ef000000 { 157*4882a593Smuzhiyun #address-cells = <1>; 158*4882a593Smuzhiyun #size-cells = <1>; 159*4882a593Smuzhiyun device_type = "soc"; 160*4882a593Smuzhiyun compatible = "fsl,mpc8572-immr", "simple-bus"; 161*4882a593Smuzhiyun ranges = <0x0 0 0xef000000 0x100000>; 162*4882a593Smuzhiyun bus-frequency = <0>; // Filled out by uboot. 163*4882a593Smuzhiyun 164*4882a593Smuzhiyun ecm-law@0 { 165*4882a593Smuzhiyun compatible = "fsl,ecm-law"; 166*4882a593Smuzhiyun reg = <0x0 0x1000>; 167*4882a593Smuzhiyun fsl,num-laws = <12>; 168*4882a593Smuzhiyun }; 169*4882a593Smuzhiyun 170*4882a593Smuzhiyun ecm@1000 { 171*4882a593Smuzhiyun compatible = "fsl,mpc8572-ecm", "fsl,ecm"; 172*4882a593Smuzhiyun reg = <0x1000 0x1000>; 173*4882a593Smuzhiyun interrupts = <17 2>; 174*4882a593Smuzhiyun interrupt-parent = <&mpic>; 175*4882a593Smuzhiyun }; 176*4882a593Smuzhiyun 177*4882a593Smuzhiyun memory-controller@2000 { 178*4882a593Smuzhiyun compatible = "fsl,mpc8572-memory-controller"; 179*4882a593Smuzhiyun reg = <0x2000 0x1000>; 180*4882a593Smuzhiyun interrupt-parent = <&mpic>; 181*4882a593Smuzhiyun interrupts = <18 2>; 182*4882a593Smuzhiyun }; 183*4882a593Smuzhiyun 184*4882a593Smuzhiyun memory-controller@6000 { 185*4882a593Smuzhiyun compatible = "fsl,mpc8572-memory-controller"; 186*4882a593Smuzhiyun reg = <0x6000 0x1000>; 187*4882a593Smuzhiyun interrupt-parent = <&mpic>; 188*4882a593Smuzhiyun interrupts = <18 2>; 189*4882a593Smuzhiyun }; 190*4882a593Smuzhiyun 191*4882a593Smuzhiyun L2: l2-cache-controller@20000 { 192*4882a593Smuzhiyun compatible = "fsl,mpc8572-l2-cache-controller"; 193*4882a593Smuzhiyun reg = <0x20000 0x1000>; 194*4882a593Smuzhiyun cache-line-size = <32>; // 32 bytes 195*4882a593Smuzhiyun cache-size = <0x100000>; // L2, 1M 196*4882a593Smuzhiyun interrupt-parent = <&mpic>; 197*4882a593Smuzhiyun interrupts = <16 2>; 198*4882a593Smuzhiyun }; 199*4882a593Smuzhiyun 200*4882a593Smuzhiyun i2c@3000 { 201*4882a593Smuzhiyun #address-cells = <1>; 202*4882a593Smuzhiyun #size-cells = <0>; 203*4882a593Smuzhiyun cell-index = <0>; 204*4882a593Smuzhiyun compatible = "fsl-i2c"; 205*4882a593Smuzhiyun reg = <0x3000 0x100>; 206*4882a593Smuzhiyun interrupts = <43 2>; 207*4882a593Smuzhiyun interrupt-parent = <&mpic>; 208*4882a593Smuzhiyun dfsrr; 209*4882a593Smuzhiyun 210*4882a593Smuzhiyun temp-sensor@48 { 211*4882a593Smuzhiyun compatible = "dallas,ds1631", "dallas,ds1621"; 212*4882a593Smuzhiyun reg = <0x48>; 213*4882a593Smuzhiyun }; 214*4882a593Smuzhiyun 215*4882a593Smuzhiyun temp-sensor@4c { 216*4882a593Smuzhiyun compatible = "adi,adt7461"; 217*4882a593Smuzhiyun reg = <0x4c>; 218*4882a593Smuzhiyun }; 219*4882a593Smuzhiyun 220*4882a593Smuzhiyun cpu-supervisor@51 { 221*4882a593Smuzhiyun compatible = "dallas,ds4510"; 222*4882a593Smuzhiyun reg = <0x51>; 223*4882a593Smuzhiyun }; 224*4882a593Smuzhiyun 225*4882a593Smuzhiyun eeprom@54 { 226*4882a593Smuzhiyun compatible = "atmel,at24c128b"; 227*4882a593Smuzhiyun reg = <0x54>; 228*4882a593Smuzhiyun }; 229*4882a593Smuzhiyun 230*4882a593Smuzhiyun rtc@68 { 231*4882a593Smuzhiyun compatible = "st,m41t00", 232*4882a593Smuzhiyun "dallas,ds1338"; 233*4882a593Smuzhiyun reg = <0x68>; 234*4882a593Smuzhiyun }; 235*4882a593Smuzhiyun 236*4882a593Smuzhiyun pcie-switch@70 { 237*4882a593Smuzhiyun compatible = "plx,pex8518"; 238*4882a593Smuzhiyun reg = <0x70>; 239*4882a593Smuzhiyun }; 240*4882a593Smuzhiyun 241*4882a593Smuzhiyun gpio1: gpio@18 { 242*4882a593Smuzhiyun compatible = "nxp,pca9557"; 243*4882a593Smuzhiyun reg = <0x18>; 244*4882a593Smuzhiyun #gpio-cells = <2>; 245*4882a593Smuzhiyun gpio-controller; 246*4882a593Smuzhiyun polarity = <0x00>; 247*4882a593Smuzhiyun }; 248*4882a593Smuzhiyun 249*4882a593Smuzhiyun gpio2: gpio@1c { 250*4882a593Smuzhiyun compatible = "nxp,pca9557"; 251*4882a593Smuzhiyun reg = <0x1c>; 252*4882a593Smuzhiyun #gpio-cells = <2>; 253*4882a593Smuzhiyun gpio-controller; 254*4882a593Smuzhiyun polarity = <0x00>; 255*4882a593Smuzhiyun }; 256*4882a593Smuzhiyun 257*4882a593Smuzhiyun gpio3: gpio@1e { 258*4882a593Smuzhiyun compatible = "nxp,pca9557"; 259*4882a593Smuzhiyun reg = <0x1e>; 260*4882a593Smuzhiyun #gpio-cells = <2>; 261*4882a593Smuzhiyun gpio-controller; 262*4882a593Smuzhiyun polarity = <0x00>; 263*4882a593Smuzhiyun }; 264*4882a593Smuzhiyun 265*4882a593Smuzhiyun gpio4: gpio@1f { 266*4882a593Smuzhiyun compatible = "nxp,pca9557"; 267*4882a593Smuzhiyun reg = <0x1f>; 268*4882a593Smuzhiyun #gpio-cells = <2>; 269*4882a593Smuzhiyun gpio-controller; 270*4882a593Smuzhiyun polarity = <0x00>; 271*4882a593Smuzhiyun }; 272*4882a593Smuzhiyun }; 273*4882a593Smuzhiyun 274*4882a593Smuzhiyun i2c@3100 { 275*4882a593Smuzhiyun #address-cells = <1>; 276*4882a593Smuzhiyun #size-cells = <0>; 277*4882a593Smuzhiyun cell-index = <1>; 278*4882a593Smuzhiyun compatible = "fsl-i2c"; 279*4882a593Smuzhiyun reg = <0x3100 0x100>; 280*4882a593Smuzhiyun interrupts = <43 2>; 281*4882a593Smuzhiyun interrupt-parent = <&mpic>; 282*4882a593Smuzhiyun dfsrr; 283*4882a593Smuzhiyun }; 284*4882a593Smuzhiyun 285*4882a593Smuzhiyun dma@c300 { 286*4882a593Smuzhiyun #address-cells = <1>; 287*4882a593Smuzhiyun #size-cells = <1>; 288*4882a593Smuzhiyun compatible = "fsl,mpc8572-dma", "fsl,eloplus-dma"; 289*4882a593Smuzhiyun reg = <0xc300 0x4>; 290*4882a593Smuzhiyun ranges = <0x0 0xc100 0x200>; 291*4882a593Smuzhiyun cell-index = <1>; 292*4882a593Smuzhiyun dma-channel@0 { 293*4882a593Smuzhiyun compatible = "fsl,mpc8572-dma-channel", 294*4882a593Smuzhiyun "fsl,eloplus-dma-channel"; 295*4882a593Smuzhiyun reg = <0x0 0x80>; 296*4882a593Smuzhiyun cell-index = <0>; 297*4882a593Smuzhiyun interrupt-parent = <&mpic>; 298*4882a593Smuzhiyun interrupts = <76 2>; 299*4882a593Smuzhiyun }; 300*4882a593Smuzhiyun dma-channel@80 { 301*4882a593Smuzhiyun compatible = "fsl,mpc8572-dma-channel", 302*4882a593Smuzhiyun "fsl,eloplus-dma-channel"; 303*4882a593Smuzhiyun reg = <0x80 0x80>; 304*4882a593Smuzhiyun cell-index = <1>; 305*4882a593Smuzhiyun interrupt-parent = <&mpic>; 306*4882a593Smuzhiyun interrupts = <77 2>; 307*4882a593Smuzhiyun }; 308*4882a593Smuzhiyun dma-channel@100 { 309*4882a593Smuzhiyun compatible = "fsl,mpc8572-dma-channel", 310*4882a593Smuzhiyun "fsl,eloplus-dma-channel"; 311*4882a593Smuzhiyun reg = <0x100 0x80>; 312*4882a593Smuzhiyun cell-index = <2>; 313*4882a593Smuzhiyun interrupt-parent = <&mpic>; 314*4882a593Smuzhiyun interrupts = <78 2>; 315*4882a593Smuzhiyun }; 316*4882a593Smuzhiyun dma-channel@180 { 317*4882a593Smuzhiyun compatible = "fsl,mpc8572-dma-channel", 318*4882a593Smuzhiyun "fsl,eloplus-dma-channel"; 319*4882a593Smuzhiyun reg = <0x180 0x80>; 320*4882a593Smuzhiyun cell-index = <3>; 321*4882a593Smuzhiyun interrupt-parent = <&mpic>; 322*4882a593Smuzhiyun interrupts = <79 2>; 323*4882a593Smuzhiyun }; 324*4882a593Smuzhiyun }; 325*4882a593Smuzhiyun 326*4882a593Smuzhiyun dma@21300 { 327*4882a593Smuzhiyun #address-cells = <1>; 328*4882a593Smuzhiyun #size-cells = <1>; 329*4882a593Smuzhiyun compatible = "fsl,mpc8572-dma", "fsl,eloplus-dma"; 330*4882a593Smuzhiyun reg = <0x21300 0x4>; 331*4882a593Smuzhiyun ranges = <0x0 0x21100 0x200>; 332*4882a593Smuzhiyun cell-index = <0>; 333*4882a593Smuzhiyun dma-channel@0 { 334*4882a593Smuzhiyun compatible = "fsl,mpc8572-dma-channel", 335*4882a593Smuzhiyun "fsl,eloplus-dma-channel"; 336*4882a593Smuzhiyun reg = <0x0 0x80>; 337*4882a593Smuzhiyun cell-index = <0>; 338*4882a593Smuzhiyun interrupt-parent = <&mpic>; 339*4882a593Smuzhiyun interrupts = <20 2>; 340*4882a593Smuzhiyun }; 341*4882a593Smuzhiyun dma-channel@80 { 342*4882a593Smuzhiyun compatible = "fsl,mpc8572-dma-channel", 343*4882a593Smuzhiyun "fsl,eloplus-dma-channel"; 344*4882a593Smuzhiyun reg = <0x80 0x80>; 345*4882a593Smuzhiyun cell-index = <1>; 346*4882a593Smuzhiyun interrupt-parent = <&mpic>; 347*4882a593Smuzhiyun interrupts = <21 2>; 348*4882a593Smuzhiyun }; 349*4882a593Smuzhiyun dma-channel@100 { 350*4882a593Smuzhiyun compatible = "fsl,mpc8572-dma-channel", 351*4882a593Smuzhiyun "fsl,eloplus-dma-channel"; 352*4882a593Smuzhiyun reg = <0x100 0x80>; 353*4882a593Smuzhiyun cell-index = <2>; 354*4882a593Smuzhiyun interrupt-parent = <&mpic>; 355*4882a593Smuzhiyun interrupts = <22 2>; 356*4882a593Smuzhiyun }; 357*4882a593Smuzhiyun dma-channel@180 { 358*4882a593Smuzhiyun compatible = "fsl,mpc8572-dma-channel", 359*4882a593Smuzhiyun "fsl,eloplus-dma-channel"; 360*4882a593Smuzhiyun reg = <0x180 0x80>; 361*4882a593Smuzhiyun cell-index = <3>; 362*4882a593Smuzhiyun interrupt-parent = <&mpic>; 363*4882a593Smuzhiyun interrupts = <23 2>; 364*4882a593Smuzhiyun }; 365*4882a593Smuzhiyun }; 366*4882a593Smuzhiyun 367*4882a593Smuzhiyun /* eTSEC 1 */ 368*4882a593Smuzhiyun enet0: ethernet@24000 { 369*4882a593Smuzhiyun #address-cells = <1>; 370*4882a593Smuzhiyun #size-cells = <1>; 371*4882a593Smuzhiyun cell-index = <0>; 372*4882a593Smuzhiyun device_type = "network"; 373*4882a593Smuzhiyun model = "eTSEC"; 374*4882a593Smuzhiyun compatible = "gianfar"; 375*4882a593Smuzhiyun reg = <0x24000 0x1000>; 376*4882a593Smuzhiyun ranges = <0x0 0x24000 0x1000>; 377*4882a593Smuzhiyun local-mac-address = [ 00 00 00 00 00 00 ]; 378*4882a593Smuzhiyun interrupts = <29 2 30 2 34 2>; 379*4882a593Smuzhiyun interrupt-parent = <&mpic>; 380*4882a593Smuzhiyun tbi-handle = <&tbi0>; 381*4882a593Smuzhiyun phy-handle = <&phy0>; 382*4882a593Smuzhiyun phy-connection-type = "sgmii"; 383*4882a593Smuzhiyun 384*4882a593Smuzhiyun mdio@520 { 385*4882a593Smuzhiyun #address-cells = <1>; 386*4882a593Smuzhiyun #size-cells = <0>; 387*4882a593Smuzhiyun compatible = "fsl,gianfar-mdio"; 388*4882a593Smuzhiyun reg = <0x520 0x20>; 389*4882a593Smuzhiyun 390*4882a593Smuzhiyun phy0: ethernet-phy@1 { 391*4882a593Smuzhiyun interrupt-parent = <&mpic>; 392*4882a593Smuzhiyun interrupts = <8 1>; 393*4882a593Smuzhiyun reg = <0x1>; 394*4882a593Smuzhiyun }; 395*4882a593Smuzhiyun phy1: ethernet-phy@2 { 396*4882a593Smuzhiyun interrupt-parent = <&mpic>; 397*4882a593Smuzhiyun interrupts = <8 1>; 398*4882a593Smuzhiyun reg = <0x2>; 399*4882a593Smuzhiyun }; 400*4882a593Smuzhiyun tbi0: tbi-phy@11 { 401*4882a593Smuzhiyun reg = <0x11>; 402*4882a593Smuzhiyun device_type = "tbi-phy"; 403*4882a593Smuzhiyun }; 404*4882a593Smuzhiyun }; 405*4882a593Smuzhiyun }; 406*4882a593Smuzhiyun 407*4882a593Smuzhiyun /* eTSEC 2 */ 408*4882a593Smuzhiyun enet1: ethernet@25000 { 409*4882a593Smuzhiyun #address-cells = <1>; 410*4882a593Smuzhiyun #size-cells = <1>; 411*4882a593Smuzhiyun cell-index = <1>; 412*4882a593Smuzhiyun device_type = "network"; 413*4882a593Smuzhiyun model = "eTSEC"; 414*4882a593Smuzhiyun compatible = "gianfar"; 415*4882a593Smuzhiyun reg = <0x25000 0x1000>; 416*4882a593Smuzhiyun ranges = <0x0 0x25000 0x1000>; 417*4882a593Smuzhiyun local-mac-address = [ 00 00 00 00 00 00 ]; 418*4882a593Smuzhiyun interrupts = <35 2 36 2 40 2>; 419*4882a593Smuzhiyun interrupt-parent = <&mpic>; 420*4882a593Smuzhiyun tbi-handle = <&tbi1>; 421*4882a593Smuzhiyun phy-handle = <&phy1>; 422*4882a593Smuzhiyun phy-connection-type = "sgmii"; 423*4882a593Smuzhiyun 424*4882a593Smuzhiyun mdio@520 { 425*4882a593Smuzhiyun #address-cells = <1>; 426*4882a593Smuzhiyun #size-cells = <0>; 427*4882a593Smuzhiyun compatible = "fsl,gianfar-tbi"; 428*4882a593Smuzhiyun reg = <0x520 0x20>; 429*4882a593Smuzhiyun 430*4882a593Smuzhiyun tbi1: tbi-phy@11 { 431*4882a593Smuzhiyun reg = <0x11>; 432*4882a593Smuzhiyun device_type = "tbi-phy"; 433*4882a593Smuzhiyun }; 434*4882a593Smuzhiyun }; 435*4882a593Smuzhiyun }; 436*4882a593Smuzhiyun 437*4882a593Smuzhiyun /* UART0 */ 438*4882a593Smuzhiyun serial0: serial@4500 { 439*4882a593Smuzhiyun cell-index = <0>; 440*4882a593Smuzhiyun device_type = "serial"; 441*4882a593Smuzhiyun compatible = "fsl,ns16550", "ns16550"; 442*4882a593Smuzhiyun reg = <0x4500 0x100>; 443*4882a593Smuzhiyun clock-frequency = <0>; 444*4882a593Smuzhiyun interrupts = <42 2>; 445*4882a593Smuzhiyun interrupt-parent = <&mpic>; 446*4882a593Smuzhiyun }; 447*4882a593Smuzhiyun 448*4882a593Smuzhiyun /* UART1 */ 449*4882a593Smuzhiyun serial1: serial@4600 { 450*4882a593Smuzhiyun cell-index = <1>; 451*4882a593Smuzhiyun device_type = "serial"; 452*4882a593Smuzhiyun compatible = "fsl,ns16550", "ns16550"; 453*4882a593Smuzhiyun reg = <0x4600 0x100>; 454*4882a593Smuzhiyun clock-frequency = <0>; 455*4882a593Smuzhiyun interrupts = <42 2>; 456*4882a593Smuzhiyun interrupt-parent = <&mpic>; 457*4882a593Smuzhiyun }; 458*4882a593Smuzhiyun 459*4882a593Smuzhiyun global-utilities@e0000 { //global utilities block 460*4882a593Smuzhiyun compatible = "fsl,mpc8572-guts"; 461*4882a593Smuzhiyun reg = <0xe0000 0x1000>; 462*4882a593Smuzhiyun fsl,has-rstcr; 463*4882a593Smuzhiyun }; 464*4882a593Smuzhiyun 465*4882a593Smuzhiyun msi@41600 { 466*4882a593Smuzhiyun compatible = "fsl,mpc8572-msi", "fsl,mpic-msi"; 467*4882a593Smuzhiyun reg = <0x41600 0x80>; 468*4882a593Smuzhiyun msi-available-ranges = <0 0x100>; 469*4882a593Smuzhiyun interrupts = < 470*4882a593Smuzhiyun 0xe0 0 471*4882a593Smuzhiyun 0xe1 0 472*4882a593Smuzhiyun 0xe2 0 473*4882a593Smuzhiyun 0xe3 0 474*4882a593Smuzhiyun 0xe4 0 475*4882a593Smuzhiyun 0xe5 0 476*4882a593Smuzhiyun 0xe6 0 477*4882a593Smuzhiyun 0xe7 0>; 478*4882a593Smuzhiyun interrupt-parent = <&mpic>; 479*4882a593Smuzhiyun }; 480*4882a593Smuzhiyun 481*4882a593Smuzhiyun crypto@30000 { 482*4882a593Smuzhiyun compatible = "fsl,sec3.0", "fsl,sec2.4", "fsl,sec2.2", 483*4882a593Smuzhiyun "fsl,sec2.1", "fsl,sec2.0"; 484*4882a593Smuzhiyun reg = <0x30000 0x10000>; 485*4882a593Smuzhiyun interrupts = <45 2 58 2>; 486*4882a593Smuzhiyun interrupt-parent = <&mpic>; 487*4882a593Smuzhiyun fsl,num-channels = <4>; 488*4882a593Smuzhiyun fsl,channel-fifo-len = <24>; 489*4882a593Smuzhiyun fsl,exec-units-mask = <0x9fe>; 490*4882a593Smuzhiyun fsl,descriptor-types-mask = <0x3ab0ebf>; 491*4882a593Smuzhiyun }; 492*4882a593Smuzhiyun 493*4882a593Smuzhiyun mpic: pic@40000 { 494*4882a593Smuzhiyun interrupt-controller; 495*4882a593Smuzhiyun #address-cells = <0>; 496*4882a593Smuzhiyun #interrupt-cells = <2>; 497*4882a593Smuzhiyun reg = <0x40000 0x40000>; 498*4882a593Smuzhiyun compatible = "chrp,open-pic"; 499*4882a593Smuzhiyun device_type = "open-pic"; 500*4882a593Smuzhiyun }; 501*4882a593Smuzhiyun 502*4882a593Smuzhiyun gpio0: gpio@f000 { 503*4882a593Smuzhiyun compatible = "fsl,mpc8572-gpio"; 504*4882a593Smuzhiyun reg = <0xf000 0x1000>; 505*4882a593Smuzhiyun interrupts = <47 2>; 506*4882a593Smuzhiyun interrupt-parent = <&mpic>; 507*4882a593Smuzhiyun #gpio-cells = <2>; 508*4882a593Smuzhiyun gpio-controller; 509*4882a593Smuzhiyun }; 510*4882a593Smuzhiyun 511*4882a593Smuzhiyun gpio-leds { 512*4882a593Smuzhiyun compatible = "gpio-leds"; 513*4882a593Smuzhiyun 514*4882a593Smuzhiyun heartbeat { 515*4882a593Smuzhiyun label = "Heartbeat"; 516*4882a593Smuzhiyun gpios = <&gpio0 4 1>; 517*4882a593Smuzhiyun linux,default-trigger = "heartbeat"; 518*4882a593Smuzhiyun }; 519*4882a593Smuzhiyun 520*4882a593Smuzhiyun yellow { 521*4882a593Smuzhiyun label = "Yellow"; 522*4882a593Smuzhiyun gpios = <&gpio0 5 1>; 523*4882a593Smuzhiyun }; 524*4882a593Smuzhiyun 525*4882a593Smuzhiyun red { 526*4882a593Smuzhiyun label = "Red"; 527*4882a593Smuzhiyun gpios = <&gpio0 6 1>; 528*4882a593Smuzhiyun }; 529*4882a593Smuzhiyun 530*4882a593Smuzhiyun green { 531*4882a593Smuzhiyun label = "Green"; 532*4882a593Smuzhiyun gpios = <&gpio0 7 1>; 533*4882a593Smuzhiyun }; 534*4882a593Smuzhiyun }; 535*4882a593Smuzhiyun 536*4882a593Smuzhiyun /* PME (pattern-matcher) */ 537*4882a593Smuzhiyun pme@10000 { 538*4882a593Smuzhiyun compatible = "fsl,mpc8572-pme", "pme8572"; 539*4882a593Smuzhiyun reg = <0x10000 0x5000>; 540*4882a593Smuzhiyun interrupts = <57 2 64 2 65 2 66 2 67 2>; 541*4882a593Smuzhiyun interrupt-parent = <&mpic>; 542*4882a593Smuzhiyun }; 543*4882a593Smuzhiyun 544*4882a593Smuzhiyun tlu@2f000 { 545*4882a593Smuzhiyun compatible = "fsl,mpc8572-tlu", "fsl_tlu"; 546*4882a593Smuzhiyun reg = <0x2f000 0x1000>; 547*4882a593Smuzhiyun interrupts = <61 2>; 548*4882a593Smuzhiyun interrupt-parent = <&mpic>; 549*4882a593Smuzhiyun }; 550*4882a593Smuzhiyun 551*4882a593Smuzhiyun tlu@15000 { 552*4882a593Smuzhiyun compatible = "fsl,mpc8572-tlu", "fsl_tlu"; 553*4882a593Smuzhiyun reg = <0x15000 0x1000>; 554*4882a593Smuzhiyun interrupts = <75 2>; 555*4882a593Smuzhiyun interrupt-parent = <&mpic>; 556*4882a593Smuzhiyun }; 557*4882a593Smuzhiyun }; 558*4882a593Smuzhiyun 559*4882a593Smuzhiyun /* 560*4882a593Smuzhiyun * PCI Express controller 3 @ ef008000 is not used. 561*4882a593Smuzhiyun * This would have been pci0 on other mpc85xx platforms. 562*4882a593Smuzhiyun */ 563*4882a593Smuzhiyun 564*4882a593Smuzhiyun /* PCI Express controller 2, wired to XMC P15 connector */ 565*4882a593Smuzhiyun pci1: pcie@ef009000 { 566*4882a593Smuzhiyun compatible = "fsl,mpc8548-pcie"; 567*4882a593Smuzhiyun device_type = "pci"; 568*4882a593Smuzhiyun #interrupt-cells = <1>; 569*4882a593Smuzhiyun #size-cells = <2>; 570*4882a593Smuzhiyun #address-cells = <3>; 571*4882a593Smuzhiyun reg = <0 0xef009000 0 0x1000>; 572*4882a593Smuzhiyun bus-range = <0 255>; 573*4882a593Smuzhiyun ranges = <0x2000000 0x0 0xc0000000 0 0xc0000000 0x0 0x10000000 574*4882a593Smuzhiyun 0x1000000 0x0 0x00000000 0 0xe8800000 0x0 0x00010000>; 575*4882a593Smuzhiyun clock-frequency = <33333333>; 576*4882a593Smuzhiyun interrupt-parent = <&mpic>; 577*4882a593Smuzhiyun interrupts = <25 2>; 578*4882a593Smuzhiyun interrupt-map-mask = <0xf800 0x0 0x0 0x7>; 579*4882a593Smuzhiyun interrupt-map = < 580*4882a593Smuzhiyun /* IDSEL 0x0 */ 581*4882a593Smuzhiyun 0x0 0x0 0x0 0x1 &mpic 0x4 0x1 582*4882a593Smuzhiyun 0x0 0x0 0x0 0x2 &mpic 0x5 0x1 583*4882a593Smuzhiyun 0x0 0x0 0x0 0x3 &mpic 0x6 0x1 584*4882a593Smuzhiyun 0x0 0x0 0x0 0x4 &mpic 0x7 0x1 585*4882a593Smuzhiyun >; 586*4882a593Smuzhiyun pcie@0 { 587*4882a593Smuzhiyun reg = <0x00000000 0x00000000 0x00000000 0x00000000 0x00000000>; 588*4882a593Smuzhiyun #size-cells = <2>; 589*4882a593Smuzhiyun #address-cells = <3>; 590*4882a593Smuzhiyun device_type = "pci"; 591*4882a593Smuzhiyun ranges = <0x2000000 0x0 0xc0000000 592*4882a593Smuzhiyun 0x2000000 0x0 0xc0000000 593*4882a593Smuzhiyun 0x0 0x10000000 594*4882a593Smuzhiyun 595*4882a593Smuzhiyun 0x1000000 0x0 0x0 596*4882a593Smuzhiyun 0x1000000 0x0 0x0 597*4882a593Smuzhiyun 0x0 0x100000>; 598*4882a593Smuzhiyun }; 599*4882a593Smuzhiyun }; 600*4882a593Smuzhiyun 601*4882a593Smuzhiyun /* PCI Express controller 1, wired to PEX8112 for PMC interface */ 602*4882a593Smuzhiyun pci2: pcie@ef00a000 { 603*4882a593Smuzhiyun compatible = "fsl,mpc8548-pcie"; 604*4882a593Smuzhiyun device_type = "pci"; 605*4882a593Smuzhiyun #interrupt-cells = <1>; 606*4882a593Smuzhiyun #size-cells = <2>; 607*4882a593Smuzhiyun #address-cells = <3>; 608*4882a593Smuzhiyun reg = <0 0xef00a000 0 0x1000>; 609*4882a593Smuzhiyun bus-range = <0 255>; 610*4882a593Smuzhiyun ranges = <0x2000000 0x0 0x80000000 0 0x80000000 0x0 0x40000000 611*4882a593Smuzhiyun 0x1000000 0x0 0x00000000 0 0xe8000000 0x0 0x10000>; 612*4882a593Smuzhiyun clock-frequency = <33333333>; 613*4882a593Smuzhiyun interrupt-parent = <&mpic>; 614*4882a593Smuzhiyun interrupts = <26 2>; 615*4882a593Smuzhiyun interrupt-map-mask = <0xf800 0x0 0x0 0x7>; 616*4882a593Smuzhiyun interrupt-map = < 617*4882a593Smuzhiyun /* IDSEL 0x0 */ 618*4882a593Smuzhiyun 0x0 0x0 0x0 0x1 &mpic 0x0 0x1 619*4882a593Smuzhiyun 0x0 0x0 0x0 0x2 &mpic 0x1 0x1 620*4882a593Smuzhiyun 0x0 0x0 0x0 0x3 &mpic 0x2 0x1 621*4882a593Smuzhiyun 0x0 0x0 0x0 0x4 &mpic 0x3 0x1 622*4882a593Smuzhiyun >; 623*4882a593Smuzhiyun pcie@0 { 624*4882a593Smuzhiyun reg = <0x0 0x0 0x0 0x0 0x0>; 625*4882a593Smuzhiyun #size-cells = <2>; 626*4882a593Smuzhiyun #address-cells = <3>; 627*4882a593Smuzhiyun device_type = "pci"; 628*4882a593Smuzhiyun ranges = <0x2000000 0x0 0x80000000 629*4882a593Smuzhiyun 0x2000000 0x0 0x80000000 630*4882a593Smuzhiyun 0x0 0x40000000 631*4882a593Smuzhiyun 632*4882a593Smuzhiyun 0x1000000 0x0 0x0 633*4882a593Smuzhiyun 0x1000000 0x0 0x0 634*4882a593Smuzhiyun 0x0 0x100000>; 635*4882a593Smuzhiyun }; 636*4882a593Smuzhiyun }; 637*4882a593Smuzhiyun}; 638