blob: 69ca5025d9723cc143b2e0e711c4ba50d6f0304f [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 Galab533f8ae2007-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 Galab533f8ae2007-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 {
66 device_type = "i2c";
67 compatible = "fsl-i2c";
68 reg = <3000 100>;
Kumar Galab533f8ae2007-07-03 02:35:35 -050069 interrupts = <2b 2>;
Kumar Gala52094872007-02-17 16:04:23 -060070 interrupt-parent = <&mpic>;
Andy Fleming2654d632006-08-18 18:04:34 -050071 dfsrr;
72 };
73
74 mdio@24520 {
75 #address-cells = <1>;
76 #size-cells = <0>;
77 device_type = "mdio";
78 compatible = "gianfar";
79 reg = <24520 20>;
Kumar Gala52094872007-02-17 16:04:23 -060080 phy0: ethernet-phy@0 {
81 interrupt-parent = <&mpic>;
Kumar Gala58fe2552007-07-03 03:05:58 -050082 interrupts = <5 1>;
Andy Fleming2654d632006-08-18 18:04:34 -050083 reg = <0>;
84 device_type = "ethernet-phy";
85 };
Kumar Gala52094872007-02-17 16:04:23 -060086 phy1: ethernet-phy@1 {
87 interrupt-parent = <&mpic>;
Kumar Gala58fe2552007-07-03 03:05:58 -050088 interrupts = <5 1>;
Andy Fleming2654d632006-08-18 18:04:34 -050089 reg = <1>;
90 device_type = "ethernet-phy";
91 };
Kumar Gala52094872007-02-17 16:04:23 -060092 phy2: ethernet-phy@2 {
93 interrupt-parent = <&mpic>;
Kumar Gala58fe2552007-07-03 03:05:58 -050094 interrupts = <5 1>;
Andy Fleming2654d632006-08-18 18:04:34 -050095 reg = <2>;
96 device_type = "ethernet-phy";
97 };
Kumar Gala52094872007-02-17 16:04:23 -060098 phy3: ethernet-phy@3 {
99 interrupt-parent = <&mpic>;
Kumar Gala58fe2552007-07-03 03:05:58 -0500100 interrupts = <5 1>;
Andy Fleming2654d632006-08-18 18:04:34 -0500101 reg = <3>;
102 device_type = "ethernet-phy";
103 };
104 };
105
106 ethernet@24000 {
107 #address-cells = <1>;
108 #size-cells = <0>;
109 device_type = "network";
110 model = "eTSEC";
111 compatible = "gianfar";
112 reg = <24000 1000>;
Timur Tabieae98262007-06-22 14:33:15 -0500113 local-mac-address = [ 00 00 00 00 00 00 ];
Kumar Galab533f8ae2007-07-03 02:35:35 -0500114 interrupts = <1d 2 1e 2 22 2>;
Kumar Gala52094872007-02-17 16:04:23 -0600115 interrupt-parent = <&mpic>;
116 phy-handle = <&phy0>;
Andy Fleming2654d632006-08-18 18:04:34 -0500117 };
118
119 ethernet@25000 {
120 #address-cells = <1>;
121 #size-cells = <0>;
122 device_type = "network";
123 model = "eTSEC";
124 compatible = "gianfar";
125 reg = <25000 1000>;
Timur Tabieae98262007-06-22 14:33:15 -0500126 local-mac-address = [ 00 00 00 00 00 00 ];
Kumar Galab533f8ae2007-07-03 02:35:35 -0500127 interrupts = <23 2 24 2 28 2>;
Kumar Gala52094872007-02-17 16:04:23 -0600128 interrupt-parent = <&mpic>;
129 phy-handle = <&phy1>;
Andy Fleming2654d632006-08-18 18:04:34 -0500130 };
131
Kumar Gala52094872007-02-17 16:04:23 -0600132/* eTSEC 3/4 are currently broken
Andy Fleming2654d632006-08-18 18:04:34 -0500133 ethernet@26000 {
134 #address-cells = <1>;
135 #size-cells = <0>;
136 device_type = "network";
137 model = "eTSEC";
138 compatible = "gianfar";
139 reg = <26000 1000>;
Timur Tabieae98262007-06-22 14:33:15 -0500140 local-mac-address = [ 00 00 00 00 00 00 ];
Kumar Galab533f8ae2007-07-03 02:35:35 -0500141 interrupts = <1f 2 20 2 21 2>;
Kumar Gala52094872007-02-17 16:04:23 -0600142 interrupt-parent = <&mpic>;
143 phy-handle = <&phy2>;
Andy Fleming2654d632006-08-18 18:04:34 -0500144 };
145
Andy Fleming2654d632006-08-18 18:04:34 -0500146 ethernet@27000 {
147 #address-cells = <1>;
148 #size-cells = <0>;
149 device_type = "network";
150 model = "eTSEC";
151 compatible = "gianfar";
152 reg = <27000 1000>;
Timur Tabieae98262007-06-22 14:33:15 -0500153 local-mac-address = [ 00 00 00 00 00 00 ];
Kumar Galab533f8ae2007-07-03 02:35:35 -0500154 interrupts = <25 2 26 2 27 2>;
Kumar Gala52094872007-02-17 16:04:23 -0600155 interrupt-parent = <&mpic>;
156 phy-handle = <&phy3>;
Andy Fleming2654d632006-08-18 18:04:34 -0500157 };
158 */
159
160 serial@4500 {
161 device_type = "serial";
162 compatible = "ns16550";
Randy Vinson6af01252007-07-17 16:37:12 -0700163 reg = <4500 100>; // reg base, size
164 clock-frequency = <0>; // should we fill in in uboot?
Kumar Galab533f8ae2007-07-03 02:35:35 -0500165 interrupts = <2a 2>;
Kumar Gala52094872007-02-17 16:04:23 -0600166 interrupt-parent = <&mpic>;
Andy Fleming2654d632006-08-18 18:04:34 -0500167 };
168
169 serial@4600 {
170 device_type = "serial";
171 compatible = "ns16550";
172 reg = <4600 100>; // reg base, size
Randy Vinson6af01252007-07-17 16:37:12 -0700173 clock-frequency = <0>; // should we fill in in uboot?
Kumar Galab533f8ae2007-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
Roy Zang68fb0d22007-06-13 17:13:42 +0800178 global-utilities@e0000 { //global utilities reg
179 compatible = "fsl,mpc8548-guts";
180 reg = <e0000 1000>;
181 fsl,has-rstcr;
182 };
183
Kumar Gala52094872007-02-17 16:04:23 -0600184 mpic: pic@40000 {
Andy Fleming2654d632006-08-18 18:04:34 -0500185 clock-frequency = <0>;
186 interrupt-controller;
187 #address-cells = <0>;
188 #interrupt-cells = <2>;
189 reg = <40000 40000>;
Andy Fleming2654d632006-08-18 18:04:34 -0500190 compatible = "chrp,open-pic";
191 device_type = "open-pic";
192 big-endian;
193 };
194 };
Kumar Gala1b3c5cd2007-09-12 18:23:46 -0500195
196 pci@e0008000 {
197 interrupt-map-mask = <f800 0 0 7>;
198 interrupt-map = <
199 /* IDSEL 0x4 (PCIX Slot 2) */
200 02000 0 0 1 &mpic 0 1
201 02000 0 0 2 &mpic 1 1
202 02000 0 0 3 &mpic 2 1
203 02000 0 0 4 &mpic 3 1
204
205 /* IDSEL 0x5 (PCIX Slot 3) */
206 02800 0 0 1 &mpic 1 1
207 02800 0 0 2 &mpic 2 1
208 02800 0 0 3 &mpic 3 1
209 02800 0 0 4 &mpic 0 1
210
211 /* IDSEL 0x6 (PCIX Slot 4) */
212 03000 0 0 1 &mpic 2 1
213 03000 0 0 2 &mpic 3 1
214 03000 0 0 3 &mpic 0 1
215 03000 0 0 4 &mpic 1 1
216
217 /* IDSEL 0x8 (PCIX Slot 5) */
218 04000 0 0 1 &mpic 0 1
219 04000 0 0 2 &mpic 1 1
220 04000 0 0 3 &mpic 2 1
221 04000 0 0 4 &mpic 3 1
222
223 /* IDSEL 0xC (Tsi310 bridge) */
224 06000 0 0 1 &mpic 0 1
225 06000 0 0 2 &mpic 1 1
226 06000 0 0 3 &mpic 2 1
227 06000 0 0 4 &mpic 3 1
228
229 /* IDSEL 0x14 (Slot 2) */
230 0a000 0 0 1 &mpic 0 1
231 0a000 0 0 2 &mpic 1 1
232 0a000 0 0 3 &mpic 2 1
233 0a000 0 0 4 &mpic 3 1
234
235 /* IDSEL 0x15 (Slot 3) */
236 0a800 0 0 1 &mpic 1 1
237 0a800 0 0 2 &mpic 2 1
238 0a800 0 0 3 &mpic 3 1
239 0a800 0 0 4 &mpic 0 1
240
241 /* IDSEL 0x16 (Slot 4) */
242 0b000 0 0 1 &mpic 2 1
243 0b000 0 0 2 &mpic 3 1
244 0b000 0 0 3 &mpic 0 1
245 0b000 0 0 4 &mpic 1 1
246
247 /* IDSEL 0x18 (Slot 5) */
248 0c000 0 0 1 &mpic 0 1
249 0c000 0 0 2 &mpic 1 1
250 0c000 0 0 3 &mpic 2 1
251 0c000 0 0 4 &mpic 3 1
252
253 /* IDSEL 0x1C (Tsi310 bridge PCI primary) */
254 0E000 0 0 1 &mpic 0 1
255 0E000 0 0 2 &mpic 1 1
256 0E000 0 0 3 &mpic 2 1
257 0E000 0 0 4 &mpic 3 1>;
258
259 interrupt-parent = <&mpic>;
260 interrupts = <18 2>;
261 bus-range = <0 0>;
262 ranges = <02000000 0 80000000 80000000 0 10000000
263 01000000 0 00000000 e2000000 0 00800000>;
264 clock-frequency = <3f940aa>;
265 #interrupt-cells = <1>;
266 #size-cells = <2>;
267 #address-cells = <3>;
268 reg = <e0008000 1000>;
269 compatible = "fsl,mpc8540-pcix", "fsl,mpc8540-pci";
270 device_type = "pci";
271
272 pci_bridge@1c {
273 interrupt-map-mask = <f800 0 0 7>;
274 interrupt-map = <
275
276 /* IDSEL 0x00 (PrPMC Site) */
277 0000 0 0 1 &mpic 0 1
278 0000 0 0 2 &mpic 1 1
279 0000 0 0 3 &mpic 2 1
280 0000 0 0 4 &mpic 3 1
281
282 /* IDSEL 0x04 (VIA chip) */
283 2000 0 0 1 &mpic 0 1
284 2000 0 0 2 &mpic 1 1
285 2000 0 0 3 &mpic 2 1
286 2000 0 0 4 &mpic 3 1
287
288 /* IDSEL 0x05 (8139) */
289 2800 0 0 1 &mpic 1 1
290
291 /* IDSEL 0x06 (Slot 6) */
292 3000 0 0 1 &mpic 2 1
293 3000 0 0 2 &mpic 3 1
294 3000 0 0 3 &mpic 0 1
295 3000 0 0 4 &mpic 1 1
296
297 /* IDESL 0x07 (Slot 7) */
298 3800 0 0 1 &mpic 3 1
299 3800 0 0 2 &mpic 0 1
300 3800 0 0 3 &mpic 1 1
301 3800 0 0 4 &mpic 2 1>;
302
303 reg = <e000 0 0 0 0>;
304 #interrupt-cells = <1>;
305 #size-cells = <2>;
306 #address-cells = <3>;
307 ranges = <02000000 0 80000000
308 02000000 0 80000000
309 0 20000000
310 01000000 0 00000000
311 01000000 0 00000000
312 0 00080000>;
313 clock-frequency = <1fca055>;
314
315 isa@4 {
316 device_type = "isa";
317 #interrupt-cells = <2>;
318 #size-cells = <1>;
319 #address-cells = <2>;
320 reg = <2000 0 0 0 0>;
321 ranges = <1 0 01000000 0 0 00001000>;
322 interrupt-parent = <&i8259>;
323
324 i8259: interrupt-controller@20 {
325 interrupt-controller;
326 device_type = "interrupt-controller";
327 reg = <1 20 2
328 1 a0 2
329 1 4d0 2>;
330 #address-cells = <0>;
331 #interrupt-cells = <2>;
332 compatible = "chrp,iic";
333 interrupts = <0 1>;
334 interrupt-parent = <&mpic>;
335 };
336
337 rtc@70 {
338 compatible = "pnpPNP,b00";
339 reg = <1 70 2>;
340 };
341 };
342 };
343 };
344
345 pci@e0009000 {
346 interrupt-map-mask = <f800 0 0 7>;
347 interrupt-map = <
348
349 /* IDSEL 0x15 */
350 a800 0 0 1 &mpic b 1
351 a800 0 0 2 &mpic 1 1
352 a800 0 0 3 &mpic 2 1
353 a800 0 0 4 &mpic 3 1>;
354
355 interrupt-parent = <&mpic>;
356 interrupts = <19 2>;
357 bus-range = <0 0>;
358 ranges = <02000000 0 90000000 90000000 0 10000000
359 01000000 0 00000000 e2800000 0 00800000>;
360 clock-frequency = <3f940aa>;
361 #interrupt-cells = <1>;
362 #size-cells = <2>;
363 #address-cells = <3>;
364 reg = <e0009000 1000>;
365 compatible = "fsl,mpc8540-pci";
366 device_type = "pci";
367 };
368
369 pcie@e000a000 {
370 interrupt-map-mask = <f800 0 0 7>;
371 interrupt-map = <
372
373 /* IDSEL 0x0 (PEX) */
374 00000 0 0 1 &mpic 0 1
375 00000 0 0 2 &mpic 1 1
376 00000 0 0 3 &mpic 2 1
377 00000 0 0 4 &mpic 3 1>;
378
379 interrupt-parent = <&mpic>;
380 interrupts = <1a 2>;
381 bus-range = <0 ff>;
382 ranges = <02000000 0 a0000000 a0000000 0 20000000
383 01000000 0 00000000 e3000000 0 08000000>;
384 clock-frequency = <1fca055>;
385 #interrupt-cells = <1>;
386 #size-cells = <2>;
387 #address-cells = <3>;
388 reg = <e000a000 1000>;
389 compatible = "fsl,mpc8548-pcie";
390 device_type = "pci";
391 pcie@0 {
392 reg = <0 0 0 0 0>;
393 #size-cells = <2>;
394 #address-cells = <3>;
395 device_type = "pci";
396 ranges = <02000000 0 a0000000
397 02000000 0 a0000000
398 0 20000000
399
400 01000000 0 00000000
401 01000000 0 00000000
402 0 08000000>;
403 };
404 };
Andy Fleming2654d632006-08-18 18:04:34 -0500405};