2 * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
7 * Based on "omap4.dtsi"
10 #include <dt-bindings/gpio/gpio.h>
11 #include <dt-bindings/interrupt-controller/arm-gic.h>
12 #include <dt-bindings/pinctrl/omap.h>
14 #include "skeleton.dtsi"
20 compatible = "ti,omap5";
21 interrupt-parent = <&gic>;
38 compatible = "arm,cortex-a15";
43 compatible = "arm,cortex-a15";
49 compatible = "arm,armv7-timer";
50 /* PPI secure/nonsecure IRQ */
51 interrupts = <GIC_PPI 13 (GIC_CPU_MASK_RAW(3) | IRQ_TYPE_LEVEL_LOW)>,
52 <GIC_PPI 14 (GIC_CPU_MASK_RAW(3) | IRQ_TYPE_LEVEL_LOW)>,
53 <GIC_PPI 11 (GIC_CPU_MASK_RAW(3) | IRQ_TYPE_LEVEL_LOW)>,
54 <GIC_PPI 10 (GIC_CPU_MASK_RAW(3) | IRQ_TYPE_LEVEL_LOW)>;
55 clock-frequency = <6144000>;
58 gic: interrupt-controller@48211000 {
59 compatible = "arm,cortex-a15-gic";
61 #interrupt-cells = <3>;
62 reg = <0x48211000 0x1000>,
69 * The soc node represents the soc top level view. It is uses for IPs
70 * that are not memory mapped in the MPU view or for the MPU itself.
73 compatible = "ti,omap-infra";
75 compatible = "ti,omap5-mpu";
81 * XXX: Use a flat representation of the OMAP3 interconnect.
82 * The real OMAP interconnect network is quite complex.
83 * Since that will not bring real advantage to represent that in DT for
84 * the moment, just use a fake OCP bus entry to represent the whole bus
88 compatible = "ti,omap4-l3-noc", "simple-bus";
92 ti,hwmods = "l3_main_1", "l3_main_2", "l3_main_3";
93 reg = <0x44000000 0x2000>,
96 interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>,
97 <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
99 counter32k: counter@4ae04000 {
100 compatible = "ti,omap-counter32k";
101 reg = <0x4ae04000 0x40>;
102 ti,hwmods = "counter_32k";
105 omap5_pmx_core: pinmux@4a002840 {
106 compatible = "ti,omap4-padconf", "pinctrl-single";
107 reg = <0x4a002840 0x01b6>;
108 #address-cells = <1>;
110 pinctrl-single,register-width = <16>;
111 pinctrl-single,function-mask = <0x7fff>;
113 omap5_pmx_wkup: pinmux@4ae0c840 {
114 compatible = "ti,omap4-padconf", "pinctrl-single";
115 reg = <0x4ae0c840 0x0038>;
116 #address-cells = <1>;
118 pinctrl-single,register-width = <16>;
119 pinctrl-single,function-mask = <0x7fff>;
122 sdma: dma-controller@4a056000 {
123 compatible = "ti,omap4430-sdma";
124 reg = <0x4a056000 0x1000>;
125 interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>,
126 <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>,
127 <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>,
128 <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
130 #dma-channels = <32>;
131 #dma-requests = <127>;
134 gpio1: gpio@4ae10000 {
135 compatible = "ti,omap4-gpio";
136 reg = <0x4ae10000 0x200>;
137 interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
142 interrupt-controller;
143 #interrupt-cells = <2>;
146 gpio2: gpio@48055000 {
147 compatible = "ti,omap4-gpio";
148 reg = <0x48055000 0x200>;
149 interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
153 interrupt-controller;
154 #interrupt-cells = <2>;
157 gpio3: gpio@48057000 {
158 compatible = "ti,omap4-gpio";
159 reg = <0x48057000 0x200>;
160 interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
164 interrupt-controller;
165 #interrupt-cells = <2>;
168 gpio4: gpio@48059000 {
169 compatible = "ti,omap4-gpio";
170 reg = <0x48059000 0x200>;
171 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
175 interrupt-controller;
176 #interrupt-cells = <2>;
179 gpio5: gpio@4805b000 {
180 compatible = "ti,omap4-gpio";
181 reg = <0x4805b000 0x200>;
182 interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
186 interrupt-controller;
187 #interrupt-cells = <2>;
190 gpio6: gpio@4805d000 {
191 compatible = "ti,omap4-gpio";
192 reg = <0x4805d000 0x200>;
193 interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
197 interrupt-controller;
198 #interrupt-cells = <2>;
201 gpio7: gpio@48051000 {
202 compatible = "ti,omap4-gpio";
203 reg = <0x48051000 0x200>;
204 interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
208 interrupt-controller;
209 #interrupt-cells = <2>;
212 gpio8: gpio@48053000 {
213 compatible = "ti,omap4-gpio";
214 reg = <0x48053000 0x200>;
215 interrupts = <GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>;
219 interrupt-controller;
220 #interrupt-cells = <2>;
223 gpmc: gpmc@50000000 {
224 compatible = "ti,omap4430-gpmc";
225 reg = <0x50000000 0x1000>;
226 #address-cells = <2>;
228 interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
230 gpmc,num-waitpins = <4>;
235 compatible = "ti,omap4-i2c";
236 reg = <0x48070000 0x100>;
237 interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>;
238 #address-cells = <1>;
244 compatible = "ti,omap4-i2c";
245 reg = <0x48072000 0x100>;
246 interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
247 #address-cells = <1>;
253 compatible = "ti,omap4-i2c";
254 reg = <0x48060000 0x100>;
255 interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
256 #address-cells = <1>;
262 compatible = "ti,omap4-i2c";
263 reg = <0x4807a000 0x100>;
264 interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>;
265 #address-cells = <1>;
271 compatible = "ti,omap4-i2c";
272 reg = <0x4807c000 0x100>;
273 interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>;
274 #address-cells = <1>;
279 mcspi1: spi@48098000 {
280 compatible = "ti,omap4-mcspi";
281 reg = <0x48098000 0x200>;
282 interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>;
283 #address-cells = <1>;
285 ti,hwmods = "mcspi1";
295 dma-names = "tx0", "rx0", "tx1", "rx1",
296 "tx2", "rx2", "tx3", "rx3";
299 mcspi2: spi@4809a000 {
300 compatible = "ti,omap4-mcspi";
301 reg = <0x4809a000 0x200>;
302 interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>;
303 #address-cells = <1>;
305 ti,hwmods = "mcspi2";
311 dma-names = "tx0", "rx0", "tx1", "rx1";
314 mcspi3: spi@480b8000 {
315 compatible = "ti,omap4-mcspi";
316 reg = <0x480b8000 0x200>;
317 interrupts = <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>;
318 #address-cells = <1>;
320 ti,hwmods = "mcspi3";
322 dmas = <&sdma 15>, <&sdma 16>;
323 dma-names = "tx0", "rx0";
326 mcspi4: spi@480ba000 {
327 compatible = "ti,omap4-mcspi";
328 reg = <0x480ba000 0x200>;
329 interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>;
330 #address-cells = <1>;
332 ti,hwmods = "mcspi4";
334 dmas = <&sdma 70>, <&sdma 71>;
335 dma-names = "tx0", "rx0";
338 uart1: serial@4806a000 {
339 compatible = "ti,omap4-uart";
340 reg = <0x4806a000 0x100>;
341 interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>;
343 clock-frequency = <48000000>;
346 uart2: serial@4806c000 {
347 compatible = "ti,omap4-uart";
348 reg = <0x4806c000 0x100>;
349 interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>;
351 clock-frequency = <48000000>;
354 uart3: serial@48020000 {
355 compatible = "ti,omap4-uart";
356 reg = <0x48020000 0x100>;
357 interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
359 clock-frequency = <48000000>;
362 uart4: serial@4806e000 {
363 compatible = "ti,omap4-uart";
364 reg = <0x4806e000 0x100>;
365 interrupts = <GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>;
367 clock-frequency = <48000000>;
370 uart5: serial@48066000 {
371 compatible = "ti,omap4-uart";
372 reg = <0x48066000 0x100>;
373 interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>;
375 clock-frequency = <48000000>;
378 uart6: serial@48068000 {
379 compatible = "ti,omap4-uart";
380 reg = <0x48068000 0x100>;
381 interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
383 clock-frequency = <48000000>;
387 compatible = "ti,omap4-hsmmc";
388 reg = <0x4809c000 0x400>;
389 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
392 ti,needs-special-reset;
393 dmas = <&sdma 61>, <&sdma 62>;
394 dma-names = "tx", "rx";
398 compatible = "ti,omap4-hsmmc";
399 reg = <0x480b4000 0x400>;
400 interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
402 ti,needs-special-reset;
403 dmas = <&sdma 47>, <&sdma 48>;
404 dma-names = "tx", "rx";
408 compatible = "ti,omap4-hsmmc";
409 reg = <0x480ad000 0x400>;
410 interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
412 ti,needs-special-reset;
413 dmas = <&sdma 77>, <&sdma 78>;
414 dma-names = "tx", "rx";
418 compatible = "ti,omap4-hsmmc";
419 reg = <0x480d1000 0x400>;
420 interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
422 ti,needs-special-reset;
423 dmas = <&sdma 57>, <&sdma 58>;
424 dma-names = "tx", "rx";
428 compatible = "ti,omap4-hsmmc";
429 reg = <0x480d5000 0x400>;
430 interrupts = <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>;
432 ti,needs-special-reset;
433 dmas = <&sdma 59>, <&sdma 60>;
434 dma-names = "tx", "rx";
437 keypad: keypad@4ae1c000 {
438 compatible = "ti,omap4-keypad";
439 reg = <0x4ae1c000 0x400>;
443 mcpdm: mcpdm@40132000 {
444 compatible = "ti,omap4-mcpdm";
445 reg = <0x40132000 0x7f>, /* MPU private access */
446 <0x49032000 0x7f>; /* L3 Interconnect */
447 reg-names = "mpu", "dma";
448 interrupts = <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>;
452 dma-names = "up_link", "dn_link";
455 dmic: dmic@4012e000 {
456 compatible = "ti,omap4-dmic";
457 reg = <0x4012e000 0x7f>, /* MPU private access */
458 <0x4902e000 0x7f>; /* L3 Interconnect */
459 reg-names = "mpu", "dma";
460 interrupts = <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>;
463 dma-names = "up_link";
466 mcbsp1: mcbsp@40122000 {
467 compatible = "ti,omap4-mcbsp";
468 reg = <0x40122000 0xff>, /* MPU private access */
469 <0x49022000 0xff>; /* L3 Interconnect */
470 reg-names = "mpu", "dma";
471 interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
472 interrupt-names = "common";
473 ti,buffer-size = <128>;
474 ti,hwmods = "mcbsp1";
477 dma-names = "tx", "rx";
480 mcbsp2: mcbsp@40124000 {
481 compatible = "ti,omap4-mcbsp";
482 reg = <0x40124000 0xff>, /* MPU private access */
483 <0x49024000 0xff>; /* L3 Interconnect */
484 reg-names = "mpu", "dma";
485 interrupts = <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>;
486 interrupt-names = "common";
487 ti,buffer-size = <128>;
488 ti,hwmods = "mcbsp2";
491 dma-names = "tx", "rx";
494 mcbsp3: mcbsp@40126000 {
495 compatible = "ti,omap4-mcbsp";
496 reg = <0x40126000 0xff>, /* MPU private access */
497 <0x49026000 0xff>; /* L3 Interconnect */
498 reg-names = "mpu", "dma";
499 interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
500 interrupt-names = "common";
501 ti,buffer-size = <128>;
502 ti,hwmods = "mcbsp3";
505 dma-names = "tx", "rx";
508 timer1: timer@4ae18000 {
509 compatible = "ti,omap5430-timer";
510 reg = <0x4ae18000 0x80>;
511 interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
512 ti,hwmods = "timer1";
516 timer2: timer@48032000 {
517 compatible = "ti,omap5430-timer";
518 reg = <0x48032000 0x80>;
519 interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
520 ti,hwmods = "timer2";
523 timer3: timer@48034000 {
524 compatible = "ti,omap5430-timer";
525 reg = <0x48034000 0x80>;
526 interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>;
527 ti,hwmods = "timer3";
530 timer4: timer@48036000 {
531 compatible = "ti,omap5430-timer";
532 reg = <0x48036000 0x80>;
533 interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>;
534 ti,hwmods = "timer4";
537 timer5: timer@40138000 {
538 compatible = "ti,omap5430-timer";
539 reg = <0x40138000 0x80>,
541 interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
542 ti,hwmods = "timer5";
547 timer6: timer@4013a000 {
548 compatible = "ti,omap5430-timer";
549 reg = <0x4013a000 0x80>,
551 interrupts = <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>;
552 ti,hwmods = "timer6";
557 timer7: timer@4013c000 {
558 compatible = "ti,omap5430-timer";
559 reg = <0x4013c000 0x80>,
561 interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
562 ti,hwmods = "timer7";
566 timer8: timer@4013e000 {
567 compatible = "ti,omap5430-timer";
568 reg = <0x4013e000 0x80>,
570 interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
571 ti,hwmods = "timer8";
576 timer9: timer@4803e000 {
577 compatible = "ti,omap5430-timer";
578 reg = <0x4803e000 0x80>;
579 interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
580 ti,hwmods = "timer9";
584 timer10: timer@48086000 {
585 compatible = "ti,omap5430-timer";
586 reg = <0x48086000 0x80>;
587 interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>;
588 ti,hwmods = "timer10";
592 timer11: timer@48088000 {
593 compatible = "ti,omap5430-timer";
594 reg = <0x48088000 0x80>;
595 interrupts = <GIC_SPI 47 IRQ_TYPE_LEVEL_HIGH>;
596 ti,hwmods = "timer11";
601 compatible = "ti,omap5-wdt", "ti,omap3-wdt";
602 reg = <0x4ae14000 0x80>;
603 interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>;
604 ti,hwmods = "wd_timer2";
607 emif1: emif@0x4c000000 {
608 compatible = "ti,emif-4d5";
610 phy-type = <2>; /* DDR PHY type: Intelli PHY */
611 reg = <0x4c000000 0x400>;
612 interrupts = <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>;
613 hw-caps-read-idle-ctrl;
614 hw-caps-ll-interface;
618 emif2: emif@0x4d000000 {
619 compatible = "ti,emif-4d5";
621 phy-type = <2>; /* DDR PHY type: Intelli PHY */
622 reg = <0x4d000000 0x400>;
623 interrupts = <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
624 hw-caps-read-idle-ctrl;
625 hw-caps-ll-interface;
629 omap_control_usb: omap-control-usb@4a002300 {
630 compatible = "ti,omap-control-usb";
631 reg = <0x4a002300 0x4>,
633 reg-names = "control_dev_conf", "phy_power_usb";
638 compatible = "ti,dwc3";
639 ti,hwmods = "usb_otg_ss";
640 reg = <0x4a020000 0x10000>;
641 interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
642 #address-cells = <1>;
647 compatible = "snps,dwc3";
648 reg = <0x4a030000 0x10000>;
649 interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>;
650 usb-phy = <&usb2_phy>, <&usb3_phy>;
656 compatible = "ti,omap-ocp2scp";
657 #address-cells = <1>;
659 reg = <0x4a080000 0x20>;
661 ti,hwmods = "ocp2scp1";
662 usb2_phy: usb2phy@4a084000 {
663 compatible = "ti,omap-usb2";
664 reg = <0x4a084000 0x7c>;
665 ctrl-module = <&omap_control_usb>;
668 usb3_phy: usb3phy@4a084400 {
669 compatible = "ti,omap-usb3";
670 reg = <0x4a084400 0x80>,
673 reg-names = "phy_rx", "phy_tx", "pll_ctrl";
674 ctrl-module = <&omap_control_usb>;
678 usbhstll: usbhstll@4a062000 {
679 compatible = "ti,usbhs-tll";
680 reg = <0x4a062000 0x1000>;
681 interrupts = <GIC_SPI 78 IRQ_TYPE_LEVEL_HIGH>;
682 ti,hwmods = "usb_tll_hs";
685 usbhshost: usbhshost@4a064000 {
686 compatible = "ti,usbhs-host";
687 reg = <0x4a064000 0x800>;
688 ti,hwmods = "usb_host_hs";
689 #address-cells = <1>;
693 usbhsohci: ohci@4a064800 {
694 compatible = "ti,ohci-omap3", "usb-ohci";
695 reg = <0x4a064800 0x400>;
696 interrupt-parent = <&gic>;
697 interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>;
700 usbhsehci: ehci@4a064c00 {
701 compatible = "ti,ehci-omap", "usb-ehci";
702 reg = <0x4a064c00 0x400>;
703 interrupt-parent = <&gic>;
704 interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
709 reg = <0x4a0021e0 0xc
713 interrupts = <GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>;
714 compatible = "ti,omap5430-bandgap";