1/*
2 * Keymile KMETER1 Device Tree Source
3 *
4 * 2008 DENX Software Engineering GmbH
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/dts-v1/;
13
14/ {
15	model = "KMETER1";
16	compatible = "keymile,KMETER1";
17	#address-cells = <1>;
18	#size-cells = <1>;
19
20	aliases {
21		ethernet0 = &enet_piggy2;
22		ethernet1 = &enet_estar1;
23		ethernet2 = &enet_estar2;
24		ethernet3 = &enet_eth1;
25		ethernet4 = &enet_eth2;
26		ethernet5 = &enet_eth3;
27		ethernet6 = &enet_eth4;
28		serial0 = &serial0;
29	};
30
31	cpus {
32		#address-cells = <1>;
33		#size-cells = <0>;
34
35		PowerPC,8360@0 {
36			device_type = "cpu";
37			reg = <0x0>;
38			d-cache-line-size = <32>;	// 32 bytes
39			i-cache-line-size = <32>;	// 32 bytes
40			d-cache-size = <32768>;		// L1, 32K
41			i-cache-size = <32768>;		// L1, 32K
42			timebase-frequency = <0>;	/* Filled in by U-Boot */
43			bus-frequency = <0>;	/* Filled in by U-Boot */
44			clock-frequency = <0>;	/* Filled in by U-Boot */
45		};
46	};
47
48	memory {
49		device_type = "memory";
50		reg = <0 0>;	/* Filled in by U-Boot */
51	};
52
53	soc8360@e0000000 {
54		#address-cells = <1>;
55		#size-cells = <1>;
56		device_type = "soc";
57		compatible = "fsl,mpc8360-immr", "simple-bus";
58		ranges = <0x0 0xe0000000 0x00200000>;
59		reg = <0xe0000000 0x00000200>;
60		bus-frequency = <0>;	/* Filled in by U-Boot */
61
62		i2c@3000 {
63			#address-cells = <1>;
64			#size-cells = <0>;
65			cell-index = <0>;
66			compatible = "fsl-i2c";
67			reg = <0x3000 0x100>;
68			interrupts = <14 0x8>;
69			interrupt-parent = <&ipic>;
70			dfsrr;
71		};
72
73		serial0: serial@4500 {
74			cell-index = <0>;
75			device_type = "serial";
76			compatible = "ns16550";
77			reg = <0x4500 0x100>;
78			clock-frequency = <264000000>;
79			interrupts = <9 0x8>;
80			interrupt-parent = <&ipic>;
81		};
82
83		dma@82a8 {
84			#address-cells = <1>;
85			#size-cells = <1>;
86			compatible = "fsl,mpc8360-dma", "fsl,elo-dma";
87			reg = <0x82a8 4>;
88			ranges = <0 0x8100 0x1a8>;
89			interrupt-parent = <&ipic>;
90			interrupts = <71 8>;
91			cell-index = <0>;
92			dma-channel@0 {
93				compatible = "fsl,mpc8360-dma-channel", "fsl,elo-dma-channel";
94				reg = <0 0x80>;
95				interrupt-parent = <&ipic>;
96				interrupts = <71 8>;
97			};
98			dma-channel@80 {
99				compatible = "fsl,mpc8360-dma-channel", "fsl,elo-dma-channel";
100				reg = <0x80 0x80>;
101				interrupt-parent = <&ipic>;
102				interrupts = <71 8>;
103			};
104			dma-channel@100 {
105				compatible = "fsl,mpc8360-dma-channel", "fsl,elo-dma-channel";
106				reg = <0x100 0x80>;
107				interrupt-parent = <&ipic>;
108				interrupts = <71 8>;
109			};
110			dma-channel@180 {
111				compatible = "fsl,mpc8360-dma-channel", "fsl,elo-dma-channel";
112				reg = <0x180 0x28>;
113				interrupt-parent = <&ipic>;
114				interrupts = <71 8>;
115			};
116		};
117
118		ipic: pic@700 {
119			#address-cells = <0>;
120			#interrupt-cells = <2>;
121			compatible = "fsl,pq2pro-pic", "fsl,ipic";
122			interrupt-controller;
123			reg = <0x700 0x100>;
124		};
125
126		par_io@1400 {
127			#address-cells = <1>;
128			#size-cells = <0>;
129			reg = <0x1400 0x100>;
130			compatible = "fsl,mpc8360-par_io";
131			num-ports = <7>;
132
133			pio_ucc1: ucc_pin@0 {
134				reg = <0>;
135
136				pio-map = <
137					/* port pin dir open_drain assignment has_irq */
138					0   1  3  0  2  0	/* MDIO   */
139					0   2  1  0  1  0	/* MDC    */
140
141					0   3  1  0  1  0	/* TxD0   */
142					0   4  1  0  1  0	/* TxD1   */
143					0   5  1  0  1  0	/* TxD2   */
144					0   6  1  0  1  0	/* TxD3   */
145					0   9  2  0  1  0	/* RxD0   */
146					0  10  2  0  1  0	/* RxD1   */
147					0  11  2  0  1  0	/* RxD2   */
148					0  12  2  0  1  0	/* RxD3   */
149					0   7  1  0  1  0	/* TX_EN  */
150					0   8  1  0  1  0	/* TX_ER  */
151					0  15  2  0  1  0	/* RX_DV  */
152					0  16  2  0  1  0	/* RX_ER  */
153					0   0  2  0  1  0	/* RX_CLK */
154					2   9  1  0  3  0	/* GTX_CLK - CLK10 */
155					2   8  2  0  1  0	/* GTX125  - CLK9  */
156				>;
157			};
158
159			pio_ucc2: ucc_pin@1 {
160				reg = <1>;
161
162				pio-map = <
163					/* port pin dir open_drain assignment has_irq */
164					0   1  3  0  2  0	/* MDIO   */
165					0   2  1  0  1  0	/* MDC    */
166
167					0  17  1  0  1  0	/* TxD0   */
168					0  18  1  0  1  0	/* TxD1   */
169					0  19  1  0  1  0	/* TxD2   */
170					0  20  1  0  1  0	/* TxD3   */
171					0  23  2  0  1  0	/* RxD0   */
172					0  24  2  0  1  0	/* RxD1   */
173					0  25  2  0  1  0	/* RxD2   */
174					0  26  2  0  1  0	/* RxD3   */
175					0  21  1  0  1  0	/* TX_EN  */
176					0  22  1  0  1  0	/* TX_ER  */
177					0  29  2  0  1  0	/* RX_DV  */
178					0  30  2  0  1  0	/* RX_ER  */
179					0  31  2  0  1  0	/* RX_CLK */
180					2  2   1  0  2  0	/* GTX_CLK - CLK3  */
181					2  3   2  0  1  0	/* GTX125  - CLK4  */
182				>;
183			};
184
185			pio_ucc4: ucc_pin@3 {
186				reg = <3>;
187
188				pio-map = <
189					/* port pin dir open_drain assignment has_irq */
190					0   1  3  0  2  0	/* MDIO */
191					0   2  1  0  1  0	/* MDC  */
192
193					1  14  1  0  1  0	/* TxD0   (PB14, out, f1) */
194					1  15  1  0  1  0	/* TxD1   (PB15, out, f1) */
195					1  20  2  0  1  0	/* RxD0   (PB20, in,  f1) */
196					1  21  2  0  1  0	/* RxD1   (PB21, in,  f1) */
197					1  18  1  0  1  0	/* TX_EN  (PB18, out, f1) */
198					1  26  2  0  1  0	/* RX_DV  (PB26, in,  f1) */
199					1  27  2  0  1  0	/* RX_ER  (PB27, in,  f1) */
200
201					2  16  2  0  1  0	/* UCC4_RMII_CLK (CLK17) */
202				>;
203			};
204
205			pio_ucc5: ucc_pin@4 {
206				reg = <4>;
207
208				pio-map = <
209					/* port pin dir open_drain assignment has_irq */
210					0   1  3  0  2  0	/* MDIO */
211					0   2  1  0  1  0	/* MDC  */
212
213					3   0  1  0  1  0	/* TxD0  (PD0,  out, f1) */
214					3   1  1  0  1  0	/* TxD1  (PD1,  out, f1) */
215					3   6  2  0  1  0	/* RxD0  (PD6,   in, f1) */
216					3   7  2  0  1  0	/* RxD1  (PD7,   in, f1) */
217					3   4  1  0  1  0	/* TX_EN (PD4,  out, f1) */
218					3  12  2  0  1  0	/* RX_DV (PD12,  in, f1) */
219					3  13  2  0  1  0	/* RX_ER (PD13,  in, f1) */
220				>;
221			};
222
223			pio_ucc6: ucc_pin@5 {
224				reg = <5>;
225
226				pio-map = <
227					/* port pin dir open_drain assignment has_irq */
228					0   1  3  0  2  0	/* MDIO */
229					0   2  1  0  1  0	/* MDC  */
230
231					3  14  1  0  1  0	/* TxD0   (PD14, out, f1) */
232					3  15  1  0  1  0	/* TxD1   (PD15, out, f1) */
233					3  20  2  0  1  0	/* RxD0   (PD20, in,  f1) */
234					3  21  2  0  1  0	/* RxD1   (PD21, in,  f1) */
235					3  18  1  0  1  0	/* TX_EN  (PD18, out, f1) */
236					3  26  2  0  1  0	/* RX_DV  (PD26, in,  f1) */
237					3  27  2  0  1  0	/* RX_ER  (PD27, in,  f1) */
238				>;
239			};
240
241			pio_ucc7: ucc_pin@6 {
242				reg = <6>;
243
244				pio-map = <
245					/* port pin dir open_drain assignment has_irq */
246					0   1  3  0  2  0	/* MDIO */
247					0   2  1  0  1  0	/* MDC  */
248
249					4   0  1  0  1  0	/* TxD0   (PE0,  out, f1) */
250					4   1  1  0  1  0	/* TxD1   (PE1,  out, f1) */
251					4   6  2  0  1  0	/* RxD0   (PE6,   in, f1) */
252					4   7  2  0  1  0	/* RxD1   (PE7,   in, f1) */
253					4   4  1  0  1  0	/* TX_EN  (PE4,  out, f1) */
254					4  12  2  0  1  0	/* RX_DV  (PE12,  in, f1) */
255					4  13  2  0  1  0	/* RX_ER  (PE13,  in, f1) */
256				>;
257			};
258
259			pio_ucc8: ucc_pin@7 {
260				reg = <7>;
261
262				pio-map = <
263					/* port pin dir open_drain assignment has_irq */
264					0   1  3  0  2  0	/* MDIO */
265					0   2  1  0  1  0	/* MDC  */
266
267					4  14  1  0  2  0	/* TxD0   (PE14, out, f2) */
268					4  15  1  0  1  0	/* TxD1   (PE15, out, f1) */
269					4  20  2  0  1  0	/* RxD0   (PE20, in,  f1) */
270					4  21  2  0  1  0	/* RxD1   (PE21, in,  f1) */
271					4  18  1  0  1  0	/* TX_EN  (PE18, out, f1) */
272					4  26  2  0  1  0	/* RX_DV  (PE26, in,  f1) */
273					4  27  2  0  1  0	/* RX_ER  (PE27, in,  f1) */
274
275					2  15  2  0  1  0	/* UCCx_RMII_CLK (CLK16) */
276				>;
277			};
278
279		};
280
281		qe@100000 {
282			#address-cells = <1>;
283			#size-cells = <1>;
284			compatible = "fsl,qe";
285			ranges = <0x0 0x100000 0x100000>;
286			reg = <0x100000 0x480>;
287			clock-frequency = <0>;	/* Filled in by U-Boot */
288			brg-frequency = <0>;	/* Filled in by U-Boot */
289			bus-frequency = <0>;	/* Filled in by U-Boot */
290
291			muram@10000 {
292				#address-cells = <1>;
293				#size-cells = <1>;
294				compatible = "fsl,qe-muram", "fsl,cpm-muram";
295				ranges = <0x0 0x00010000 0x0000c000>;
296
297				data-only@0 {
298					compatible = "fsl,qe-muram-data",
299						     "fsl,cpm-muram-data";
300					reg = <0x0 0xc000>;
301				};
302			};
303
304			/* ESTAR-1 (UCC1, MDIO 0x10, RGMII) */
305			enet_estar1: ucc@2000 {
306				device_type = "network";
307				compatible = "ucc_geth";
308				cell-index = <1>;
309				reg = <0x2000 0x200>;
310				interrupts = <32>;
311				interrupt-parent = <&qeic>;
312				local-mac-address = [ 00 00 00 00 00 00 ];
313				rx-clock-name = "none";
314				tx-clock-name = "clk9";
315				phy-handle = <&phy_estar1>;
316				phy-connection-type = "rgmii-id";
317				pio-handle = <&pio_ucc1>;
318			};
319
320			/* ESTAR-2 (UCC2, MDIO 0x11, RGMII) */
321			enet_estar2: ucc@3000 {
322				device_type = "network";
323				compatible = "ucc_geth";
324				cell-index = <2>;
325				reg = <0x3000 0x200>;
326				interrupts = <33>;
327				interrupt-parent = <&qeic>;
328				local-mac-address = [ 00 00 00 00 00 00 ];
329				rx-clock-name = "none";
330				tx-clock-name = "clk4";
331				phy-handle = <&phy_estar2>;
332				phy-connection-type = "rgmii-id";
333				pio-handle = <&pio_ucc2>;
334			};
335
336			/* Piggy2 (UCC4, MDIO 0x00, RMII) */
337			enet_piggy2: ucc@3200 {
338				device_type = "network";
339				compatible = "ucc_geth";
340				cell-index = <4>;
341				reg = <0x3200 0x200>;
342				interrupts = <35>;
343				interrupt-parent = <&qeic>;
344				local-mac-address = [ 00 00 00 00 00 00 ];
345				rx-clock-name = "none";
346				tx-clock-name = "clk17";
347				phy-handle = <&phy_piggy2>;
348				phy-connection-type = "rmii";
349				pio-handle = <&pio_ucc4>;
350			};
351
352			/* Eth-1 (UCC5, MDIO 0x08, RMII) */
353			enet_eth1: ucc@2400 {
354				device_type = "network";
355				compatible = "ucc_geth";
356				cell-index = <5>;
357				reg = <0x2400 0x200>;
358				interrupts = <40>;
359				interrupt-parent = <&qeic>;
360				local-mac-address = [ 00 00 00 00 00 00 ];
361				rx-clock-name = "none";
362				tx-clock-name = "clk16";
363				phy-handle = <&phy_eth1>;
364				phy-connection-type = "rmii";
365				pio-handle = <&pio_ucc5>;
366			};
367
368			/* Eth-2 (UCC6, MDIO 0x09, RMII) */
369			enet_eth2: ucc@3400 {
370				device_type = "network";
371				compatible = "ucc_geth";
372				cell-index = <6>;
373				reg = <0x3400 0x200>;
374				interrupts = <41>;
375				interrupt-parent = <&qeic>;
376				local-mac-address = [ 00 00 00 00 00 00 ];
377				rx-clock-name = "none";
378				tx-clock-name = "clk16";
379				phy-handle = <&phy_eth2>;
380				phy-connection-type = "rmii";
381				pio-handle = <&pio_ucc6>;
382			};
383
384			/* Eth-3 (UCC7, MDIO 0x0a, RMII) */
385			enet_eth3: ucc@2600 {
386				device_type = "network";
387				compatible = "ucc_geth";
388				cell-index = <7>;
389				reg = <0x2600 0x200>;
390				interrupts = <42>;
391				interrupt-parent = <&qeic>;
392				local-mac-address = [ 00 00 00 00 00 00 ];
393				rx-clock-name = "none";
394				tx-clock-name = "clk16";
395				phy-handle = <&phy_eth3>;
396				phy-connection-type = "rmii";
397				pio-handle = <&pio_ucc7>;
398			};
399
400			/* Eth-4 (UCC8, MDIO 0x0b, RMII) */
401			enet_eth4: ucc@3600 {
402				device_type = "network";
403				compatible = "ucc_geth";
404				cell-index = <8>;
405				reg = <0x3600 0x200>;
406				interrupts = <43>;
407				interrupt-parent = <&qeic>;
408				local-mac-address = [ 00 00 00 00 00 00 ];
409				rx-clock-name = "none";
410				tx-clock-name = "clk16";
411				phy-handle = <&phy_eth4>;
412				phy-connection-type = "rmii";
413				pio-handle = <&pio_ucc8>;
414			};
415
416			mdio@3320 {
417				#address-cells = <1>;
418				#size-cells = <0>;
419				reg = <0x3320 0x18>;
420				compatible = "fsl,ucc-mdio";
421
422				/* Piggy2 (UCC4, MDIO 0x00, RMII) */
423				phy_piggy2: ethernet-phy@00 {
424					reg = <0x0>;
425				};
426
427				/* Eth-1 (UCC5, MDIO 0x08, RMII) */
428				phy_eth1: ethernet-phy@08 {
429					reg = <0x08>;
430				};
431
432				/* Eth-2 (UCC6, MDIO 0x09, RMII) */
433				phy_eth2: ethernet-phy@09 {
434					reg = <0x09>;
435				};
436
437				/* Eth-3 (UCC7, MDIO 0x0a, RMII) */
438				phy_eth3: ethernet-phy@0a {
439					reg = <0x0a>;
440				};
441
442				/* Eth-4 (UCC8, MDIO 0x0b, RMII) */
443				phy_eth4: ethernet-phy@0b {
444					reg = <0x0b>;
445				};
446
447				/* ESTAR-1 (UCC1, MDIO 0x10, RGMII) */
448				phy_estar1: ethernet-phy@10 {
449					interrupt-parent = <&ipic>;
450					interrupts = <17 0x8>;
451					reg = <0x10>;
452				};
453
454				/* ESTAR-2 (UCC2, MDIO 0x11, RGMII) */
455				phy_estar2: ethernet-phy@11 {
456					interrupt-parent = <&ipic>;
457					interrupts = <18 0x8>;
458					reg = <0x11>;
459				};
460			};
461
462			qeic: interrupt-controller@80 {
463				interrupt-controller;
464				compatible = "fsl,qe-ic";
465				#address-cells = <0>;
466				#interrupt-cells = <1>;
467				reg = <0x80 0x80>;
468				interrupts = <32 8 33 8>;
469				interrupt-parent = <&ipic>;
470			};
471		};
472	};
473
474	localbus@e0005000 {
475		#address-cells = <2>;
476		#size-cells = <1>;
477		compatible = "fsl,mpc8360-localbus", "fsl,pq2pro-localbus",
478			     "simple-bus";
479		reg = <0xe0005000 0xd8>;
480		ranges = <0 0 0xf0000000 0x04000000>;	/* Filled in by U-Boot */
481
482		flash@f0000000,0 {
483			compatible = "cfi-flash";
484			/*
485			 * The Intel P30 chip has 2 non-identical chips on
486			 * one die, so we need to define 2 seperate regions
487			 * that are scanned by physmap_of independantly.
488			 */
489			reg = <0 0x00000000 0x02000000
490			       0 0x02000000 0x02000000>;	/* Filled in by U-Boot */
491			bank-width = <2>;
492			#address-cells = <1>;
493			#size-cells = <1>;
494			partition@0 {
495				label = "u-boot";
496				reg = <0 0x40000>;
497			};
498			partition@40000 {
499				label = "env";
500				reg = <0x40000 0x40000>;
501			};
502			partition@80000 {
503				label = "dtb";
504				reg = <0x80000 0x20000>;
505			};
506			partition@a0000 {
507				label = "kernel";
508				reg = <0xa0000 0x300000>;
509			};
510			partition@3a0000 {
511				label = "ramdisk";
512				reg = <0x3a0000 0x800000>;
513			};
514			partition@ba0000 {
515				label = "user";
516				reg = <0xba0000 0x3460000>;
517			};
518		};
519	};
520};
521