blob: 6c2e8e41b1e936cb4412c7240d5700a891e4333b [file] [log] [blame]
Nishanth Menon5a0f93c2014-11-07 11:47:13 -06001/*
2 * Copyright (C) 2014 Texas Instruments Incorporated - http://www.ti.com/
3 *
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 */
8/dts-v1/;
9
10#include "dra74x.dtsi"
11#include <dt-bindings/clk/ti-dra7-atl.h>
12#include <dt-bindings/gpio/gpio.h>
13#include <dt-bindings/interrupt-controller/irq.h>
14
15/ {
16 model = "TI AM5728 BeagleBoard-X15";
17 compatible = "ti,am572x-beagle-x15", "ti,am5728", "ti,dra742", "ti,dra74", "ti,dra7";
18
19 aliases {
20 rtc0 = &mcp_rtc;
21 rtc1 = &tps659038_rtc;
22 };
23
24 memory {
25 device_type = "memory";
26 reg = <0x80000000 0x80000000>;
27 };
28
29 vdd_3v3: fixedregulator-vdd_3v3 {
30 compatible = "regulator-fixed";
31 regulator-name = "vdd_3v3";
32 vin-supply = <&regen1>;
33 regulator-min-microvolt = <3300000>;
34 regulator-max-microvolt = <3300000>;
35 };
36
37 vtt_fixed: fixedregulator-vtt {
38 /* TPS51200 */
39 compatible = "regulator-fixed";
40 regulator-name = "vtt_fixed";
41 vin-supply = <&smps3_reg>;
42 regulator-min-microvolt = <3300000>;
43 regulator-max-microvolt = <3300000>;
44 regulator-always-on;
45 regulator-boot-on;
46 enable-active-high;
47 gpio = <&gpio7 11 GPIO_ACTIVE_HIGH>;
48 };
49
50 leds {
51 compatible = "gpio-leds";
52 pinctrl-names = "default";
53 pinctrl-0 = <&leds_pins_default>;
54
55 led@0 {
56 label = "beagle-x15:usr0";
57 gpios = <&gpio7 9 GPIO_ACTIVE_HIGH>;
58 linux,default-trigger = "heartbeat";
59 default-state = "off";
60 };
61
62 led@1 {
63 label = "beagle-x15:usr1";
64 gpios = <&gpio7 8 GPIO_ACTIVE_HIGH>;
65 linux,default-trigger = "cpu0";
66 default-state = "off";
67 };
68
69 led@2 {
70 label = "beagle-x15:usr2";
71 gpios = <&gpio7 14 GPIO_ACTIVE_HIGH>;
72 linux,default-trigger = "mmc0";
73 default-state = "off";
74 };
75
76 led@3 {
77 label = "beagle-x15:usr3";
78 gpios = <&gpio7 15 GPIO_ACTIVE_HIGH>;
79 linux,default-trigger = "ide-disk";
80 default-state = "off";
81 };
82 };
83};
84
85&dra7_pmx_core {
86 leds_pins_default: leds_pins_default {
87 pinctrl-single,pins = <
88 0x3a8 (PIN_OUTPUT | MUX_MODE14) /* spi1_d1.gpio7_8 */
89 0x3ac (PIN_OUTPUT | MUX_MODE14) /* spi1_d0.gpio7_9 */
90 0x3c0 (PIN_OUTPUT | MUX_MODE14) /* spi2_sclk.gpio7_14 */
91 0x3c4 (PIN_OUTPUT | MUX_MODE14) /* spi2_d1.gpio7_15 */
92 >;
93 };
94
95 i2c1_pins_default: i2c1_pins_default {
96 pinctrl-single,pins = <
97 0x400 (PIN_INPUT_PULLUP | MUX_MODE0) /* i2c1_sda.sda */
98 0x404 (PIN_INPUT_PULLUP | MUX_MODE0) /* i2c1_scl.scl */
99 >;
100 };
101
102 i2c3_pins_default: i2c3_pins_default {
103 pinctrl-single,pins = <
104 0x2a4 (PIN_INPUT| MUX_MODE10) /* mcasp1_aclkx.i2c3_sda */
105 0x2a8 (PIN_INPUT| MUX_MODE10) /* mcasp1_fsx.i2c3_scl */
106 >;
107 };
108
109 uart3_pins_default: uart3_pins_default {
110 pinctrl-single,pins = <
111 0x248 (PIN_INPUT_SLEW | MUX_MODE0) /* uart3_rxd.rxd */
112 0x24c (PIN_INPUT_SLEW | MUX_MODE0) /* uart3_txd.txd */
113 >;
114 };
115
116 mmc1_pins_default: mmc1_pins_default {
117 pinctrl-single,pins = <
118 0x36c (PIN_INPUT | MUX_MODE14) /* mmc1sdcd.gpio219 */
119 0x354 (PIN_INPUT_PULLUP | MUX_MODE0) /* mmc1_clk.clk */
120 0x358 (PIN_INPUT_PULLUP | MUX_MODE0) /* mmc1_cmd.cmd */
121 0x35c (PIN_INPUT_PULLUP | MUX_MODE0) /* mmc1_dat0.dat0 */
122 0x360 (PIN_INPUT_PULLUP | MUX_MODE0) /* mmc1_dat1.dat1 */
123 0x364 (PIN_INPUT_PULLUP | MUX_MODE0) /* mmc1_dat2.dat2 */
124 0x368 (PIN_INPUT_PULLUP | MUX_MODE0) /* mmc1_dat3.dat3 */
125 >;
126 };
127
128 mmc2_pins_default: mmc2_pins_default {
129 pinctrl-single,pins = <
130 0x9c (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_a23.mmc2_clk */
131 0xb0 (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_cs1.mmc2_cmd */
132 0xa0 (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_a24.mmc2_dat0 */
133 0xa4 (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_a25.mmc2_dat1 */
134 0xa8 (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_a26.mmc2_dat2 */
135 0xac (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_a27.mmc2_dat3 */
136 0x8c (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_a19.mmc2_dat4 */
137 0x90 (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_a20.mmc2_dat5 */
138 0x94 (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_a21.mmc2_dat6 */
139 0x98 (PIN_INPUT_PULLUP | MUX_MODE1) /* gpmc_a22.mmc2_dat7 */
140 >;
141 };
142
Felipe Balbia75dacf2014-12-04 15:02:57 -0600143 cpsw_pins_default: cpsw_pins_default {
144 pinctrl-single,pins = <
145 /* Slave 1 */
146 0x250 (PIN_OUTPUT | MUX_MODE0) /* rgmii1_tclk */
147 0x254 (PIN_OUTPUT | MUX_MODE0) /* rgmii1_tctl */
148 0x258 (PIN_OUTPUT | MUX_MODE0) /* rgmii1_td3 */
149 0x25c (PIN_OUTPUT | MUX_MODE0) /* rgmii1_td2 */
150 0x260 (PIN_OUTPUT | MUX_MODE0) /* rgmii1_td1 */
151 0x264 (PIN_OUTPUT | MUX_MODE0) /* rgmii1_td0 */
152 0x268 (PIN_INPUT | MUX_MODE0) /* rgmii1_rclk */
153 0x26c (PIN_INPUT | MUX_MODE0) /* rgmii1_rctl */
154 0x270 (PIN_INPUT | MUX_MODE0) /* rgmii1_rd3 */
155 0x274 (PIN_INPUT | MUX_MODE0) /* rgmii1_rd2 */
156 0x278 (PIN_INPUT | MUX_MODE0) /* rgmii1_rd1 */
157 0x27c (PIN_INPUT | MUX_MODE0) /* rgmii1_rd0 */
158
159 /* Slave 2 */
160 0x198 (PIN_OUTPUT | MUX_MODE3) /* rgmii2_tclk */
161 0x19c (PIN_OUTPUT | MUX_MODE3) /* rgmii2_tctl */
162 0x1a0 (PIN_OUTPUT | MUX_MODE3) /* rgmii2_td3 */
163 0x1a4 (PIN_OUTPUT | MUX_MODE3) /* rgmii2_td2 */
164 0x1a8 (PIN_OUTPUT | MUX_MODE3) /* rgmii2_td1 */
165 0x1ac (PIN_OUTPUT | MUX_MODE3) /* rgmii2_td0 */
166 0x1b0 (PIN_INPUT | MUX_MODE3) /* rgmii2_rclk */
167 0x1b4 (PIN_INPUT | MUX_MODE3) /* rgmii2_rctl */
168 0x1b8 (PIN_INPUT | MUX_MODE3) /* rgmii2_rd3 */
169 0x1bc (PIN_INPUT | MUX_MODE3) /* rgmii2_rd2 */
170 0x1c0 (PIN_INPUT | MUX_MODE3) /* rgmii2_rd1 */
171 0x1c4 (PIN_INPUT | MUX_MODE3) /* rgmii2_rd0 */
172 >;
173
174 };
175
176 cpsw_pins_sleep: cpsw_pins_sleep {
177 pinctrl-single,pins = <
178 /* Slave 1 */
179 0x250 (PIN_INPUT | MUX_MODE15)
180 0x254 (PIN_INPUT | MUX_MODE15)
181 0x258 (PIN_INPUT | MUX_MODE15)
182 0x25c (PIN_INPUT | MUX_MODE15)
183 0x260 (PIN_INPUT | MUX_MODE15)
184 0x264 (PIN_INPUT | MUX_MODE15)
185 0x268 (PIN_INPUT | MUX_MODE15)
186 0x26c (PIN_INPUT | MUX_MODE15)
187 0x270 (PIN_INPUT | MUX_MODE15)
188 0x274 (PIN_INPUT | MUX_MODE15)
189 0x278 (PIN_INPUT | MUX_MODE15)
190 0x27c (PIN_INPUT | MUX_MODE15)
191
192 /* Slave 2 */
193 0x198 (PIN_INPUT | MUX_MODE15)
194 0x19c (PIN_INPUT | MUX_MODE15)
195 0x1a0 (PIN_INPUT | MUX_MODE15)
196 0x1a4 (PIN_INPUT | MUX_MODE15)
197 0x1a8 (PIN_INPUT | MUX_MODE15)
198 0x1ac (PIN_INPUT | MUX_MODE15)
199 0x1b0 (PIN_INPUT | MUX_MODE15)
200 0x1b4 (PIN_INPUT | MUX_MODE15)
201 0x1b8 (PIN_INPUT | MUX_MODE15)
202 0x1bc (PIN_INPUT | MUX_MODE15)
203 0x1c0 (PIN_INPUT | MUX_MODE15)
204 0x1c4 (PIN_INPUT | MUX_MODE15)
205 >;
206 };
207
208 davinci_mdio_pins_default: davinci_mdio_pins_default {
209 pinctrl-single,pins = <
210 /* MDIO */
211 0x23c (PIN_OUTPUT_PULLUP | MUX_MODE0) /* mdio_mclk */
212 0x240 (PIN_INPUT_PULLUP | MUX_MODE0) /* mdio_d */
213 >;
214 };
215
216 davinci_mdio_pins_sleep: davinci_mdio_pins_sleep {
217 pinctrl-single,pins = <
218 0x23c (PIN_INPUT | MUX_MODE15)
219 0x240 (PIN_INPUT | MUX_MODE15)
220 >;
221 };
222
Nishanth Menon5a0f93c2014-11-07 11:47:13 -0600223 tps659038_pins_default: tps659038_pins_default {
224 pinctrl-single,pins = <
225 0x418 (PIN_INPUT_PULLUP | MUX_MODE14) /* wakeup0.gpio1_0 */
226 >;
227 };
228
229 tmp102_pins_default: tmp102_pins_default {
230 pinctrl-single,pins = <
231 0x3C8 (PIN_INPUT_PULLUP | MUX_MODE14) /* spi2_d0.gpio7_16 */
232 >;
233 };
234
235 mcp79410_pins_default: mcp79410_pins_default {
236 pinctrl-single,pins = <
237 0x424 (PIN_INPUT_PULLUP | MUX_MODE1) /* wakeup3.sys_nirq1 */
238 >;
239 };
240
241 usb1_pins: pinmux_usb1_pins {
242 pinctrl-single,pins = <
243 0x280 (PIN_INPUT_SLEW | MUX_MODE0) /* usb1_drvvbus */
244 >;
245 };
246
247};
248
249&i2c1 {
250 status = "okay";
251 pinctrl-names = "default";
252 pinctrl-0 = <&i2c1_pins_default>;
253 clock-frequency = <400000>;
254
255 tps659038: tps659038@58 {
256 compatible = "ti,tps659038";
257 reg = <0x58>;
258 interrupt-parent = <&gpio1>;
259 interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
260
261 pinctrl-names = "default";
262 pinctrl-0 = <&tps659038_pins_default>;
263
264 #interrupt-cells = <2>;
265 interrupt-controller;
266
267 ti,system-power-controller;
268
269 tps659038_pmic {
270 compatible = "ti,tps659038-pmic";
271
272 regulators {
273 smps12_reg: smps12 {
274 /* VDD_MPU */
275 regulator-name = "smps12";
276 regulator-min-microvolt = < 850000>;
277 regulator-max-microvolt = <1250000>;
278 regulator-always-on;
279 regulator-boot-on;
280 };
281
282 smps3_reg: smps3 {
283 /* VDD_DDR */
284 regulator-name = "smps3";
285 regulator-min-microvolt = <1350000>;
286 regulator-max-microvolt = <1350000>;
287 regulator-always-on;
288 regulator-boot-on;
289 };
290
291 smps45_reg: smps45 {
292 /* VDD_DSPEVE, VDD_IVA, VDD_GPU */
293 regulator-name = "smps45";
294 regulator-min-microvolt = < 850000>;
295 regulator-max-microvolt = <1150000>;
296 regulator-always-on;
297 regulator-boot-on;
298 };
299
300 smps6_reg: smps6 {
301 /* VDD_CORE */
302 regulator-name = "smps6";
303 regulator-min-microvolt = <850000>;
304 regulator-max-microvolt = <1030000>;
305 regulator-always-on;
306 regulator-boot-on;
307 };
308
309 /* SMPS7 unused */
310
311 smps8_reg: smps8 {
312 /* VDD_1V8 */
313 regulator-name = "smps8";
314 regulator-min-microvolt = <1800000>;
315 regulator-max-microvolt = <1800000>;
316 regulator-always-on;
317 regulator-boot-on;
318 };
319
320 /* SMPS9 unused */
321
322 ldo1_reg: ldo1 {
323 /* VDD_SD */
324 regulator-name = "ldo1";
325 regulator-min-microvolt = <1800000>;
326 regulator-max-microvolt = <3300000>;
327 regulator-boot-on;
328 };
329
330 ldo2_reg: ldo2 {
331 /* VDD_SHV5 */
332 regulator-name = "ldo2";
333 regulator-min-microvolt = <3300000>;
334 regulator-max-microvolt = <3300000>;
335 regulator-always-on;
336 regulator-boot-on;
337 };
338
339 ldo3_reg: ldo3 {
340 /* VDDA_1V8_PHY */
341 regulator-name = "ldo3";
342 regulator-min-microvolt = <1800000>;
343 regulator-max-microvolt = <1800000>;
344 regulator-always-on;
345 regulator-boot-on;
346 };
347
348 ldo9_reg: ldo9 {
349 /* VDD_RTC */
350 regulator-name = "ldo9";
351 regulator-min-microvolt = <1050000>;
352 regulator-max-microvolt = <1050000>;
353 regulator-always-on;
354 regulator-boot-on;
355 };
356
357 ldoln_reg: ldoln {
358 /* VDDA_1V8_PLL */
359 regulator-name = "ldoln";
360 regulator-min-microvolt = <1800000>;
361 regulator-max-microvolt = <1800000>;
362 regulator-always-on;
363 regulator-boot-on;
364 };
365
366 ldousb_reg: ldousb {
367 /* VDDA_3V_USB: VDDA_USBHS33 */
368 regulator-name = "ldousb";
369 regulator-min-microvolt = <3300000>;
370 regulator-max-microvolt = <3300000>;
371 regulator-boot-on;
372 };
373
374 regen1: regen1 {
375 /* VDD_3V3_ON */
376 regulator-name = "regen1";
377 regulator-boot-on;
378 regulator-always-on;
379 };
380 };
381 };
382
383 tps659038_rtc: tps659038_rtc {
384 compatible = "ti,palmas-rtc";
385 interrupt-parent = <&tps659038>;
386 interrupts = <8 IRQ_TYPE_EDGE_FALLING>;
387 wakeup-source;
388 };
389
390 tps659038_pwr_button: tps659038_pwr_button {
391 compatible = "ti,palmas-pwrbutton";
392 interrupt-parent = <&tps659038>;
393 interrupts = <1 IRQ_TYPE_EDGE_FALLING>;
394 wakeup-source;
395 ti,palmas-long-press-seconds = <12>;
396 };
397 };
398
399 tmp102: tmp102@48 {
400 compatible = "ti,tmp102";
401 reg = <0x48>;
402 pinctrl-names = "default";
403 pinctrl-0 = <&tmp102_pins_default>;
404 interrupt-parent = <&gpio7>;
405 interrupts = <16 IRQ_TYPE_LEVEL_LOW>;
406 };
407};
408
409&i2c3 {
410 status = "okay";
411 pinctrl-names = "default";
412 pinctrl-0 = <&i2c3_pins_default>;
413 clock-frequency = <400000>;
414
415 mcp_rtc: rtc@6f {
416 compatible = "microchip,mcp7941x";
417 reg = <0x6f>;
418 interrupt-parent = <&gic>;
419 interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_LOW>; /* IRQ_SYS_1N */
420
421 pinctrl-names = "default";
422 pinctrl-0 = <&mcp79410_pins_default>;
423
424 vcc-supply = <&vdd_3v3>;
425 wakeup-source;
426 };
427};
428
429&gpio7 {
430 ti,no-reset-on-init;
431 ti,no-idle-on-init;
432};
433
434&cpu0 {
435 cpu0-supply = <&smps12_reg>;
436 voltage-tolerance = <1>;
437};
438
439&uart3 {
440 status = "okay";
441 interrupts-extended = <&gic GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>,
442 <&dra7_pmx_core 0x248>;
443
444 pinctrl-names = "default";
445 pinctrl-0 = <&uart3_pins_default>;
446};
447
Felipe Balbia75dacf2014-12-04 15:02:57 -0600448&mac {
449 status = "okay";
450 pinctrl-names = "default", "sleep";
451 pinctrl-0 = <&cpsw_pins_default>;
452 pinctrl-1 = <&cpsw_pins_sleep>;
453 dual_emac;
454};
455
456&cpsw_emac0 {
457 phy_id = <&davinci_mdio>, <1>;
458 phy-mode = "rgmii";
459 dual_emac_res_vlan = <1>;
460};
461
462&cpsw_emac1 {
463 phy_id = <&davinci_mdio>, <2>;
464 phy-mode = "rgmii";
465 dual_emac_res_vlan = <2>;
466};
467
468&davinci_mdio {
469 pinctrl-names = "default", "sleep";
470 pinctrl-0 = <&davinci_mdio_pins_default>;
471 pinctrl-1 = <&davinci_mdio_pins_sleep>;
472};
473
Nishanth Menon5a0f93c2014-11-07 11:47:13 -0600474&mmc1 {
475 status = "okay";
476
477 pinctrl-names = "default";
478 pinctrl-0 = <&mmc1_pins_default>;
479
480 vmmc-supply = <&ldo1_reg>;
481 vmmc_aux-supply = <&vdd_3v3>;
482 pbias-supply = <&pbias_mmc_reg>;
483 bus-width = <4>;
484 cd-gpios = <&gpio6 27 0>; /* gpio 219 */
485};
486
487&mmc2 {
488 status = "okay";
489
490 pinctrl-names = "default";
491 pinctrl-0 = <&mmc2_pins_default>;
492
493 vmmc-supply = <&vdd_3v3>;
494 bus-width = <8>;
495 ti,non-removable;
496 cap-mmc-dual-data-rate;
497};
498
499&sata {
500 status = "okay";
501};
502
503&usb2_phy1 {
504 phy-supply = <&ldousb_reg>;
505};
506
507&usb1 {
508 dr_mode = "host";
509 pinctrl-names = "default";
510 pinctrl-0 = <&usb1_pins>;
511};