blob: ed9d769b1a23cefe41912c6668de6209326d7ac5 [file] [log] [blame]
Shawn Guo9daaf312011-10-17 08:42:17 +08001/*
2 * Copyright 2011 Freescale Semiconductor, Inc.
3 * Copyright 2011 Linaro Ltd.
4 *
5 * The code contained herein is licensed under the GNU General Public
6 * License. You may obtain a copy of the GNU General Public License
7 * Version 2 or later at the following locations:
8 *
9 * http://www.opensource.org/licenses/gpl-license.html
10 * http://www.gnu.org/copyleft/gpl.html
11 */
12
13/dts-v1/;
Shawn Guo36dffd82013-04-07 10:49:34 +080014#include "imx51.dtsi"
Shawn Guo9daaf312011-10-17 08:42:17 +080015
16/ {
17 model = "Freescale i.MX51 Babbage Board";
18 compatible = "fsl,imx51-babbage", "fsl,imx51";
19
Shawn Guo9daaf312011-10-17 08:42:17 +080020 memory {
21 reg = <0x90000000 0x20000000>;
22 };
23
Russell King17b50012013-11-03 11:23:34 +000024 display0: display@di0 {
Shawn Guobe4ccfc2012-12-31 11:32:48 +080025 compatible = "fsl,imx-parallel-display";
Shawn Guobe4ccfc2012-12-31 11:32:48 +080026 interface-pix-fmt = "rgb24";
27 pinctrl-names = "default";
Shawn Guo5a2a7d52013-11-04 16:05:37 +080028 pinctrl-0 = <&pinctrl_ipu_disp1>;
Fabio Estevam493a8632013-10-08 15:52:12 -030029 display-timings {
30 native-mode = <&timing0>;
31 timing0: dvi {
32 clock-frequency = <65000000>;
33 hactive = <1024>;
34 vactive = <768>;
35 hback-porch = <220>;
36 hfront-porch = <40>;
37 vback-porch = <21>;
38 vfront-porch = <7>;
39 hsync-len = <60>;
40 vsync-len = <10>;
41 };
42 };
Philipp Zabelde10e042014-03-05 10:20:59 +010043
44 port {
45 display0_in: endpoint {
46 remote-endpoint = <&ipu_di0_disp0>;
47 };
48 };
Shawn Guobe4ccfc2012-12-31 11:32:48 +080049 };
Sascha Hauerd6aef842012-11-12 15:39:01 +010050
Russell King17b50012013-11-03 11:23:34 +000051 display1: display@di1 {
Shawn Guobe4ccfc2012-12-31 11:32:48 +080052 compatible = "fsl,imx-parallel-display";
Shawn Guobe4ccfc2012-12-31 11:32:48 +080053 interface-pix-fmt = "rgb565";
54 pinctrl-names = "default";
Shawn Guo5a2a7d52013-11-04 16:05:37 +080055 pinctrl-0 = <&pinctrl_ipu_disp2>;
Fabio Estevam493a8632013-10-08 15:52:12 -030056 status = "disabled";
57 display-timings {
58 native-mode = <&timing1>;
59 timing1: claawvga {
60 clock-frequency = <27000000>;
61 hactive = <800>;
62 vactive = <480>;
63 hback-porch = <40>;
64 hfront-porch = <60>;
65 vback-porch = <10>;
66 vfront-porch = <10>;
67 hsync-len = <20>;
68 vsync-len = <10>;
69 hsync-active = <0>;
70 vsync-active = <0>;
71 de-active = <1>;
72 pixelclk-active = <0>;
73 };
74 };
Philipp Zabelde10e042014-03-05 10:20:59 +010075
76 port {
77 display1_in: endpoint {
78 remote-endpoint = <&ipu_di1_disp1>;
79 };
80 };
Shawn Guo9daaf312011-10-17 08:42:17 +080081 };
82
83 gpio-keys {
84 compatible = "gpio-keys";
Alexander Shiyan2ccc4472014-04-16 11:24:51 +040085 pinctrl-names = "default";
86 pinctrl-0 = <&pinctrl_gpio_keys>;
Shawn Guo9daaf312011-10-17 08:42:17 +080087
88 power {
89 label = "Power Button";
Alexander Shiyanbdb3eec2013-11-19 15:47:27 +040090 gpios = <&gpio2 21 GPIO_ACTIVE_HIGH>;
Alexander Shiyan02134e72014-04-16 11:24:53 +040091 linux,code = <KEY_POWER>;
Shawn Guo9daaf312011-10-17 08:42:17 +080092 gpio-key,wakeup;
93 };
94 };
Shawn Guoa15d9f82012-05-11 13:08:46 +080095
Liu Yinga198af22014-02-10 15:05:46 +080096 leds {
97 compatible = "gpio-leds";
98 pinctrl-names = "default";
99 pinctrl-0 = <&pinctrl_gpio_leds>;
100
101 led-diagnostic {
102 label = "diagnostic";
103 gpios = <&gpio2 6 GPIO_ACTIVE_HIGH>;
104 };
105 };
106
Shawn Guoa15d9f82012-05-11 13:08:46 +0800107 sound {
108 compatible = "fsl,imx51-babbage-sgtl5000",
109 "fsl,imx-audio-sgtl5000";
110 model = "imx51-babbage-sgtl5000";
111 ssi-controller = <&ssi2>;
112 audio-codec = <&sgtl5000>;
113 audio-routing =
114 "MIC_IN", "Mic Jack",
115 "Mic Jack", "Mic Bias",
116 "Headphone Jack", "HP_OUT";
117 mux-int-port = <2>;
118 mux-ext-port = <3>;
119 };
Fabio Estevam84bb0842013-06-09 22:07:47 -0300120
121 clocks {
Alexander Shiyan677e28b2013-07-27 11:19:45 +0400122 ckih1 {
123 clock-frequency = <22579200>;
124 };
125
Fabio Estevam84bb0842013-06-09 22:07:47 -0300126 clk_26M: codec_clock {
127 compatible = "fixed-clock";
128 reg=<0>;
129 #clock-cells = <0>;
130 clock-frequency = <26000000>;
Alexander Shiyanbdb3eec2013-11-19 15:47:27 +0400131 gpios = <&gpio4 26 GPIO_ACTIVE_LOW>;
Fabio Estevam84bb0842013-06-09 22:07:47 -0300132 };
133 };
Fabio Estevam9bf206a2014-03-26 11:54:38 -0300134
135 regulators {
136 compatible = "simple-bus";
137 #address-cells = <1>;
138 #size-cells = <0>;
139
Alexander Shiyandb8235e2014-04-16 11:24:54 +0400140 reg_usbh1_vbus: regulator@0 {
Fabio Estevam9bf206a2014-03-26 11:54:38 -0300141 compatible = "regulator-fixed";
Alexander Shiyan2ccc4472014-04-16 11:24:51 +0400142 pinctrl-names = "default";
Alexander Shiyandb8235e2014-04-16 11:24:54 +0400143 pinctrl-0 = <&pinctrl_usbh1reg>;
Fabio Estevam9bf206a2014-03-26 11:54:38 -0300144 reg = <0>;
Alexander Shiyandb8235e2014-04-16 11:24:54 +0400145 regulator-name = "usbh1_vbus";
Fabio Estevam9bf206a2014-03-26 11:54:38 -0300146 regulator-min-microvolt = <5000000>;
147 regulator-max-microvolt = <5000000>;
Alexander Shiyan2ccc4472014-04-16 11:24:51 +0400148 gpio = <&gpio2 5 GPIO_ACTIVE_HIGH>;
Fabio Estevam9bf206a2014-03-26 11:54:38 -0300149 enable-active-high;
150 };
Alexander Shiyandb8235e2014-04-16 11:24:54 +0400151
152 reg_usbotg_vbus: regulator@1 {
153 compatible = "regulator-fixed";
154 pinctrl-names = "default";
155 pinctrl-0 = <&pinctrl_usbotgreg>;
156 reg = <1>;
157 regulator-name = "usbotg_vbus";
158 regulator-min-microvolt = <5000000>;
159 regulator-max-microvolt = <5000000>;
160 gpio = <&gpio1 7 GPIO_ACTIVE_HIGH>;
161 enable-active-high;
162 };
Fabio Estevam9bf206a2014-03-26 11:54:38 -0300163 };
164
165 usbphy {
166 #address-cells = <1>;
167 #size-cells = <0>;
168 compatible = "simple-bus";
169
170 usbh1phy: usbh1phy@0 {
171 compatible = "usb-nop-xceiv";
172 reg = <0>;
173 clocks = <&clks 0>;
174 clock-names = "main_clk";
175 };
176 };
Shawn Guo9daaf312011-10-17 08:42:17 +0800177};
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800178
179&esdhc1 {
180 pinctrl-names = "default";
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800181 pinctrl-0 = <&pinctrl_esdhc1>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800182 fsl,cd-controller;
183 fsl,wp-controller;
184 status = "okay";
185};
186
187&esdhc2 {
188 pinctrl-names = "default";
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800189 pinctrl-0 = <&pinctrl_esdhc2>;
Alexander Shiyanbdb3eec2013-11-19 15:47:27 +0400190 cd-gpios = <&gpio1 6 GPIO_ACTIVE_HIGH>;
191 wp-gpios = <&gpio1 5 GPIO_ACTIVE_HIGH>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800192 status = "okay";
193};
194
195&uart3 {
196 pinctrl-names = "default";
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800197 pinctrl-0 = <&pinctrl_uart3>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800198 fsl,uart-has-rtscts;
199 status = "okay";
200};
201
202&ecspi1 {
203 pinctrl-names = "default";
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800204 pinctrl-0 = <&pinctrl_ecspi1>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800205 fsl,spi-num-chipselects = <2>;
Alexander Shiyanbdb3eec2013-11-19 15:47:27 +0400206 cs-gpios = <&gpio4 24 GPIO_ACTIVE_HIGH>,
Alexander Shiyand2176f22013-11-27 15:55:45 +0400207 <&gpio4 25 GPIO_ACTIVE_LOW>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800208 status = "okay";
209
210 pmic: mc13892@0 {
211 #address-cells = <1>;
212 #size-cells = <0>;
213 compatible = "fsl,mc13892";
Alexander Shiyan1ddcff42014-04-16 11:24:52 +0400214 pinctrl-names = "default";
215 pinctrl-0 = <&pinctrl_pmic>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800216 spi-max-frequency = <6000000>;
Sascha Hauerdc071432013-06-25 15:51:59 +0200217 spi-cs-high;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800218 reg = <0>;
219 interrupt-parent = <&gpio1>;
Alexander Shiyan1cbb74f2013-11-07 12:45:08 +0400220 interrupts = <8 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800221
222 regulators {
223 sw1_reg: sw1 {
224 regulator-min-microvolt = <600000>;
225 regulator-max-microvolt = <1375000>;
226 regulator-boot-on;
227 regulator-always-on;
228 };
229
230 sw2_reg: sw2 {
231 regulator-min-microvolt = <900000>;
232 regulator-max-microvolt = <1850000>;
233 regulator-boot-on;
234 regulator-always-on;
235 };
236
237 sw3_reg: sw3 {
238 regulator-min-microvolt = <1100000>;
239 regulator-max-microvolt = <1850000>;
240 regulator-boot-on;
241 regulator-always-on;
242 };
243
244 sw4_reg: sw4 {
245 regulator-min-microvolt = <1100000>;
246 regulator-max-microvolt = <1850000>;
247 regulator-boot-on;
248 regulator-always-on;
249 };
250
251 vpll_reg: vpll {
252 regulator-min-microvolt = <1050000>;
253 regulator-max-microvolt = <1800000>;
254 regulator-boot-on;
255 regulator-always-on;
256 };
257
258 vdig_reg: vdig {
259 regulator-min-microvolt = <1650000>;
260 regulator-max-microvolt = <1650000>;
261 regulator-boot-on;
262 };
263
264 vsd_reg: vsd {
265 regulator-min-microvolt = <1800000>;
266 regulator-max-microvolt = <3150000>;
267 };
268
269 vusb2_reg: vusb2 {
270 regulator-min-microvolt = <2400000>;
271 regulator-max-microvolt = <2775000>;
272 regulator-boot-on;
273 regulator-always-on;
274 };
275
276 vvideo_reg: vvideo {
277 regulator-min-microvolt = <2775000>;
278 regulator-max-microvolt = <2775000>;
279 };
280
281 vaudio_reg: vaudio {
282 regulator-min-microvolt = <2300000>;
283 regulator-max-microvolt = <3000000>;
284 };
285
286 vcam_reg: vcam {
287 regulator-min-microvolt = <2500000>;
288 regulator-max-microvolt = <3000000>;
289 };
290
291 vgen1_reg: vgen1 {
292 regulator-min-microvolt = <1200000>;
293 regulator-max-microvolt = <1200000>;
294 };
295
296 vgen2_reg: vgen2 {
297 regulator-min-microvolt = <1200000>;
298 regulator-max-microvolt = <3150000>;
299 regulator-always-on;
300 };
301
302 vgen3_reg: vgen3 {
303 regulator-min-microvolt = <1800000>;
304 regulator-max-microvolt = <2900000>;
305 regulator-always-on;
306 };
307 };
308 };
309
310 flash: at45db321d@1 {
311 #address-cells = <1>;
312 #size-cells = <1>;
313 compatible = "atmel,at45db321d", "atmel,at45", "atmel,dataflash";
314 spi-max-frequency = <25000000>;
315 reg = <1>;
316
317 partition@0 {
318 label = "U-Boot";
319 reg = <0x0 0x40000>;
320 read-only;
321 };
322
323 partition@40000 {
324 label = "Kernel";
325 reg = <0x40000 0x3c0000>;
326 };
327 };
328};
329
Philipp Zabelde10e042014-03-05 10:20:59 +0100330&ipu_di0_disp0 {
331 remote-endpoint = <&display0_in>;
332};
333
334&ipu_di1_disp1 {
335 remote-endpoint = <&display1_in>;
336};
337
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800338&ssi2 {
339 fsl,mode = "i2s-slave";
340 status = "okay";
341};
342
343&iomuxc {
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800344 imx51-babbage {
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800345 pinctrl_audmux: audmuxgrp {
346 fsl,pins = <
347 MX51_PAD_AUD3_BB_TXD__AUD3_TXD 0x80000000
348 MX51_PAD_AUD3_BB_RXD__AUD3_RXD 0x80000000
349 MX51_PAD_AUD3_BB_CK__AUD3_TXC 0x80000000
350 MX51_PAD_AUD3_BB_FS__AUD3_TXFS 0x80000000
351 >;
352 };
353
Alexander Shiyan2ccc4472014-04-16 11:24:51 +0400354 pinctrl_clkcodec: clkcodecgrp {
355 fsl,pins = <
356 MX51_PAD_CSPI1_RDY__GPIO4_26 0x80000000
357 >;
358 };
359
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800360 pinctrl_ecspi1: ecspi1grp {
361 fsl,pins = <
362 MX51_PAD_CSPI1_MISO__ECSPI1_MISO 0x185
363 MX51_PAD_CSPI1_MOSI__ECSPI1_MOSI 0x185
364 MX51_PAD_CSPI1_SCLK__ECSPI1_SCLK 0x185
Alexander Shiyan2ccc4472014-04-16 11:24:51 +0400365 MX51_PAD_CSPI1_SS0__GPIO4_24 0x85 /* CS0 */
366 MX51_PAD_CSPI1_SS1__GPIO4_25 0x85 /* CS1 */
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800367 >;
368 };
369
370 pinctrl_esdhc1: esdhc1grp {
371 fsl,pins = <
372 MX51_PAD_SD1_CMD__SD1_CMD 0x400020d5
373 MX51_PAD_SD1_CLK__SD1_CLK 0x20d5
374 MX51_PAD_SD1_DATA0__SD1_DATA0 0x20d5
375 MX51_PAD_SD1_DATA1__SD1_DATA1 0x20d5
376 MX51_PAD_SD1_DATA2__SD1_DATA2 0x20d5
377 MX51_PAD_SD1_DATA3__SD1_DATA3 0x20d5
Alexander Shiyan2ccc4472014-04-16 11:24:51 +0400378 MX51_PAD_GPIO1_0__SD1_CD 0x20d5
379 MX51_PAD_GPIO1_1__SD1_WP 0x20d5
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800380 >;
381 };
382
383 pinctrl_esdhc2: esdhc2grp {
384 fsl,pins = <
385 MX51_PAD_SD2_CMD__SD2_CMD 0x400020d5
386 MX51_PAD_SD2_CLK__SD2_CLK 0x20d5
387 MX51_PAD_SD2_DATA0__SD2_DATA0 0x20d5
388 MX51_PAD_SD2_DATA1__SD2_DATA1 0x20d5
389 MX51_PAD_SD2_DATA2__SD2_DATA2 0x20d5
390 MX51_PAD_SD2_DATA3__SD2_DATA3 0x20d5
Alexander Shiyan2ccc4472014-04-16 11:24:51 +0400391 MX51_PAD_GPIO1_5__GPIO1_5 0x100 /* WP */
392 MX51_PAD_GPIO1_6__GPIO1_6 0x100 /* CD */
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800393 >;
394 };
395
396 pinctrl_fec: fecgrp {
397 fsl,pins = <
398 MX51_PAD_EIM_EB2__FEC_MDIO 0x80000000
399 MX51_PAD_EIM_EB3__FEC_RDATA1 0x80000000
400 MX51_PAD_EIM_CS2__FEC_RDATA2 0x80000000
401 MX51_PAD_EIM_CS3__FEC_RDATA3 0x80000000
402 MX51_PAD_EIM_CS4__FEC_RX_ER 0x80000000
403 MX51_PAD_EIM_CS5__FEC_CRS 0x80000000
404 MX51_PAD_NANDF_RB2__FEC_COL 0x80000000
405 MX51_PAD_NANDF_RB3__FEC_RX_CLK 0x80000000
406 MX51_PAD_NANDF_D9__FEC_RDATA0 0x80000000
407 MX51_PAD_NANDF_D8__FEC_TDATA0 0x80000000
408 MX51_PAD_NANDF_CS2__FEC_TX_ER 0x80000000
409 MX51_PAD_NANDF_CS3__FEC_MDC 0x80000000
410 MX51_PAD_NANDF_CS4__FEC_TDATA1 0x80000000
411 MX51_PAD_NANDF_CS5__FEC_TDATA2 0x80000000
412 MX51_PAD_NANDF_CS6__FEC_TDATA3 0x80000000
413 MX51_PAD_NANDF_CS7__FEC_TX_EN 0x80000000
414 MX51_PAD_NANDF_RDY_INT__FEC_TX_CLK 0x80000000
Alexander Shiyan0c33f662013-11-27 15:55:46 +0400415 MX51_PAD_EIM_A20__GPIO2_14 0x85 /* Reset */
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800416 >;
417 };
418
Alexander Shiyan2ccc4472014-04-16 11:24:51 +0400419 pinctrl_gpio_keys: gpiokeysgrp {
420 fsl,pins = <
421 MX51_PAD_EIM_A27__GPIO2_21 0x5
422 >;
423 };
424
Liu Yinga198af22014-02-10 15:05:46 +0800425 pinctrl_gpio_leds: gpioledsgrp {
426 fsl,pins = <
427 MX51_PAD_EIM_D22__GPIO2_6 0x80000000
428 >;
429 };
430
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800431 pinctrl_i2c2: i2c2grp {
432 fsl,pins = <
433 MX51_PAD_KEY_COL4__I2C2_SCL 0x400001ed
434 MX51_PAD_KEY_COL5__I2C2_SDA 0x400001ed
435 >;
436 };
437
438 pinctrl_ipu_disp1: ipudisp1grp {
439 fsl,pins = <
440 MX51_PAD_DISP1_DAT0__DISP1_DAT0 0x5
441 MX51_PAD_DISP1_DAT1__DISP1_DAT1 0x5
442 MX51_PAD_DISP1_DAT2__DISP1_DAT2 0x5
443 MX51_PAD_DISP1_DAT3__DISP1_DAT3 0x5
444 MX51_PAD_DISP1_DAT4__DISP1_DAT4 0x5
445 MX51_PAD_DISP1_DAT5__DISP1_DAT5 0x5
446 MX51_PAD_DISP1_DAT6__DISP1_DAT6 0x5
447 MX51_PAD_DISP1_DAT7__DISP1_DAT7 0x5
448 MX51_PAD_DISP1_DAT8__DISP1_DAT8 0x5
449 MX51_PAD_DISP1_DAT9__DISP1_DAT9 0x5
450 MX51_PAD_DISP1_DAT10__DISP1_DAT10 0x5
451 MX51_PAD_DISP1_DAT11__DISP1_DAT11 0x5
452 MX51_PAD_DISP1_DAT12__DISP1_DAT12 0x5
453 MX51_PAD_DISP1_DAT13__DISP1_DAT13 0x5
454 MX51_PAD_DISP1_DAT14__DISP1_DAT14 0x5
455 MX51_PAD_DISP1_DAT15__DISP1_DAT15 0x5
456 MX51_PAD_DISP1_DAT16__DISP1_DAT16 0x5
457 MX51_PAD_DISP1_DAT17__DISP1_DAT17 0x5
458 MX51_PAD_DISP1_DAT18__DISP1_DAT18 0x5
459 MX51_PAD_DISP1_DAT19__DISP1_DAT19 0x5
460 MX51_PAD_DISP1_DAT20__DISP1_DAT20 0x5
461 MX51_PAD_DISP1_DAT21__DISP1_DAT21 0x5
462 MX51_PAD_DISP1_DAT22__DISP1_DAT22 0x5
463 MX51_PAD_DISP1_DAT23__DISP1_DAT23 0x5
464 MX51_PAD_DI1_PIN2__DI1_PIN2 0x5
465 MX51_PAD_DI1_PIN3__DI1_PIN3 0x5
466 >;
467 };
468
469 pinctrl_ipu_disp2: ipudisp2grp {
470 fsl,pins = <
471 MX51_PAD_DISP2_DAT0__DISP2_DAT0 0x5
472 MX51_PAD_DISP2_DAT1__DISP2_DAT1 0x5
473 MX51_PAD_DISP2_DAT2__DISP2_DAT2 0x5
474 MX51_PAD_DISP2_DAT3__DISP2_DAT3 0x5
475 MX51_PAD_DISP2_DAT4__DISP2_DAT4 0x5
476 MX51_PAD_DISP2_DAT5__DISP2_DAT5 0x5
477 MX51_PAD_DISP2_DAT6__DISP2_DAT6 0x5
478 MX51_PAD_DISP2_DAT7__DISP2_DAT7 0x5
479 MX51_PAD_DISP2_DAT8__DISP2_DAT8 0x5
480 MX51_PAD_DISP2_DAT9__DISP2_DAT9 0x5
481 MX51_PAD_DISP2_DAT10__DISP2_DAT10 0x5
482 MX51_PAD_DISP2_DAT11__DISP2_DAT11 0x5
483 MX51_PAD_DISP2_DAT12__DISP2_DAT12 0x5
484 MX51_PAD_DISP2_DAT13__DISP2_DAT13 0x5
485 MX51_PAD_DISP2_DAT14__DISP2_DAT14 0x5
486 MX51_PAD_DISP2_DAT15__DISP2_DAT15 0x5
487 MX51_PAD_DI2_PIN2__DI2_PIN2 0x5
488 MX51_PAD_DI2_PIN3__DI2_PIN3 0x5
489 MX51_PAD_DI2_DISP_CLK__DI2_DISP_CLK 0x5
490 MX51_PAD_DI_GP4__DI2_PIN15 0x5
491 >;
492 };
493
494 pinctrl_kpp: kppgrp {
495 fsl,pins = <
496 MX51_PAD_KEY_ROW0__KEY_ROW0 0xe0
497 MX51_PAD_KEY_ROW1__KEY_ROW1 0xe0
498 MX51_PAD_KEY_ROW2__KEY_ROW2 0xe0
499 MX51_PAD_KEY_ROW3__KEY_ROW3 0xe0
500 MX51_PAD_KEY_COL0__KEY_COL0 0xe8
501 MX51_PAD_KEY_COL1__KEY_COL1 0xe8
502 MX51_PAD_KEY_COL2__KEY_COL2 0xe8
503 MX51_PAD_KEY_COL3__KEY_COL3 0xe8
504 >;
505 };
506
Alexander Shiyan1ddcff42014-04-16 11:24:52 +0400507 pinctrl_pmic: pmicgrp {
508 fsl,pins = <
509 MX51_PAD_GPIO1_8__GPIO1_8 0xe5 /* IRQ */
510 >;
511 };
512
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800513 pinctrl_uart1: uart1grp {
514 fsl,pins = <
515 MX51_PAD_UART1_RXD__UART1_RXD 0x1c5
516 MX51_PAD_UART1_TXD__UART1_TXD 0x1c5
517 MX51_PAD_UART1_RTS__UART1_RTS 0x1c5
518 MX51_PAD_UART1_CTS__UART1_CTS 0x1c5
519 >;
520 };
521
522 pinctrl_uart2: uart2grp {
523 fsl,pins = <
524 MX51_PAD_UART2_RXD__UART2_RXD 0x1c5
525 MX51_PAD_UART2_TXD__UART2_TXD 0x1c5
526 >;
527 };
528
529 pinctrl_uart3: uart3grp {
530 fsl,pins = <
531 MX51_PAD_EIM_D25__UART3_RXD 0x1c5
532 MX51_PAD_EIM_D26__UART3_TXD 0x1c5
533 MX51_PAD_EIM_D27__UART3_RTS 0x1c5
534 MX51_PAD_EIM_D24__UART3_CTS 0x1c5
535 >;
536 };
Fabio Estevam9bf206a2014-03-26 11:54:38 -0300537
538 pinctrl_usbh1: usbh1grp {
539 fsl,pins = <
540 MX51_PAD_USBH1_CLK__USBH1_CLK 0x80000000
541 MX51_PAD_USBH1_DIR__USBH1_DIR 0x80000000
542 MX51_PAD_USBH1_NXT__USBH1_NXT 0x80000000
543 MX51_PAD_USBH1_DATA0__USBH1_DATA0 0x80000000
544 MX51_PAD_USBH1_DATA1__USBH1_DATA1 0x80000000
545 MX51_PAD_USBH1_DATA2__USBH1_DATA2 0x80000000
546 MX51_PAD_USBH1_DATA3__USBH1_DATA3 0x80000000
547 MX51_PAD_USBH1_DATA4__USBH1_DATA4 0x80000000
548 MX51_PAD_USBH1_DATA5__USBH1_DATA5 0x80000000
549 MX51_PAD_USBH1_DATA6__USBH1_DATA6 0x80000000
550 MX51_PAD_USBH1_DATA7__USBH1_DATA7 0x80000000
Alexander Shiyan2ccc4472014-04-16 11:24:51 +0400551 >;
552 };
553
Alexander Shiyandb8235e2014-04-16 11:24:54 +0400554 pinctrl_usbh1reg: usbh1reggrp {
Alexander Shiyan2ccc4472014-04-16 11:24:51 +0400555 fsl,pins = <
556 MX51_PAD_EIM_D21__GPIO2_5 0x85
Fabio Estevam9bf206a2014-03-26 11:54:38 -0300557 >;
558 };
Alexander Shiyandb8235e2014-04-16 11:24:54 +0400559
560 pinctrl_usbotgreg: usbotgreggrp {
561 fsl,pins = <
562 MX51_PAD_GPIO1_7__GPIO1_7 0x85
563 >;
564 };
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800565 };
566};
567
568&uart1 {
569 pinctrl-names = "default";
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800570 pinctrl-0 = <&pinctrl_uart1>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800571 fsl,uart-has-rtscts;
572 status = "okay";
573};
574
575&uart2 {
576 pinctrl-names = "default";
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800577 pinctrl-0 = <&pinctrl_uart2>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800578 status = "okay";
579};
580
581&i2c2 {
582 pinctrl-names = "default";
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800583 pinctrl-0 = <&pinctrl_i2c2>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800584 status = "okay";
585
586 sgtl5000: codec@0a {
587 compatible = "fsl,sgtl5000";
Alexander Shiyan2ccc4472014-04-16 11:24:51 +0400588 pinctrl-names = "default";
589 pinctrl-0 = <&pinctrl_clkcodec>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800590 reg = <0x0a>;
Fabio Estevam84bb0842013-06-09 22:07:47 -0300591 clocks = <&clk_26M>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800592 VDDA-supply = <&vdig_reg>;
593 VDDIO-supply = <&vvideo_reg>;
594 };
595};
596
597&audmux {
598 pinctrl-names = "default";
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800599 pinctrl-0 = <&pinctrl_audmux>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800600 status = "okay";
601};
602
603&fec {
604 pinctrl-names = "default";
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800605 pinctrl-0 = <&pinctrl_fec>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800606 phy-mode = "mii";
Alexander Shiyan0c33f662013-11-27 15:55:46 +0400607 phy-reset-gpios = <&gpio2 14 GPIO_ACTIVE_LOW>;
608 phy-reset-duration = <1>;
Shawn Guobe4ccfc2012-12-31 11:32:48 +0800609 status = "okay";
610};
Liu Ying67eb7c02013-01-03 20:37:34 +0800611
612&kpp {
613 pinctrl-names = "default";
Shawn Guo5a2a7d52013-11-04 16:05:37 +0800614 pinctrl-0 = <&pinctrl_kpp>;
Alexander Shiyan72d86d22014-01-11 10:54:19 +0400615 linux,keymap = <
616 MATRIX_KEY(0, 0, KEY_UP)
617 MATRIX_KEY(0, 1, KEY_DOWN)
618 MATRIX_KEY(0, 2, KEY_VOLUMEDOWN)
619 MATRIX_KEY(0, 3, KEY_HOME)
620 MATRIX_KEY(1, 0, KEY_RIGHT)
621 MATRIX_KEY(1, 1, KEY_LEFT)
622 MATRIX_KEY(1, 2, KEY_ENTER)
623 MATRIX_KEY(1, 3, KEY_VOLUMEUP)
624 MATRIX_KEY(2, 0, KEY_F6)
625 MATRIX_KEY(2, 1, KEY_F8)
626 MATRIX_KEY(2, 2, KEY_F9)
627 MATRIX_KEY(2, 3, KEY_F10)
628 MATRIX_KEY(3, 0, KEY_F1)
629 MATRIX_KEY(3, 1, KEY_F2)
630 MATRIX_KEY(3, 2, KEY_F3)
631 MATRIX_KEY(3, 3, KEY_POWER)
632 >;
Liu Ying67eb7c02013-01-03 20:37:34 +0800633 status = "okay";
634};
Fabio Estevam9bf206a2014-03-26 11:54:38 -0300635
636&usbh1 {
637 pinctrl-names = "default";
638 pinctrl-0 = <&pinctrl_usbh1>;
Alexander Shiyandb8235e2014-04-16 11:24:54 +0400639 vbus-supply = <&reg_usbh1_vbus>;
Fabio Estevam9bf206a2014-03-26 11:54:38 -0300640 fsl,usbphy = <&usbh1phy>;
641 phy_type = "ulpi";
642 status = "okay";
643};
Fabio Estevam7538d4f2014-03-26 11:54:39 -0300644
645&usbotg {
646 dr_mode = "otg";
647 disable-over-current;
648 phy_type = "utmi_wide";
Alexander Shiyandb8235e2014-04-16 11:24:54 +0400649 vbus-supply = <&reg_usbotg_vbus>;
Fabio Estevam7538d4f2014-03-26 11:54:39 -0300650 status = "okay";
651};