blob: b5093020ee9702677daa54f8814696a2d99261c6 [file] [log] [blame]
Simon Glassb37e8152014-06-02 22:04:55 -06001/*
2 * Device Tree Source for AM33XX SoC
3 *
4 * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
5 *
6 * This file is licensed under the terms of the GNU General Public License
7 * version 2. This program is licensed "as is" without any warranty of any
8 * kind, whether express or implied.
9 */
10
Dario Binacchi96d04d72020-12-30 00:06:30 +010011#include <dt-bindings/bus/ti-sysc.h>
Simon Glassb37e8152014-06-02 22:04:55 -060012#include <dt-bindings/gpio/gpio.h>
13#include <dt-bindings/pinctrl/am33xx.h>
Felix Brack7262f382018-12-05 14:53:42 +010014#include <dt-bindings/clock/am3.h>
Simon Glassb37e8152014-06-02 22:04:55 -060015
16/ {
17 compatible = "ti,am33xx";
18 interrupt-parent = <&intc>;
Felix Brack7262f382018-12-05 14:53:42 +010019 #address-cells = <1>;
20 #size-cells = <1>;
21 chosen { };
Simon Glassb37e8152014-06-02 22:04:55 -060022
23 aliases {
Tom Rini5ba15962015-07-31 19:55:08 -040024 i2c0 = &i2c0;
25 i2c1 = &i2c1;
26 i2c2 = &i2c2;
Simon Glassb37e8152014-06-02 22:04:55 -060027 serial0 = &uart0;
28 serial1 = &uart1;
29 serial2 = &uart2;
30 serial3 = &uart3;
31 serial4 = &uart4;
32 serial5 = &uart5;
Felix Brack7262f382018-12-05 14:53:42 +010033 d-can0 = &dcan0;
34 d-can1 = &dcan1;
Simon Glassb37e8152014-06-02 22:04:55 -060035 usb0 = &usb0;
36 usb1 = &usb1;
37 phy0 = &usb0_phy;
38 phy1 = &usb1_phy;
Tom Rini5ba15962015-07-31 19:55:08 -040039 ethernet0 = &cpsw_emac0;
40 ethernet1 = &cpsw_emac1;
Felix Brack7262f382018-12-05 14:53:42 +010041 spi0 = &spi0;
42 spi1 = &spi1;
Simon Glassb37e8152014-06-02 22:04:55 -060043 };
44
45 cpus {
46 #address-cells = <1>;
47 #size-cells = <0>;
48 cpu@0 {
49 compatible = "arm,cortex-a8";
Dario Binacchi96d04d72020-12-30 00:06:30 +010050 enable-method = "ti,am3352";
Simon Glassb37e8152014-06-02 22:04:55 -060051 device_type = "cpu";
52 reg = <0>;
53
Felix Brack7262f382018-12-05 14:53:42 +010054 operating-points-v2 = <&cpu0_opp_table>;
Tom Rini5ba15962015-07-31 19:55:08 -040055
56 clocks = <&dpll_mpu_ck>;
57 clock-names = "cpu";
58
Simon Glassb37e8152014-06-02 22:04:55 -060059 clock-latency = <300000>; /* From omap-cpufreq driver */
Dario Binacchi96d04d72020-12-30 00:06:30 +010060 cpu-idle-states = <&mpu_gate>;
61 };
62
63 idle-states {
64 mpu_gate: mpu_gate {
65 compatible = "arm,idle-state";
66 entry-latency-us = <40>;
67 exit-latency-us = <90>;
68 min-residency-us = <300>;
69 ti,idle-wkup-m3;
70 };
Simon Glassb37e8152014-06-02 22:04:55 -060071 };
72 };
73
Felix Brack7262f382018-12-05 14:53:42 +010074 cpu0_opp_table: opp-table {
75 compatible = "operating-points-v2-ti-cpu";
76 syscon = <&scm_conf>;
77
78 /*
79 * The three following nodes are marked with opp-suspend
80 * because the can not be enabled simultaneously on a
81 * single SoC.
82 */
83 opp50-300000000 {
84 opp-hz = /bits/ 64 <300000000>;
85 opp-microvolt = <950000 931000 969000>;
86 opp-supported-hw = <0x06 0x0010>;
87 opp-suspend;
88 };
89
90 opp100-275000000 {
91 opp-hz = /bits/ 64 <275000000>;
92 opp-microvolt = <1100000 1078000 1122000>;
93 opp-supported-hw = <0x01 0x00FF>;
94 opp-suspend;
95 };
96
97 opp100-300000000 {
98 opp-hz = /bits/ 64 <300000000>;
99 opp-microvolt = <1100000 1078000 1122000>;
100 opp-supported-hw = <0x06 0x0020>;
101 opp-suspend;
102 };
103
104 opp100-500000000 {
105 opp-hz = /bits/ 64 <500000000>;
106 opp-microvolt = <1100000 1078000 1122000>;
107 opp-supported-hw = <0x01 0xFFFF>;
108 };
109
110 opp100-600000000 {
111 opp-hz = /bits/ 64 <600000000>;
112 opp-microvolt = <1100000 1078000 1122000>;
113 opp-supported-hw = <0x06 0x0040>;
114 };
115
116 opp120-600000000 {
117 opp-hz = /bits/ 64 <600000000>;
118 opp-microvolt = <1200000 1176000 1224000>;
119 opp-supported-hw = <0x01 0xFFFF>;
120 };
121
122 opp120-720000000 {
123 opp-hz = /bits/ 64 <720000000>;
124 opp-microvolt = <1200000 1176000 1224000>;
125 opp-supported-hw = <0x06 0x0080>;
126 };
127
128 oppturbo-720000000 {
129 opp-hz = /bits/ 64 <720000000>;
130 opp-microvolt = <1260000 1234800 1285200>;
131 opp-supported-hw = <0x01 0xFFFF>;
132 };
133
134 oppturbo-800000000 {
135 opp-hz = /bits/ 64 <800000000>;
136 opp-microvolt = <1260000 1234800 1285200>;
137 opp-supported-hw = <0x06 0x0100>;
138 };
139
140 oppnitro-1000000000 {
141 opp-hz = /bits/ 64 <1000000000>;
142 opp-microvolt = <1325000 1298500 1351500>;
143 opp-supported-hw = <0x04 0x0200>;
144 };
145 };
146
147 pmu@4b000000 {
Tom Rini5ba15962015-07-31 19:55:08 -0400148 compatible = "arm,cortex-a8-pmu";
149 interrupts = <3>;
Felix Brack7262f382018-12-05 14:53:42 +0100150 reg = <0x4b000000 0x1000000>;
151 ti,hwmods = "debugss";
Tom Rini5ba15962015-07-31 19:55:08 -0400152 };
153
Simon Glassb37e8152014-06-02 22:04:55 -0600154 /*
Tom Rini5ba15962015-07-31 19:55:08 -0400155 * The soc node represents the soc top level view. It is used for IPs
Simon Glassb37e8152014-06-02 22:04:55 -0600156 * that are not memory mapped in the MPU view or for the MPU itself.
157 */
158 soc {
159 compatible = "ti,omap-infra";
160 mpu {
161 compatible = "ti,omap3-mpu";
162 ti,hwmods = "mpu";
Felix Brack7262f382018-12-05 14:53:42 +0100163 pm-sram = <&pm_sram_code
164 &pm_sram_data>;
Simon Glassb37e8152014-06-02 22:04:55 -0600165 };
166 };
167
Simon Glassb37e8152014-06-02 22:04:55 -0600168 /*
169 * XXX: Use a flat representation of the AM33XX interconnect.
Tom Rini5ba15962015-07-31 19:55:08 -0400170 * The real AM33XX interconnect network is quite complex. Since
171 * it will not bring real advantage to represent that in DT
Simon Glassb37e8152014-06-02 22:04:55 -0600172 * for the moment, just use a fake OCP bus entry to represent
173 * the whole bus hierarchy.
174 */
175 ocp {
176 compatible = "simple-bus";
177 #address-cells = <1>;
178 #size-cells = <1>;
179 ranges;
180 ti,hwmods = "l3_main";
181
Tom Rini5ba15962015-07-31 19:55:08 -0400182 l4_wkup: l4_wkup@44c00000 {
Felix Brack7262f382018-12-05 14:53:42 +0100183 wkup_m3: wkup_m3@100000 {
184 compatible = "ti,am3352-wkup-m3";
185 reg = <0x100000 0x4000>,
186 <0x180000 0x2000>;
187 reg-names = "umem", "dmem";
188 ti,hwmods = "wkup_m3";
189 ti,pm-firmware = "am335x-pm-firmware.elf";
190 };
Dario Binacchi96d04d72020-12-30 00:06:30 +0100191 };
192 l4_per: interconnect@48000000 {
193 };
194 l4_fw: interconnect@47c00000 {
195 };
196 l4_fast: interconnect@4a000000 {
197 };
198 l4_mpuss: interconnect@4b140000 {
Tom Rini5ba15962015-07-31 19:55:08 -0400199 };
200
Simon Glassb37e8152014-06-02 22:04:55 -0600201 intc: interrupt-controller@48200000 {
Tom Rini5ba15962015-07-31 19:55:08 -0400202 compatible = "ti,am33xx-intc";
Simon Glassb37e8152014-06-02 22:04:55 -0600203 interrupt-controller;
204 #interrupt-cells = <1>;
Simon Glassb37e8152014-06-02 22:04:55 -0600205 reg = <0x48200000 0x1000>;
206 };
207
Dario Binacchi96d04d72020-12-30 00:06:30 +0100208 target-module@49000000 {
209 compatible = "ti,sysc-omap4", "ti,sysc";
210 reg = <0x49000000 0x4>;
211 reg-names = "rev";
212 clocks = <&l3_clkctrl AM3_L3_TPCC_CLKCTRL 0>;
213 clock-names = "fck";
214 #address-cells = <1>;
215 #size-cells = <1>;
216 ranges = <0x0 0x49000000 0x10000>;
217
218 edma: dma@0 {
219 compatible = "ti,edma3-tpcc";
220 reg = <0 0x10000>;
221 reg-names = "edma3_cc";
222 interrupts = <12 13 14>;
223 interrupt-names = "edma3_ccint", "edma3_mperr",
224 "edma3_ccerrint";
225 dma-requests = <64>;
226 #dma-cells = <2>;
Felix Brack7262f382018-12-05 14:53:42 +0100227
Dario Binacchi96d04d72020-12-30 00:06:30 +0100228 ti,tptcs = <&edma_tptc0 7>, <&edma_tptc1 5>,
229 <&edma_tptc2 0>;
Felix Brack7262f382018-12-05 14:53:42 +0100230
Dario Binacchi96d04d72020-12-30 00:06:30 +0100231 ti,edma-memcpy-channels = <20 21>;
232 };
Tom Rini5ba15962015-07-31 19:55:08 -0400233 };
234
Dario Binacchi96d04d72020-12-30 00:06:30 +0100235 target-module@49800000 {
236 compatible = "ti,sysc-omap4", "ti,sysc";
237 reg = <0x49800000 0x4>,
238 <0x49800010 0x4>;
239 reg-names = "rev", "sysc";
240 ti,sysc-mask = <SYSC_OMAP4_SOFTRESET>;
241 ti,sysc-midle = <SYSC_IDLE_FORCE>;
242 ti,sysc-sidle = <SYSC_IDLE_FORCE>,
243 <SYSC_IDLE_SMART>;
244 clocks = <&l3_clkctrl AM3_L3_TPTC0_CLKCTRL 0>;
245 clock-names = "fck";
246 #address-cells = <1>;
247 #size-cells = <1>;
248 ranges = <0x0 0x49800000 0x100000>;
249
250 edma_tptc0: dma@0 {
251 compatible = "ti,edma3-tptc";
252 reg = <0 0x100000>;
253 interrupts = <112>;
254 interrupt-names = "edma3_tcerrint";
255 };
Felix Brack7262f382018-12-05 14:53:42 +0100256 };
257
Dario Binacchi96d04d72020-12-30 00:06:30 +0100258 target-module@49900000 {
259 compatible = "ti,sysc-omap4", "ti,sysc";
260 reg = <0x49900000 0x4>,
261 <0x49900010 0x4>;
262 reg-names = "rev", "sysc";
263 ti,sysc-mask = <SYSC_OMAP4_SOFTRESET>;
264 ti,sysc-midle = <SYSC_IDLE_FORCE>;
265 ti,sysc-sidle = <SYSC_IDLE_FORCE>,
266 <SYSC_IDLE_SMART>;
267 clocks = <&l3_clkctrl AM3_L3_TPTC1_CLKCTRL 0>;
268 clock-names = "fck";
269 #address-cells = <1>;
270 #size-cells = <1>;
271 ranges = <0x0 0x49900000 0x100000>;
272
273 edma_tptc1: dma@0 {
274 compatible = "ti,edma3-tptc";
275 reg = <0 0x100000>;
276 interrupts = <113>;
277 interrupt-names = "edma3_tcerrint";
278 };
Felix Brack7262f382018-12-05 14:53:42 +0100279 };
280
Dario Binacchi96d04d72020-12-30 00:06:30 +0100281 target-module@49a00000 {
282 compatible = "ti,sysc-omap4", "ti,sysc";
283 reg = <0x49a00000 0x4>,
284 <0x49a00010 0x4>;
285 reg-names = "rev", "sysc";
286 ti,sysc-mask = <SYSC_OMAP4_SOFTRESET>;
287 ti,sysc-midle = <SYSC_IDLE_FORCE>;
288 ti,sysc-sidle = <SYSC_IDLE_FORCE>,
289 <SYSC_IDLE_SMART>;
290 clocks = <&l3_clkctrl AM3_L3_TPTC2_CLKCTRL 0>;
291 clock-names = "fck";
292 #address-cells = <1>;
293 #size-cells = <1>;
294 ranges = <0x0 0x49a00000 0x100000>;
295
296 edma_tptc2: dma@0 {
297 compatible = "ti,edma3-tptc";
298 reg = <0 0x100000>;
299 interrupts = <114>;
300 interrupt-names = "edma3_tcerrint";
301 };
Felix Brack7262f382018-12-05 14:53:42 +0100302 };
303
Simon Glassb37e8152014-06-02 22:04:55 -0600304 i2c0: i2c@44e0b000 {
305 compatible = "ti,omap4-i2c";
306 #address-cells = <1>;
307 #size-cells = <0>;
308 ti,hwmods = "i2c1";
309 reg = <0x44e0b000 0x1000>;
310 interrupts = <70>;
311 status = "disabled";
312 };
313
314 i2c1: i2c@4802a000 {
315 compatible = "ti,omap4-i2c";
316 #address-cells = <1>;
317 #size-cells = <0>;
318 ti,hwmods = "i2c2";
319 reg = <0x4802a000 0x1000>;
320 interrupts = <71>;
321 status = "disabled";
322 };
323
324 i2c2: i2c@4819c000 {
325 compatible = "ti,omap4-i2c";
326 #address-cells = <1>;
327 #size-cells = <0>;
328 ti,hwmods = "i2c3";
329 reg = <0x4819c000 0x1000>;
330 interrupts = <30>;
331 status = "disabled";
332 };
333
Tom Rini5ba15962015-07-31 19:55:08 -0400334 mmc1: mmc@48060000 {
335 compatible = "ti,omap4-hsmmc";
336 ti,hwmods = "mmc1";
337 ti,dual-volt;
338 ti,needs-special-reset;
339 ti,needs-special-hs-handling;
Felix Brack7262f382018-12-05 14:53:42 +0100340 dmas = <&edma_xbar 24 0 0
341 &edma_xbar 25 0 0>;
Tom Rini5ba15962015-07-31 19:55:08 -0400342 dma-names = "tx", "rx";
343 interrupts = <64>;
Tom Rini5ba15962015-07-31 19:55:08 -0400344 reg = <0x48060000 0x1000>;
345 status = "disabled";
346 };
347
348 mmc2: mmc@481d8000 {
349 compatible = "ti,omap4-hsmmc";
350 ti,hwmods = "mmc2";
351 ti,needs-special-reset;
Felix Brack7262f382018-12-05 14:53:42 +0100352 dmas = <&edma 2 0
353 &edma 3 0>;
Tom Rini5ba15962015-07-31 19:55:08 -0400354 dma-names = "tx", "rx";
355 interrupts = <28>;
Tom Rini5ba15962015-07-31 19:55:08 -0400356 reg = <0x481d8000 0x1000>;
357 status = "disabled";
358 };
359
360 mmc3: mmc@47810000 {
361 compatible = "ti,omap4-hsmmc";
362 ti,hwmods = "mmc3";
363 ti,needs-special-reset;
364 interrupts = <29>;
Tom Rini5ba15962015-07-31 19:55:08 -0400365 reg = <0x47810000 0x1000>;
366 status = "disabled";
367 };
368
Simon Glassb37e8152014-06-02 22:04:55 -0600369 wdt2: wdt@44e35000 {
370 compatible = "ti,omap3-wdt";
371 ti,hwmods = "wd_timer2";
372 reg = <0x44e35000 0x1000>;
373 interrupts = <91>;
374 };
375
Simon Glassb37e8152014-06-02 22:04:55 -0600376 usb: usb@47400000 {
377 compatible = "ti,am33xx-usb";
378 reg = <0x47400000 0x1000>;
379 ranges;
380 #address-cells = <1>;
381 #size-cells = <1>;
382 ti,hwmods = "usb_otg_hs";
Simon Glassb37e8152014-06-02 22:04:55 -0600383
Tom Rini5ba15962015-07-31 19:55:08 -0400384 usb_ctrl_mod: control@44e10620 {
Simon Glassb37e8152014-06-02 22:04:55 -0600385 compatible = "ti,am335x-usb-ctrl-module";
386 reg = <0x44e10620 0x10
387 0x44e10648 0x4>;
388 reg-names = "phy_ctrl", "wakeup";
Simon Glassb37e8152014-06-02 22:04:55 -0600389 };
390
391 usb0_phy: usb-phy@47401300 {
392 compatible = "ti,am335x-usb-phy";
393 reg = <0x47401300 0x100>;
394 reg-names = "phy";
Tom Rini5ba15962015-07-31 19:55:08 -0400395 ti,ctrl_mod = <&usb_ctrl_mod>;
Felix Brack7262f382018-12-05 14:53:42 +0100396 #phy-cells = <0>;
Simon Glassb37e8152014-06-02 22:04:55 -0600397 };
398
399 usb0: usb@47401000 {
400 compatible = "ti,musb-am33xx";
Simon Glassb37e8152014-06-02 22:04:55 -0600401 reg = <0x47401400 0x400
402 0x47401000 0x200>;
403 reg-names = "mc", "control";
404
405 interrupts = <18>;
406 interrupt-names = "mc";
407 dr_mode = "otg";
408 mentor,multipoint = <1>;
409 mentor,num-eps = <16>;
410 mentor,ram-bits = <12>;
411 mentor,power = <500>;
412 phys = <&usb0_phy>;
413
414 dmas = <&cppi41dma 0 0 &cppi41dma 1 0
415 &cppi41dma 2 0 &cppi41dma 3 0
416 &cppi41dma 4 0 &cppi41dma 5 0
417 &cppi41dma 6 0 &cppi41dma 7 0
418 &cppi41dma 8 0 &cppi41dma 9 0
419 &cppi41dma 10 0 &cppi41dma 11 0
420 &cppi41dma 12 0 &cppi41dma 13 0
421 &cppi41dma 14 0 &cppi41dma 0 1
422 &cppi41dma 1 1 &cppi41dma 2 1
423 &cppi41dma 3 1 &cppi41dma 4 1
424 &cppi41dma 5 1 &cppi41dma 6 1
425 &cppi41dma 7 1 &cppi41dma 8 1
426 &cppi41dma 9 1 &cppi41dma 10 1
427 &cppi41dma 11 1 &cppi41dma 12 1
428 &cppi41dma 13 1 &cppi41dma 14 1>;
429 dma-names =
430 "rx1", "rx2", "rx3", "rx4", "rx5", "rx6", "rx7",
431 "rx8", "rx9", "rx10", "rx11", "rx12", "rx13",
432 "rx14", "rx15",
433 "tx1", "tx2", "tx3", "tx4", "tx5", "tx6", "tx7",
434 "tx8", "tx9", "tx10", "tx11", "tx12", "tx13",
435 "tx14", "tx15";
436 };
437
438 usb1_phy: usb-phy@47401b00 {
439 compatible = "ti,am335x-usb-phy";
440 reg = <0x47401b00 0x100>;
441 reg-names = "phy";
Tom Rini5ba15962015-07-31 19:55:08 -0400442 ti,ctrl_mod = <&usb_ctrl_mod>;
Felix Brack7262f382018-12-05 14:53:42 +0100443 #phy-cells = <0>;
Simon Glassb37e8152014-06-02 22:04:55 -0600444 };
445
446 usb1: usb@47401800 {
447 compatible = "ti,musb-am33xx";
Simon Glassb37e8152014-06-02 22:04:55 -0600448 reg = <0x47401c00 0x400
449 0x47401800 0x200>;
450 reg-names = "mc", "control";
451 interrupts = <19>;
452 interrupt-names = "mc";
453 dr_mode = "otg";
454 mentor,multipoint = <1>;
455 mentor,num-eps = <16>;
456 mentor,ram-bits = <12>;
457 mentor,power = <500>;
458 phys = <&usb1_phy>;
459
460 dmas = <&cppi41dma 15 0 &cppi41dma 16 0
461 &cppi41dma 17 0 &cppi41dma 18 0
462 &cppi41dma 19 0 &cppi41dma 20 0
463 &cppi41dma 21 0 &cppi41dma 22 0
464 &cppi41dma 23 0 &cppi41dma 24 0
465 &cppi41dma 25 0 &cppi41dma 26 0
466 &cppi41dma 27 0 &cppi41dma 28 0
467 &cppi41dma 29 0 &cppi41dma 15 1
468 &cppi41dma 16 1 &cppi41dma 17 1
469 &cppi41dma 18 1 &cppi41dma 19 1
470 &cppi41dma 20 1 &cppi41dma 21 1
471 &cppi41dma 22 1 &cppi41dma 23 1
472 &cppi41dma 24 1 &cppi41dma 25 1
473 &cppi41dma 26 1 &cppi41dma 27 1
474 &cppi41dma 28 1 &cppi41dma 29 1>;
475 dma-names =
476 "rx1", "rx2", "rx3", "rx4", "rx5", "rx6", "rx7",
477 "rx8", "rx9", "rx10", "rx11", "rx12", "rx13",
478 "rx14", "rx15",
479 "tx1", "tx2", "tx3", "tx4", "tx5", "tx6", "tx7",
480 "tx8", "tx9", "tx10", "tx11", "tx12", "tx13",
481 "tx14", "tx15";
482 };
483
Dario Binacchi96d04d72020-12-30 00:06:30 +0100484 cppi41dma: dma-controller@2000 {
Simon Glassb37e8152014-06-02 22:04:55 -0600485 compatible = "ti,am3359-cppi41";
Dario Binacchi96d04d72020-12-30 00:06:30 +0100486 reg = <0x0000 0x1000>,
487 <0x2000 0x1000>,
488 <0x3000 0x1000>,
489 <0x4000 0x4000>;
Simon Glassb37e8152014-06-02 22:04:55 -0600490 reg-names = "glue", "controller", "scheduler", "queuemgr";
491 interrupts = <17>;
492 interrupt-names = "glue";
493 #dma-cells = <2>;
494 #dma-channels = <30>;
495 #dma-requests = <256>;
Simon Glassb37e8152014-06-02 22:04:55 -0600496 };
497 };
498
Simon Glassb37e8152014-06-02 22:04:55 -0600499 mac: ethernet@4a100000 {
Felix Brack7262f382018-12-05 14:53:42 +0100500 compatible = "ti,am335x-cpsw","ti,cpsw";
Simon Glassb37e8152014-06-02 22:04:55 -0600501 ti,hwmods = "cpgmac0";
Tom Rini5ba15962015-07-31 19:55:08 -0400502 clocks = <&cpsw_125mhz_gclk>, <&cpsw_cpts_rft_clk>;
503 clock-names = "fck", "cpts";
Simon Glassb37e8152014-06-02 22:04:55 -0600504 cpdma_channels = <8>;
505 ale_entries = <1024>;
506 bd_ram_size = <0x2000>;
Simon Glassb37e8152014-06-02 22:04:55 -0600507 mac_control = <0x20>;
508 slaves = <2>;
509 active_slave = <0>;
510 cpts_clock_mult = <0x80000000>;
511 cpts_clock_shift = <29>;
512 reg = <0x4a100000 0x800
513 0x4a101200 0x100>;
514 #address-cells = <1>;
515 #size-cells = <1>;
Simon Glassb37e8152014-06-02 22:04:55 -0600516 /*
517 * c0_rx_thresh_pend
518 * c0_rx_pend
519 * c0_tx_pend
520 * c0_misc_pend
521 */
522 interrupts = <40 41 42 43>;
523 ranges;
Tom Rini5ba15962015-07-31 19:55:08 -0400524 syscon = <&scm_conf>;
525 status = "disabled";
Simon Glassb37e8152014-06-02 22:04:55 -0600526
527 davinci_mdio: mdio@4a101000 {
Felix Brack7262f382018-12-05 14:53:42 +0100528 compatible = "ti,cpsw-mdio","ti,davinci_mdio";
Simon Glassb37e8152014-06-02 22:04:55 -0600529 #address-cells = <1>;
530 #size-cells = <0>;
531 ti,hwmods = "davinci_mdio";
532 bus_freq = <1000000>;
533 reg = <0x4a101000 0x100>;
Tom Rini5ba15962015-07-31 19:55:08 -0400534 status = "disabled";
Simon Glassb37e8152014-06-02 22:04:55 -0600535 };
536
537 cpsw_emac0: slave@4a100200 {
538 /* Filled in by U-Boot */
539 mac-address = [ 00 00 00 00 00 00 ];
540 };
541
542 cpsw_emac1: slave@4a100300 {
543 /* Filled in by U-Boot */
544 mac-address = [ 00 00 00 00 00 00 ];
545 };
Tom Rini5ba15962015-07-31 19:55:08 -0400546
547 phy_sel: cpsw-phy-sel@44e10650 {
548 compatible = "ti,am3352-cpsw-phy-sel";
549 reg= <0x44e10650 0x4>;
550 reg-names = "gmii-sel";
551 };
Simon Glassb37e8152014-06-02 22:04:55 -0600552 };
553
Dario Binacchi96d04d72020-12-30 00:06:30 +0100554 ocmcram: sram@40300000 {
Tom Rini5ba15962015-07-31 19:55:08 -0400555 compatible = "mmio-sram";
556 reg = <0x40300000 0x10000>; /* 64k */
Felix Brack7262f382018-12-05 14:53:42 +0100557 ranges = <0x0 0x40300000 0x10000>;
558 #address-cells = <1>;
559 #size-cells = <1>;
Simon Glassb37e8152014-06-02 22:04:55 -0600560
Dario Binacchi96d04d72020-12-30 00:06:30 +0100561 pm_sram_code: pm-code-sram@0 {
Felix Brack7262f382018-12-05 14:53:42 +0100562 compatible = "ti,sram";
563 reg = <0x0 0x1000>;
564 protect-exec;
565 };
566
Dario Binacchi96d04d72020-12-30 00:06:30 +0100567 pm_sram_data: pm-data-sram@1000 {
Felix Brack7262f382018-12-05 14:53:42 +0100568 compatible = "ti,sram";
569 reg = <0x1000 0x1000>;
570 pool;
571 };
Simon Glassb37e8152014-06-02 22:04:55 -0600572 };
573
Felix Brack7262f382018-12-05 14:53:42 +0100574 emif: emif@4c000000 {
575 compatible = "ti,emif-am3352";
576 reg = <0x4c000000 0x1000000>;
577 ti,hwmods = "emif";
578 interrupts = <101>;
579 sram = <&pm_sram_code
580 &pm_sram_data>;
581 ti,no-idle;
582 };
583
Simon Glassb37e8152014-06-02 22:04:55 -0600584 gpmc: gpmc@50000000 {
585 compatible = "ti,am3352-gpmc";
586 ti,hwmods = "gpmc";
Tom Rini5ba15962015-07-31 19:55:08 -0400587 ti,no-idle-on-init;
Simon Glassb37e8152014-06-02 22:04:55 -0600588 reg = <0x50000000 0x2000>;
589 interrupts = <100>;
Felix Brack7262f382018-12-05 14:53:42 +0100590 dmas = <&edma 52 0>;
591 dma-names = "rxtx";
Simon Glassb37e8152014-06-02 22:04:55 -0600592 gpmc,num-cs = <7>;
593 gpmc,num-waitpins = <2>;
594 #address-cells = <2>;
595 #size-cells = <1>;
Felix Brack7262f382018-12-05 14:53:42 +0100596 interrupt-controller;
597 #interrupt-cells = <2>;
598 gpio-controller;
599 #gpio-cells = <2>;
Simon Glassb37e8152014-06-02 22:04:55 -0600600 status = "disabled";
Tom Rini5ba15962015-07-31 19:55:08 -0400601 };
602
Dario Binacchi96d04d72020-12-30 00:06:30 +0100603 sham_target: target-module@53100000 {
604 compatible = "ti,sysc-omap3-sham", "ti,sysc";
605 reg = <0x53100100 0x4>,
606 <0x53100110 0x4>,
607 <0x53100114 0x4>;
608 reg-names = "rev", "sysc", "syss";
609 ti,sysc-mask = <(SYSC_OMAP2_SOFTRESET |
610 SYSC_OMAP2_AUTOIDLE)>;
611 ti,sysc-sidle = <SYSC_IDLE_FORCE>,
612 <SYSC_IDLE_NO>,
613 <SYSC_IDLE_SMART>;
614 ti,syss-mask = <1>;
615 /* Domains (P, C): per_pwrdm, l3_clkdm */
616 clocks = <&l3_clkctrl AM3_L3_SHAM_CLKCTRL 0>;
617 clock-names = "fck";
618 #address-cells = <1>;
619 #size-cells = <1>;
620 ranges = <0x0 0x53100000 0x1000>;
Tom Rini5ba15962015-07-31 19:55:08 -0400621
Dario Binacchi96d04d72020-12-30 00:06:30 +0100622 sham: sham@0 {
623 compatible = "ti,omap4-sham";
624 reg = <0 0x200>;
625 interrupts = <109>;
626 dmas = <&edma 36 0>;
627 dma-names = "rx";
628 };
Tom Rini5ba15962015-07-31 19:55:08 -0400629 };
630
Dario Binacchi96d04d72020-12-30 00:06:30 +0100631 aes_target: target-module@53500000 {
632 compatible = "ti,sysc-omap2", "ti,sysc";
633 reg = <0x53500080 0x4>,
634 <0x53500084 0x4>,
635 <0x53500088 0x4>;
636 reg-names = "rev", "sysc", "syss";
637 ti,sysc-mask = <(SYSC_OMAP2_SOFTRESET |
638 SYSC_OMAP2_AUTOIDLE)>;
639 ti,sysc-sidle = <SYSC_IDLE_FORCE>,
640 <SYSC_IDLE_NO>,
641 <SYSC_IDLE_SMART>,
642 <SYSC_IDLE_SMART_WKUP>;
643 ti,syss-mask = <1>;
644 /* Domains (P, C): per_pwrdm, l3_clkdm */
645 clocks = <&l3_clkctrl AM3_L3_AES_CLKCTRL 0>;
646 clock-names = "fck";
647 #address-cells = <1>;
648 #size-cells = <1>;
649 ranges = <0x0 0x53500000 0x1000>;
Tom Rini5ba15962015-07-31 19:55:08 -0400650
Dario Binacchi96d04d72020-12-30 00:06:30 +0100651 aes: aes@0 {
652 compatible = "ti,omap4-aes";
653 reg = <0 0xa0>;
654 interrupts = <103>;
655 dmas = <&edma 6 0>,
656 <&edma 5 0>;
657 dma-names = "tx", "rx";
658 };
Tom Rini5ba15962015-07-31 19:55:08 -0400659 };
660
Dario Binacchi96d04d72020-12-30 00:06:30 +0100661 target-module@56000000 {
662 compatible = "ti,sysc-omap4", "ti,sysc";
663 reg = <0x5600fe00 0x4>,
664 <0x5600fe10 0x4>;
665 reg-names = "rev", "sysc";
666 ti,sysc-midle = <SYSC_IDLE_FORCE>,
667 <SYSC_IDLE_NO>,
668 <SYSC_IDLE_SMART>;
669 ti,sysc-sidle = <SYSC_IDLE_FORCE>,
670 <SYSC_IDLE_NO>,
671 <SYSC_IDLE_SMART>;
672 clocks = <&gfx_l3_clkctrl AM3_GFX_L3_GFX_CLKCTRL 0>;
673 clock-names = "fck";
674 resets = <&prm_gfx 0>;
675 reset-names = "rstctrl";
676 #address-cells = <1>;
677 #size-cells = <1>;
678 ranges = <0 0x56000000 0x1000000>;
679
680 /*
681 * Closed source PowerVR driver, no child device
682 * binding or driver in mainline
683 */
Simon Glassb37e8152014-06-02 22:04:55 -0600684 };
685 };
686};
Tom Rini5ba15962015-07-31 19:55:08 -0400687
Dario Binacchi96d04d72020-12-30 00:06:30 +0100688#include "am33xx-l4.dtsi"
Felix Brack7262f382018-12-05 14:53:42 +0100689#include "am33xx-clocks.dtsi"
Dario Binacchi96d04d72020-12-30 00:06:30 +0100690
691&prcm {
692 prm_per: prm@c00 {
693 compatible = "ti,am3-prm-inst", "ti,omap-prm-inst";
694 reg = <0xc00 0x100>;
695 #reset-cells = <1>;
696 };
697
698 prm_wkup: prm@d00 {
699 compatible = "ti,am3-prm-inst", "ti,omap-prm-inst";
700 reg = <0xd00 0x100>;
701 #reset-cells = <1>;
702 };
703
704 prm_device: prm@f00 {
705 compatible = "ti,am3-prm-inst", "ti,omap-prm-inst";
706 reg = <0xf00 0x100>;
707 #reset-cells = <1>;
708 };
709
710 prm_gfx: prm@1100 {
711 compatible = "ti,am3-prm-inst", "ti,omap-prm-inst";
712 reg = <0x1100 0x100>;
713 #reset-cells = <1>;
714 };
715};