ARM: EXYNOS5: Add machine and dt support for EHCI
[cascardo/linux.git] / arch / arm / boot / dts / exynos5250.dtsi
1 /*
2  * SAMSUNG EXYNOS5250 SoC device tree source
3  *
4  * Copyright (c) 2012 Samsung Electronics Co., Ltd.
5  *              http://www.samsung.com
6  *
7  * SAMSUNG EXYNOS5250 SoC device nodes are listed in this file.
8  * EXYNOS5250 based board files can include this file and provide
9  * values for board specfic bindings.
10  *
11  * Note: This file does not include device nodes for all the controllers in
12  * EXYNOS5250 SoC. As device tree coverage for EXYNOS5250 increases,
13  * additional nodes can be added to this file.
14  *
15  * This program is free software; you can redistribute it and/or modify
16  * it under the terms of the GNU General Public License version 2 as
17  * published by the Free Software Foundation.
18 */
19
20 /include/ "skeleton.dtsi"
21
22 / {
23         compatible = "samsung,exynos5250";
24         interrupt-parent = <&gic>;
25
26         gic:interrupt-controller@10481000 {
27                 compatible = "arm,cortex-a9-gic";
28                 #interrupt-cells = <3>;
29                 #address-cells = <0>;
30                 #size-cells = <0>;
31                 interrupt-controller;
32                 reg = <0x10481000 0x1000>, <0x10482000 0x2000>;
33         };
34
35         combiner:interrupt-controller@10440000 {
36                 compatible = "samsung,exynos4210-combiner";
37                 #interrupt-cells = <2>;
38                 interrupt-controller;
39                 samsung,combiner-nr = <32>;
40                 reg = <0x10440000 0x1000>;
41                 interrupts = <0 0 0>, <0 1 0>, <0 2 0>, <0 3 0>,
42                              <0 4 0>, <0 5 0>, <0 6 0>, <0 7 0>,
43                              <0 8 0>, <0 9 0>, <0 10 0>, <0 11 0>,
44                              <0 12 0>, <0 13 0>, <0 14 0>, <0 15 0>,
45                              <0 16 0>, <0 17 0>, <0 18 0>, <0 19 0>,
46                              <0 20 0>, <0 21 0>, <0 22 0>, <0 23 0>,
47                              <0 24 0>, <0 25 0>, <0 26 0>, <0 27 0>,
48                              <0 28 0>, <0 29 0>, <0 30 0>, <0 31 0>;
49         };
50
51         wakeup_eint: interrupt-controller@11400000 {
52                 compatible = "samsung,exynos5210-wakeup-eint";
53                 reg = <0x11400000 0x1000>;
54                 interrupt-controller;
55                 #interrupt-cells = <2>;
56                 interrupt-parent = <&wakeup_map>;
57                 interrupts = <0x0 0>, <0x1 0>, <0x2 0>, <0x3 0>,
58                              <0x4 0>, <0x5 0>, <0x6 0>, <0x7 0>,
59                              <0x8 0>, <0x9 0>, <0xa 0>, <0xb 0>,
60                              <0xc 0>, <0xd 0>, <0xe 0>, <0xf 0>,
61                              <0x10 0>;
62
63                 wakeup_map: interrupt-map {
64                         compatible = "samsung,exynos5210-wakeup-eint-map";
65                         #interrupt-cells = <2>;
66                         #address-cells = <0>;
67                         #size-cells = <0>;
68                         interrupt-map = <0x0 0 &combiner 23 0>,
69                                         <0x1 0 &combiner 24 0>,
70                                         <0x2 0 &combiner 25 0>,
71                                         <0x3 0 &combiner 25 1>,
72                                         <0x4 0 &combiner 26 0>,
73                                         <0x5 0 &combiner 26 1>,
74                                         <0x6 0 &combiner 27 0>,
75                                         <0x7 0 &combiner 27 1>,
76                                         <0x8 0 &combiner 28 0>,
77                                         <0x9 0 &combiner 28 1>,
78                                         <0xa 0 &combiner 29 0>,
79                                         <0xb 0 &combiner 29 1>,
80                                         <0xc 0 &combiner 30 0>,
81                                         <0xd 0 &combiner 30 1>,
82                                         <0xe 0 &combiner 31 0>,
83                                         <0xf 0 &combiner 31 1>,
84                                         <0x10 0 &gic 0 32 0>;
85                 };
86         };
87
88         watchdog {
89                 compatible = "samsung,s3c2410-wdt";
90                 reg = <0x101D0000 0x100>;
91                 interrupts = <0 42 0>;
92         };
93
94         mfc {
95                 compatible = "samsung,s5p-mfc-v6";
96                 reg = <0x11000000 0x10000>;
97                 interrupts = <0 96 0>;
98         };
99
100         ohci {
101                 compatible = "samsung,exynos-ohci";
102                 reg = <0x12120000 0x100>;
103                 interrupts = <0 71 0>;
104         };
105
106         ehci {
107                 compatible = "samsung,exynos-ehci";
108                 reg = <0x12110000 0x100>;
109                 interrupts = <0 71 0>;
110         };
111
112         rtc {
113                 compatible = "samsung,s3c6410-rtc";
114                 reg = <0x101E0000 0x100>;
115                 interrupts = <0 43 0>, <0 44 0>;
116         };
117
118         serial@12C00000 {
119                 compatible = "samsung,exynos4210-uart";
120                 reg = <0x12C00000 0x100>;
121                 interrupts = <0 51 0>;
122         };
123
124         serial@12C10000 {
125                 compatible = "samsung,exynos4210-uart";
126                 reg = <0x12C10000 0x100>;
127                 interrupts = <0 52 0>;
128         };
129
130         serial@12C20000 {
131                 compatible = "samsung,exynos4210-uart";
132                 reg = <0x12C20000 0x100>;
133                 interrupts = <0 53 0>;
134         };
135
136         serial@12C30000 {
137                 compatible = "samsung,exynos4210-uart";
138                 reg = <0x12C30000 0x100>;
139                 interrupts = <0 54 0>;
140         };
141
142         i2c@12C60000 {
143                 compatible = "samsung,s3c2440-i2c";
144                 reg = <0x12C60000 0x100>;
145                 interrupts = <0 56 0>;
146         };
147
148         i2c@12C70000 {
149                 compatible = "samsung,s3c2440-i2c";
150                 reg = <0x12C70000 0x100>;
151                 interrupts = <0 57 0>;
152         };
153
154         i2c@12C80000 {
155                 compatible = "samsung,s3c2440-i2c";
156                 reg = <0x12C80000 0x100>;
157                 interrupts = <0 58 0>;
158         };
159
160         i2c@12C90000 {
161                 compatible = "samsung,s3c2440-i2c";
162                 reg = <0x12C90000 0x100>;
163                 interrupts = <0 59 0>;
164         };
165
166         i2c@12CA0000 {
167                 compatible = "samsung,s3c2440-i2c";
168                 reg = <0x12CA0000 0x100>;
169                 interrupts = <0 60 0>;
170         };
171
172         i2c@12CB0000 {
173                 compatible = "samsung,s3c2440-i2c";
174                 reg = <0x12CB0000 0x100>;
175                 interrupts = <0 61 0>;
176         };
177
178         i2c@12CC0000 {
179                 compatible = "samsung,s3c2440-i2c";
180                 reg = <0x12CC0000 0x100>;
181                 interrupts = <0 62 0>;
182         };
183
184         i2c@12CD0000 {
185                 compatible = "samsung,s3c2440-i2c";
186                 reg = <0x12CD0000 0x100>;
187                 interrupts = <0 63 0>;
188         };
189
190         sysmmu_2: sysmmu@0x10A60000 {
191                 compatible = "samsung,s5p-sysmmu";
192                 reg = <0x10A60000 0x100>;
193                 interrupts = <24 5>;
194                 interrupt-parent = <&combiner>;
195         };
196
197         sysmmu_3: sysmmu@0x11200000 {
198                 compatible = "samsung,s5p-sysmmu";
199                 reg = <0x11200000 0x100>;
200                 interrupts = <8 5>;
201                 interrupt-parent = <&combiner>;
202         };
203
204         sysmmu_4: sysmmu@0x11210000 {
205                 compatible = "samsung,s5p-sysmmu";
206                 reg = <0x11210000 0x100>;
207                 interrupts = <6 2>;
208                 interrupt-parent = <&combiner>;
209         };
210
211         sysmmu_27: sysmmu@0x14640000 {
212                 compatible = "samsung,s5p-sysmmu";
213                 reg = <0x14640000 0x100>;
214                 interrupts = <3 2>;
215                 interrupt-parent = <&combiner>;
216         };
217
218         sysmmu_28: sysmmu@0x14650000 {
219                 compatible = "samsung,s5p-sysmmu";
220                 reg = <0x14650000 0x100>;
221                 interrupts = <7 4>;
222                 interrupt-parent = <&combiner>;
223         };
224
225         sysmmu_23: sysmmu@0x13E80000 {
226                 compatible = "samsung,s5p-sysmmu";
227                 reg = <0x13E80000 0x100>;
228                 interrupts = <2 0>;
229                 interrupt-parent = <&combiner>;
230         };
231
232         sysmmu_24: sysmmu@0x13E90000 {
233                 compatible = "samsung,s5p-sysmmu";
234                 reg = <0x13E90000 0x100>;
235                 interrupts = <2 2>;
236                 interrupt-parent = <&combiner>;
237         };
238
239         sysmmu_25: sysmmu@0x13EA0000 {
240                 compatible = "samsung,s5p-sysmmu";
241                 reg = <0x13EA0000 0x100>;
242                 interrupts = <2 4>;
243                 interrupt-parent = <&combiner>;
244         };
245
246         sysmmu_26: sysmmu@0x13EB0000 {
247                 compatible = "samsung,s5p-sysmmu";
248                 reg = <0x13EB0000 0x100>;
249                 interrupts = <2 6>;
250                 interrupt-parent = <&combiner>;
251         };
252
253         dwmmc0@12200000 {
254                 compatible = "synopsis,dw-mshc-exynos5250";
255                 reg = <0x12200000 0x1000>;
256                 interrupts = <0 75 0>;
257         };
258
259         dwmmc1@12210000 {
260                 compatible = "synopsis,dw-mshc-exynos5250";
261                 reg = <0x12210000 0x1000>;
262                 interrupts = <0 76 0>;
263         };
264
265         dwmmc2@12220000 {
266                 compatible = "synopsis,dw-mshc-exynos5250";
267                 reg = <0x12220000 0x1000>;
268                 interrupts = <0 77 0>;
269         };
270         
271         dwmmc3@12230000 {
272                 compatible = "synopsis,dw-mshc-exynos5250";
273                 reg = <0x12230000 0x1000>;
274                 interrupts = <0 78 0>;
275         };
276
277         amba {
278                 #address-cells = <1>;
279                 #size-cells = <1>;
280                 compatible = "arm,amba-bus";
281                 interrupt-parent = <&gic>;
282                 ranges;
283
284                 pdma0: pdma@121A0000 {
285                         compatible = "arm,pl330", "arm,primecell";
286                         reg = <0x121A0000 0x1000>;
287                         interrupts = <0 34 0>;
288                 };
289
290                 pdma1: pdma@121B0000 {
291                         compatible = "arm,pl330", "arm,primecell";
292                         reg = <0x121B0000 0x1000>;
293                         interrupts = <0 35 0>;
294                 };
295
296                 mdma0: mdma@10800000 {
297                         compatible = "arm,pl330", "arm,primecell";
298                         reg = <0x10800000 0x1000>;
299                         interrupts = <0 33 0>;
300                 };
301
302                 mdma1: mdma@11C10000 {
303                         compatible = "arm,pl330", "arm,primecell";
304                         reg = <0x11C10000 0x1000>;
305                         interrupts = <0 124 0>;
306                 };
307         };
308
309         gpio-controllers {
310                 #address-cells = <1>;
311                 #size-cells = <1>;
312                 gpio-controller;
313                 ranges;
314
315                 gpa0: gpio-controller@11400000 {
316                         compatible = "samsung,exynos4-gpio";
317                         reg = <0x11400000 0x20>;
318                         #gpio-cells = <4>;
319                 };
320
321                 gpa1: gpio-controller@11400020 {
322                         compatible = "samsung,exynos4-gpio";
323                         reg = <0x11400020 0x20>;
324                         #gpio-cells = <4>;
325                 };
326
327                 gpa2: gpio-controller@11400040 {
328                         compatible = "samsung,exynos4-gpio";
329                         reg = <0x11400040 0x20>;
330                         #gpio-cells = <4>;
331                 };
332
333                 gpb0: gpio-controller@11400060 {
334                         compatible = "samsung,exynos4-gpio";
335                         reg = <0x11400060 0x20>;
336                         #gpio-cells = <4>;
337                 };
338
339                 gpb1: gpio-controller@11400080 {
340                         compatible = "samsung,exynos4-gpio";
341                         reg = <0x11400080 0x20>;
342                         #gpio-cells = <4>;
343                 };
344
345                 gpb2: gpio-controller@114000A0 {
346                         compatible = "samsung,exynos4-gpio";
347                         reg = <0x114000A0 0x20>;
348                         #gpio-cells = <4>;
349                 };
350
351                 gpb3: gpio-controller@114000C0 {
352                         compatible = "samsung,exynos4-gpio";
353                         reg = <0x114000C0 0x20>;
354                         #gpio-cells = <4>;
355                 };
356
357                 gpc0: gpio-controller@114000E0 {
358                         compatible = "samsung,exynos4-gpio";
359                         reg = <0x114000E0 0x20>;
360                         #gpio-cells = <4>;
361                 };
362
363                 gpc1: gpio-controller@11400100 {
364                         compatible = "samsung,exynos4-gpio";
365                         reg = <0x11400100 0x20>;
366                         #gpio-cells = <4>;
367                 };
368
369                 gpc2: gpio-controller@11400120 {
370                         compatible = "samsung,exynos4-gpio";
371                         reg = <0x11400120 0x20>;
372                         #gpio-cells = <4>;
373                 };
374
375                 gpc3: gpio-controller@11400140 {
376                         compatible = "samsung,exynos4-gpio";
377                         reg = <0x11400140 0x20>;
378                         #gpio-cells = <4>;
379                 };
380
381                 gpc4: gpio-controller@114002E0 {
382                         compatible = "samsung,exynos4-gpio";
383                         reg = <0x114002E0 0x20>;
384                         #gpio-cells = <4>;
385                 };
386
387                 gpd0: gpio-controller@11400160 {
388                         compatible = "samsung,exynos4-gpio";
389                         reg = <0x11400160 0x20>;
390                         #gpio-cells = <4>;
391                 };
392
393                 gpd1: gpio-controller@11400180 {
394                         compatible = "samsung,exynos4-gpio";
395                         reg = <0x11400180 0x20>;
396                         #gpio-cells = <4>;
397                 };
398
399                 gpy0: gpio-controller@114001A0 {
400                         compatible = "samsung,exynos4-gpio";
401                         reg = <0x114001A0 0x20>;
402                         #gpio-cells = <4>;
403                 };
404
405                 gpy1: gpio-controller@114001C0 {
406                         compatible = "samsung,exynos4-gpio";
407                         reg = <0x114001C0 0x20>;
408                         #gpio-cells = <4>;
409                 };
410
411                 gpy2: gpio-controller@114001E0 {
412                         compatible = "samsung,exynos4-gpio";
413                         reg = <0x114001E0 0x20>;
414                         #gpio-cells = <4>;
415                 };
416
417                 gpy3: gpio-controller@11400200 {
418                         compatible = "samsung,exynos4-gpio";
419                         reg = <0x11400200 0x20>;
420                         #gpio-cells = <4>;
421                 };
422
423                 gpy4: gpio-controller@11400220 {
424                         compatible = "samsung,exynos4-gpio";
425                         reg = <0x11400220 0x20>;
426                         #gpio-cells = <4>;
427                 };
428
429                 gpy5: gpio-controller@11400240 {
430                         compatible = "samsung,exynos4-gpio";
431                         reg = <0x11400240 0x20>;
432                         #gpio-cells = <4>;
433                 };
434
435                 gpy6: gpio-controller@11400260 {
436                         compatible = "samsung,exynos4-gpio";
437                         reg = <0x11400260 0x20>;
438                         #gpio-cells = <4>;
439                 };
440
441                 gpx0: gpio-controller@11400C00 {
442                         compatible = "samsung,exynos4-gpio";
443                         reg = <0x11400C00 0x20>;
444                         #gpio-cells = <4>;
445                 };
446
447                 gpx1: gpio-controller@11400C20 {
448                         compatible = "samsung,exynos4-gpio";
449                         reg = <0x11400C20 0x20>;
450                         #gpio-cells = <4>;
451                 };
452
453                 gpx2: gpio-controller@11400C40 {
454                         compatible = "samsung,exynos4-gpio";
455                         reg = <0x11400C40 0x20>;
456                         #gpio-cells = <4>;
457                 };
458
459                 gpx3: gpio-controller@11400C60 {
460                         compatible = "samsung,exynos4-gpio";
461                         reg = <0x11400C60 0x20>;
462                         #gpio-cells = <4>;
463                 };
464
465                 gpe0: gpio-controller@13400000 {
466                         compatible = "samsung,exynos4-gpio";
467                         reg = <0x13400000 0x20>;
468                         #gpio-cells = <4>;
469                 };
470
471                 gpe1: gpio-controller@13400020 {
472                         compatible = "samsung,exynos4-gpio";
473                         reg = <0x13400020 0x20>;
474                         #gpio-cells = <4>;
475                 };
476
477                 gpf0: gpio-controller@13400040 {
478                         compatible = "samsung,exynos4-gpio";
479                         reg = <0x13400040 0x20>;
480                         #gpio-cells = <4>;
481                 };
482
483                 gpf1: gpio-controller@13400060 {
484                         compatible = "samsung,exynos4-gpio";
485                         reg = <0x13400060 0x20>;
486                         #gpio-cells = <4>;
487                 };
488
489                 gpg0: gpio-controller@13400080 {
490                         compatible = "samsung,exynos4-gpio";
491                         reg = <0x13400080 0x20>;
492                         #gpio-cells = <4>;
493                 };
494
495                 gpg1: gpio-controller@134000A0 {
496                         compatible = "samsung,exynos4-gpio";
497                         reg = <0x134000A0 0x20>;
498                         #gpio-cells = <4>;
499                 };
500
501                 gpg2: gpio-controller@134000C0 {
502                         compatible = "samsung,exynos4-gpio";
503                         reg = <0x134000C0 0x20>;
504                         #gpio-cells = <4>;
505                 };
506
507                 gph0: gpio-controller@134000E0 {
508                         compatible = "samsung,exynos4-gpio";
509                         reg = <0x134000E0 0x20>;
510                         #gpio-cells = <4>;
511                 };
512
513                 gph1: gpio-controller@13400100 {
514                         compatible = "samsung,exynos4-gpio";
515                         reg = <0x13400100 0x20>;
516                         #gpio-cells = <4>;
517                 };
518
519                 gpv0: gpio-controller@10D10000 {
520                         compatible = "samsung,exynos4-gpio";
521                         reg = <0x10D10000 0x20>;
522                         #gpio-cells = <4>;
523                 };
524
525                 gpv1: gpio-controller@10D10020 {
526                         compatible = "samsung,exynos4-gpio";
527                         reg = <0x10D10020 0x20>;
528                         #gpio-cells = <4>;
529                 };
530
531                 gpv2: gpio-controller@10D10040 {
532                         compatible = "samsung,exynos4-gpio";
533                         reg = <0x10D10060 0x20>;
534                         #gpio-cells = <4>;
535                 };
536
537                 gpv3: gpio-controller@10D10060 {
538                         compatible = "samsung,exynos4-gpio";
539                         reg = <0x10D10080 0x20>;
540                         #gpio-cells = <4>;
541                 };
542
543                 gpv4: gpio-controller@10D10080 {
544                         compatible = "samsung,exynos4-gpio";
545                         reg = <0x10D100C0 0x20>;
546                         #gpio-cells = <4>;
547                 };
548
549                 gpz: gpio-controller@03860000 {
550                         compatible = "samsung,exynos4-gpio";
551                         reg = <0x03860000 0x20>;
552                         #gpio-cells = <4>;
553                 };
554         };
555
556         fimd {
557                 compatible = "samsung,exynos5-fb";
558                 interrupt-parent = <&combiner>;
559                 reg = <0x14400000 0x40000>;
560                 interrupts = <18 4>, <18 5>, <18 6>;
561         };
562
563         mipi {
564                 compatible = "samsung,exynos5-mipi";
565                 reg = <0x14500000 0x10000>;
566                 interrupts = <0 82 0>;
567         };
568
569         gsc_0:  gsc@0x13e00000 {
570                 compatible = "samsung,exynos-gsc";
571                 reg = <0x13e00000 0x1000>;
572                 interrupts = <0 85 0>;
573         };
574
575         gsc_1:  gsc@0x13e10000 {
576                 compatible = "samsung,exynos-gsc";
577                 reg = <0x13e10000 0x1000>;
578                 interrupts = <0 86 0>;
579         };
580
581         gsc_2:  gsc@0x13e20000 {
582                 compatible = "samsung,exynos-gsc";
583                 reg = <0x13e20000 0x1000>;
584                 interrupts = <0 87 0>;
585         };
586
587         gsc_3:  gsc@0x13e30000 {
588                 compatible = "samsung,exynos-gsc";
589                 reg = <0x13e30000 0x1000>;
590                 interrupts = <0 88 0>;
591         };
592
593         g2d {
594                 compatible = "samsung,s5p-g2d";
595                 reg = <0x10850000 0x400>;
596                 interrupts = <0 91 0>;
597         };
598 };