xref: /linux/arch/arm/boot/dts/nxp/imx/imx51-apf51dev.dts (revision fcc79e1714e8c2b8e216dc3149812edd37884eef)
1// SPDX-License-Identifier: GPL-2.0-or-later
2/*
3 * Copyright 2013 Armadeus Systems - <support@armadeus.com>
4 */
5
6/* APF51Dev is a docking board for the APF51 SOM */
7#include "imx51-apf51.dts"
8
9/ {
10	model = "Armadeus Systems APF51Dev docking/development board";
11	compatible = "armadeus,imx51-apf51dev", "armadeus,imx51-apf51", "fsl,imx51";
12
13	backlight {
14		pinctrl-names = "default";
15		pinctrl-0 = <&pinctrl_backlight>;
16		compatible = "gpio-backlight";
17		gpios = <&gpio3 4 GPIO_ACTIVE_HIGH>;
18		default-on;
19	};
20
21	disp1 {
22		compatible = "fsl,imx-parallel-display";
23		interface-pix-fmt = "bgr666";
24		pinctrl-names = "default";
25		pinctrl-0 = <&pinctrl_ipu_disp1>;
26
27		display-timings {
28			native-mode = <&timing0>;
29			timing0: timing-lw700 {
30				clock-frequency = <33000033>;
31				hactive = <800>;
32				vactive = <480>;
33				hback-porch = <96>;
34				hfront-porch = <96>;
35				vback-porch = <20>;
36				vfront-porch = <21>;
37				hsync-len = <64>;
38				vsync-len = <4>;
39				hsync-active = <1>;
40				vsync-active = <1>;
41				de-active = <1>;
42				pixelclk-active = <0>;
43			};
44		};
45
46		port {
47			display_in: endpoint {
48				remote-endpoint = <&ipu_di0_disp1>;
49			};
50		};
51	};
52
53	gpio-keys {
54		compatible = "gpio-keys";
55
56		user-key {
57			label = "user";
58			gpios = <&gpio1 3 GPIO_ACTIVE_HIGH>;
59			linux,code = <256>; /* BTN_0 */
60		};
61	};
62
63	leds {
64		compatible = "gpio-leds";
65
66		led-user {
67			label = "Heartbeat";
68			gpios = <&gpio1 2 GPIO_ACTIVE_HIGH>;
69			linux,default-trigger = "heartbeat";
70		};
71	};
72};
73
74&ecspi1 {
75	pinctrl-names = "default";
76	pinctrl-0 = <&pinctrl_ecspi1>;
77	cs-gpios = <&gpio4 24 GPIO_ACTIVE_LOW>,
78		   <&gpio4 25 GPIO_ACTIVE_LOW>;
79	status = "okay";
80};
81
82&ecspi2 {
83	pinctrl-names = "default";
84	pinctrl-0 = <&pinctrl_ecspi2>;
85	cs-gpios = <&gpio3 28 GPIO_ACTIVE_LOW>,
86		   <&gpio3 27 GPIO_ACTIVE_LOW>;
87	status = "okay";
88};
89
90&esdhc1 {
91	pinctrl-names = "default";
92	pinctrl-0 = <&pinctrl_esdhc1>;
93	cd-gpios = <&gpio2 29 GPIO_ACTIVE_LOW>;
94	bus-width = <4>;
95	status = "okay";
96};
97
98&esdhc2 {
99	pinctrl-names = "default";
100	pinctrl-0 = <&pinctrl_esdhc2>;
101	bus-width = <4>;
102	non-removable;
103	status = "okay";
104};
105
106&i2c2 {
107	pinctrl-names = "default";
108	pinctrl-0 = <&pinctrl_i2c2>;
109	status = "okay";
110};
111
112&iomuxc {
113	pinctrl-names = "default";
114	pinctrl-0 = <&pinctrl_hog>;
115
116	pinctrl_backlight: backlightgrp {
117		fsl,pins = <
118			MX51_PAD_DI1_D1_CS__GPIO3_4 0x1F5
119		>;
120	};
121
122	pinctrl_hog: hoggrp {
123		fsl,pins = <
124			MX51_PAD_EIM_EB2__GPIO2_22   0x0C5
125			MX51_PAD_EIM_EB3__GPIO2_23   0x0C5
126			MX51_PAD_EIM_CS4__GPIO2_29   0x100
127			MX51_PAD_NANDF_D13__GPIO3_27 0x0C5
128			MX51_PAD_NANDF_D12__GPIO3_28 0x0C5
129			MX51_PAD_CSPI1_SS0__GPIO4_24 0x0C5
130			MX51_PAD_CSPI1_SS1__GPIO4_25 0x0C5
131			MX51_PAD_GPIO1_2__GPIO1_2    0x0C5
132			MX51_PAD_GPIO1_3__GPIO1_3    0x0C5
133		>;
134	};
135
136	pinctrl_ecspi1: ecspi1grp {
137		fsl,pins = <
138			MX51_PAD_CSPI1_MISO__ECSPI1_MISO	0x185
139			MX51_PAD_CSPI1_MOSI__ECSPI1_MOSI	0x185
140			MX51_PAD_CSPI1_SCLK__ECSPI1_SCLK	0x185
141		>;
142	};
143
144	pinctrl_ecspi2: ecspi2grp {
145		fsl,pins = <
146			MX51_PAD_NANDF_RB3__ECSPI2_MISO		0x185
147			MX51_PAD_NANDF_D15__ECSPI2_MOSI		0x185
148			MX51_PAD_NANDF_RB2__ECSPI2_SCLK		0x185
149		>;
150	};
151
152	pinctrl_esdhc1: esdhc1grp {
153		fsl,pins = <
154			MX51_PAD_SD1_CMD__SD1_CMD		0x400020d5
155			MX51_PAD_SD1_CLK__SD1_CLK		0x20d5
156			MX51_PAD_SD1_DATA0__SD1_DATA0		0x20d5
157			MX51_PAD_SD1_DATA1__SD1_DATA1		0x20d5
158			MX51_PAD_SD1_DATA2__SD1_DATA2		0x20d5
159			MX51_PAD_SD1_DATA3__SD1_DATA3		0x20d5
160		>;
161	};
162
163	pinctrl_esdhc2: esdhc2grp {
164		fsl,pins = <
165			MX51_PAD_SD2_CMD__SD2_CMD		0x400020d5
166			MX51_PAD_SD2_CLK__SD2_CLK		0x20d5
167			MX51_PAD_SD2_DATA0__SD2_DATA0		0x20d5
168			MX51_PAD_SD2_DATA1__SD2_DATA1		0x20d5
169			MX51_PAD_SD2_DATA2__SD2_DATA2		0x20d5
170			MX51_PAD_SD2_DATA3__SD2_DATA3		0x20d5
171		>;
172	};
173
174	pinctrl_i2c2: i2c2grp {
175		fsl,pins = <
176			MX51_PAD_EIM_D27__I2C2_SCL		0x400001ed
177			MX51_PAD_EIM_D24__I2C2_SDA		0x400001ed
178		>;
179	};
180
181	pinctrl_ipu_disp1: ipudisp1grp {
182		fsl,pins = <
183			MX51_PAD_DISP1_DAT0__DISP1_DAT0		0x5
184			MX51_PAD_DISP1_DAT1__DISP1_DAT1		0x5
185			MX51_PAD_DISP1_DAT2__DISP1_DAT2		0x5
186			MX51_PAD_DISP1_DAT3__DISP1_DAT3		0x5
187			MX51_PAD_DISP1_DAT4__DISP1_DAT4		0x5
188			MX51_PAD_DISP1_DAT5__DISP1_DAT5		0x5
189			MX51_PAD_DISP1_DAT6__DISP1_DAT6		0x5
190			MX51_PAD_DISP1_DAT7__DISP1_DAT7		0x5
191			MX51_PAD_DISP1_DAT8__DISP1_DAT8		0x5
192			MX51_PAD_DISP1_DAT9__DISP1_DAT9		0x5
193			MX51_PAD_DISP1_DAT10__DISP1_DAT10	0x5
194			MX51_PAD_DISP1_DAT11__DISP1_DAT11	0x5
195			MX51_PAD_DISP1_DAT12__DISP1_DAT12	0x5
196			MX51_PAD_DISP1_DAT13__DISP1_DAT13	0x5
197			MX51_PAD_DISP1_DAT14__DISP1_DAT14	0x5
198			MX51_PAD_DISP1_DAT15__DISP1_DAT15	0x5
199			MX51_PAD_DISP1_DAT16__DISP1_DAT16	0x5
200			MX51_PAD_DISP1_DAT17__DISP1_DAT17	0x5
201			MX51_PAD_DISP1_DAT18__DISP1_DAT18	0x5
202			MX51_PAD_DISP1_DAT19__DISP1_DAT19	0x5
203			MX51_PAD_DISP1_DAT20__DISP1_DAT20	0x5
204			MX51_PAD_DISP1_DAT21__DISP1_DAT21	0x5
205			MX51_PAD_DISP1_DAT22__DISP1_DAT22	0x5
206			MX51_PAD_DISP1_DAT23__DISP1_DAT23	0x5
207			MX51_PAD_DI1_PIN2__DI1_PIN2		0x5
208			MX51_PAD_DI1_PIN3__DI1_PIN3		0x5
209		>;
210	};
211};
212
213&ipu_di0_disp1 {
214	remote-endpoint = <&display_in>;
215};
216