Loading...
1/*
2 * This file is licensed under the terms of the GNU General Public License
3 * version 2. This program is licensed "as is" without any warranty of any
4 * kind, whether express or implied.
5 */
6
7#include <dt-bindings/gpio/gpio.h>
8#include <dt-bindings/pinctrl/dm814x.h>
9
10/ {
11 compatible = "ti,dm814";
12 interrupt-parent = <&intc>;
13 #address-cells = <1>;
14 #size-cells = <1>;
15 chosen { };
16
17 aliases {
18 i2c0 = &i2c1;
19 i2c1 = &i2c2;
20 serial0 = &uart1;
21 serial1 = &uart2;
22 serial2 = &uart3;
23 ethernet0 = &cpsw_emac0;
24 ethernet1 = &cpsw_emac1;
25 usb0 = &usb0;
26 usb1 = &usb1;
27 phy0 = &usb0_phy;
28 phy1 = &usb1_phy;
29 };
30
31 cpus {
32 #address-cells = <1>;
33 #size-cells = <0>;
34 cpu@0 {
35 compatible = "arm,cortex-a8";
36 device_type = "cpu";
37 reg = <0>;
38 };
39 };
40
41 pmu {
42 compatible = "arm,cortex-a8-pmu";
43 interrupts = <3>;
44 };
45
46 /*
47 * The soc node represents the soc top level view. It is used for IPs
48 * that are not memory mapped in the MPU view or for the MPU itself.
49 */
50 soc {
51 compatible = "ti,omap-infra";
52 mpu {
53 compatible = "ti,omap3-mpu";
54 ti,hwmods = "mpu";
55 };
56 };
57
58 ocp {
59 compatible = "simple-bus";
60 #address-cells = <1>;
61 #size-cells = <1>;
62 ranges;
63 ti,hwmods = "l3_main";
64
65 usb: usb@47400000 {
66 compatible = "ti,am33xx-usb";
67 reg = <0x47400000 0x1000>;
68 ranges;
69 #address-cells = <1>;
70 #size-cells = <1>;
71 ti,hwmods = "usb_otg_hs";
72
73 usb0_phy: usb-phy@47401300 {
74 compatible = "ti,am335x-usb-phy";
75 reg = <0x47401300 0x100>;
76 reg-names = "phy";
77 ti,ctrl_mod = <&usb_ctrl_mod>;
78 #phy-cells = <0>;
79 };
80
81 usb0: usb@47401000 {
82 compatible = "ti,musb-am33xx";
83 reg = <0x47401400 0x400
84 0x47401000 0x200>;
85 reg-names = "mc", "control";
86
87 interrupts = <18>;
88 interrupt-names = "mc";
89 dr_mode = "otg";
90 mentor,multipoint = <1>;
91 mentor,num-eps = <16>;
92 mentor,ram-bits = <12>;
93 mentor,power = <500>;
94 phys = <&usb0_phy>;
95
96 dmas = <&cppi41dma 0 0 &cppi41dma 1 0
97 &cppi41dma 2 0 &cppi41dma 3 0
98 &cppi41dma 4 0 &cppi41dma 5 0
99 &cppi41dma 6 0 &cppi41dma 7 0
100 &cppi41dma 8 0 &cppi41dma 9 0
101 &cppi41dma 10 0 &cppi41dma 11 0
102 &cppi41dma 12 0 &cppi41dma 13 0
103 &cppi41dma 14 0 &cppi41dma 0 1
104 &cppi41dma 1 1 &cppi41dma 2 1
105 &cppi41dma 3 1 &cppi41dma 4 1
106 &cppi41dma 5 1 &cppi41dma 6 1
107 &cppi41dma 7 1 &cppi41dma 8 1
108 &cppi41dma 9 1 &cppi41dma 10 1
109 &cppi41dma 11 1 &cppi41dma 12 1
110 &cppi41dma 13 1 &cppi41dma 14 1>;
111 dma-names =
112 "rx1", "rx2", "rx3", "rx4", "rx5", "rx6", "rx7",
113 "rx8", "rx9", "rx10", "rx11", "rx12", "rx13",
114 "rx14", "rx15",
115 "tx1", "tx2", "tx3", "tx4", "tx5", "tx6", "tx7",
116 "tx8", "tx9", "tx10", "tx11", "tx12", "tx13",
117 "tx14", "tx15";
118 };
119
120 usb1: usb@47401800 {
121 compatible = "ti,musb-am33xx";
122 reg = <0x47401c00 0x400
123 0x47401800 0x200>;
124 reg-names = "mc", "control";
125 interrupts = <19>;
126 interrupt-names = "mc";
127 dr_mode = "otg";
128 mentor,multipoint = <1>;
129 mentor,num-eps = <16>;
130 mentor,ram-bits = <12>;
131 mentor,power = <500>;
132 phys = <&usb1_phy>;
133
134 dmas = <&cppi41dma 15 0 &cppi41dma 16 0
135 &cppi41dma 17 0 &cppi41dma 18 0
136 &cppi41dma 19 0 &cppi41dma 20 0
137 &cppi41dma 21 0 &cppi41dma 22 0
138 &cppi41dma 23 0 &cppi41dma 24 0
139 &cppi41dma 25 0 &cppi41dma 26 0
140 &cppi41dma 27 0 &cppi41dma 28 0
141 &cppi41dma 29 0 &cppi41dma 15 1
142 &cppi41dma 16 1 &cppi41dma 17 1
143 &cppi41dma 18 1 &cppi41dma 19 1
144 &cppi41dma 20 1 &cppi41dma 21 1
145 &cppi41dma 22 1 &cppi41dma 23 1
146 &cppi41dma 24 1 &cppi41dma 25 1
147 &cppi41dma 26 1 &cppi41dma 27 1
148 &cppi41dma 28 1 &cppi41dma 29 1>;
149 dma-names =
150 "rx1", "rx2", "rx3", "rx4", "rx5", "rx6", "rx7",
151 "rx8", "rx9", "rx10", "rx11", "rx12", "rx13",
152 "rx14", "rx15",
153 "tx1", "tx2", "tx3", "tx4", "tx5", "tx6", "tx7",
154 "tx8", "tx9", "tx10", "tx11", "tx12", "tx13",
155 "tx14", "tx15";
156 };
157
158 cppi41dma: dma-controller@47402000 {
159 compatible = "ti,am3359-cppi41";
160 reg = <0x47400000 0x1000
161 0x47402000 0x1000
162 0x47403000 0x1000
163 0x47404000 0x4000>;
164 reg-names = "glue", "controller", "scheduler", "queuemgr";
165 interrupts = <17>;
166 interrupt-names = "glue";
167 #dma-cells = <2>;
168 #dma-channels = <30>;
169 #dma-requests = <256>;
170 };
171 };
172
173 /*
174 * See TRM "Table 1-317. L4LS Instance Summary" for hints.
175 * It shows the module target agent registers though, so the
176 * actual device is typically 0x1000 before the target agent
177 * except in cases where the module is larger than 0x1000.
178 */
179 l4ls: l4ls@48000000 {
180 compatible = "ti,dm814-l4ls", "simple-bus";
181 #address-cells = <1>;
182 #size-cells = <1>;
183 ranges = <0 0x48000000 0x2000000>;
184
185 i2c1: i2c@28000 {
186 compatible = "ti,omap4-i2c";
187 #address-cells = <1>;
188 #size-cells = <0>;
189 ti,hwmods = "i2c1";
190 reg = <0x28000 0x1000>;
191 interrupts = <70>;
192 };
193
194 elm: elm@80000 {
195 compatible = "ti,814-elm";
196 ti,hwmods = "elm";
197 reg = <0x80000 0x2000>;
198 interrupts = <4>;
199 };
200
201 gpio1: gpio@32000 {
202 compatible = "ti,omap4-gpio";
203 ti,hwmods = "gpio1";
204 ti,gpio-always-on;
205 reg = <0x32000 0x2000>;
206 interrupts = <96>;
207 gpio-controller;
208 #gpio-cells = <2>;
209 interrupt-controller;
210 #interrupt-cells = <2>;
211 };
212
213 gpio2: gpio@4c000 {
214 compatible = "ti,omap4-gpio";
215 ti,hwmods = "gpio2";
216 ti,gpio-always-on;
217 reg = <0x4c000 0x2000>;
218 interrupts = <98>;
219 gpio-controller;
220 #gpio-cells = <2>;
221 interrupt-controller;
222 #interrupt-cells = <2>;
223 };
224
225 i2c2: i2c@2a000 {
226 compatible = "ti,omap4-i2c";
227 #address-cells = <1>;
228 #size-cells = <0>;
229 ti,hwmods = "i2c2";
230 reg = <0x2a000 0x1000>;
231 interrupts = <71>;
232 };
233
234 mcspi1: spi@30000 {
235 compatible = "ti,omap4-mcspi";
236 reg = <0x30000 0x1000>;
237 #address-cells = <1>;
238 #size-cells = <0>;
239 interrupts = <65>;
240 ti,spi-num-cs = <4>;
241 ti,hwmods = "mcspi1";
242 dmas = <&edma 16 0 &edma 17 0
243 &edma 18 0 &edma 19 0>;
244 dma-names = "tx0", "rx0", "tx1", "rx1";
245 };
246
247 timer1: timer@2e000 {
248 compatible = "ti,dm814-timer";
249 reg = <0x2e000 0x2000>;
250 interrupts = <67>;
251 ti,hwmods = "timer1";
252 ti,timer-alwon;
253 clocks = <&timer1_fck>;
254 clock-names = "fck";
255 };
256
257 uart1: uart@20000 {
258 compatible = "ti,am3352-uart", "ti,omap3-uart";
259 ti,hwmods = "uart1";
260 reg = <0x20000 0x2000>;
261 clock-frequency = <48000000>;
262 interrupts = <72>;
263 dmas = <&edma 26 0 &edma 27 0>;
264 dma-names = "tx", "rx";
265 };
266
267 uart2: uart@22000 {
268 compatible = "ti,am3352-uart", "ti,omap3-uart";
269 ti,hwmods = "uart2";
270 reg = <0x22000 0x2000>;
271 clock-frequency = <48000000>;
272 interrupts = <73>;
273 dmas = <&edma 28 0 &edma 29 0>;
274 dma-names = "tx", "rx";
275 };
276
277 uart3: uart@24000 {
278 compatible = "ti,am3352-uart", "ti,omap3-uart";
279 ti,hwmods = "uart3";
280 reg = <0x24000 0x2000>;
281 clock-frequency = <48000000>;
282 interrupts = <74>;
283 dmas = <&edma 30 0 &edma 31 0>;
284 dma-names = "tx", "rx";
285 };
286
287 timer2: timer@40000 {
288 compatible = "ti,dm814-timer";
289 reg = <0x40000 0x2000>;
290 interrupts = <68>;
291 ti,hwmods = "timer2";
292 clocks = <&timer2_fck>;
293 clock-names = "fck";
294 };
295
296 timer3: timer@42000 {
297 compatible = "ti,dm814-timer";
298 reg = <0x42000 0x2000>;
299 interrupts = <69>;
300 ti,hwmods = "timer3";
301 };
302
303 mmc1: mmc@60000 {
304 compatible = "ti,omap4-hsmmc";
305 ti,hwmods = "mmc1";
306 dmas = <&edma 24 0
307 &edma 25 0>;
308 dma-names = "tx", "rx";
309 interrupts = <64>;
310 interrupt-parent = <&intc>;
311 reg = <0x60000 0x1000>;
312 };
313
314 rtc: rtc@c0000 {
315 compatible = "ti,am3352-rtc", "ti,da830-rtc";
316 reg = <0xc0000 0x1000>;
317 interrupts = <75 76>;
318 ti,hwmods = "rtc";
319 };
320
321 mmc2: mmc@1d8000 {
322 compatible = "ti,omap4-hsmmc";
323 ti,hwmods = "mmc2";
324 dmas = <&edma 2 0
325 &edma 3 0>;
326 dma-names = "tx", "rx";
327 interrupts = <28>;
328 interrupt-parent = <&intc>;
329 reg = <0x1d8000 0x1000>;
330 };
331
332 control: control@140000 {
333 compatible = "ti,dm814-scm", "simple-bus";
334 reg = <0x140000 0x20000>;
335 #address-cells = <1>;
336 #size-cells = <1>;
337 ranges = <0 0x140000 0x20000>;
338
339 scm_conf: scm_conf@0 {
340 compatible = "syscon", "simple-bus";
341 reg = <0x0 0x800>;
342 #address-cells = <1>;
343 #size-cells = <1>;
344 ranges = <0 0 0x800>;
345
346 scm_clocks: clocks {
347 #address-cells = <1>;
348 #size-cells = <0>;
349 };
350
351 scm_clockdomains: clockdomains {
352 };
353 };
354
355 usb_ctrl_mod: control@620 {
356 compatible = "ti,am335x-usb-ctrl-module";
357 reg = <0x620 0x10
358 0x648 0x4>;
359 reg-names = "phy_ctrl", "wakeup";
360 };
361
362 edma_xbar: dma-router@f90 {
363 compatible = "ti,am335x-edma-crossbar";
364 reg = <0xf90 0x40>;
365 #dma-cells = <3>;
366 dma-requests = <32>;
367 dma-masters = <&edma>;
368 };
369
370 /*
371 * Note that silicon revision 2.1 and older
372 * require input enabled (bit 18 set) for all
373 * 3.3V I/Os to avoid cumulative hardware damage.
374 * For more info, see errata advisory 2.1.87.
375 * We leave bit 18 out of function-mask and rely
376 * on the bootloader for it.
377 */
378 pincntl: pinmux@800 {
379 compatible = "pinctrl-single";
380 reg = <0x800 0x438>;
381 #address-cells = <1>;
382 #size-cells = <0>;
383 #pinctrl-cells = <1>;
384 pinctrl-single,register-width = <32>;
385 pinctrl-single,function-mask = <0x307ff>;
386 };
387
388 usb1_phy: usb-phy@1b00 {
389 compatible = "ti,am335x-usb-phy";
390 reg = <0x1b00 0x100>;
391 reg-names = "phy";
392 ti,ctrl_mod = <&usb_ctrl_mod>;
393 #phy-cells = <0>;
394 };
395 };
396
397 prcm: prcm@180000 {
398 compatible = "ti,dm814-prcm", "simple-bus";
399 reg = <0x180000 0x2000>;
400 #address-cells = <1>;
401 #size-cells = <1>;
402 ranges = <0 0x180000 0x2000>;
403
404 prcm_clocks: clocks {
405 #address-cells = <1>;
406 #size-cells = <0>;
407 };
408
409 prcm_clockdomains: clockdomains {
410 };
411 };
412
413 /* See TRM PLL_SUBSYS_BASE and "PLLSS Registers" */
414 pllss: pllss@1c5000 {
415 compatible = "ti,dm814-pllss", "simple-bus";
416 reg = <0x1c5000 0x1000>;
417 #address-cells = <1>;
418 #size-cells = <1>;
419 ranges = <0 0x1c5000 0x1000>;
420
421 pllss_clocks: clocks {
422 #address-cells = <1>;
423 #size-cells = <0>;
424 };
425
426 pllss_clockdomains: clockdomains {
427 };
428 };
429
430 wdt1: wdt@1c7000 {
431 compatible = "ti,omap3-wdt";
432 ti,hwmods = "wd_timer";
433 reg = <0x1c7000 0x1000>;
434 interrupts = <91>;
435 };
436 };
437
438 intc: interrupt-controller@48200000 {
439 compatible = "ti,dm814-intc";
440 interrupt-controller;
441 #interrupt-cells = <1>;
442 reg = <0x48200000 0x1000>;
443 };
444
445 /* Board must configure evtmux with edma_xbar for EDMA */
446 mmc3: mmc@47810000 {
447 compatible = "ti,omap4-hsmmc";
448 ti,hwmods = "mmc3";
449 interrupts = <29>;
450 interrupt-parent = <&intc>;
451 reg = <0x47810000 0x1000>;
452 };
453
454 edma: edma@49000000 {
455 compatible = "ti,edma3-tpcc";
456 ti,hwmods = "tpcc";
457 reg = <0x49000000 0x10000>;
458 reg-names = "edma3_cc";
459 interrupts = <12 13 14>;
460 interrupt-names = "edma3_ccint", "edma3_mperr",
461 "edma3_ccerrint";
462 dma-requests = <64>;
463 #dma-cells = <2>;
464
465 ti,tptcs = <&edma_tptc0 7>, <&edma_tptc1 5>,
466 <&edma_tptc2 3>, <&edma_tptc3 0>;
467
468 ti,edma-memcpy-channels = <20 21>;
469 };
470
471 edma_tptc0: tptc@49800000 {
472 compatible = "ti,edma3-tptc";
473 ti,hwmods = "tptc0";
474 reg = <0x49800000 0x100000>;
475 interrupts = <112>;
476 interrupt-names = "edma3_tcerrint";
477 };
478
479 edma_tptc1: tptc@49900000 {
480 compatible = "ti,edma3-tptc";
481 ti,hwmods = "tptc1";
482 reg = <0x49900000 0x100000>;
483 interrupts = <113>;
484 interrupt-names = "edma3_tcerrint";
485 };
486
487 edma_tptc2: tptc@49a00000 {
488 compatible = "ti,edma3-tptc";
489 ti,hwmods = "tptc2";
490 reg = <0x49a00000 0x100000>;
491 interrupts = <114>;
492 interrupt-names = "edma3_tcerrint";
493 };
494
495 edma_tptc3: tptc@49b00000 {
496 compatible = "ti,edma3-tptc";
497 ti,hwmods = "tptc3";
498 reg = <0x49b00000 0x100000>;
499 interrupts = <115>;
500 interrupt-names = "edma3_tcerrint";
501 };
502
503 /* See TRM "Table 1-318. L4HS Instance Summary" */
504 l4hs: l4hs@4a000000 {
505 compatible = "ti,dm814-l4hs", "simple-bus";
506 #address-cells = <1>;
507 #size-cells = <1>;
508 ranges = <0 0x4a000000 0x1b4040>;
509 };
510
511 /* REVISIT: Move to live under l4hs once driver is fixed */
512 mac: ethernet@4a100000 {
513 compatible = "ti,cpsw";
514 ti,hwmods = "cpgmac0";
515 clocks = <&cpsw_125mhz_gclk>, <&cpsw_cpts_rft_clk>;
516 clock-names = "fck", "cpts";
517 cpdma_channels = <8>;
518 ale_entries = <1024>;
519 bd_ram_size = <0x2000>;
520 mac_control = <0x20>;
521 slaves = <2>;
522 active_slave = <0>;
523 cpts_clock_mult = <0x80000000>;
524 cpts_clock_shift = <29>;
525 reg = <0x4a100000 0x800
526 0x4a100900 0x100>;
527 #address-cells = <1>;
528 #size-cells = <1>;
529 interrupt-parent = <&intc>;
530 /*
531 * c0_rx_thresh_pend
532 * c0_rx_pend
533 * c0_tx_pend
534 * c0_misc_pend
535 */
536 interrupts = <40 41 42 43>;
537 ranges;
538 syscon = <&scm_conf>;
539
540 davinci_mdio: mdio@4a100800 {
541 compatible = "ti,davinci_mdio";
542 #address-cells = <1>;
543 #size-cells = <0>;
544 ti,hwmods = "davinci_mdio";
545 bus_freq = <1000000>;
546 reg = <0x4a100800 0x100>;
547 };
548
549 cpsw_emac0: slave@4a100200 {
550 /* Filled in by U-Boot */
551 mac-address = [ 00 00 00 00 00 00 ];
552 };
553
554 cpsw_emac1: slave@4a100300 {
555 /* Filled in by U-Boot */
556 mac-address = [ 00 00 00 00 00 00 ];
557 };
558
559 phy_sel: cpsw-phy-sel@48140650 {
560 compatible = "ti,am3352-cpsw-phy-sel";
561 reg= <0x48140650 0x4>;
562 reg-names = "gmii-sel";
563 };
564 };
565
566 gpmc: gpmc@50000000 {
567 compatible = "ti,am3352-gpmc";
568 ti,hwmods = "gpmc";
569 ti,no-idle-on-init;
570 reg = <0x50000000 0x2000>;
571 interrupts = <100>;
572 gpmc,num-cs = <7>;
573 gpmc,num-waitpins = <2>;
574 #address-cells = <2>;
575 #size-cells = <1>;
576 interrupt-controller;
577 #interrupt-cells = <2>;
578 gpio-controller;
579 #gpio-cells = <2>;
580 };
581 };
582};
583
584#include "dm814x-clocks.dtsi"
1/*
2 * This file is licensed under the terms of the GNU General Public License
3 * version 2. This program is licensed "as is" without any warranty of any
4 * kind, whether express or implied.
5 */
6
7#include <dt-bindings/gpio/gpio.h>
8#include <dt-bindings/pinctrl/dm814x.h>
9
10/ {
11 compatible = "ti,dm814";
12 interrupt-parent = <&intc>;
13 #address-cells = <1>;
14 #size-cells = <1>;
15 chosen { };
16
17 aliases {
18 i2c0 = &i2c1;
19 i2c1 = &i2c2;
20 serial0 = &uart1;
21 serial1 = &uart2;
22 serial2 = &uart3;
23 ethernet0 = &cpsw_emac0;
24 ethernet1 = &cpsw_emac1;
25 usb0 = &usb0;
26 usb1 = &usb1;
27 phy0 = &usb0_phy;
28 phy1 = &usb1_phy;
29 };
30
31 cpus {
32 #address-cells = <1>;
33 #size-cells = <0>;
34 cpu@0 {
35 compatible = "arm,cortex-a8";
36 device_type = "cpu";
37 reg = <0>;
38 };
39 };
40
41 pmu {
42 compatible = "arm,cortex-a8-pmu";
43 interrupts = <3>;
44 };
45
46 /*
47 * The soc node represents the soc top level view. It is used for IPs
48 * that are not memory mapped in the MPU view or for the MPU itself.
49 */
50 soc {
51 compatible = "ti,omap-infra";
52 mpu {
53 compatible = "ti,omap3-mpu";
54 ti,hwmods = "mpu";
55 };
56 };
57
58 ocp {
59 compatible = "simple-bus";
60 #address-cells = <1>;
61 #size-cells = <1>;
62 ranges;
63 ti,hwmods = "l3_main";
64
65 usb: usb@47400000 {
66 compatible = "ti,am33xx-usb";
67 reg = <0x47400000 0x1000>;
68 ranges;
69 #address-cells = <1>;
70 #size-cells = <1>;
71 ti,hwmods = "usb_otg_hs";
72
73 usb0_phy: usb-phy@47401300 {
74 compatible = "ti,am335x-usb-phy";
75 reg = <0x47401300 0x100>;
76 reg-names = "phy";
77 ti,ctrl_mod = <&usb_ctrl_mod>;
78 #phy-cells = <0>;
79 };
80
81 usb0: usb@47401000 {
82 compatible = "ti,musb-am33xx";
83 reg = <0x47401400 0x400
84 0x47401000 0x200>;
85 reg-names = "mc", "control";
86
87 interrupts = <18>;
88 interrupt-names = "mc";
89 dr_mode = "otg";
90 mentor,multipoint = <1>;
91 mentor,num-eps = <16>;
92 mentor,ram-bits = <12>;
93 mentor,power = <500>;
94 phys = <&usb0_phy>;
95
96 dmas = <&cppi41dma 0 0 &cppi41dma 1 0
97 &cppi41dma 2 0 &cppi41dma 3 0
98 &cppi41dma 4 0 &cppi41dma 5 0
99 &cppi41dma 6 0 &cppi41dma 7 0
100 &cppi41dma 8 0 &cppi41dma 9 0
101 &cppi41dma 10 0 &cppi41dma 11 0
102 &cppi41dma 12 0 &cppi41dma 13 0
103 &cppi41dma 14 0 &cppi41dma 0 1
104 &cppi41dma 1 1 &cppi41dma 2 1
105 &cppi41dma 3 1 &cppi41dma 4 1
106 &cppi41dma 5 1 &cppi41dma 6 1
107 &cppi41dma 7 1 &cppi41dma 8 1
108 &cppi41dma 9 1 &cppi41dma 10 1
109 &cppi41dma 11 1 &cppi41dma 12 1
110 &cppi41dma 13 1 &cppi41dma 14 1>;
111 dma-names =
112 "rx1", "rx2", "rx3", "rx4", "rx5", "rx6", "rx7",
113 "rx8", "rx9", "rx10", "rx11", "rx12", "rx13",
114 "rx14", "rx15",
115 "tx1", "tx2", "tx3", "tx4", "tx5", "tx6", "tx7",
116 "tx8", "tx9", "tx10", "tx11", "tx12", "tx13",
117 "tx14", "tx15";
118 };
119
120 usb1: usb@47401800 {
121 compatible = "ti,musb-am33xx";
122 reg = <0x47401c00 0x400
123 0x47401800 0x200>;
124 reg-names = "mc", "control";
125 interrupts = <19>;
126 interrupt-names = "mc";
127 dr_mode = "otg";
128 mentor,multipoint = <1>;
129 mentor,num-eps = <16>;
130 mentor,ram-bits = <12>;
131 mentor,power = <500>;
132 phys = <&usb1_phy>;
133
134 dmas = <&cppi41dma 15 0 &cppi41dma 16 0
135 &cppi41dma 17 0 &cppi41dma 18 0
136 &cppi41dma 19 0 &cppi41dma 20 0
137 &cppi41dma 21 0 &cppi41dma 22 0
138 &cppi41dma 23 0 &cppi41dma 24 0
139 &cppi41dma 25 0 &cppi41dma 26 0
140 &cppi41dma 27 0 &cppi41dma 28 0
141 &cppi41dma 29 0 &cppi41dma 15 1
142 &cppi41dma 16 1 &cppi41dma 17 1
143 &cppi41dma 18 1 &cppi41dma 19 1
144 &cppi41dma 20 1 &cppi41dma 21 1
145 &cppi41dma 22 1 &cppi41dma 23 1
146 &cppi41dma 24 1 &cppi41dma 25 1
147 &cppi41dma 26 1 &cppi41dma 27 1
148 &cppi41dma 28 1 &cppi41dma 29 1>;
149 dma-names =
150 "rx1", "rx2", "rx3", "rx4", "rx5", "rx6", "rx7",
151 "rx8", "rx9", "rx10", "rx11", "rx12", "rx13",
152 "rx14", "rx15",
153 "tx1", "tx2", "tx3", "tx4", "tx5", "tx6", "tx7",
154 "tx8", "tx9", "tx10", "tx11", "tx12", "tx13",
155 "tx14", "tx15";
156 };
157
158 cppi41dma: dma-controller@47402000 {
159 compatible = "ti,am3359-cppi41";
160 reg = <0x47400000 0x1000
161 0x47402000 0x1000
162 0x47403000 0x1000
163 0x47404000 0x4000>;
164 reg-names = "glue", "controller", "scheduler", "queuemgr";
165 interrupts = <17>;
166 interrupt-names = "glue";
167 #dma-cells = <2>;
168 #dma-channels = <30>;
169 #dma-requests = <256>;
170 };
171 };
172
173 /*
174 * See TRM "Table 1-317. L4LS Instance Summary" for hints.
175 * It shows the module target agent registers though, so the
176 * actual device is typically 0x1000 before the target agent
177 * except in cases where the module is larger than 0x1000.
178 */
179 l4ls: l4ls@48000000 {
180 compatible = "ti,dm814-l4ls", "simple-bus";
181 #address-cells = <1>;
182 #size-cells = <1>;
183 ranges = <0 0x48000000 0x2000000>;
184
185 i2c1: i2c@28000 {
186 compatible = "ti,omap4-i2c";
187 #address-cells = <1>;
188 #size-cells = <0>;
189 ti,hwmods = "i2c1";
190 reg = <0x28000 0x1000>;
191 interrupts = <70>;
192 };
193
194 elm: elm@80000 {
195 compatible = "ti,814-elm";
196 ti,hwmods = "elm";
197 reg = <0x80000 0x2000>;
198 interrupts = <4>;
199 };
200
201 gpio1: gpio@32000 {
202 compatible = "ti,omap4-gpio";
203 ti,hwmods = "gpio1";
204 ti,gpio-always-on;
205 reg = <0x32000 0x2000>;
206 interrupts = <96>;
207 gpio-controller;
208 #gpio-cells = <2>;
209 interrupt-controller;
210 #interrupt-cells = <2>;
211 };
212
213 gpio2: gpio@4c000 {
214 compatible = "ti,omap4-gpio";
215 ti,hwmods = "gpio2";
216 ti,gpio-always-on;
217 reg = <0x4c000 0x2000>;
218 interrupts = <98>;
219 gpio-controller;
220 #gpio-cells = <2>;
221 interrupt-controller;
222 #interrupt-cells = <2>;
223 };
224
225 gpio3: gpio@1ac000 {
226 compatible = "ti,omap4-gpio";
227 ti,hwmods = "gpio3";
228 ti,gpio-always-on;
229 reg = <0x1ac000 0x2000>;
230 interrupts = <32>;
231 gpio-controller;
232 #gpio-cells = <2>;
233 interrupt-controller;
234 #interrupt-cells = <2>;
235 };
236
237 gpio4: gpio@1ae000 {
238 compatible = "ti,omap4-gpio";
239 ti,hwmods = "gpio4";
240 ti,gpio-always-on;
241 reg = <0x1ae000 0x2000>;
242 interrupts = <62>;
243 gpio-controller;
244 #gpio-cells = <2>;
245 interrupt-controller;
246 #interrupt-cells = <2>;
247 };
248
249 i2c2: i2c@2a000 {
250 compatible = "ti,omap4-i2c";
251 #address-cells = <1>;
252 #size-cells = <0>;
253 ti,hwmods = "i2c2";
254 reg = <0x2a000 0x1000>;
255 interrupts = <71>;
256 };
257
258 mcspi1: spi@30000 {
259 compatible = "ti,omap4-mcspi";
260 reg = <0x30000 0x1000>;
261 #address-cells = <1>;
262 #size-cells = <0>;
263 interrupts = <65>;
264 ti,spi-num-cs = <4>;
265 ti,hwmods = "mcspi1";
266 dmas = <&edma 16 0 &edma 17 0
267 &edma 18 0 &edma 19 0
268 &edma 20 0 &edma 21 0
269 &edma 22 0 &edma 23 0>;
270
271 dma-names = "tx0", "rx0", "tx1", "rx1",
272 "tx2", "rx2", "tx3", "rx3";
273 };
274
275 mcspi2: spi@1a0000 {
276 compatible = "ti,omap4-mcspi";
277 reg = <0x1a0000 0x1000>;
278 #address-cells = <1>;
279 #size-cells = <0>;
280 interrupts = <125>;
281 ti,spi-num-cs = <4>;
282 ti,hwmods = "mcspi2";
283 dmas = <&edma 42 0 &edma 43 0
284 &edma 44 0 &edma 45 0>;
285 dma-names = "tx0", "rx0", "tx1", "rx1";
286 };
287
288 /* Board must configure dmas with edma_xbar for EDMA */
289 mcspi3: spi@1a2000 {
290 compatible = "ti,omap4-mcspi";
291 reg = <0x1a2000 0x1000>;
292 #address-cells = <1>;
293 #size-cells = <0>;
294 interrupts = <126>;
295 ti,spi-num-cs = <4>;
296 ti,hwmods = "mcspi3";
297 };
298
299 mcspi4: spi@1a4000 {
300 compatible = "ti,omap4-mcspi";
301 reg = <0x1a4000 0x1000>;
302 #address-cells = <1>;
303 #size-cells = <0>;
304 interrupts = <127>;
305 ti,spi-num-cs = <4>;
306 ti,hwmods = "mcspi4";
307 };
308
309 timer1: timer@2e000 {
310 compatible = "ti,dm814-timer";
311 reg = <0x2e000 0x2000>;
312 interrupts = <67>;
313 ti,hwmods = "timer1";
314 ti,timer-alwon;
315 clocks = <&timer1_fck>;
316 clock-names = "fck";
317 };
318
319 uart1: uart@20000 {
320 compatible = "ti,am3352-uart", "ti,omap3-uart";
321 ti,hwmods = "uart1";
322 reg = <0x20000 0x2000>;
323 clock-frequency = <48000000>;
324 interrupts = <72>;
325 dmas = <&edma 26 0 &edma 27 0>;
326 dma-names = "tx", "rx";
327 };
328
329 uart2: uart@22000 {
330 compatible = "ti,am3352-uart", "ti,omap3-uart";
331 ti,hwmods = "uart2";
332 reg = <0x22000 0x2000>;
333 clock-frequency = <48000000>;
334 interrupts = <73>;
335 dmas = <&edma 28 0 &edma 29 0>;
336 dma-names = "tx", "rx";
337 };
338
339 uart3: uart@24000 {
340 compatible = "ti,am3352-uart", "ti,omap3-uart";
341 ti,hwmods = "uart3";
342 reg = <0x24000 0x2000>;
343 clock-frequency = <48000000>;
344 interrupts = <74>;
345 dmas = <&edma 30 0 &edma 31 0>;
346 dma-names = "tx", "rx";
347 };
348
349 timer2: timer@40000 {
350 compatible = "ti,dm814-timer";
351 reg = <0x40000 0x2000>;
352 interrupts = <68>;
353 ti,hwmods = "timer2";
354 clocks = <&timer2_fck>;
355 clock-names = "fck";
356 };
357
358 timer3: timer@42000 {
359 compatible = "ti,dm814-timer";
360 reg = <0x42000 0x2000>;
361 interrupts = <69>;
362 ti,hwmods = "timer3";
363 };
364
365 mmc1: mmc@60000 {
366 compatible = "ti,omap4-hsmmc";
367 ti,hwmods = "mmc1";
368 dmas = <&edma 24 0
369 &edma 25 0>;
370 dma-names = "tx", "rx";
371 interrupts = <64>;
372 interrupt-parent = <&intc>;
373 reg = <0x60000 0x1000>;
374 };
375
376 rtc: rtc@c0000 {
377 compatible = "ti,am3352-rtc", "ti,da830-rtc";
378 reg = <0xc0000 0x1000>;
379 interrupts = <75 76>;
380 ti,hwmods = "rtc";
381 };
382
383 mmc2: mmc@1d8000 {
384 compatible = "ti,omap4-hsmmc";
385 ti,hwmods = "mmc2";
386 dmas = <&edma 2 0
387 &edma 3 0>;
388 dma-names = "tx", "rx";
389 interrupts = <28>;
390 interrupt-parent = <&intc>;
391 reg = <0x1d8000 0x1000>;
392 };
393
394 control: control@140000 {
395 compatible = "ti,dm814-scm", "simple-bus";
396 reg = <0x140000 0x20000>;
397 #address-cells = <1>;
398 #size-cells = <1>;
399 ranges = <0 0x140000 0x20000>;
400
401 scm_conf: scm_conf@0 {
402 compatible = "syscon", "simple-bus";
403 reg = <0x0 0x800>;
404 #address-cells = <1>;
405 #size-cells = <1>;
406 ranges = <0 0 0x800>;
407
408 phy_gmii_sel: phy-gmii-sel {
409 compatible = "ti,dm814-phy-gmii-sel";
410 reg = <0x650 0x4>;
411 #phy-cells = <1>;
412 };
413
414 scm_clocks: clocks {
415 #address-cells = <1>;
416 #size-cells = <0>;
417 };
418
419 scm_clockdomains: clockdomains {
420 };
421 };
422
423 usb_ctrl_mod: control@620 {
424 compatible = "ti,am335x-usb-ctrl-module";
425 reg = <0x620 0x10
426 0x648 0x4>;
427 reg-names = "phy_ctrl", "wakeup";
428 };
429
430 edma_xbar: dma-router@f90 {
431 compatible = "ti,am335x-edma-crossbar";
432 reg = <0xf90 0x40>;
433 #dma-cells = <3>;
434 dma-requests = <32>;
435 dma-masters = <&edma>;
436 };
437
438 /*
439 * Note that silicon revision 2.1 and older
440 * require input enabled (bit 18 set) for all
441 * 3.3V I/Os to avoid cumulative hardware damage.
442 * For more info, see errata advisory 2.1.87.
443 * We leave bit 18 out of function-mask and rely
444 * on the bootloader for it.
445 */
446 pincntl: pinmux@800 {
447 compatible = "pinctrl-single";
448 reg = <0x800 0x438>;
449 #address-cells = <1>;
450 #size-cells = <0>;
451 #pinctrl-cells = <1>;
452 pinctrl-single,register-width = <32>;
453 pinctrl-single,function-mask = <0x307ff>;
454 };
455
456 usb1_phy: usb-phy@1b00 {
457 compatible = "ti,am335x-usb-phy";
458 reg = <0x1b00 0x100>;
459 reg-names = "phy";
460 ti,ctrl_mod = <&usb_ctrl_mod>;
461 #phy-cells = <0>;
462 };
463 };
464
465 prcm: prcm@180000 {
466 compatible = "ti,dm814-prcm", "simple-bus";
467 reg = <0x180000 0x2000>;
468 #address-cells = <1>;
469 #size-cells = <1>;
470 ranges = <0 0x180000 0x2000>;
471
472 prcm_clocks: clocks {
473 #address-cells = <1>;
474 #size-cells = <0>;
475 };
476
477 prcm_clockdomains: clockdomains {
478 };
479 };
480
481 /* See TRM PLL_SUBSYS_BASE and "PLLSS Registers" */
482 pllss: pllss@1c5000 {
483 compatible = "ti,dm814-pllss", "simple-bus";
484 reg = <0x1c5000 0x1000>;
485 #address-cells = <1>;
486 #size-cells = <1>;
487 ranges = <0 0x1c5000 0x1000>;
488
489 pllss_clocks: clocks {
490 #address-cells = <1>;
491 #size-cells = <0>;
492 };
493
494 pllss_clockdomains: clockdomains {
495 };
496 };
497
498 wdt1: wdt@1c7000 {
499 compatible = "ti,omap3-wdt";
500 ti,hwmods = "wd_timer";
501 reg = <0x1c7000 0x1000>;
502 interrupts = <91>;
503 };
504 };
505
506 intc: interrupt-controller@48200000 {
507 compatible = "ti,dm814-intc";
508 interrupt-controller;
509 #interrupt-cells = <1>;
510 reg = <0x48200000 0x1000>;
511 };
512
513 /* Board must configure evtmux with edma_xbar for EDMA */
514 mmc3: mmc@47810000 {
515 compatible = "ti,omap4-hsmmc";
516 ti,hwmods = "mmc3";
517 interrupts = <29>;
518 interrupt-parent = <&intc>;
519 reg = <0x47810000 0x1000>;
520 };
521
522 edma: edma@49000000 {
523 compatible = "ti,edma3-tpcc";
524 ti,hwmods = "tpcc";
525 reg = <0x49000000 0x10000>;
526 reg-names = "edma3_cc";
527 interrupts = <12 13 14>;
528 interrupt-names = "edma3_ccint", "edma3_mperr",
529 "edma3_ccerrint";
530 dma-requests = <64>;
531 #dma-cells = <2>;
532
533 ti,tptcs = <&edma_tptc0 7>, <&edma_tptc1 5>,
534 <&edma_tptc2 3>, <&edma_tptc3 0>;
535
536 ti,edma-memcpy-channels = <20 21>;
537 };
538
539 edma_tptc0: tptc@49800000 {
540 compatible = "ti,edma3-tptc";
541 ti,hwmods = "tptc0";
542 reg = <0x49800000 0x100000>;
543 interrupts = <112>;
544 interrupt-names = "edma3_tcerrint";
545 };
546
547 edma_tptc1: tptc@49900000 {
548 compatible = "ti,edma3-tptc";
549 ti,hwmods = "tptc1";
550 reg = <0x49900000 0x100000>;
551 interrupts = <113>;
552 interrupt-names = "edma3_tcerrint";
553 };
554
555 edma_tptc2: tptc@49a00000 {
556 compatible = "ti,edma3-tptc";
557 ti,hwmods = "tptc2";
558 reg = <0x49a00000 0x100000>;
559 interrupts = <114>;
560 interrupt-names = "edma3_tcerrint";
561 };
562
563 edma_tptc3: tptc@49b00000 {
564 compatible = "ti,edma3-tptc";
565 ti,hwmods = "tptc3";
566 reg = <0x49b00000 0x100000>;
567 interrupts = <115>;
568 interrupt-names = "edma3_tcerrint";
569 };
570
571 /* See TRM "Table 1-318. L4HS Instance Summary" */
572 l4hs: l4hs@4a000000 {
573 compatible = "ti,dm814-l4hs", "simple-bus";
574 #address-cells = <1>;
575 #size-cells = <1>;
576 ranges = <0 0x4a000000 0x1b4040>;
577 };
578
579 /* REVISIT: Move to live under l4hs once driver is fixed */
580 mac: ethernet@4a100000 {
581 compatible = "ti,cpsw";
582 ti,hwmods = "cpgmac0";
583 clocks = <&cpsw_125mhz_gclk>, <&cpsw_cpts_rft_clk>;
584 clock-names = "fck", "cpts";
585 cpdma_channels = <8>;
586 ale_entries = <1024>;
587 bd_ram_size = <0x2000>;
588 mac_control = <0x20>;
589 slaves = <2>;
590 active_slave = <0>;
591 cpts_clock_mult = <0x80000000>;
592 cpts_clock_shift = <29>;
593 reg = <0x4a100000 0x800
594 0x4a100900 0x100>;
595 #address-cells = <1>;
596 #size-cells = <1>;
597 interrupt-parent = <&intc>;
598 /*
599 * c0_rx_thresh_pend
600 * c0_rx_pend
601 * c0_tx_pend
602 * c0_misc_pend
603 */
604 interrupts = <40 41 42 43>;
605 ranges;
606 syscon = <&scm_conf>;
607
608 davinci_mdio: mdio@4a100800 {
609 compatible = "ti,davinci_mdio";
610 #address-cells = <1>;
611 #size-cells = <0>;
612 ti,hwmods = "davinci_mdio";
613 bus_freq = <1000000>;
614 reg = <0x4a100800 0x100>;
615 };
616
617 cpsw_emac0: slave@4a100200 {
618 /* Filled in by U-Boot */
619 mac-address = [ 00 00 00 00 00 00 ];
620 phys = <&phy_gmii_sel 1>;
621
622 };
623
624 cpsw_emac1: slave@4a100300 {
625 /* Filled in by U-Boot */
626 mac-address = [ 00 00 00 00 00 00 ];
627 phys = <&phy_gmii_sel 2>;
628 };
629 };
630
631 gpmc: gpmc@50000000 {
632 compatible = "ti,am3352-gpmc";
633 ti,hwmods = "gpmc";
634 ti,no-idle-on-init;
635 reg = <0x50000000 0x2000>;
636 interrupts = <100>;
637 gpmc,num-cs = <7>;
638 gpmc,num-waitpins = <2>;
639 #address-cells = <2>;
640 #size-cells = <1>;
641 interrupt-controller;
642 #interrupt-cells = <2>;
643 gpio-controller;
644 #gpio-cells = <2>;
645 };
646 };
647};
648
649#include "dm814x-clocks.dtsi"