Merge tag 'trace-fixes-v3.16-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git...
[linux-2.6-block.git] / arch / arm / boot / dts / imx6sl-evk.dts
CommitLineData
117ccd55
SG
1/*
2 * Copyright (C) 2013 Freescale Semiconductor, Inc.
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
9/dts-v1/;
10
33106702 11#include <dt-bindings/gpio/gpio.h>
4291b645 12#include <dt-bindings/input/input.h>
117ccd55
SG
13#include "imx6sl.dtsi"
14
15/ {
16 model = "Freescale i.MX6 SoloLite EVK Board";
17 compatible = "fsl,imx6sl-evk", "fsl,imx6sl";
18
19 memory {
20 reg = <0x80000000 0x40000000>;
21 };
6022232b 22
33106702
FE
23 leds {
24 compatible = "gpio-leds";
25 pinctrl-names = "default";
26 pinctrl-0 = <&pinctrl_led>;
27
28 user {
29 label = "debug";
30 gpios = <&gpio3 20 GPIO_ACTIVE_HIGH>;
31 linux,default-trigger = "heartbeat";
32 };
33 };
34
6022232b
PC
35 regulators {
36 compatible = "simple-bus";
56160e33
SG
37 #address-cells = <1>;
38 #size-cells = <0>;
6022232b 39
56160e33 40 reg_usb_otg1_vbus: regulator@0 {
6022232b 41 compatible = "regulator-fixed";
56160e33 42 reg = <0>;
6022232b
PC
43 regulator-name = "usb_otg1_vbus";
44 regulator-min-microvolt = <5000000>;
45 regulator-max-microvolt = <5000000>;
46 gpio = <&gpio4 0 0>;
47 enable-active-high;
48 };
49
56160e33 50 reg_usb_otg2_vbus: regulator@1 {
6022232b 51 compatible = "regulator-fixed";
56160e33 52 reg = <1>;
6022232b
PC
53 regulator-name = "usb_otg2_vbus";
54 regulator-min-microvolt = <5000000>;
55 regulator-max-microvolt = <5000000>;
56 gpio = <&gpio4 2 0>;
57 enable-active-high;
58 };
032de438
FE
59
60 reg_aud3v: regulator@2 {
61 compatible = "regulator-fixed";
62 reg = <2>;
63 regulator-name = "wm8962-supply-3v15";
64 regulator-min-microvolt = <3150000>;
65 regulator-max-microvolt = <3150000>;
66 regulator-boot-on;
67 };
68
69 reg_aud4v: regulator@3 {
70 compatible = "regulator-fixed";
71 reg = <3>;
72 regulator-name = "wm8962-supply-4v2";
73 regulator-min-microvolt = <4325000>;
74 regulator-max-microvolt = <4325000>;
75 regulator-boot-on;
76 };
77 };
78
79 sound {
80 compatible = "fsl,imx6sl-evk-wm8962", "fsl,imx-audio-wm8962";
81 model = "wm8962-audio";
82 ssi-controller = <&ssi2>;
83 audio-codec = <&codec>;
84 audio-routing =
85 "Headphone Jack", "HPOUTL",
86 "Headphone Jack", "HPOUTR",
87 "Ext Spk", "SPKOUTL",
88 "Ext Spk", "SPKOUTR",
89 "AMIC", "MICBIAS",
90 "IN3R", "AMIC";
91 mux-int-port = <2>;
92 mux-ext-port = <3>;
6022232b 93 };
117ccd55
SG
94};
95
032de438
FE
96&audmux {
97 pinctrl-names = "default";
98 pinctrl-0 = <&pinctrl_audmux3>;
99 status = "okay";
100};
101
d1b53975
HS
102&ecspi1 {
103 fsl,spi-num-chipselects = <1>;
104 cs-gpios = <&gpio4 11 0>;
105 pinctrl-names = "default";
fffaa65d 106 pinctrl-0 = <&pinctrl_ecspi1>;
d1b53975
HS
107 status = "okay";
108
109 flash: m25p80@0 {
110 #address-cells = <1>;
111 #size-cells = <1>;
112 compatible = "st,m25p32";
113 spi-max-frequency = <20000000>;
114 reg = <0>;
115 };
116};
117
117ccd55
SG
118&fec {
119 pinctrl-names = "default";
fffaa65d 120 pinctrl-0 = <&pinctrl_fec>;
117ccd55
SG
121 phy-mode = "rmii";
122 status = "okay";
123};
124
56df2680
FE
125&i2c1 {
126 clock-frequency = <100000>;
127 pinctrl-names = "default";
128 pinctrl-0 = <&pinctrl_i2c1>;
129 status = "okay";
130
131 pmic: pfuze100@08 {
132 compatible = "fsl,pfuze100";
133 reg = <0x08>;
134
135 regulators {
136 sw1a_reg: sw1ab {
137 regulator-min-microvolt = <300000>;
138 regulator-max-microvolt = <1875000>;
139 regulator-boot-on;
140 regulator-always-on;
141 regulator-ramp-delay = <6250>;
142 };
143
144 sw1c_reg: sw1c {
145 regulator-min-microvolt = <300000>;
146 regulator-max-microvolt = <1875000>;
147 regulator-boot-on;
148 regulator-always-on;
149 regulator-ramp-delay = <6250>;
150 };
151
152 sw2_reg: sw2 {
153 regulator-min-microvolt = <800000>;
154 regulator-max-microvolt = <3300000>;
155 regulator-boot-on;
156 regulator-always-on;
157 };
158
159 sw3a_reg: sw3a {
160 regulator-min-microvolt = <400000>;
161 regulator-max-microvolt = <1975000>;
162 regulator-boot-on;
163 regulator-always-on;
164 };
165
166 sw3b_reg: sw3b {
167 regulator-min-microvolt = <400000>;
168 regulator-max-microvolt = <1975000>;
169 regulator-boot-on;
170 regulator-always-on;
171 };
172
173 sw4_reg: sw4 {
174 regulator-min-microvolt = <800000>;
175 regulator-max-microvolt = <3300000>;
176 };
177
178 swbst_reg: swbst {
179 regulator-min-microvolt = <5000000>;
180 regulator-max-microvolt = <5150000>;
181 };
182
183 snvs_reg: vsnvs {
184 regulator-min-microvolt = <1000000>;
185 regulator-max-microvolt = <3000000>;
186 regulator-boot-on;
187 regulator-always-on;
188 };
189
190 vref_reg: vrefddr {
191 regulator-boot-on;
192 regulator-always-on;
193 };
194
195 vgen1_reg: vgen1 {
196 regulator-min-microvolt = <800000>;
197 regulator-max-microvolt = <1550000>;
d2c3936e 198 regulator-always-on;
56df2680
FE
199 };
200
201 vgen2_reg: vgen2 {
202 regulator-min-microvolt = <800000>;
203 regulator-max-microvolt = <1550000>;
204 };
205
206 vgen3_reg: vgen3 {
207 regulator-min-microvolt = <1800000>;
208 regulator-max-microvolt = <3300000>;
209 };
210
211 vgen4_reg: vgen4 {
212 regulator-min-microvolt = <1800000>;
213 regulator-max-microvolt = <3300000>;
214 regulator-always-on;
215 };
216
217 vgen5_reg: vgen5 {
218 regulator-min-microvolt = <1800000>;
219 regulator-max-microvolt = <3300000>;
220 regulator-always-on;
221 };
222
223 vgen6_reg: vgen6 {
224 regulator-min-microvolt = <1800000>;
225 regulator-max-microvolt = <3300000>;
226 regulator-always-on;
227 };
228 };
229 };
230};
231
032de438
FE
232&i2c2 {
233 clock-frequency = <100000>;
234 pinctrl-names = "default";
235 pinctrl-0 = <&pinctrl_i2c2>;
236 status = "okay";
237
238 codec: wm8962@1a {
239 compatible = "wlf,wm8962";
240 reg = <0x1a>;
241 clocks = <&clks IMX6SL_CLK_EXTERN_AUDIO>;
242 DCVDD-supply = <&vgen3_reg>;
243 DBVDD-supply = <&reg_aud3v>;
244 AVDD-supply = <&vgen3_reg>;
245 CPVDD-supply = <&vgen3_reg>;
246 MICVDD-supply = <&reg_aud3v>;
247 PLLVDD-supply = <&vgen3_reg>;
248 SPKVDD1-supply = <&reg_aud4v>;
249 SPKVDD2-supply = <&reg_aud4v>;
250 };
251};
252
117ccd55
SG
253&iomuxc {
254 pinctrl-names = "default";
255 pinctrl-0 = <&pinctrl_hog>;
256
fffaa65d 257 imx6sl-evk {
117ccd55
SG
258 pinctrl_hog: hoggrp {
259 fsl,pins = <
260 MX6SL_PAD_KEY_ROW7__GPIO4_IO07 0x17059
261 MX6SL_PAD_KEY_COL7__GPIO4_IO06 0x17059
262 MX6SL_PAD_SD2_DAT7__GPIO5_IO00 0x17059
263 MX6SL_PAD_SD2_DAT6__GPIO4_IO29 0x17059
264 MX6SL_PAD_REF_CLK_32K__GPIO3_IO22 0x17059
6022232b
PC
265 MX6SL_PAD_KEY_COL4__GPIO4_IO00 0x80000000
266 MX6SL_PAD_KEY_COL5__GPIO4_IO02 0x80000000
032de438
FE
267 MX6SL_PAD_AUD_MCLK__AUDIO_CLK_OUT 0x4130b0
268 >;
269 };
270
271 pinctrl_audmux3: audmux3grp {
272 fsl,pins = <
273 MX6SL_PAD_AUD_RXD__AUD3_RXD 0x4130b0
274 MX6SL_PAD_AUD_TXC__AUD3_TXC 0x4130b0
275 MX6SL_PAD_AUD_TXD__AUD3_TXD 0x4110b0
276 MX6SL_PAD_AUD_TXFS__AUD3_TXFS 0x4130b0
117ccd55
SG
277 >;
278 };
fffaa65d
SG
279
280 pinctrl_ecspi1: ecspi1grp {
281 fsl,pins = <
282 MX6SL_PAD_ECSPI1_MISO__ECSPI1_MISO 0x100b1
283 MX6SL_PAD_ECSPI1_MOSI__ECSPI1_MOSI 0x100b1
284 MX6SL_PAD_ECSPI1_SCLK__ECSPI1_SCLK 0x100b1
2cd36711 285 MX6SL_PAD_ECSPI1_SS0__GPIO4_IO11 0x80000000
fffaa65d
SG
286 >;
287 };
288
289 pinctrl_fec: fecgrp {
290 fsl,pins = <
291 MX6SL_PAD_FEC_MDC__FEC_MDC 0x1b0b0
292 MX6SL_PAD_FEC_MDIO__FEC_MDIO 0x1b0b0
293 MX6SL_PAD_FEC_CRS_DV__FEC_RX_DV 0x1b0b0
294 MX6SL_PAD_FEC_RXD0__FEC_RX_DATA0 0x1b0b0
295 MX6SL_PAD_FEC_RXD1__FEC_RX_DATA1 0x1b0b0
296 MX6SL_PAD_FEC_TX_EN__FEC_TX_EN 0x1b0b0
297 MX6SL_PAD_FEC_TXD0__FEC_TX_DATA0 0x1b0b0
298 MX6SL_PAD_FEC_TXD1__FEC_TX_DATA1 0x1b0b0
299 MX6SL_PAD_FEC_REF_CLK__FEC_REF_OUT 0x4001b0a8
300 >;
301 };
302
56df2680
FE
303 pinctrl_i2c1: i2c1grp {
304 fsl,pins = <
305 MX6SL_PAD_I2C1_SCL__I2C1_SCL 0x4001b8b1
306 MX6SL_PAD_I2C1_SDA__I2C1_SDA 0x4001b8b1
307 >;
308 };
309
032de438
FE
310
311 pinctrl_i2c2: i2c2grp {
312 fsl,pins = <
313 MX6SL_PAD_I2C2_SCL__I2C2_SCL 0x4001b8b1
314 MX6SL_PAD_I2C2_SDA__I2C2_SDA 0x4001b8b1
315 >;
316 };
317
33106702
FE
318 pinctrl_led: ledgrp {
319 fsl,pins = <
320 MX6SL_PAD_HSIC_STROBE__GPIO3_IO20 0x17059
321 >;
322 };
323
4291b645
AH
324 pinctrl_kpp: kppgrp {
325 fsl,pins = <
326 MX6SL_PAD_KEY_ROW0__KEY_ROW0 0x1b010
327 MX6SL_PAD_KEY_ROW1__KEY_ROW1 0x1b010
328 MX6SL_PAD_KEY_ROW2__KEY_ROW2 0x1b0b0
329 MX6SL_PAD_KEY_COL0__KEY_COL0 0x110b0
330 MX6SL_PAD_KEY_COL1__KEY_COL1 0x110b0
331 MX6SL_PAD_KEY_COL2__KEY_COL2 0x110b0
332 >;
333 };
334
fffaa65d
SG
335 pinctrl_uart1: uart1grp {
336 fsl,pins = <
337 MX6SL_PAD_UART1_RXD__UART1_RX_DATA 0x1b0b1
338 MX6SL_PAD_UART1_TXD__UART1_TX_DATA 0x1b0b1
339 >;
340 };
341
342 pinctrl_usbotg1: usbotg1grp {
343 fsl,pins = <
344 MX6SL_PAD_EPDC_PWRCOM__USB_OTG1_ID 0x17059
345 >;
346 };
347
348 pinctrl_usdhc1: usdhc1grp {
349 fsl,pins = <
350 MX6SL_PAD_SD1_CMD__SD1_CMD 0x17059
351 MX6SL_PAD_SD1_CLK__SD1_CLK 0x10059
352 MX6SL_PAD_SD1_DAT0__SD1_DATA0 0x17059
353 MX6SL_PAD_SD1_DAT1__SD1_DATA1 0x17059
354 MX6SL_PAD_SD1_DAT2__SD1_DATA2 0x17059
355 MX6SL_PAD_SD1_DAT3__SD1_DATA3 0x17059
356 MX6SL_PAD_SD1_DAT4__SD1_DATA4 0x17059
357 MX6SL_PAD_SD1_DAT5__SD1_DATA5 0x17059
358 MX6SL_PAD_SD1_DAT6__SD1_DATA6 0x17059
359 MX6SL_PAD_SD1_DAT7__SD1_DATA7 0x17059
360 >;
361 };
362
363 pinctrl_usdhc1_100mhz: usdhc1grp100mhz {
364 fsl,pins = <
365 MX6SL_PAD_SD1_CMD__SD1_CMD 0x170b9
366 MX6SL_PAD_SD1_CLK__SD1_CLK 0x100b9
367 MX6SL_PAD_SD1_DAT0__SD1_DATA0 0x170b9
368 MX6SL_PAD_SD1_DAT1__SD1_DATA1 0x170b9
369 MX6SL_PAD_SD1_DAT2__SD1_DATA2 0x170b9
370 MX6SL_PAD_SD1_DAT3__SD1_DATA3 0x170b9
371 MX6SL_PAD_SD1_DAT4__SD1_DATA4 0x170b9
372 MX6SL_PAD_SD1_DAT5__SD1_DATA5 0x170b9
373 MX6SL_PAD_SD1_DAT6__SD1_DATA6 0x170b9
374 MX6SL_PAD_SD1_DAT7__SD1_DATA7 0x170b9
375 >;
376 };
377
378 pinctrl_usdhc1_200mhz: usdhc1grp200mhz {
379 fsl,pins = <
380 MX6SL_PAD_SD1_CMD__SD1_CMD 0x170f9
381 MX6SL_PAD_SD1_CLK__SD1_CLK 0x100f9
382 MX6SL_PAD_SD1_DAT0__SD1_DATA0 0x170f9
383 MX6SL_PAD_SD1_DAT1__SD1_DATA1 0x170f9
384 MX6SL_PAD_SD1_DAT2__SD1_DATA2 0x170f9
385 MX6SL_PAD_SD1_DAT3__SD1_DATA3 0x170f9
386 MX6SL_PAD_SD1_DAT4__SD1_DATA4 0x170f9
387 MX6SL_PAD_SD1_DAT5__SD1_DATA5 0x170f9
388 MX6SL_PAD_SD1_DAT6__SD1_DATA6 0x170f9
389 MX6SL_PAD_SD1_DAT7__SD1_DATA7 0x170f9
390 >;
391 };
392
393 pinctrl_usdhc2: usdhc2grp {
394 fsl,pins = <
395 MX6SL_PAD_SD2_CMD__SD2_CMD 0x17059
396 MX6SL_PAD_SD2_CLK__SD2_CLK 0x10059
397 MX6SL_PAD_SD2_DAT0__SD2_DATA0 0x17059
398 MX6SL_PAD_SD2_DAT1__SD2_DATA1 0x17059
399 MX6SL_PAD_SD2_DAT2__SD2_DATA2 0x17059
400 MX6SL_PAD_SD2_DAT3__SD2_DATA3 0x17059
401 >;
402 };
403
404 pinctrl_usdhc2_100mhz: usdhc2grp100mhz {
405 fsl,pins = <
406 MX6SL_PAD_SD2_CMD__SD2_CMD 0x170b9
407 MX6SL_PAD_SD2_CLK__SD2_CLK 0x100b9
408 MX6SL_PAD_SD2_DAT0__SD2_DATA0 0x170b9
409 MX6SL_PAD_SD2_DAT1__SD2_DATA1 0x170b9
410 MX6SL_PAD_SD2_DAT2__SD2_DATA2 0x170b9
411 MX6SL_PAD_SD2_DAT3__SD2_DATA3 0x170b9
412 >;
413 };
414
415 pinctrl_usdhc2_200mhz: usdhc2grp200mhz {
416 fsl,pins = <
417 MX6SL_PAD_SD2_CMD__SD2_CMD 0x170f9
418 MX6SL_PAD_SD2_CLK__SD2_CLK 0x100f9
419 MX6SL_PAD_SD2_DAT0__SD2_DATA0 0x170f9
420 MX6SL_PAD_SD2_DAT1__SD2_DATA1 0x170f9
421 MX6SL_PAD_SD2_DAT2__SD2_DATA2 0x170f9
422 MX6SL_PAD_SD2_DAT3__SD2_DATA3 0x170f9
423 >;
424 };
425
426 pinctrl_usdhc3: usdhc3grp {
427 fsl,pins = <
428 MX6SL_PAD_SD3_CMD__SD3_CMD 0x17059
429 MX6SL_PAD_SD3_CLK__SD3_CLK 0x10059
430 MX6SL_PAD_SD3_DAT0__SD3_DATA0 0x17059
431 MX6SL_PAD_SD3_DAT1__SD3_DATA1 0x17059
432 MX6SL_PAD_SD3_DAT2__SD3_DATA2 0x17059
433 MX6SL_PAD_SD3_DAT3__SD3_DATA3 0x17059
434 >;
435 };
436
437 pinctrl_usdhc3_100mhz: usdhc3grp100mhz {
438 fsl,pins = <
439 MX6SL_PAD_SD3_CMD__SD3_CMD 0x170b9
440 MX6SL_PAD_SD3_CLK__SD3_CLK 0x100b9
441 MX6SL_PAD_SD3_DAT0__SD3_DATA0 0x170b9
442 MX6SL_PAD_SD3_DAT1__SD3_DATA1 0x170b9
443 MX6SL_PAD_SD3_DAT2__SD3_DATA2 0x170b9
444 MX6SL_PAD_SD3_DAT3__SD3_DATA3 0x170b9
445 >;
446 };
447
448 pinctrl_usdhc3_200mhz: usdhc3grp200mhz {
449 fsl,pins = <
450 MX6SL_PAD_SD3_CMD__SD3_CMD 0x170f9
451 MX6SL_PAD_SD3_CLK__SD3_CLK 0x100f9
452 MX6SL_PAD_SD3_DAT0__SD3_DATA0 0x170f9
453 MX6SL_PAD_SD3_DAT1__SD3_DATA1 0x170f9
454 MX6SL_PAD_SD3_DAT2__SD3_DATA2 0x170f9
455 MX6SL_PAD_SD3_DAT3__SD3_DATA3 0x170f9
456 >;
457 };
117ccd55
SG
458 };
459};
460
4291b645
AH
461&kpp {
462 pinctrl-names = "default";
463 pinctrl-0 = <&pinctrl_kpp>;
464 linux,keymap = <
465 MATRIX_KEY(0x0, 0x0, KEY_UP) /* ROW0, COL0 */
466 MATRIX_KEY(0x0, 0x1, KEY_DOWN) /* ROW0, COL1 */
467 MATRIX_KEY(0x0, 0x2, KEY_ENTER) /* ROW0, COL2 */
468 MATRIX_KEY(0x1, 0x0, KEY_HOME) /* ROW1, COL0 */
469 MATRIX_KEY(0x1, 0x1, KEY_RIGHT) /* ROW1, COL1 */
470 MATRIX_KEY(0x1, 0x2, KEY_LEFT) /* ROW1, COL2 */
471 MATRIX_KEY(0x2, 0x0, KEY_VOLUMEDOWN) /* ROW2, COL0 */
472 MATRIX_KEY(0x2, 0x1, KEY_VOLUMEUP) /* ROW2, COL1 */
473 >;
474 status = "okay";
475};
476
032de438
FE
477&ssi2 {
478 fsl,mode = "i2s-slave";
479 status = "okay";
480};
481
117ccd55
SG
482&uart1 {
483 pinctrl-names = "default";
fffaa65d 484 pinctrl-0 = <&pinctrl_uart1>;
117ccd55
SG
485 status = "okay";
486};
487
6022232b
PC
488&usbotg1 {
489 vbus-supply = <&reg_usb_otg1_vbus>;
490 pinctrl-names = "default";
fffaa65d 491 pinctrl-0 = <&pinctrl_usbotg1>;
6022232b
PC
492 disable-over-current;
493 status = "okay";
494};
495
496&usbotg2 {
497 vbus-supply = <&reg_usb_otg2_vbus>;
498 dr_mode = "host";
499 disable-over-current;
500 status = "okay";
501};
502
117ccd55 503&usdhc1 {
fa87dfd6 504 pinctrl-names = "default", "state_100mhz", "state_200mhz";
fffaa65d
SG
505 pinctrl-0 = <&pinctrl_usdhc1>;
506 pinctrl-1 = <&pinctrl_usdhc1_100mhz>;
507 pinctrl-2 = <&pinctrl_usdhc1_200mhz>;
117ccd55
SG
508 bus-width = <8>;
509 cd-gpios = <&gpio4 7 0>;
510 wp-gpios = <&gpio4 6 0>;
511 status = "okay";
512};
513
514&usdhc2 {
fa87dfd6 515 pinctrl-names = "default", "state_100mhz", "state_200mhz";
fffaa65d
SG
516 pinctrl-0 = <&pinctrl_usdhc2>;
517 pinctrl-1 = <&pinctrl_usdhc2_100mhz>;
518 pinctrl-2 = <&pinctrl_usdhc2_200mhz>;
117ccd55
SG
519 cd-gpios = <&gpio5 0 0>;
520 wp-gpios = <&gpio4 29 0>;
521 status = "okay";
522};
523
524&usdhc3 {
fa87dfd6 525 pinctrl-names = "default", "state_100mhz", "state_200mhz";
fffaa65d
SG
526 pinctrl-0 = <&pinctrl_usdhc3>;
527 pinctrl-1 = <&pinctrl_usdhc3_100mhz>;
528 pinctrl-2 = <&pinctrl_usdhc3_200mhz>;
117ccd55
SG
529 cd-gpios = <&gpio3 22 0>;
530 status = "okay";
531};