blob: 64f83d0fb5aa5b064ddcf227bf192e62f2c1239f [file] [log] [blame]
Andy Fleming2654d632006-08-18 18:04:34 -05001/*
Roy Zang02edff52007-07-10 18:46:47 +08002 * MPC8548 CDS Device Tree Source
Andy Fleming2654d632006-08-18 18:04:34 -05003 *
4 * Copyright 2006 Freescale Semiconductor Inc.
5 *
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2 of the License, or (at your
9 * option) any later version.
10 */
11
12
13/ {
14 model = "MPC8548CDS";
Kumar Gala52094872007-02-17 16:04:23 -060015 compatible = "MPC8548CDS", "MPC85xxCDS";
Andy Fleming2654d632006-08-18 18:04:34 -050016 #address-cells = <1>;
17 #size-cells = <1>;
Andy Fleming2654d632006-08-18 18:04:34 -050018
19 cpus {
Andy Fleming2654d632006-08-18 18:04:34 -050020 #address-cells = <1>;
21 #size-cells = <0>;
Andy Fleming2654d632006-08-18 18:04:34 -050022
23 PowerPC,8548@0 {
24 device_type = "cpu";
25 reg = <0>;
26 d-cache-line-size = <20>; // 32 bytes
27 i-cache-line-size = <20>; // 32 bytes
28 d-cache-size = <8000>; // L1, 32K
29 i-cache-size = <8000>; // L1, 32K
30 timebase-frequency = <0>; // 33 MHz, from uboot
31 bus-frequency = <0>; // 166 MHz
32 clock-frequency = <0>; // 825 MHz, from uboot
Andy Fleming2654d632006-08-18 18:04:34 -050033 };
34 };
35
36 memory {
37 device_type = "memory";
Andy Fleming2654d632006-08-18 18:04:34 -050038 reg = <00000000 08000000>; // 128M at 0x0
39 };
40
41 soc8548@e0000000 {
42 #address-cells = <1>;
43 #size-cells = <1>;
Andy Fleming2654d632006-08-18 18:04:34 -050044 device_type = "soc";
Kumar Gala1b3c5cd2007-09-12 18:23:46 -050045 ranges = <00000000 e0000000 00100000>;
Randy Vinson6af01252007-07-17 16:37:12 -070046 reg = <e0000000 00001000>; // CCSRBAR
Andy Fleming2654d632006-08-18 18:04:34 -050047 bus-frequency = <0>;
48
Dave Jiang50cf6702007-05-10 10:03:05 -070049 memory-controller@2000 {
50 compatible = "fsl,8548-memory-controller";
51 reg = <2000 1000>;
52 interrupt-parent = <&mpic>;
Kumar Galab533f8a2007-07-03 02:35:35 -050053 interrupts = <12 2>;
Dave Jiang50cf6702007-05-10 10:03:05 -070054 };
55
56 l2-cache-controller@20000 {
57 compatible = "fsl,8548-l2-cache-controller";
58 reg = <20000 1000>;
59 cache-line-size = <20>; // 32 bytes
60 cache-size = <80000>; // L2, 512K
61 interrupt-parent = <&mpic>;
Kumar Galab533f8a2007-07-03 02:35:35 -050062 interrupts = <10 2>;
Dave Jiang50cf6702007-05-10 10:03:05 -070063 };
64
Andy Fleming2654d632006-08-18 18:04:34 -050065 i2c@3000 {
Kumar Galaec9686c2007-12-11 23:17:24 -060066 #address-cells = <1>;
67 #size-cells = <0>;
68 cell-index = <0>;
Andy Fleming2654d632006-08-18 18:04:34 -050069 compatible = "fsl-i2c";
70 reg = <3000 100>;
Kumar Galab533f8a2007-07-03 02:35:35 -050071 interrupts = <2b 2>;
Kumar Gala52094872007-02-17 16:04:23 -060072 interrupt-parent = <&mpic>;
Andy Fleming2654d632006-08-18 18:04:34 -050073 dfsrr;
74 };
75
Kumar Galaec9686c2007-12-11 23:17:24 -060076 i2c@3100 {
77 #address-cells = <1>;
78 #size-cells = <0>;
79 cell-index = <1>;
80 compatible = "fsl-i2c";
81 reg = <3100 100>;
82 interrupts = <2b 2>;
83 interrupt-parent = <&mpic>;
84 dfsrr;
85 };
86
Andy Fleming2654d632006-08-18 18:04:34 -050087 mdio@24520 {
88 #address-cells = <1>;
89 #size-cells = <0>;
Kumar Galae77b28e2007-12-12 00:28:35 -060090 compatible = "fsl,gianfar-mdio";
Andy Fleming2654d632006-08-18 18:04:34 -050091 reg = <24520 20>;
Kumar Galae77b28e2007-12-12 00:28:35 -060092
Kumar Gala52094872007-02-17 16:04:23 -060093 phy0: ethernet-phy@0 {
94 interrupt-parent = <&mpic>;
Kumar Gala58fe2552007-07-03 03:05:58 -050095 interrupts = <5 1>;
Andy Fleming2654d632006-08-18 18:04:34 -050096 reg = <0>;
97 device_type = "ethernet-phy";
98 };
Kumar Gala52094872007-02-17 16:04:23 -060099 phy1: ethernet-phy@1 {
100 interrupt-parent = <&mpic>;
Kumar Gala58fe2552007-07-03 03:05:58 -0500101 interrupts = <5 1>;
Andy Fleming2654d632006-08-18 18:04:34 -0500102 reg = <1>;
103 device_type = "ethernet-phy";
104 };
Kumar Gala52094872007-02-17 16:04:23 -0600105 phy2: ethernet-phy@2 {
106 interrupt-parent = <&mpic>;
Kumar Gala58fe2552007-07-03 03:05:58 -0500107 interrupts = <5 1>;
Andy Fleming2654d632006-08-18 18:04:34 -0500108 reg = <2>;
109 device_type = "ethernet-phy";
110 };
Kumar Gala52094872007-02-17 16:04:23 -0600111 phy3: ethernet-phy@3 {
112 interrupt-parent = <&mpic>;
Kumar Gala58fe2552007-07-03 03:05:58 -0500113 interrupts = <5 1>;
Andy Fleming2654d632006-08-18 18:04:34 -0500114 reg = <3>;
115 device_type = "ethernet-phy";
116 };
117 };
118
Kumar Galae77b28e2007-12-12 00:28:35 -0600119 enet0: ethernet@24000 {
120 cell-index = <0>;
Andy Fleming2654d632006-08-18 18:04:34 -0500121 device_type = "network";
122 model = "eTSEC";
123 compatible = "gianfar";
124 reg = <24000 1000>;
Timur Tabieae98262007-06-22 14:33:15 -0500125 local-mac-address = [ 00 00 00 00 00 00 ];
Kumar Galab533f8a2007-07-03 02:35:35 -0500126 interrupts = <1d 2 1e 2 22 2>;
Kumar Gala52094872007-02-17 16:04:23 -0600127 interrupt-parent = <&mpic>;
128 phy-handle = <&phy0>;
Andy Fleming2654d632006-08-18 18:04:34 -0500129 };
130
Kumar Galae77b28e2007-12-12 00:28:35 -0600131 enet1: ethernet@25000 {
132 cell-index = <1>;
Andy Fleming2654d632006-08-18 18:04:34 -0500133 device_type = "network";
134 model = "eTSEC";
135 compatible = "gianfar";
136 reg = <25000 1000>;
Timur Tabieae98262007-06-22 14:33:15 -0500137 local-mac-address = [ 00 00 00 00 00 00 ];
Kumar Galab533f8a2007-07-03 02:35:35 -0500138 interrupts = <23 2 24 2 28 2>;
Kumar Gala52094872007-02-17 16:04:23 -0600139 interrupt-parent = <&mpic>;
140 phy-handle = <&phy1>;
Andy Fleming2654d632006-08-18 18:04:34 -0500141 };
142
Kumar Gala52094872007-02-17 16:04:23 -0600143/* eTSEC 3/4 are currently broken
Kumar Galae77b28e2007-12-12 00:28:35 -0600144 enet2: ethernet@26000 {
145 cell-index = <2>;
Andy Fleming2654d632006-08-18 18:04:34 -0500146 device_type = "network";
147 model = "eTSEC";
148 compatible = "gianfar";
149 reg = <26000 1000>;
Timur Tabieae98262007-06-22 14:33:15 -0500150 local-mac-address = [ 00 00 00 00 00 00 ];
Kumar Galab533f8a2007-07-03 02:35:35 -0500151 interrupts = <1f 2 20 2 21 2>;
Kumar Gala52094872007-02-17 16:04:23 -0600152 interrupt-parent = <&mpic>;
153 phy-handle = <&phy2>;
Andy Fleming2654d632006-08-18 18:04:34 -0500154 };
155
Kumar Galae77b28e2007-12-12 00:28:35 -0600156 enet3: ethernet@27000 {
157 cell-index = <3>;
Andy Fleming2654d632006-08-18 18:04:34 -0500158 device_type = "network";
159 model = "eTSEC";
160 compatible = "gianfar";
161 reg = <27000 1000>;
Timur Tabieae98262007-06-22 14:33:15 -0500162 local-mac-address = [ 00 00 00 00 00 00 ];
Kumar Galab533f8a2007-07-03 02:35:35 -0500163 interrupts = <25 2 26 2 27 2>;
Kumar Gala52094872007-02-17 16:04:23 -0600164 interrupt-parent = <&mpic>;
165 phy-handle = <&phy3>;
Andy Fleming2654d632006-08-18 18:04:34 -0500166 };
167 */
168
169 serial@4500 {
170 device_type = "serial";
171 compatible = "ns16550";
Randy Vinson6af01252007-07-17 16:37:12 -0700172 reg = <4500 100>; // reg base, size
173 clock-frequency = <0>; // should we fill in in uboot?
Kumar Galab533f8a2007-07-03 02:35:35 -0500174 interrupts = <2a 2>;
Kumar Gala52094872007-02-17 16:04:23 -0600175 interrupt-parent = <&mpic>;
Andy Fleming2654d632006-08-18 18:04:34 -0500176 };
177
178 serial@4600 {
179 device_type = "serial";
180 compatible = "ns16550";
181 reg = <4600 100>; // reg base, size
Randy Vinson6af01252007-07-17 16:37:12 -0700182 clock-frequency = <0>; // should we fill in in uboot?
Kumar Galab533f8a2007-07-03 02:35:35 -0500183 interrupts = <2a 2>;
Kumar Gala52094872007-02-17 16:04:23 -0600184 interrupt-parent = <&mpic>;
Andy Fleming2654d632006-08-18 18:04:34 -0500185 };
186
Roy Zang68fb0d22007-06-13 17:13:42 +0800187 global-utilities@e0000 { //global utilities reg
188 compatible = "fsl,mpc8548-guts";
189 reg = <e0000 1000>;
190 fsl,has-rstcr;
191 };
192
Kumar Gala52094872007-02-17 16:04:23 -0600193 mpic: pic@40000 {
Andy Fleming2654d632006-08-18 18:04:34 -0500194 clock-frequency = <0>;
195 interrupt-controller;
196 #address-cells = <0>;
197 #interrupt-cells = <2>;
198 reg = <40000 40000>;
Andy Fleming2654d632006-08-18 18:04:34 -0500199 compatible = "chrp,open-pic";
200 device_type = "open-pic";
201 big-endian;
202 };
203 };
Kumar Gala1b3c5cd2007-09-12 18:23:46 -0500204
205 pci@e0008000 {
206 interrupt-map-mask = <f800 0 0 7>;
207 interrupt-map = <
208 /* IDSEL 0x4 (PCIX Slot 2) */
209 02000 0 0 1 &mpic 0 1
210 02000 0 0 2 &mpic 1 1
211 02000 0 0 3 &mpic 2 1
212 02000 0 0 4 &mpic 3 1
213
214 /* IDSEL 0x5 (PCIX Slot 3) */
215 02800 0 0 1 &mpic 1 1
216 02800 0 0 2 &mpic 2 1
217 02800 0 0 3 &mpic 3 1
218 02800 0 0 4 &mpic 0 1
219
220 /* IDSEL 0x6 (PCIX Slot 4) */
221 03000 0 0 1 &mpic 2 1
222 03000 0 0 2 &mpic 3 1
223 03000 0 0 3 &mpic 0 1
224 03000 0 0 4 &mpic 1 1
225
226 /* IDSEL 0x8 (PCIX Slot 5) */
227 04000 0 0 1 &mpic 0 1
228 04000 0 0 2 &mpic 1 1
229 04000 0 0 3 &mpic 2 1
230 04000 0 0 4 &mpic 3 1
231
232 /* IDSEL 0xC (Tsi310 bridge) */
233 06000 0 0 1 &mpic 0 1
234 06000 0 0 2 &mpic 1 1
235 06000 0 0 3 &mpic 2 1
236 06000 0 0 4 &mpic 3 1
237
238 /* IDSEL 0x14 (Slot 2) */
239 0a000 0 0 1 &mpic 0 1
240 0a000 0 0 2 &mpic 1 1
241 0a000 0 0 3 &mpic 2 1
242 0a000 0 0 4 &mpic 3 1
243
244 /* IDSEL 0x15 (Slot 3) */
245 0a800 0 0 1 &mpic 1 1
246 0a800 0 0 2 &mpic 2 1
247 0a800 0 0 3 &mpic 3 1
248 0a800 0 0 4 &mpic 0 1
249
250 /* IDSEL 0x16 (Slot 4) */
251 0b000 0 0 1 &mpic 2 1
252 0b000 0 0 2 &mpic 3 1
253 0b000 0 0 3 &mpic 0 1
254 0b000 0 0 4 &mpic 1 1
255
256 /* IDSEL 0x18 (Slot 5) */
257 0c000 0 0 1 &mpic 0 1
258 0c000 0 0 2 &mpic 1 1
259 0c000 0 0 3 &mpic 2 1
260 0c000 0 0 4 &mpic 3 1
261
262 /* IDSEL 0x1C (Tsi310 bridge PCI primary) */
263 0E000 0 0 1 &mpic 0 1
264 0E000 0 0 2 &mpic 1 1
265 0E000 0 0 3 &mpic 2 1
266 0E000 0 0 4 &mpic 3 1>;
267
268 interrupt-parent = <&mpic>;
269 interrupts = <18 2>;
270 bus-range = <0 0>;
271 ranges = <02000000 0 80000000 80000000 0 10000000
272 01000000 0 00000000 e2000000 0 00800000>;
273 clock-frequency = <3f940aa>;
274 #interrupt-cells = <1>;
275 #size-cells = <2>;
276 #address-cells = <3>;
277 reg = <e0008000 1000>;
278 compatible = "fsl,mpc8540-pcix", "fsl,mpc8540-pci";
279 device_type = "pci";
280
281 pci_bridge@1c {
282 interrupt-map-mask = <f800 0 0 7>;
283 interrupt-map = <
284
285 /* IDSEL 0x00 (PrPMC Site) */
286 0000 0 0 1 &mpic 0 1
287 0000 0 0 2 &mpic 1 1
288 0000 0 0 3 &mpic 2 1
289 0000 0 0 4 &mpic 3 1
290
291 /* IDSEL 0x04 (VIA chip) */
292 2000 0 0 1 &mpic 0 1
293 2000 0 0 2 &mpic 1 1
294 2000 0 0 3 &mpic 2 1
295 2000 0 0 4 &mpic 3 1
296
297 /* IDSEL 0x05 (8139) */
298 2800 0 0 1 &mpic 1 1
299
300 /* IDSEL 0x06 (Slot 6) */
301 3000 0 0 1 &mpic 2 1
302 3000 0 0 2 &mpic 3 1
303 3000 0 0 3 &mpic 0 1
304 3000 0 0 4 &mpic 1 1
305
306 /* IDESL 0x07 (Slot 7) */
307 3800 0 0 1 &mpic 3 1
308 3800 0 0 2 &mpic 0 1
309 3800 0 0 3 &mpic 1 1
310 3800 0 0 4 &mpic 2 1>;
311
312 reg = <e000 0 0 0 0>;
313 #interrupt-cells = <1>;
314 #size-cells = <2>;
315 #address-cells = <3>;
316 ranges = <02000000 0 80000000
317 02000000 0 80000000
318 0 20000000
319 01000000 0 00000000
320 01000000 0 00000000
321 0 00080000>;
322 clock-frequency = <1fca055>;
323
324 isa@4 {
325 device_type = "isa";
326 #interrupt-cells = <2>;
327 #size-cells = <1>;
328 #address-cells = <2>;
329 reg = <2000 0 0 0 0>;
330 ranges = <1 0 01000000 0 0 00001000>;
331 interrupt-parent = <&i8259>;
332
333 i8259: interrupt-controller@20 {
334 interrupt-controller;
335 device_type = "interrupt-controller";
336 reg = <1 20 2
337 1 a0 2
338 1 4d0 2>;
339 #address-cells = <0>;
340 #interrupt-cells = <2>;
341 compatible = "chrp,iic";
342 interrupts = <0 1>;
343 interrupt-parent = <&mpic>;
344 };
345
346 rtc@70 {
347 compatible = "pnpPNP,b00";
348 reg = <1 70 2>;
349 };
350 };
351 };
352 };
353
354 pci@e0009000 {
355 interrupt-map-mask = <f800 0 0 7>;
356 interrupt-map = <
357
358 /* IDSEL 0x15 */
359 a800 0 0 1 &mpic b 1
360 a800 0 0 2 &mpic 1 1
361 a800 0 0 3 &mpic 2 1
362 a800 0 0 4 &mpic 3 1>;
363
364 interrupt-parent = <&mpic>;
365 interrupts = <19 2>;
366 bus-range = <0 0>;
367 ranges = <02000000 0 90000000 90000000 0 10000000
368 01000000 0 00000000 e2800000 0 00800000>;
369 clock-frequency = <3f940aa>;
370 #interrupt-cells = <1>;
371 #size-cells = <2>;
372 #address-cells = <3>;
373 reg = <e0009000 1000>;
374 compatible = "fsl,mpc8540-pci";
375 device_type = "pci";
376 };
377
378 pcie@e000a000 {
379 interrupt-map-mask = <f800 0 0 7>;
380 interrupt-map = <
381
382 /* IDSEL 0x0 (PEX) */
383 00000 0 0 1 &mpic 0 1
384 00000 0 0 2 &mpic 1 1
385 00000 0 0 3 &mpic 2 1
386 00000 0 0 4 &mpic 3 1>;
387
388 interrupt-parent = <&mpic>;
389 interrupts = <1a 2>;
390 bus-range = <0 ff>;
391 ranges = <02000000 0 a0000000 a0000000 0 20000000
392 01000000 0 00000000 e3000000 0 08000000>;
393 clock-frequency = <1fca055>;
394 #interrupt-cells = <1>;
395 #size-cells = <2>;
396 #address-cells = <3>;
397 reg = <e000a000 1000>;
398 compatible = "fsl,mpc8548-pcie";
399 device_type = "pci";
400 pcie@0 {
401 reg = <0 0 0 0 0>;
402 #size-cells = <2>;
403 #address-cells = <3>;
404 device_type = "pci";
405 ranges = <02000000 0 a0000000
406 02000000 0 a0000000
407 0 20000000
408
409 01000000 0 00000000
410 01000000 0 00000000
411 0 08000000>;
412 };
413 };
Andy Fleming2654d632006-08-18 18:04:34 -0500414};