Merge git://git.infradead.org/~dwmw2/mtd-2.6.35
[pandora-kernel.git] / arch / powerpc / boot / dts / katmai.dts
1 /*
2  * Device Tree Source for AMCC Katmai eval board
3  *
4  * Copyright (c) 2006, 2007 IBM Corp.
5  * Benjamin Herrenschmidt <benh@kernel.crashing.org>
6  *
7  * Copyright (c) 2006, 2007 IBM Corp.
8  * Josh Boyer <jwboyer@linux.vnet.ibm.com>
9  *
10  * This file is licensed under the terms of the GNU General Public
11  * License version 2.  This program is licensed "as is" without
12  * any warranty of any kind, whether express or implied.
13  */
14
15 /dts-v1/;
16
17 / {
18         #address-cells = <2>;
19         #size-cells = <2>;
20         model = "amcc,katmai";
21         compatible = "amcc,katmai";
22         dcr-parent = <&{/cpus/cpu@0}>;
23
24         aliases {
25                 ethernet0 = &EMAC0;
26                 serial0 = &UART0;
27                 serial1 = &UART1;
28                 serial2 = &UART2;
29         };
30
31         cpus {
32                 #address-cells = <1>;
33                 #size-cells = <0>;
34
35                 cpu@0 {
36                         device_type = "cpu";
37                         model = "PowerPC,440SPe";
38                         reg = <0x00000000>;
39                         clock-frequency = <0>; /* Filled in by zImage */
40                         timebase-frequency = <0>; /* Filled in by zImage */
41                         i-cache-line-size = <32>;
42                         d-cache-line-size = <32>;
43                         i-cache-size = <32768>;
44                         d-cache-size = <32768>;
45                         dcr-controller;
46                         dcr-access-method = "native";
47                         reset-type = <2>;       /* Use chip-reset */
48                 };
49         };
50
51         memory {
52                 device_type = "memory";
53                 reg = <0x0 0x00000000 0x0 0x00000000>; /* Filled in by U-Boot */
54         };
55
56         UIC0: interrupt-controller0 {
57                 compatible = "ibm,uic-440spe","ibm,uic";
58                 interrupt-controller;
59                 cell-index = <0>;
60                 dcr-reg = <0x0c0 0x009>;
61                 #address-cells = <0>;
62                 #size-cells = <0>;
63                 #interrupt-cells = <2>;
64         };
65
66         UIC1: interrupt-controller1 {
67                 compatible = "ibm,uic-440spe","ibm,uic";
68                 interrupt-controller;
69                 cell-index = <1>;
70                 dcr-reg = <0x0d0 0x009>;
71                 #address-cells = <0>;
72                 #size-cells = <0>;
73                 #interrupt-cells = <2>;
74                 interrupts = <0x1e 0x4 0x1f 0x4>; /* cascade */
75                 interrupt-parent = <&UIC0>;
76         };
77
78         UIC2: interrupt-controller2 {
79                 compatible = "ibm,uic-440spe","ibm,uic";
80                 interrupt-controller;
81                 cell-index = <2>;
82                 dcr-reg = <0x0e0 0x009>;
83                 #address-cells = <0>;
84                 #size-cells = <0>;
85                 #interrupt-cells = <2>;
86                 interrupts = <0xa 0x4 0xb 0x4>; /* cascade */
87                 interrupt-parent = <&UIC0>;
88         };
89
90         UIC3: interrupt-controller3 {
91                 compatible = "ibm,uic-440spe","ibm,uic";
92                 interrupt-controller;
93                 cell-index = <3>;
94                 dcr-reg = <0x0f0 0x009>;
95                 #address-cells = <0>;
96                 #size-cells = <0>;
97                 #interrupt-cells = <2>;
98                 interrupts = <0x10 0x4 0x11 0x4>; /* cascade */
99                 interrupt-parent = <&UIC0>;
100         };
101
102         SDR0: sdr {
103                 compatible = "ibm,sdr-440spe";
104                 dcr-reg = <0x00e 0x002>;
105         };
106
107         CPR0: cpr {
108                 compatible = "ibm,cpr-440spe";
109                 dcr-reg = <0x00c 0x002>;
110         };
111
112         MQ0: mq {
113                 compatible = "ibm,mq-440spe";
114                 dcr-reg = <0x040 0x020>;
115         };
116
117         plb {
118                 compatible = "ibm,plb-440spe", "ibm,plb-440gp", "ibm,plb4";
119                 #address-cells = <2>;
120                 #size-cells = <1>;
121                 /*        addr-child     addr-parent    size */
122                 ranges = <0x4 0x00100000 0x4 0x00100000 0x00001000
123                           0x4 0x00200000 0x4 0x00200000 0x00000400
124                           0x4 0xe0000000 0x4 0xe0000000 0x20000000
125                           0xc 0x00000000 0xc 0x00000000 0x20000000
126                           0xd 0x00000000 0xd 0x00000000 0x80000000
127                           0xd 0x80000000 0xd 0x80000000 0x80000000
128                           0xe 0x00000000 0xe 0x00000000 0x80000000
129                           0xe 0x80000000 0xe 0x80000000 0x80000000
130                           0xf 0x00000000 0xf 0x00000000 0x80000000
131                           0xf 0x80000000 0xf 0x80000000 0x80000000>;
132                 clock-frequency = <0>; /* Filled in by zImage */
133
134                 SDRAM0: sdram {
135                         compatible = "ibm,sdram-440spe", "ibm,sdram-405gp";
136                         dcr-reg = <0x010 0x002>;
137                 };
138
139                 MAL0: mcmal {
140                         compatible = "ibm,mcmal-440spe", "ibm,mcmal2";
141                         dcr-reg = <0x180 0x062>;
142                         num-tx-chans = <2>;
143                         num-rx-chans = <1>;
144                         interrupt-parent = <&MAL0>;
145                         interrupts = <0x0 0x1 0x2 0x3 0x4>;
146                         #interrupt-cells = <1>;
147                         #address-cells = <0>;
148                         #size-cells = <0>;
149                         interrupt-map = </*TXEOB*/ 0x0 &UIC1 0x6 0x4
150                                          /*RXEOB*/ 0x1 &UIC1 0x7 0x4
151                                          /*SERR*/  0x2 &UIC1 0x1 0x4
152                                          /*TXDE*/  0x3 &UIC1 0x2 0x4
153                                          /*RXDE*/  0x4 &UIC1 0x3 0x4>;
154                 };
155
156                 POB0: opb {
157                         compatible = "ibm,opb-440spe", "ibm,opb-440gp", "ibm,opb";
158                         #address-cells = <1>;
159                         #size-cells = <1>;
160                         ranges = <0xe0000000 0x00000004 0xe0000000 0x20000000>;
161                         clock-frequency = <0>; /* Filled in by zImage */
162
163                         EBC0: ebc {
164                                 compatible = "ibm,ebc-440spe", "ibm,ebc-440gp", "ibm,ebc";
165                                 dcr-reg = <0x012 0x002>;
166                                 #address-cells = <2>;
167                                 #size-cells = <1>;
168                                 clock-frequency = <0>; /* Filled in by zImage */
169                                 /* ranges property is supplied by U-Boot */
170                                 interrupts = <0x5 0x1>;
171                                 interrupt-parent = <&UIC1>;
172
173                                 nor_flash@0,0 {
174                                         compatible = "cfi-flash";
175                                         bank-width = <2>;
176                                         reg = <0x00000000 0x00000000 0x01000000>;
177                                         #address-cells = <1>;
178                                         #size-cells = <1>;
179                                         partition@0 {
180                                                 label = "kernel";
181                                                 reg = <0x00000000 0x001e0000>;
182                                         };
183                                         partition@1e0000 {
184                                                 label = "dtb";
185                                                 reg = <0x001e0000 0x00020000>;
186                                         };
187                                         partition@200000 {
188                                                 label = "root";
189                                                 reg = <0x00200000 0x00200000>;
190                                         };
191                                         partition@400000 {
192                                                 label = "user";
193                                                 reg = <0x00400000 0x00b60000>;
194                                         };
195                                         partition@f60000 {
196                                                 label = "env";
197                                                 reg = <0x00f60000 0x00040000>;
198                                         };
199                                         partition@fa0000 {
200                                                 label = "u-boot";
201                                                 reg = <0x00fa0000 0x00060000>;
202                                         };
203                                 };
204                         };
205
206                         UART0: serial@f0000200 {
207                                 device_type = "serial";
208                                 compatible = "ns16550";
209                                 reg = <0xf0000200 0x00000008>;
210                                 virtual-reg = <0xa0000200>;
211                                 clock-frequency = <0>; /* Filled in by zImage */
212                                 current-speed = <115200>;
213                                 interrupt-parent = <&UIC0>;
214                                 interrupts = <0x0 0x4>;
215                         };
216
217                         UART1: serial@f0000300 {
218                                 device_type = "serial";
219                                 compatible = "ns16550";
220                                 reg = <0xf0000300 0x00000008>;
221                                 virtual-reg = <0xa0000300>;
222                                 clock-frequency = <0>;
223                                 current-speed = <0>;
224                                 interrupt-parent = <&UIC0>;
225                                 interrupts = <0x1 0x4>;
226                         };
227
228
229                         UART2: serial@f0000600 {
230                                 device_type = "serial";
231                                 compatible = "ns16550";
232                                 reg = <0xf0000600 0x00000008>;
233                                 virtual-reg = <0xa0000600>;
234                                 clock-frequency = <0>;
235                                 current-speed = <0>;
236                                 interrupt-parent = <&UIC1>;
237                                 interrupts = <0x5 0x4>;
238                         };
239
240                         IIC0: i2c@f0000400 {
241                                 compatible = "ibm,iic-440spe", "ibm,iic-440gp", "ibm,iic";
242                                 reg = <0xf0000400 0x00000014>;
243                                 interrupt-parent = <&UIC0>;
244                                 interrupts = <0x2 0x4>;
245                         };
246
247                         IIC1: i2c@f0000500 {
248                                 compatible = "ibm,iic-440spe", "ibm,iic-440gp", "ibm,iic";
249                                 reg = <0xf0000500 0x00000014>;
250                                 interrupt-parent = <&UIC0>;
251                                 interrupts = <0x3 0x4>;
252                         };
253
254                         EMAC0: ethernet@f0000800 {
255                                 linux,network-index = <0x0>;
256                                 device_type = "network";
257                                 compatible = "ibm,emac-440spe", "ibm,emac4";
258                                 interrupt-parent = <&UIC1>;
259                                 interrupts = <0x1c 0x4 0x1d 0x4>;
260                                 reg = <0xf0000800 0x00000074>;
261                                 local-mac-address = [000000000000];
262                                 mal-device = <&MAL0>;
263                                 mal-tx-channel = <0>;
264                                 mal-rx-channel = <0>;
265                                 cell-index = <0>;
266                                 max-frame-size = <9000>;
267                                 rx-fifo-size = <4096>;
268                                 tx-fifo-size = <2048>;
269                                 phy-mode = "gmii";
270                                 phy-map = <0x00000000>;
271                                 has-inverted-stacr-oc;
272                                 has-new-stacr-staopc;
273                         };
274                 };
275
276                 PCIX0: pci@c0ec00000 {
277                         device_type = "pci";
278                         #interrupt-cells = <1>;
279                         #size-cells = <2>;
280                         #address-cells = <3>;
281                         compatible = "ibm,plb-pcix-440spe", "ibm,plb-pcix";
282                         primary;
283                         large-inbound-windows;
284                         enable-msi-hole;
285                         reg = <0x0000000c 0x0ec00000 0x00000008   /* Config space access */
286                                0x00000000 0x00000000 0x00000000   /* no IACK cycles */
287                                0x0000000c 0x0ed00000 0x00000004   /* Special cycles */
288                                0x0000000c 0x0ec80000 0x00000100   /* Internal registers */
289                                0x0000000c 0x0ec80100 0x000000fc>; /* Internal messaging registers */
290
291                         /* Outbound ranges, one memory and one IO,
292                          * later cannot be changed
293                          */
294                         ranges = <0x02000000 0x00000000 0x80000000 0x0000000d 0x80000000 0x00000000 0x80000000
295                                   0x01000000 0x00000000 0x00000000 0x0000000c 0x08000000 0x00000000 0x00010000>;
296
297                         /* Inbound 4GB range starting at 0 */
298                         dma-ranges = <0x42000000 0x0 0x0 0x0 0x0 0x1 0x00000000>;
299
300                         /* This drives busses 0 to 0xf */
301                         bus-range = <0x0 0xf>;
302
303                         /*
304                          * On Katmai, the following PCI-X interrupts signals
305                          * have to be enabled via jumpers (only INTA is
306                          * enabled per default):
307                          *
308                          * INTB: J3: 1-2
309                          * INTC: J2: 1-2
310                          * INTD: J1: 1-2
311                          */
312                         interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
313                         interrupt-map = <
314                                 /* IDSEL 1 */
315                                 0x800 0x0 0x0 0x1 &UIC1 0x14 0x8
316                                 0x800 0x0 0x0 0x2 &UIC1 0x13 0x8
317                                 0x800 0x0 0x0 0x3 &UIC1 0x12 0x8
318                                 0x800 0x0 0x0 0x4 &UIC1 0x11 0x8
319                         >;
320                 };
321
322                 PCIE0: pciex@d00000000 {
323                         device_type = "pci";
324                         #interrupt-cells = <1>;
325                         #size-cells = <2>;
326                         #address-cells = <3>;
327                         compatible = "ibm,plb-pciex-440spe", "ibm,plb-pciex";
328                         primary;
329                         port = <0x0>; /* port number */
330                         reg = <0x0000000d 0x00000000 0x20000000 /* Config space access */
331                                0x0000000c 0x10000000 0x00001000>;       /* Registers */
332                         dcr-reg = <0x100 0x020>;
333                         sdr-base = <0x300>;
334
335                         /* Outbound ranges, one memory and one IO,
336                          * later cannot be changed
337                          */
338                         ranges = <0x02000000 0x00000000 0x80000000 0x0000000e 0x00000000 0x00000000 0x80000000
339                                   0x01000000 0x00000000 0x00000000 0x0000000f 0x80000000 0x00000000 0x00010000>;
340
341                         /* Inbound 4GB range starting at 0 */
342                         dma-ranges = <0x42000000 0x0 0x0 0x0 0x0 0x1 0x00000000>;
343
344                         /* This drives busses 0x10 to 0x1f */
345                         bus-range = <0x10 0x1f>;
346
347                         /* Legacy interrupts (note the weird polarity, the bridge seems
348                          * to invert PCIe legacy interrupts).
349                          * We are de-swizzling here because the numbers are actually for
350                          * port of the root complex virtual P2P bridge. But I want
351                          * to avoid putting a node for it in the tree, so the numbers
352                          * below are basically de-swizzled numbers.
353                          * The real slot is on idsel 0, so the swizzling is 1:1
354                          */
355                         interrupt-map-mask = <0x0 0x0 0x0 0x7>;
356                         interrupt-map = <
357                                 0x0 0x0 0x0 0x1 &UIC3 0x0 0x4 /* swizzled int A */
358                                 0x0 0x0 0x0 0x2 &UIC3 0x1 0x4 /* swizzled int B */
359                                 0x0 0x0 0x0 0x3 &UIC3 0x2 0x4 /* swizzled int C */
360                                 0x0 0x0 0x0 0x4 &UIC3 0x3 0x4 /* swizzled int D */>;
361                 };
362
363                 PCIE1: pciex@d20000000 {
364                         device_type = "pci";
365                         #interrupt-cells = <1>;
366                         #size-cells = <2>;
367                         #address-cells = <3>;
368                         compatible = "ibm,plb-pciex-440spe", "ibm,plb-pciex";
369                         primary;
370                         port = <0x1>; /* port number */
371                         reg = <0x0000000d 0x20000000 0x20000000 /* Config space access */
372                                0x0000000c 0x10001000 0x00001000>;       /* Registers */
373                         dcr-reg = <0x120 0x020>;
374                         sdr-base = <0x340>;
375
376                         /* Outbound ranges, one memory and one IO,
377                          * later cannot be changed
378                          */
379                         ranges = <0x02000000 0x00000000 0x80000000 0x0000000e 0x80000000 0x00000000 0x80000000
380                                   0x01000000 0x00000000 0x00000000 0x0000000f 0x80010000 0x00000000 0x00010000>;
381
382                         /* Inbound 4GB range starting at 0 */
383                         dma-ranges = <0x42000000 0x0 0x0 0x0 0x0 0x1 0x00000000>;
384
385                         /* This drives busses 0x20 to 0x2f */
386                         bus-range = <0x20 0x2f>;
387
388                         /* Legacy interrupts (note the weird polarity, the bridge seems
389                          * to invert PCIe legacy interrupts).
390                          * We are de-swizzling here because the numbers are actually for
391                          * port of the root complex virtual P2P bridge. But I want
392                          * to avoid putting a node for it in the tree, so the numbers
393                          * below are basically de-swizzled numbers.
394                          * The real slot is on idsel 0, so the swizzling is 1:1
395                          */
396                         interrupt-map-mask = <0x0 0x0 0x0 0x7>;
397                         interrupt-map = <
398                                 0x0 0x0 0x0 0x1 &UIC3 0x4 0x4 /* swizzled int A */
399                                 0x0 0x0 0x0 0x2 &UIC3 0x5 0x4 /* swizzled int B */
400                                 0x0 0x0 0x0 0x3 &UIC3 0x6 0x4 /* swizzled int C */
401                                 0x0 0x0 0x0 0x4 &UIC3 0x7 0x4 /* swizzled int D */>;
402                 };
403
404                 PCIE2: pciex@d40000000 {
405                         device_type = "pci";
406                         #interrupt-cells = <1>;
407                         #size-cells = <2>;
408                         #address-cells = <3>;
409                         compatible = "ibm,plb-pciex-440spe", "ibm,plb-pciex";
410                         primary;
411                         port = <0x2>; /* port number */
412                         reg = <0x0000000d 0x40000000 0x20000000 /* Config space access */
413                                0x0000000c 0x10002000 0x00001000>;       /* Registers */
414                         dcr-reg = <0x140 0x020>;
415                         sdr-base = <0x370>;
416
417                         /* Outbound ranges, one memory and one IO,
418                          * later cannot be changed
419                          */
420                         ranges = <0x02000000 0x00000000 0x80000000 0x0000000f 0x00000000 0x00000000 0x80000000
421                                   0x01000000 0x00000000 0x00000000 0x0000000f 0x80020000 0x00000000 0x00010000>;
422
423                         /* Inbound 4GB range starting at 0 */
424                         dma-ranges = <0x42000000 0x0 0x0 0x0 0x0 0x1 0x00000000>;
425
426                         /* This drives busses 0x30 to 0x3f */
427                         bus-range = <0x30 0x3f>;
428
429                         /* Legacy interrupts (note the weird polarity, the bridge seems
430                          * to invert PCIe legacy interrupts).
431                          * We are de-swizzling here because the numbers are actually for
432                          * port of the root complex virtual P2P bridge. But I want
433                          * to avoid putting a node for it in the tree, so the numbers
434                          * below are basically de-swizzled numbers.
435                          * The real slot is on idsel 0, so the swizzling is 1:1
436                          */
437                         interrupt-map-mask = <0x0 0x0 0x0 0x7>;
438                         interrupt-map = <
439                                 0x0 0x0 0x0 0x1 &UIC3 0x8 0x4 /* swizzled int A */
440                                 0x0 0x0 0x0 0x2 &UIC3 0x9 0x4 /* swizzled int B */
441                                 0x0 0x0 0x0 0x3 &UIC3 0xa 0x4 /* swizzled int C */
442                                 0x0 0x0 0x0 0x4 &UIC3 0xb 0x4 /* swizzled int D */>;
443                 };
444
445                 I2O: i2o@400100000 {
446                         compatible = "ibm,i2o-440spe";
447                         reg = <0x00000004 0x00100000 0x100>;
448                         dcr-reg = <0x060 0x020>;
449                 };
450
451                 DMA0: dma0@400100100 {
452                         compatible = "ibm,dma-440spe";
453                         cell-index = <0>;
454                         reg = <0x00000004 0x00100100 0x100>;
455                         dcr-reg = <0x060 0x020>;
456                         interrupt-parent = <&DMA0>;
457                         interrupts = <0 1>;
458                         #interrupt-cells = <1>;
459                         #address-cells = <0>;
460                         #size-cells = <0>;
461                         interrupt-map = <
462                                 0 &UIC0 0x14 4
463                                 1 &UIC1 0x16 4>;
464                 };
465
466                 DMA1: dma1@400100200 {
467                         compatible = "ibm,dma-440spe";
468                         cell-index = <1>;
469                         reg = <0x00000004 0x00100200 0x100>;
470                         dcr-reg = <0x060 0x020>;
471                         interrupt-parent = <&DMA1>;
472                         interrupts = <0 1>;
473                         #interrupt-cells = <1>;
474                         #address-cells = <0>;
475                         #size-cells = <0>;
476                         interrupt-map = <
477                                 0 &UIC0 0x16 4
478                                 1 &UIC1 0x16 4>;
479                 };
480
481                 xor-accel@400200000 {
482                         compatible = "amcc,xor-accelerator";
483                         reg = <0x00000004 0x00200000 0x400>;
484                         interrupt-parent = <&UIC1>;
485                         interrupts = <0x1f 4>;
486                 };
487         };
488
489         chosen {
490                 linux,stdout-path = "/plb/opb/serial@f0000200";
491         };
492 };