2 * Copyright (C) 2013 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/interrupt-controller/arm-gic.h>
11 #include <dt-bindings/pinctrl/dra.h>
13 #include "skeleton.dtsi"
19 compatible = "ti,dra7xx";
20 interrupt-parent = <&gic>;
42 compatible = "arm,cortex-a15";
51 clocks = <&dpll_mpu_ck>;
54 clock-latency = <300000>; /* From omap-cpufreq driver */
58 compatible = "arm,cortex-a15";
64 compatible = "arm,armv7-timer";
65 interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>,
66 <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>,
67 <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>,
68 <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>;
71 gic: interrupt-controller@48211000 {
72 compatible = "arm,cortex-a15-gic";
74 #interrupt-cells = <3>;
75 reg = <0x48211000 0x1000>,
79 interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_HIGH)>;
83 * The soc node represents the soc top level view. It is used for IPs
84 * that are not memory mapped in the MPU view or for the MPU itself.
87 compatible = "ti,omap-infra";
89 compatible = "ti,omap5-mpu";
95 * XXX: Use a flat representation of the SOC interconnect.
96 * The real OMAP interconnect network is quite complex.
97 * Since that will not bring real advantage to represent that in DT for
98 * the moment, just use a fake OCP bus entry to represent the whole bus
102 compatible = "ti,omap4-l3-noc", "simple-bus";
103 #address-cells = <1>;
106 ti,hwmods = "l3_main_1", "l3_main_2";
107 reg = <0x44000000 0x2000>,
109 interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>,
110 <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
113 compatible = "ti,dra7-prm";
114 reg = <0x4ae06000 0x3000>;
117 #address-cells = <1>;
121 prm_clockdomains: clockdomains {
125 cm_core_aon: cm_core_aon@4a005000 {
126 compatible = "ti,dra7-cm-core-aon";
127 reg = <0x4a005000 0x2000>;
129 cm_core_aon_clocks: clocks {
130 #address-cells = <1>;
134 cm_core_aon_clockdomains: clockdomains {
138 cm_core: cm_core@4a008000 {
139 compatible = "ti,dra7-cm-core";
140 reg = <0x4a008000 0x3000>;
142 cm_core_clocks: clocks {
143 #address-cells = <1>;
147 cm_core_clockdomains: clockdomains {
151 counter32k: counter@4ae04000 {
152 compatible = "ti,omap-counter32k";
153 reg = <0x4ae04000 0x40>;
154 ti,hwmods = "counter_32k";
157 dra7_ctrl_general: tisyscon@4a002e00 {
158 compatible = "syscon";
159 reg = <0x4a002e00 0x7c>;
162 pbias_regulator: pbias_regulator {
163 compatible = "ti,pbias-omap";
165 syscon = <&dra7_ctrl_general>;
166 pbias_mmc_reg: pbias_mmc_omap5 {
167 regulator-name = "pbias_mmc_omap5";
168 regulator-min-microvolt = <1800000>;
169 regulator-max-microvolt = <3000000>;
173 dra7_pmx_core: pinmux@4a003400 {
174 compatible = "pinctrl-single";
175 reg = <0x4a003400 0x0464>;
176 #address-cells = <1>;
178 pinctrl-single,register-width = <32>;
179 pinctrl-single,function-mask = <0x3fffffff>;
182 sdma: dma-controller@4a056000 {
183 compatible = "ti,omap4430-sdma";
184 reg = <0x4a056000 0x1000>;
185 interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>,
186 <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>,
187 <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>,
188 <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
190 #dma-channels = <32>;
191 #dma-requests = <127>;
194 gpio1: gpio@4ae10000 {
195 compatible = "ti,omap4-gpio";
196 reg = <0x4ae10000 0x200>;
197 interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
201 interrupt-controller;
202 #interrupt-cells = <1>;
205 gpio2: gpio@48055000 {
206 compatible = "ti,omap4-gpio";
207 reg = <0x48055000 0x200>;
208 interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
212 interrupt-controller;
213 #interrupt-cells = <1>;
216 gpio3: gpio@48057000 {
217 compatible = "ti,omap4-gpio";
218 reg = <0x48057000 0x200>;
219 interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
223 interrupt-controller;
224 #interrupt-cells = <1>;
227 gpio4: gpio@48059000 {
228 compatible = "ti,omap4-gpio";
229 reg = <0x48059000 0x200>;
230 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
234 interrupt-controller;
235 #interrupt-cells = <1>;
238 gpio5: gpio@4805b000 {
239 compatible = "ti,omap4-gpio";
240 reg = <0x4805b000 0x200>;
241 interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
245 interrupt-controller;
246 #interrupt-cells = <1>;
249 gpio6: gpio@4805d000 {
250 compatible = "ti,omap4-gpio";
251 reg = <0x4805d000 0x200>;
252 interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
256 interrupt-controller;
257 #interrupt-cells = <1>;
260 gpio7: gpio@48051000 {
261 compatible = "ti,omap4-gpio";
262 reg = <0x48051000 0x200>;
263 interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
267 interrupt-controller;
268 #interrupt-cells = <1>;
271 gpio8: gpio@48053000 {
272 compatible = "ti,omap4-gpio";
273 reg = <0x48053000 0x200>;
274 interrupts = <GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>;
278 interrupt-controller;
279 #interrupt-cells = <1>;
282 uart1: serial@4806a000 {
283 compatible = "ti,omap4-uart";
284 reg = <0x4806a000 0x100>;
285 interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>;
287 clock-frequency = <48000000>;
291 uart2: serial@4806c000 {
292 compatible = "ti,omap4-uart";
293 reg = <0x4806c000 0x100>;
294 interrupts = <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>;
296 clock-frequency = <48000000>;
300 uart3: serial@48020000 {
301 compatible = "ti,omap4-uart";
302 reg = <0x48020000 0x100>;
303 interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
305 clock-frequency = <48000000>;
309 uart4: serial@4806e000 {
310 compatible = "ti,omap4-uart";
311 reg = <0x4806e000 0x100>;
312 interrupts = <GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>;
314 clock-frequency = <48000000>;
318 uart5: serial@48066000 {
319 compatible = "ti,omap4-uart";
320 reg = <0x48066000 0x100>;
321 interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>;
323 clock-frequency = <48000000>;
327 uart6: serial@48068000 {
328 compatible = "ti,omap4-uart";
329 reg = <0x48068000 0x100>;
330 interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
332 clock-frequency = <48000000>;
336 uart7: serial@48420000 {
337 compatible = "ti,omap4-uart";
338 reg = <0x48420000 0x100>;
340 clock-frequency = <48000000>;
344 uart8: serial@48422000 {
345 compatible = "ti,omap4-uart";
346 reg = <0x48422000 0x100>;
348 clock-frequency = <48000000>;
352 uart9: serial@48424000 {
353 compatible = "ti,omap4-uart";
354 reg = <0x48424000 0x100>;
356 clock-frequency = <48000000>;
360 uart10: serial@4ae2b000 {
361 compatible = "ti,omap4-uart";
362 reg = <0x4ae2b000 0x100>;
363 ti,hwmods = "uart10";
364 clock-frequency = <48000000>;
368 timer1: timer@4ae18000 {
369 compatible = "ti,omap5430-timer";
370 reg = <0x4ae18000 0x80>;
371 interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
372 ti,hwmods = "timer1";
376 timer2: timer@48032000 {
377 compatible = "ti,omap5430-timer";
378 reg = <0x48032000 0x80>;
379 interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
380 ti,hwmods = "timer2";
383 timer3: timer@48034000 {
384 compatible = "ti,omap5430-timer";
385 reg = <0x48034000 0x80>;
386 interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>;
387 ti,hwmods = "timer3";
390 timer4: timer@48036000 {
391 compatible = "ti,omap5430-timer";
392 reg = <0x48036000 0x80>;
393 interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>;
394 ti,hwmods = "timer4";
397 timer5: timer@48820000 {
398 compatible = "ti,omap5430-timer";
399 reg = <0x48820000 0x80>;
400 interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
401 ti,hwmods = "timer5";
405 timer6: timer@48822000 {
406 compatible = "ti,omap5430-timer";
407 reg = <0x48822000 0x80>;
408 interrupts = <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>;
409 ti,hwmods = "timer6";
414 timer7: timer@48824000 {
415 compatible = "ti,omap5430-timer";
416 reg = <0x48824000 0x80>;
417 interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
418 ti,hwmods = "timer7";
422 timer8: timer@48826000 {
423 compatible = "ti,omap5430-timer";
424 reg = <0x48826000 0x80>;
425 interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
426 ti,hwmods = "timer8";
431 timer9: timer@4803e000 {
432 compatible = "ti,omap5430-timer";
433 reg = <0x4803e000 0x80>;
434 interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
435 ti,hwmods = "timer9";
438 timer10: timer@48086000 {
439 compatible = "ti,omap5430-timer";
440 reg = <0x48086000 0x80>;
441 interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>;
442 ti,hwmods = "timer10";
445 timer11: timer@48088000 {
446 compatible = "ti,omap5430-timer";
447 reg = <0x48088000 0x80>;
448 interrupts = <GIC_SPI 47 IRQ_TYPE_LEVEL_HIGH>;
449 ti,hwmods = "timer11";
453 timer13: timer@48828000 {
454 compatible = "ti,omap5430-timer";
455 reg = <0x48828000 0x80>;
456 ti,hwmods = "timer13";
460 timer14: timer@4882a000 {
461 compatible = "ti,omap5430-timer";
462 reg = <0x4882a000 0x80>;
463 ti,hwmods = "timer14";
467 timer15: timer@4882c000 {
468 compatible = "ti,omap5430-timer";
469 reg = <0x4882c000 0x80>;
470 ti,hwmods = "timer15";
474 timer16: timer@4882e000 {
475 compatible = "ti,omap5430-timer";
476 reg = <0x4882e000 0x80>;
477 ti,hwmods = "timer16";
482 compatible = "ti,omap4-wdt";
483 reg = <0x4ae14000 0x80>;
484 interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>;
485 ti,hwmods = "wd_timer2";
488 hwspinlock: spinlock@4a0f6000 {
489 compatible = "ti,omap4-hwspinlock";
490 reg = <0x4a0f6000 0x1000>;
491 ti,hwmods = "spinlock";
496 compatible = "ti,omap5-dmm";
497 reg = <0x4e000000 0x800>;
498 interrupts = <0 113 0x4>;
503 compatible = "ti,omap4-i2c";
504 reg = <0x48070000 0x100>;
505 interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>;
506 #address-cells = <1>;
513 compatible = "ti,omap4-i2c";
514 reg = <0x48072000 0x100>;
515 interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
516 #address-cells = <1>;
523 compatible = "ti,omap4-i2c";
524 reg = <0x48060000 0x100>;
525 interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
526 #address-cells = <1>;
533 compatible = "ti,omap4-i2c";
534 reg = <0x4807a000 0x100>;
535 interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>;
536 #address-cells = <1>;
543 compatible = "ti,omap4-i2c";
544 reg = <0x4807c000 0x100>;
545 interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>;
546 #address-cells = <1>;
553 compatible = "ti,omap4-hsmmc";
554 reg = <0x4809c000 0x400>;
555 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
558 ti,needs-special-reset;
559 dmas = <&sdma 61>, <&sdma 62>;
560 dma-names = "tx", "rx";
562 pbias-supply = <&pbias_mmc_reg>;
566 compatible = "ti,omap4-hsmmc";
567 reg = <0x480b4000 0x400>;
568 interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
570 ti,needs-special-reset;
571 dmas = <&sdma 47>, <&sdma 48>;
572 dma-names = "tx", "rx";
577 compatible = "ti,omap4-hsmmc";
578 reg = <0x480ad000 0x400>;
579 interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
581 ti,needs-special-reset;
582 dmas = <&sdma 77>, <&sdma 78>;
583 dma-names = "tx", "rx";
588 compatible = "ti,omap4-hsmmc";
589 reg = <0x480d1000 0x400>;
590 interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
592 ti,needs-special-reset;
593 dmas = <&sdma 57>, <&sdma 58>;
594 dma-names = "tx", "rx";
598 abb_mpu: regulator-abb-mpu {
599 compatible = "ti,abb-v3";
600 regulator-name = "abb_mpu";
601 #address-cells = <0>;
603 clocks = <&sys_clkin1>;
604 ti,settling-time = <50>;
605 ti,clock-cycles = <16>;
607 reg = <0x4ae07ddc 0x4>, <0x4ae07de0 0x4>,
608 <0x4ae06014 0x4>, <0x4a003b20 0x8>,
610 reg-names = "setup-address", "control-address",
611 "int-address", "efuse-address",
613 ti,tranxdone-status-mask = <0x80>;
614 /* LDOVBBMPU_FBB_MUX_CTRL */
615 ti,ldovbb-override-mask = <0x400>;
616 /* LDOVBBMPU_FBB_VSET_OUT */
617 ti,ldovbb-vset-mask = <0x1F>;
620 * NOTE: only FBB mode used but actual vset will
621 * determine final biasing
624 /*uV ABB efuse rbb_m fbb_m vset_m*/
625 1060000 0 0x0 0 0x02000000 0x01F00000
626 1160000 0 0x4 0 0x02000000 0x01F00000
627 1210000 0 0x8 0 0x02000000 0x01F00000
631 abb_ivahd: regulator-abb-ivahd {
632 compatible = "ti,abb-v3";
633 regulator-name = "abb_ivahd";
634 #address-cells = <0>;
636 clocks = <&sys_clkin1>;
637 ti,settling-time = <50>;
638 ti,clock-cycles = <16>;
640 reg = <0x4ae07e34 0x4>, <0x4ae07e24 0x4>,
641 <0x4ae06010 0x4>, <0x4a0025cc 0x8>,
643 reg-names = "setup-address", "control-address",
644 "int-address", "efuse-address",
646 ti,tranxdone-status-mask = <0x40000000>;
647 /* LDOVBBIVA_FBB_MUX_CTRL */
648 ti,ldovbb-override-mask = <0x400>;
649 /* LDOVBBIVA_FBB_VSET_OUT */
650 ti,ldovbb-vset-mask = <0x1F>;
653 * NOTE: only FBB mode used but actual vset will
654 * determine final biasing
657 /*uV ABB efuse rbb_m fbb_m vset_m*/
658 1055000 0 0x0 0 0x02000000 0x01F00000
659 1150000 0 0x4 0 0x02000000 0x01F00000
660 1250000 0 0x8 0 0x02000000 0x01F00000
664 abb_dspeve: regulator-abb-dspeve {
665 compatible = "ti,abb-v3";
666 regulator-name = "abb_dspeve";
667 #address-cells = <0>;
669 clocks = <&sys_clkin1>;
670 ti,settling-time = <50>;
671 ti,clock-cycles = <16>;
673 reg = <0x4ae07e30 0x4>, <0x4ae07e20 0x4>,
674 <0x4ae06010 0x4>, <0x4a0025e0 0x8>,
676 reg-names = "setup-address", "control-address",
677 "int-address", "efuse-address",
679 ti,tranxdone-status-mask = <0x20000000>;
680 /* LDOVBBDSPEVE_FBB_MUX_CTRL */
681 ti,ldovbb-override-mask = <0x400>;
682 /* LDOVBBDSPEVE_FBB_VSET_OUT */
683 ti,ldovbb-vset-mask = <0x1F>;
686 * NOTE: only FBB mode used but actual vset will
687 * determine final biasing
690 /*uV ABB efuse rbb_m fbb_m vset_m*/
691 1055000 0 0x0 0 0x02000000 0x01F00000
692 1150000 0 0x4 0 0x02000000 0x01F00000
693 1250000 0 0x8 0 0x02000000 0x01F00000
697 abb_gpu: regulator-abb-gpu {
698 compatible = "ti,abb-v3";
699 regulator-name = "abb_gpu";
700 #address-cells = <0>;
702 clocks = <&sys_clkin1>;
703 ti,settling-time = <50>;
704 ti,clock-cycles = <16>;
706 reg = <0x4ae07de4 0x4>, <0x4ae07de8 0x4>,
707 <0x4ae06010 0x4>, <0x4a003b08 0x8>,
709 reg-names = "setup-address", "control-address",
710 "int-address", "efuse-address",
712 ti,tranxdone-status-mask = <0x10000000>;
713 /* LDOVBBGPU_FBB_MUX_CTRL */
714 ti,ldovbb-override-mask = <0x400>;
715 /* LDOVBBGPU_FBB_VSET_OUT */
716 ti,ldovbb-vset-mask = <0x1F>;
719 * NOTE: only FBB mode used but actual vset will
720 * determine final biasing
723 /*uV ABB efuse rbb_m fbb_m vset_m*/
724 1090000 0 0x0 0 0x02000000 0x01F00000
725 1210000 0 0x4 0 0x02000000 0x01F00000
726 1280000 0 0x8 0 0x02000000 0x01F00000
730 mcspi1: spi@48098000 {
731 compatible = "ti,omap4-mcspi";
732 reg = <0x48098000 0x200>;
733 interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>;
734 #address-cells = <1>;
736 ti,hwmods = "mcspi1";
746 dma-names = "tx0", "rx0", "tx1", "rx1",
747 "tx2", "rx2", "tx3", "rx3";
751 mcspi2: spi@4809a000 {
752 compatible = "ti,omap4-mcspi";
753 reg = <0x4809a000 0x200>;
754 interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>;
755 #address-cells = <1>;
757 ti,hwmods = "mcspi2";
763 dma-names = "tx0", "rx0", "tx1", "rx1";
767 mcspi3: spi@480b8000 {
768 compatible = "ti,omap4-mcspi";
769 reg = <0x480b8000 0x200>;
770 interrupts = <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>;
771 #address-cells = <1>;
773 ti,hwmods = "mcspi3";
775 dmas = <&sdma 15>, <&sdma 16>;
776 dma-names = "tx0", "rx0";
780 mcspi4: spi@480ba000 {
781 compatible = "ti,omap4-mcspi";
782 reg = <0x480ba000 0x200>;
783 interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>;
784 #address-cells = <1>;
786 ti,hwmods = "mcspi4";
788 dmas = <&sdma 70>, <&sdma 71>;
789 dma-names = "tx0", "rx0";
795 /include/ "dra7xx-clocks.dtsi"