Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jmorris...
[linux/fpc-iii.git] / arch / powerpc / boot / dts / socrates.dts
blob134a5ff917e1c49b5c436c7ba63fe86821002ff5
1 /*
2  * Device Tree Source for the Socrates board (MPC8544).
3  *
4  * Copyright (c) 2008 Emcraft Systems.
5  * Sergei Poselenov, <sposelenov@emcraft.com>
6  *
7  * This program is free software; you can redistribute  it and/or modify it
8  * under  the terms of  the GNU General  Public License as published by the
9  * Free Software Foundation;  either version 2 of the  License, or (at your
10  * option) any later version.
11  */
13 /dts-v1/;
15 / {
16         model = "abb,socrates";
17         compatible = "abb,socrates";
18         #address-cells = <1>;
19         #size-cells = <1>;
21         aliases {
22                 ethernet0 = &enet0;
23                 ethernet1 = &enet1;
24                 serial0 = &serial0;
25                 serial1 = &serial1;
26                 pci0 = &pci0;
27         };
29         cpus {
30                 #address-cells = <1>;
31                 #size-cells = <0>;
33                 PowerPC,8544@0 {
34                         device_type = "cpu";
35                         reg = <0>;
36                         d-cache-line-size = <32>;
37                         i-cache-line-size = <32>;
38                         d-cache-size = <0x8000>;        // L1, 32K
39                         i-cache-size = <0x8000>;        // L1, 32K
40                         timebase-frequency = <0>;
41                         bus-frequency = <0>;
42                         clock-frequency = <0>;
43                         next-level-cache = <&L2>;
44                 };
45         };
47         memory {
48                 device_type = "memory";
49                 reg = <0x00000000 0x00000000>;  // Filled in by U-Boot
50         };
52         soc8544@e0000000 {
53                 #address-cells = <1>;
54                 #size-cells = <1>;
55                 device_type = "soc";
57                 ranges = <0x00000000 0xe0000000 0x00100000>;
58                 bus-frequency = <0>;            // Filled in by U-Boot
59                 compatible = "fsl,mpc8544-immr", "simple-bus";
61                 ecm-law@0 {
62                         compatible = "fsl,ecm-law";
63                         reg = <0x0 0x1000>;
64                         fsl,num-laws = <10>;
65                 };
67                 ecm@1000 {
68                         compatible = "fsl,mpc8544-ecm", "fsl,ecm";
69                         reg = <0x1000 0x1000>;
70                         interrupts = <17 2>;
71                         interrupt-parent = <&mpic>;
72                 };
74                 memory-controller@2000 {
75                         compatible = "fsl,mpc8544-memory-controller";
76                         reg = <0x2000 0x1000>;
77                         interrupt-parent = <&mpic>;
78                         interrupts = <18 2>;
79                 };
81                 L2: l2-cache-controller@20000 {
82                         compatible = "fsl,mpc8544-l2-cache-controller";
83                         reg = <0x20000 0x1000>;
84                         cache-line-size = <32>;
85                         cache-size = <0x40000>; // L2, 256K
86                         interrupt-parent = <&mpic>;
87                         interrupts = <16 2>;
88                 };
90                 i2c@3000 {
91                         #address-cells = <1>;
92                         #size-cells = <0>;
93                         cell-index = <0>;
94                         compatible = "fsl,mpc8544-i2c", "fsl-i2c";
95                         reg = <0x3000 0x100>;
96                         interrupts = <43 2>;
97                         interrupt-parent = <&mpic>;
98                         fsl,preserve-clocking;
100                         dtt@28 {
101                                 compatible = "winbond,w83782d";
102                                 reg = <0x28>;
103                         };
104                         rtc@32 {
105                                 compatible = "epson,rx8025";
106                                 reg = <0x32>;
107                                 interrupts = <7 1>;
108                                 interrupt-parent = <&mpic>;
109                         };
110                         dtt@4c {
111                                 compatible = "dallas,ds75";
112                                 reg = <0x4c>;
113                         };
114                         ts@4a {
115                                 compatible = "ti,tsc2003";
116                                 reg = <0x4a>;
117                                 interrupt-parent = <&mpic>;
118                                 interrupts = <8 1>;
119                         };
120                 };
122                 i2c@3100 {
123                         #address-cells = <1>;
124                         #size-cells = <0>;
125                         cell-index = <1>;
126                         compatible = "fsl,mpc8544-i2c", "fsl-i2c";
127                         reg = <0x3100 0x100>;
128                         interrupts = <43 2>;
129                         interrupt-parent = <&mpic>;
130                         fsl,preserve-clocking;
131                 };
133                 enet0: ethernet@24000 {
134                         #address-cells = <1>;
135                         #size-cells = <1>;
136                         cell-index = <0>;
137                         device_type = "network";
138                         model = "eTSEC";
139                         compatible = "gianfar";
140                         reg = <0x24000 0x1000>;
141                         ranges = <0x0 0x24000 0x1000>;
142                         local-mac-address = [ 00 00 00 00 00 00 ];
143                         interrupts = <29 2 30 2 34 2>;
144                         interrupt-parent = <&mpic>;
145                         phy-handle = <&phy0>;
146                         tbi-handle = <&tbi0>;
147                         phy-connection-type = "rgmii-id";
149                         mdio@520 {
150                                 #address-cells = <1>;
151                                 #size-cells = <0>;
152                                 compatible = "fsl,gianfar-mdio";
153                                 reg = <0x520 0x20>;
155                                 phy0: ethernet-phy@0 {
156                                         interrupt-parent = <&mpic>;
157                                         interrupts = <0 1>;
158                                         reg = <0>;
159                                 };
160                                 phy1: ethernet-phy@1 {
161                                         interrupt-parent = <&mpic>;
162                                         interrupts = <0 1>;
163                                         reg = <1>;
164                                 };
165                                 tbi0: tbi-phy@11 {
166                                         reg = <0x11>;
167                                 };
168                         };
169                 };
171                 enet1: ethernet@26000 {
172                         #address-cells = <1>;
173                         #size-cells = <1>;
174                         cell-index = <1>;
175                         device_type = "network";
176                         model = "eTSEC";
177                         compatible = "gianfar";
178                         reg = <0x26000 0x1000>;
179                         ranges = <0x0 0x26000 0x1000>;
180                         local-mac-address = [ 00 00 00 00 00 00 ];
181                         interrupts = <31 2 32 2 33 2>;
182                         interrupt-parent = <&mpic>;
183                         phy-handle = <&phy1>;
184                         tbi-handle = <&tbi1>;
185                         phy-connection-type = "rgmii-id";
187                         mdio@520 {
188                                 #address-cells = <1>;
189                                 #size-cells = <0>;
190                                 compatible = "fsl,gianfar-tbi";
191                                 reg = <0x520 0x20>;
193                                 tbi1: tbi-phy@11 {
194                                         reg = <0x11>;
195                                 };
196                         };
197                 };
199                 serial0: serial@4500 {
200                         cell-index = <0>;
201                         device_type = "serial";
202                         compatible = "fsl,ns16550", "ns16550";
203                         reg = <0x4500 0x100>;
204                         clock-frequency = <0>;
205                         interrupts = <42 2>;
206                         interrupt-parent = <&mpic>;
207                 };
209                 serial1: serial@4600 {
210                         cell-index = <1>;
211                         device_type = "serial";
212                         compatible = "fsl,ns16550", "ns16550";
213                         reg = <0x4600 0x100>;
214                         clock-frequency = <0>;
215                         interrupts = <42 2>;
216                         interrupt-parent = <&mpic>;
217                 };
219                 global-utilities@e0000 {        //global utilities block
220                         compatible = "fsl,mpc8548-guts";
221                         reg = <0xe0000 0x1000>;
222                         fsl,has-rstcr;
223                 };
225                 mpic: pic@40000 {
226                         interrupt-controller;
227                         #address-cells = <0>;
228                         #interrupt-cells = <2>;
229                         reg = <0x40000 0x40000>;
230                         compatible = "chrp,open-pic";
231                         device_type = "open-pic";
232                 };
233         };
236         localbus {
237                 compatible = "fsl,mpc8544-localbus",
238                              "fsl,pq3-localbus",
239                              "simple-bus";
240                 #address-cells = <2>;
241                 #size-cells = <1>;
242                 reg = <0xe0005000 0x40>;
243                 interrupt-parent = <&mpic>;
244                 interrupts = <19 2>;
246                 ranges = <0 0 0xfc000000 0x04000000
247                           2 0 0xc8000000 0x04000000
248                           3 0 0xc0000000 0x00100000
249                         >; /* Overwritten by U-Boot */
251                 nor_flash@0,0 {
252                         compatible = "amd,s29gl256n", "cfi-flash";
253                         bank-width = <2>;
254                         reg = <0x0 0x000000 0x4000000>;
255                         #address-cells = <1>;
256                         #size-cells = <1>;
257                         partition@0 {
258                                 label = "kernel";
259                                 reg = <0x0 0x1e0000>;
260                                 read-only;
261                         };
262                         partition@1e0000 {
263                                 label = "dtb";
264                                 reg = <0x1e0000 0x20000>;
265                         };
266                         partition@200000 {
267                                 label = "root";
268                                 reg = <0x200000 0x200000>;
269                         };
270                         partition@400000 {
271                                 label = "user";
272                                 reg = <0x400000 0x3b80000>;
273                         };
274                         partition@3f80000 {
275                                 label = "env";
276                                 reg = <0x3f80000 0x40000>;
277                                 read-only;
278                         };
279                         partition@3fc0000 {
280                                 label = "u-boot";
281                                 reg = <0x3fc0000 0x40000>;
282                                 read-only;
283                         };
284                 };
286                 display@2,0 {
287                         compatible = "fujitsu,lime";
288                         reg = <2 0x0 0x4000000>;
289                         interrupt-parent = <&mpic>;
290                         interrupts = <6 1>;
291                 };
293                 fpga_pic: fpga-pic@3,10 {
294                         compatible = "abb,socrates-fpga-pic";
295                         reg = <3 0x10 0x10>;
296                         interrupt-controller;
297                         /* IRQs 2, 10, 11, active low, level-sensitive */
298                         interrupts = <2 1 10 1 11 1>;
299                         interrupt-parent = <&mpic>;
300                         #interrupt-cells = <3>;
301                 };
303                 spi@3,60 {
304                         compatible = "abb,socrates-spi";
305                         reg = <3 0x60 0x10>;
306                         interrupts = <8 4 0>;   // number, type, routing
307                         interrupt-parent = <&fpga_pic>;
308                 };
310                 nand@3,70 {
311                         compatible = "abb,socrates-nand";
312                         reg = <3 0x70 0x04>;
313                         bank-width = <1>;
314                         #address-cells = <1>;
315                         #size-cells = <1>;
316                         data@0 {
317                                 label = "data";
318                                 reg = <0x0 0x40000000>;
319                         };
320                 };
322                 can@3,100 {
323                         compatible = "philips,sja1000";
324                         reg = <3 0x100 0x80>;
325                         interrupts = <2 8 1>;   // number, type, routing
326                         interrupt-parent = <&fpga_pic>;
327                 };
328         };
330         pci0: pci@e0008000 {
331                 #interrupt-cells = <1>;
332                 #size-cells = <2>;
333                 #address-cells = <3>;
334                 compatible = "fsl,mpc8540-pci";
335                 device_type = "pci";
336                 reg = <0xe0008000 0x1000>;
337                 clock-frequency = <66666666>;
339                 interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
340                 interrupt-map = <
341                                 /* IDSEL 0x11 */
342                                  0x8800 0x0 0x0 1 &mpic 5 1
343                                 /* IDSEL 0x12 */
344                                  0x9000 0x0 0x0 1 &mpic 4 1>;
345                 interrupt-parent = <&mpic>;
346                 interrupts = <24 2>;
347                 bus-range = <0x0 0x0>;
348                 ranges = <0x02000000 0x0 0x80000000 0x80000000 0x0 0x20000000
349                           0x01000000 0x0 0x00000000 0xe2000000 0x0 0x01000000>;
350         };