Loading...
1// SPDX-License-Identifier: GPL-2.0+
2//
3// Copyright 2011 Freescale Semiconductor, Inc.
4// Copyright 2011 Linaro Ltd.
5
6/dts-v1/;
7#include <dt-bindings/input/input.h>
8#include "imx53.dtsi"
9
10/ {
11 model = "Freescale i.MX53 Smart Mobile Reference Design Board";
12 compatible = "fsl,imx53-smd", "fsl,imx53";
13
14 memory@70000000 {
15 device_type = "memory";
16 reg = <0x70000000 0x40000000>;
17 };
18
19 gpio-keys {
20 compatible = "gpio-keys";
21
22 key-volume-up {
23 label = "Volume Up";
24 gpios = <&gpio2 14 0>;
25 linux,code = <KEY_VOLUMEUP>;
26 };
27
28 key-volume-down {
29 label = "Volume Down";
30 gpios = <&gpio2 15 0>;
31 linux,code = <KEY_VOLUMEDOWN>;
32 };
33 };
34};
35
36&esdhc1 {
37 pinctrl-names = "default";
38 pinctrl-0 = <&pinctrl_esdhc1>;
39 cd-gpios = <&gpio3 13 GPIO_ACTIVE_LOW>;
40 wp-gpios = <&gpio4 11 GPIO_ACTIVE_HIGH>;
41 status = "okay";
42};
43
44&esdhc2 {
45 pinctrl-names = "default";
46 pinctrl-0 = <&pinctrl_esdhc2>;
47 non-removable;
48 status = "okay";
49};
50
51&uart3 {
52 pinctrl-names = "default";
53 pinctrl-0 = <&pinctrl_uart3>;
54 uart-has-rtscts;
55 status = "okay";
56};
57
58&ecspi1 {
59 pinctrl-names = "default";
60 pinctrl-0 = <&pinctrl_ecspi1>;
61 cs-gpios = <&gpio2 30 GPIO_ACTIVE_LOW>, <&gpio3 19 GPIO_ACTIVE_LOW>;
62 status = "okay";
63
64 zigbee: mc1323@0 {
65 compatible = "fsl,mc1323";
66 spi-max-frequency = <8000000>;
67 reg = <0>;
68 };
69
70 flash: m25p32@1 {
71 #address-cells = <1>;
72 #size-cells = <1>;
73 compatible = "st,m25p32", "st,m25p", "jedec,spi-nor";
74 spi-max-frequency = <20000000>;
75 reg = <1>;
76
77 partition@0 {
78 label = "U-Boot";
79 reg = <0x0 0x40000>;
80 read-only;
81 };
82
83 partition@40000 {
84 label = "Kernel";
85 reg = <0x40000 0x3c0000>;
86 };
87 };
88};
89
90&esdhc3 {
91 pinctrl-names = "default";
92 pinctrl-0 = <&pinctrl_esdhc3>;
93 non-removable;
94 status = "okay";
95};
96
97&iomuxc {
98 pinctrl-names = "default";
99 pinctrl-0 = <&pinctrl_hog>;
100
101 imx53-smd {
102 pinctrl_hog: hoggrp {
103 fsl,pins = <
104 MX53_PAD_PATA_DATA14__GPIO2_14 0x80000000
105 MX53_PAD_PATA_DATA15__GPIO2_15 0x80000000
106 MX53_PAD_EIM_EB2__GPIO2_30 0x80000000
107 MX53_PAD_EIM_DA13__GPIO3_13 0x80000000
108 MX53_PAD_EIM_D19__GPIO3_19 0x80000000
109 MX53_PAD_KEY_ROW2__GPIO4_11 0x80000000
110 MX53_PAD_PATA_DA_0__GPIO7_6 0x80000000
111 >;
112 };
113
114 pinctrl_ecspi1: ecspi1grp {
115 fsl,pins = <
116 MX53_PAD_EIM_D16__ECSPI1_SCLK 0x80000000
117 MX53_PAD_EIM_D17__ECSPI1_MISO 0x80000000
118 MX53_PAD_EIM_D18__ECSPI1_MOSI 0x80000000
119 >;
120 };
121
122 pinctrl_esdhc1: esdhc1grp {
123 fsl,pins = <
124 MX53_PAD_SD1_DATA0__ESDHC1_DAT0 0x1d5
125 MX53_PAD_SD1_DATA1__ESDHC1_DAT1 0x1d5
126 MX53_PAD_SD1_DATA2__ESDHC1_DAT2 0x1d5
127 MX53_PAD_SD1_DATA3__ESDHC1_DAT3 0x1d5
128 MX53_PAD_SD1_CMD__ESDHC1_CMD 0x1d5
129 MX53_PAD_SD1_CLK__ESDHC1_CLK 0x1d5
130 >;
131 };
132
133 pinctrl_esdhc2: esdhc2grp {
134 fsl,pins = <
135 MX53_PAD_SD2_CMD__ESDHC2_CMD 0x1d5
136 MX53_PAD_SD2_CLK__ESDHC2_CLK 0x1d5
137 MX53_PAD_SD2_DATA0__ESDHC2_DAT0 0x1d5
138 MX53_PAD_SD2_DATA1__ESDHC2_DAT1 0x1d5
139 MX53_PAD_SD2_DATA2__ESDHC2_DAT2 0x1d5
140 MX53_PAD_SD2_DATA3__ESDHC2_DAT3 0x1d5
141 >;
142 };
143
144 pinctrl_esdhc3: esdhc3grp {
145 fsl,pins = <
146 MX53_PAD_PATA_DATA8__ESDHC3_DAT0 0x1d5
147 MX53_PAD_PATA_DATA9__ESDHC3_DAT1 0x1d5
148 MX53_PAD_PATA_DATA10__ESDHC3_DAT2 0x1d5
149 MX53_PAD_PATA_DATA11__ESDHC3_DAT3 0x1d5
150 MX53_PAD_PATA_DATA0__ESDHC3_DAT4 0x1d5
151 MX53_PAD_PATA_DATA1__ESDHC3_DAT5 0x1d5
152 MX53_PAD_PATA_DATA2__ESDHC3_DAT6 0x1d5
153 MX53_PAD_PATA_DATA3__ESDHC3_DAT7 0x1d5
154 MX53_PAD_PATA_RESET_B__ESDHC3_CMD 0x1d5
155 MX53_PAD_PATA_IORDY__ESDHC3_CLK 0x1d5
156 >;
157 };
158
159 pinctrl_fec: fecgrp {
160 fsl,pins = <
161 MX53_PAD_FEC_MDC__FEC_MDC 0x80000000
162 MX53_PAD_FEC_MDIO__FEC_MDIO 0x80000000
163 MX53_PAD_FEC_REF_CLK__FEC_TX_CLK 0x80000000
164 MX53_PAD_FEC_RX_ER__FEC_RX_ER 0x80000000
165 MX53_PAD_FEC_CRS_DV__FEC_RX_DV 0x80000000
166 MX53_PAD_FEC_RXD1__FEC_RDATA_1 0x80000000
167 MX53_PAD_FEC_RXD0__FEC_RDATA_0 0x80000000
168 MX53_PAD_FEC_TX_EN__FEC_TX_EN 0x80000000
169 MX53_PAD_FEC_TXD1__FEC_TDATA_1 0x80000000
170 MX53_PAD_FEC_TXD0__FEC_TDATA_0 0x80000000
171 >;
172 };
173
174 pinctrl_i2c1: i2c1grp {
175 fsl,pins = <
176 MX53_PAD_CSI0_DAT8__I2C1_SDA 0xc0000000
177 MX53_PAD_CSI0_DAT9__I2C1_SCL 0xc0000000
178 >;
179 };
180
181 pinctrl_i2c2: i2c2grp {
182 fsl,pins = <
183 MX53_PAD_KEY_ROW3__I2C2_SDA 0xc0000000
184 MX53_PAD_KEY_COL3__I2C2_SCL 0xc0000000
185 >;
186 };
187
188 pinctrl_ipu_csi0: ipucsi0grp {
189 fsl,pins = <
190 MX53_PAD_CSI0_DAT12__IPU_CSI0_D_12 0x1c4
191 MX53_PAD_CSI0_DAT13__IPU_CSI0_D_13 0x1c4
192 MX53_PAD_CSI0_DAT14__IPU_CSI0_D_14 0x1c4
193 MX53_PAD_CSI0_DAT15__IPU_CSI0_D_15 0x1c4
194 MX53_PAD_CSI0_DAT16__IPU_CSI0_D_16 0x1c4
195 MX53_PAD_CSI0_DAT17__IPU_CSI0_D_17 0x1c4
196 MX53_PAD_CSI0_DAT18__IPU_CSI0_D_18 0x1c4
197 MX53_PAD_CSI0_DAT19__IPU_CSI0_D_19 0x1c4
198 MX53_PAD_CSI0_PIXCLK__IPU_CSI0_PIXCLK 0x1e4
199 MX53_PAD_CSI0_VSYNC__IPU_CSI0_VSYNC 0x1e4
200 MX53_PAD_CSI0_MCLK__IPU_CSI0_HSYNC 0x1e4
201 MX53_PAD_CSI0_DATA_EN__IPU_CSI0_DATA_EN 0x1e4
202 >;
203 };
204
205 pinctrl_ov5642: ov5642grp {
206 fsl,pins = <
207 MX53_PAD_NANDF_WP_B__GPIO6_9 0x1e4
208 MX53_PAD_NANDF_RB0__GPIO6_10 0x1e4
209 MX53_PAD_GPIO_0__CCM_SSI_EXT1_CLK 0x1c4
210 >;
211 };
212
213 pinctrl_uart1: uart1grp {
214 fsl,pins = <
215 MX53_PAD_CSI0_DAT10__UART1_TXD_MUX 0x1e4
216 MX53_PAD_CSI0_DAT11__UART1_RXD_MUX 0x1e4
217 >;
218 };
219
220 pinctrl_uart2: uart2grp {
221 fsl,pins = <
222 MX53_PAD_PATA_BUFFER_EN__UART2_RXD_MUX 0x1e4
223 MX53_PAD_PATA_DMARQ__UART2_TXD_MUX 0x1e4
224 >;
225 };
226
227 pinctrl_uart3: uart3grp {
228 fsl,pins = <
229 MX53_PAD_PATA_CS_0__UART3_TXD_MUX 0x1e4
230 MX53_PAD_PATA_CS_1__UART3_RXD_MUX 0x1e4
231 MX53_PAD_PATA_DA_1__UART3_CTS 0x1e4
232 MX53_PAD_PATA_DA_2__UART3_RTS 0x1e4
233 >;
234 };
235 };
236};
237
238&uart1 {
239 pinctrl-names = "default";
240 pinctrl-0 = <&pinctrl_uart1>;
241 status = "okay";
242};
243
244&uart2 {
245 pinctrl-names = "default";
246 pinctrl-0 = <&pinctrl_uart2>;
247 status = "okay";
248};
249
250&i2c2 {
251 pinctrl-names = "default";
252 pinctrl-0 = <&pinctrl_i2c2>;
253 status = "okay";
254
255 codec: sgtl5000@a {
256 compatible = "fsl,sgtl5000";
257 reg = <0x0a>;
258 };
259
260 magnetometer: mag3110@e {
261 compatible = "fsl,mag3110";
262 reg = <0x0e>;
263 };
264
265 touchkey: mpr121@5a {
266 compatible = "fsl,mpr121";
267 reg = <0x5a>;
268 };
269};
270
271&i2c1 {
272 pinctrl-names = "default";
273 pinctrl-0 = <&pinctrl_i2c1>;
274 status = "okay";
275
276 accelerometer: mma8450@1c {
277 compatible = "fsl,mma8450";
278 reg = <0x1c>;
279 };
280
281 camera: ov5642@3c {
282 compatible = "ovti,ov5642";
283 reg = <0x3c>;
284 pinctrl-names = "default";
285 pinctrl-0 = <&pinctrl_ov5642>;
286 assigned-clocks = <&clks IMX5_CLK_SSI_EXT1_SEL>,
287 <&clks IMX5_CLK_SSI_EXT1_COM_SEL>;
288 assigned-clock-parents = <&clks IMX5_CLK_PLL2_SW>,
289 <&clks IMX5_CLK_SSI_EXT1_PODF>;
290 assigned-clock-rates = <0>, <24000000>;
291 clocks = <&clks IMX5_CLK_SSI_EXT1_GATE>;
292 clock-names = "xclk";
293 DVDD-supply = <&ldo9_reg>;
294 AVDD-supply = <&ldo7_reg>;
295 reset-gpios = <&gpio6 9 GPIO_ACTIVE_LOW>;
296 powerdown-gpios = <&gpio6 10 GPIO_ACTIVE_HIGH>;
297
298 port {
299 ov5642_to_ipu_csi0: endpoint {
300 remote-endpoint = <&ipu_csi0_from_parallel_sensor>;
301 bus-width = <8>;
302 hsync-active = <1>;
303 vsync-active = <1>;
304 };
305 };
306 };
307
308 pmic: dialog@48 {
309 compatible = "dlg,da9053", "dlg,da9052";
310 reg = <0x48>;
311 interrupt-parent = <&gpio7>;
312 interrupts = <11 IRQ_TYPE_LEVEL_LOW>;
313
314 regulators {
315 ldo7_reg: ldo7 {
316 regulator-min-microvolt = <1200000>;
317 regulator-max-microvolt = <3600000>;
318 };
319
320 ldo9_reg: ldo9 {
321 regulator-min-microvolt = <1250000>;
322 regulator-max-microvolt = <3650000>;
323 };
324 };
325 };
326};
327
328&fec {
329 pinctrl-names = "default";
330 pinctrl-0 = <&pinctrl_fec>;
331 phy-mode = "rmii";
332 phy-reset-gpios = <&gpio7 6 GPIO_ACTIVE_LOW>;
333 status = "okay";
334};
335
336&ipu_csi0_from_parallel_sensor {
337 remote-endpoint = <&ov5642_to_ipu_csi0>;
338 data-shift = <12>; /* Lines 19:12 used */
339 hsync-active = <1>;
340 vsync-active = <1>;
341};
342
343&ipu_csi0 {
344 pinctrl-names = "default";
345 pinctrl-0 = <&pinctrl_ipu_csi0>;
346};
1/*
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/;
14#include "imx53.dtsi"
15
16/ {
17 model = "Freescale i.MX53 Smart Mobile Reference Design Board";
18 compatible = "fsl,imx53-smd", "fsl,imx53";
19
20 memory {
21 reg = <0x70000000 0x40000000>;
22 };
23
24 gpio-keys {
25 compatible = "gpio-keys";
26
27 volume-up {
28 label = "Volume Up";
29 gpios = <&gpio2 14 0>;
30 linux,code = <115>; /* KEY_VOLUMEUP */
31 };
32
33 volume-down {
34 label = "Volume Down";
35 gpios = <&gpio2 15 0>;
36 linux,code = <114>; /* KEY_VOLUMEDOWN */
37 };
38 };
39};
40
41&esdhc1 {
42 pinctrl-names = "default";
43 pinctrl-0 = <&pinctrl_esdhc1>;
44 cd-gpios = <&gpio3 13 0>;
45 wp-gpios = <&gpio4 11 0>;
46 status = "okay";
47};
48
49&esdhc2 {
50 pinctrl-names = "default";
51 pinctrl-0 = <&pinctrl_esdhc2>;
52 non-removable;
53 status = "okay";
54};
55
56&uart3 {
57 pinctrl-names = "default";
58 pinctrl-0 = <&pinctrl_uart3>;
59 fsl,uart-has-rtscts;
60 status = "okay";
61};
62
63&ecspi1 {
64 pinctrl-names = "default";
65 pinctrl-0 = <&pinctrl_ecspi1>;
66 fsl,spi-num-chipselects = <2>;
67 cs-gpios = <&gpio2 30 0>, <&gpio3 19 0>;
68 status = "okay";
69
70 zigbee: mc1323@0 {
71 compatible = "fsl,mc1323";
72 spi-max-frequency = <8000000>;
73 reg = <0>;
74 };
75
76 flash: m25p32@1 {
77 #address-cells = <1>;
78 #size-cells = <1>;
79 compatible = "st,m25p32", "st,m25p";
80 spi-max-frequency = <20000000>;
81 reg = <1>;
82
83 partition@0 {
84 label = "U-Boot";
85 reg = <0x0 0x40000>;
86 read-only;
87 };
88
89 partition@40000 {
90 label = "Kernel";
91 reg = <0x40000 0x3c0000>;
92 };
93 };
94};
95
96&esdhc3 {
97 pinctrl-names = "default";
98 pinctrl-0 = <&pinctrl_esdhc3>;
99 non-removable;
100 status = "okay";
101};
102
103&iomuxc {
104 pinctrl-names = "default";
105 pinctrl-0 = <&pinctrl_hog>;
106
107 imx53-smd {
108 pinctrl_hog: hoggrp {
109 fsl,pins = <
110 MX53_PAD_PATA_DATA14__GPIO2_14 0x80000000
111 MX53_PAD_PATA_DATA15__GPIO2_15 0x80000000
112 MX53_PAD_EIM_EB2__GPIO2_30 0x80000000
113 MX53_PAD_EIM_DA13__GPIO3_13 0x80000000
114 MX53_PAD_EIM_D19__GPIO3_19 0x80000000
115 MX53_PAD_KEY_ROW2__GPIO4_11 0x80000000
116 MX53_PAD_PATA_DA_0__GPIO7_6 0x80000000
117 >;
118 };
119
120 pinctrl_ecspi1: ecspi1grp {
121 fsl,pins = <
122 MX53_PAD_EIM_D16__ECSPI1_SCLK 0x80000000
123 MX53_PAD_EIM_D17__ECSPI1_MISO 0x80000000
124 MX53_PAD_EIM_D18__ECSPI1_MOSI 0x80000000
125 >;
126 };
127
128 pinctrl_esdhc1: esdhc1grp {
129 fsl,pins = <
130 MX53_PAD_SD1_DATA0__ESDHC1_DAT0 0x1d5
131 MX53_PAD_SD1_DATA1__ESDHC1_DAT1 0x1d5
132 MX53_PAD_SD1_DATA2__ESDHC1_DAT2 0x1d5
133 MX53_PAD_SD1_DATA3__ESDHC1_DAT3 0x1d5
134 MX53_PAD_SD1_CMD__ESDHC1_CMD 0x1d5
135 MX53_PAD_SD1_CLK__ESDHC1_CLK 0x1d5
136 >;
137 };
138
139 pinctrl_esdhc2: esdhc2grp {
140 fsl,pins = <
141 MX53_PAD_SD2_CMD__ESDHC2_CMD 0x1d5
142 MX53_PAD_SD2_CLK__ESDHC2_CLK 0x1d5
143 MX53_PAD_SD2_DATA0__ESDHC2_DAT0 0x1d5
144 MX53_PAD_SD2_DATA1__ESDHC2_DAT1 0x1d5
145 MX53_PAD_SD2_DATA2__ESDHC2_DAT2 0x1d5
146 MX53_PAD_SD2_DATA3__ESDHC2_DAT3 0x1d5
147 >;
148 };
149
150 pinctrl_esdhc3: esdhc3grp {
151 fsl,pins = <
152 MX53_PAD_PATA_DATA8__ESDHC3_DAT0 0x1d5
153 MX53_PAD_PATA_DATA9__ESDHC3_DAT1 0x1d5
154 MX53_PAD_PATA_DATA10__ESDHC3_DAT2 0x1d5
155 MX53_PAD_PATA_DATA11__ESDHC3_DAT3 0x1d5
156 MX53_PAD_PATA_DATA0__ESDHC3_DAT4 0x1d5
157 MX53_PAD_PATA_DATA1__ESDHC3_DAT5 0x1d5
158 MX53_PAD_PATA_DATA2__ESDHC3_DAT6 0x1d5
159 MX53_PAD_PATA_DATA3__ESDHC3_DAT7 0x1d5
160 MX53_PAD_PATA_RESET_B__ESDHC3_CMD 0x1d5
161 MX53_PAD_PATA_IORDY__ESDHC3_CLK 0x1d5
162 >;
163 };
164
165 pinctrl_fec: fecgrp {
166 fsl,pins = <
167 MX53_PAD_FEC_MDC__FEC_MDC 0x80000000
168 MX53_PAD_FEC_MDIO__FEC_MDIO 0x80000000
169 MX53_PAD_FEC_REF_CLK__FEC_TX_CLK 0x80000000
170 MX53_PAD_FEC_RX_ER__FEC_RX_ER 0x80000000
171 MX53_PAD_FEC_CRS_DV__FEC_RX_DV 0x80000000
172 MX53_PAD_FEC_RXD1__FEC_RDATA_1 0x80000000
173 MX53_PAD_FEC_RXD0__FEC_RDATA_0 0x80000000
174 MX53_PAD_FEC_TX_EN__FEC_TX_EN 0x80000000
175 MX53_PAD_FEC_TXD1__FEC_TDATA_1 0x80000000
176 MX53_PAD_FEC_TXD0__FEC_TDATA_0 0x80000000
177 >;
178 };
179
180 pinctrl_i2c1: i2c1grp {
181 fsl,pins = <
182 MX53_PAD_CSI0_DAT8__I2C1_SDA 0xc0000000
183 MX53_PAD_CSI0_DAT9__I2C1_SCL 0xc0000000
184 >;
185 };
186
187 pinctrl_i2c2: i2c2grp {
188 fsl,pins = <
189 MX53_PAD_KEY_ROW3__I2C2_SDA 0xc0000000
190 MX53_PAD_KEY_COL3__I2C2_SCL 0xc0000000
191 >;
192 };
193
194 pinctrl_uart1: uart1grp {
195 fsl,pins = <
196 MX53_PAD_CSI0_DAT10__UART1_TXD_MUX 0x1e4
197 MX53_PAD_CSI0_DAT11__UART1_RXD_MUX 0x1e4
198 >;
199 };
200
201 pinctrl_uart2: uart2grp {
202 fsl,pins = <
203 MX53_PAD_PATA_BUFFER_EN__UART2_RXD_MUX 0x1e4
204 MX53_PAD_PATA_DMARQ__UART2_TXD_MUX 0x1e4
205 >;
206 };
207
208 pinctrl_uart3: uart3grp {
209 fsl,pins = <
210 MX53_PAD_PATA_CS_0__UART3_TXD_MUX 0x1e4
211 MX53_PAD_PATA_CS_1__UART3_RXD_MUX 0x1e4
212 MX53_PAD_PATA_DA_1__UART3_CTS 0x1e4
213 MX53_PAD_PATA_DA_2__UART3_RTS 0x1e4
214 >;
215 };
216 };
217};
218
219&uart1 {
220 pinctrl-names = "default";
221 pinctrl-0 = <&pinctrl_uart1>;
222 status = "okay";
223};
224
225&uart2 {
226 pinctrl-names = "default";
227 pinctrl-0 = <&pinctrl_uart2>;
228 status = "okay";
229};
230
231&i2c2 {
232 pinctrl-names = "default";
233 pinctrl-0 = <&pinctrl_i2c2>;
234 status = "okay";
235
236 codec: sgtl5000@0a {
237 compatible = "fsl,sgtl5000";
238 reg = <0x0a>;
239 };
240
241 magnetometer: mag3110@0e {
242 compatible = "fsl,mag3110";
243 reg = <0x0e>;
244 };
245
246 touchkey: mpr121@5a {
247 compatible = "fsl,mpr121";
248 reg = <0x5a>;
249 };
250};
251
252&i2c1 {
253 pinctrl-names = "default";
254 pinctrl-0 = <&pinctrl_i2c1>;
255 status = "okay";
256
257 accelerometer: mma8450@1c {
258 compatible = "fsl,mma8450";
259 reg = <0x1c>;
260 };
261
262 camera: ov5642@3c {
263 compatible = "ovti,ov5642";
264 reg = <0x3c>;
265 };
266
267 pmic: dialog@48 {
268 compatible = "dialog,da9053", "dialog,da9052";
269 reg = <0x48>;
270 };
271};
272
273&fec {
274 pinctrl-names = "default";
275 pinctrl-0 = <&pinctrl_fec>;
276 phy-mode = "rmii";
277 phy-reset-gpios = <&gpio7 6 0>;
278 status = "okay";
279};