Loading...
1/*
2 * Copyright 2012 Free Electrons
3 *
4 * The code contained herein is licensed under the GNU General Public
5 * License. You may obtain a copy of the GNU General Public License
6 * Version 2 or later at the following locations:
7 *
8 * http://www.opensource.org/licenses/gpl-license.html
9 * http://www.gnu.org/copyleft/gpl.html
10 */
11
12/*
13 * The CFA-10049 is an expansion board for the CFA-10036 module, thus we
14 * need to include the CFA-10036 DTS.
15 */
16#include "imx28-cfa10036.dts"
17
18/ {
19 model = "Crystalfontz CFA-10049 Board";
20 compatible = "crystalfontz,cfa10049", "crystalfontz,cfa10036", "fsl,imx28";
21
22 i2cmux {
23 compatible = "i2c-mux-gpio";
24 #address-cells = <1>;
25 #size-cells = <0>;
26 pinctrl-names = "default";
27 pinctrl-0 = <&i2cmux_pins_cfa10049>;
28 mux-gpios = <&gpio1 22 0 &gpio1 23 0>;
29 i2c-parent = <&i2c1>;
30
31 i2c@0 {
32 #address-cells = <1>;
33 #size-cells = <0>;
34 reg = <0>;
35
36 adc0: nau7802@2a {
37 compatible = "nuvoton,nau7802";
38 reg = <0x2a>;
39 nuvoton,vldo = <3000>;
40 };
41 };
42
43 i2c@1 {
44 #address-cells = <1>;
45 #size-cells = <0>;
46 reg = <1>;
47
48 adc1: nau7802@2a {
49 compatible = "nuvoton,nau7802";
50 reg = <0x2a>;
51 nuvoton,vldo = <3000>;
52 };
53 };
54
55 i2c@2 {
56 #address-cells = <1>;
57 #size-cells = <0>;
58 reg = <2>;
59
60 adc2: nau7802@2a {
61 compatible = "nuvoton,nau7802";
62 reg = <0x2a>;
63 nuvoton,vldo = <3000>;
64 };
65 };
66
67 i2c@3 {
68 reg = <3>;
69 #address-cells = <1>;
70 #size-cells = <0>;
71
72 pca9555: pca9555@20 {
73 compatible = "nxp,pca9555";
74 pinctrl-names = "default";
75 pinctrl-0 = <&pca_pins_cfa10049>;
76 interrupt-parent = <&gpio2>;
77 interrupts = <19 0x2>;
78 gpio-controller;
79 #gpio-cells = <2>;
80 interrupt-controller;
81 #interrupt-cells = <2>;
82 reg = <0x20>;
83 };
84 };
85 };
86
87 apb@80000000 {
88 apbh@80000000 {
89 pinctrl@80018000 {
90 usb_pins_cfa10049: usb-10049@0 {
91 reg = <0>;
92 fsl,pinmux-ids = <
93 MX28_PAD_GPMI_D07__GPIO_0_7
94 >;
95 fsl,drive-strength = <MXS_DRIVE_4mA>;
96 fsl,voltage = <MXS_VOLTAGE_HIGH>;
97 fsl,pull-up = <MXS_PULL_DISABLE>;
98 };
99
100 i2cmux_pins_cfa10049: i2cmux-10049@0 {
101 reg = <0>;
102 fsl,pinmux-ids = <
103 MX28_PAD_LCD_D22__GPIO_1_22
104 MX28_PAD_LCD_D23__GPIO_1_23
105 >;
106 fsl,drive-strength = <MXS_DRIVE_4mA>;
107 fsl,voltage = <MXS_VOLTAGE_HIGH>;
108 fsl,pull-up = <MXS_PULL_DISABLE>;
109 };
110
111 mac0_pins_cfa10049: mac0-10049@0 {
112 reg = <0>;
113 fsl,pinmux-ids = <
114 MX28_PAD_SSP2_SS2__GPIO_2_21
115 >;
116 fsl,drive-strength = <MXS_DRIVE_4mA>;
117 fsl,voltage = <MXS_VOLTAGE_HIGH>;
118 fsl,pull-up = <MXS_PULL_DISABLE>;
119 };
120
121 pca_pins_cfa10049: pca-10049@0 {
122 reg = <0>;
123 fsl,pinmux-ids = <
124 MX28_PAD_SSP2_SS0__GPIO_2_19
125 >;
126 fsl,drive-strength = <MXS_DRIVE_4mA>;
127 fsl,voltage = <MXS_VOLTAGE_HIGH>;
128 fsl,pull-up = <MXS_PULL_ENABLE>;
129 };
130
131 rotary_pins_cfa10049: rotary-10049@0 {
132 reg = <0>;
133 fsl,pinmux-ids = <
134 MX28_PAD_I2C0_SCL__GPIO_3_24
135 MX28_PAD_I2C0_SDA__GPIO_3_25
136 >;
137 fsl,drive-strength = <MXS_DRIVE_4mA>;
138 fsl,voltage = <MXS_VOLTAGE_HIGH>;
139 fsl,pull-up = <MXS_PULL_ENABLE>;
140 };
141
142 rotary_btn_pins_cfa10049: rotary-btn-10049@0 {
143 reg = <0>;
144 fsl,pinmux-ids = <
145 MX28_PAD_SAIF1_SDATA0__GPIO_3_26
146 >;
147 fsl,drive-strength = <MXS_DRIVE_4mA>;
148 fsl,voltage = <MXS_VOLTAGE_HIGH>;
149 fsl,pull-up = <MXS_PULL_ENABLE>;
150 };
151
152 spi2_pins_cfa10049: spi2-cfa10049@0 {
153 reg = <0>;
154 fsl,pinmux-ids = <
155 MX28_PAD_SSP2_SCK__GPIO_2_16
156 MX28_PAD_SSP2_MOSI__GPIO_2_17
157 MX28_PAD_SSP2_MISO__GPIO_2_18
158 MX28_PAD_AUART1_TX__GPIO_3_5
159 >;
160 fsl,drive-strength = <MXS_DRIVE_8mA>;
161 fsl,voltage = <MXS_VOLTAGE_HIGH>;
162 fsl,pull-up = <MXS_PULL_ENABLE>;
163 };
164
165 spi3_pins_cfa10049: spi3-cfa10049@0 {
166 reg = <0>;
167 fsl,pinmux-ids = <
168 MX28_PAD_GPMI_RDN__GPIO_0_24
169 MX28_PAD_GPMI_RESETN__GPIO_0_28
170 MX28_PAD_GPMI_CE1N__GPIO_0_17
171 MX28_PAD_GPMI_ALE__GPIO_0_26
172 MX28_PAD_GPMI_CLE__GPIO_0_27
173 >;
174 fsl,drive-strength = <MXS_DRIVE_8mA>;
175 fsl,voltage = <MXS_VOLTAGE_HIGH>;
176 fsl,pull-up = <MXS_PULL_ENABLE>;
177 };
178
179 lcdif_18bit_pins_cfa10049: lcdif-18bit@0 {
180 reg = <0>;
181 fsl,pinmux-ids = <
182 MX28_PAD_LCD_D00__LCD_D0
183 MX28_PAD_LCD_D01__LCD_D1
184 MX28_PAD_LCD_D02__LCD_D2
185 MX28_PAD_LCD_D03__LCD_D3
186 MX28_PAD_LCD_D04__LCD_D4
187 MX28_PAD_LCD_D05__LCD_D5
188 MX28_PAD_LCD_D06__LCD_D6
189 MX28_PAD_LCD_D07__LCD_D7
190 MX28_PAD_LCD_D08__LCD_D8
191 MX28_PAD_LCD_D09__LCD_D9
192 MX28_PAD_LCD_D10__LCD_D10
193 MX28_PAD_LCD_D11__LCD_D11
194 MX28_PAD_LCD_D12__LCD_D12
195 MX28_PAD_LCD_D13__LCD_D13
196 MX28_PAD_LCD_D14__LCD_D14
197 MX28_PAD_LCD_D15__LCD_D15
198 MX28_PAD_LCD_D16__LCD_D16
199 MX28_PAD_LCD_D17__LCD_D17
200 >;
201 fsl,drive-strength = <MXS_DRIVE_4mA>;
202 fsl,voltage = <MXS_VOLTAGE_HIGH>;
203 fsl,pull-up = <MXS_PULL_DISABLE>;
204 };
205
206 lcdif_pins_cfa10049: lcdif-evk@0 {
207 reg = <0>;
208 fsl,pinmux-ids = <
209 MX28_PAD_LCD_RD_E__LCD_VSYNC
210 MX28_PAD_LCD_WR_RWN__LCD_HSYNC
211 MX28_PAD_LCD_RS__LCD_DOTCLK
212 MX28_PAD_LCD_CS__LCD_ENABLE
213 >;
214 fsl,drive-strength = <MXS_DRIVE_4mA>;
215 fsl,voltage = <MXS_VOLTAGE_HIGH>;
216 fsl,pull-up = <MXS_PULL_DISABLE>;
217 };
218
219 lcdif_pins_cfa10049_pullup: lcdif-10049-pullup@0 {
220 reg = <0>;
221 fsl,pinmux-ids = <
222 MX28_PAD_LCD_RESET__GPIO_3_30
223 >;
224 fsl,drive-strength = <MXS_DRIVE_4mA>;
225 fsl,voltage = <MXS_VOLTAGE_HIGH>;
226 fsl,pull-up = <MXS_PULL_ENABLE>;
227 };
228
229 w1_gpio_pins: w1-gpio@0 {
230 reg = <0>;
231 fsl,pinmux-ids = <
232 MX28_PAD_LCD_D21__GPIO_1_21
233 >;
234 fsl,drive-strength = <MXS_DRIVE_8mA>;
235 fsl,voltage = <MXS_VOLTAGE_HIGH>;
236 fsl,pull-up = <MXS_PULL_DISABLE>; /* 0 will enable the keeper */
237 };
238 };
239
240 lcdif@80030000 {
241 pinctrl-names = "default";
242 pinctrl-0 = <&lcdif_18bit_pins_cfa10049
243 &lcdif_pins_cfa10049
244 &lcdif_pins_cfa10049_pullup>;
245 display = <&display0>;
246 status = "okay";
247
248 display0: display0 {
249 bits-per-pixel = <32>;
250 bus-width = <18>;
251
252 display-timings {
253 native-mode = <&timing0>;
254 timing0: timing0 {
255 clock-frequency = <9216000>;
256 hactive = <320>;
257 vactive = <480>;
258 hback-porch = <2>;
259 hfront-porch = <2>;
260 vback-porch = <2>;
261 vfront-porch = <2>;
262 hsync-len = <15>;
263 vsync-len = <15>;
264 hsync-active = <0>;
265 vsync-active = <0>;
266 de-active = <1>;
267 pixelclk-active = <1>;
268 };
269 };
270 };
271 };
272 };
273
274 apbx@80040000 {
275 pwm: pwm@80064000 {
276 pinctrl-names = "default";
277 pinctrl-0 = <&pwm3_pins_b>;
278 status = "okay";
279 };
280
281 i2c1: i2c@8005a000 {
282 pinctrl-names = "default";
283 pinctrl-0 = <&i2c1_pins_a>;
284 status = "okay";
285 };
286
287 usbphy1: usbphy@8007e000 {
288 status = "okay";
289 };
290
291 lradc@80050000 {
292 status = "okay";
293 fsl,lradc-touchscreen-wires = <4>;
294 };
295 };
296 };
297
298 ahb@80080000 {
299 usb1: usb@80090000 {
300 vbus-supply = <®_usb1_vbus>;
301 pinctrl-0 = <&usb1_pins_a>;
302 pinctrl-names = "default";
303 status = "okay";
304 };
305 };
306
307 regulators {
308 compatible = "simple-bus";
309 #address-cells = <1>;
310 #size-cells = <0>;
311
312 reg_usb1_vbus: regulator@0 {
313 compatible = "regulator-fixed";
314 reg = <0>;
315 pinctrl-names = "default";
316 pinctrl-0 = <&usb_pins_cfa10049>;
317 regulator-name = "usb1_vbus";
318 regulator-min-microvolt = <5000000>;
319 regulator-max-microvolt = <5000000>;
320 gpio = <&gpio0 7 1>;
321 };
322 };
323
324 ahb@80080000 {
325 mac0: ethernet@800f0000 {
326 phy-mode = "rmii";
327 pinctrl-names = "default";
328 pinctrl-0 = <&mac0_pins_a
329 &mac0_pins_cfa10049>;
330 phy-reset-gpios = <&gpio2 21 GPIO_ACTIVE_LOW>;
331 phy-reset-duration = <100>;
332 status = "okay";
333 };
334 };
335
336 spi2 {
337 compatible = "spi-gpio";
338 pinctrl-names = "default";
339 pinctrl-0 = <&spi2_pins_cfa10049>;
340 status = "okay";
341 gpio-sck = <&gpio2 16 0>;
342 gpio-mosi = <&gpio2 17 0>;
343 gpio-miso = <&gpio2 18 0>;
344 cs-gpios = <&gpio3 5 0>;
345 num-chipselects = <1>;
346 #address-cells = <1>;
347 #size-cells = <0>;
348
349 hx8357: hx8357@0 {
350 compatible = "himax,hx8357b", "himax,hx8357";
351 reg = <0>;
352 spi-max-frequency = <100000>;
353 spi-cpol;
354 spi-cpha;
355 gpios-reset = <&gpio3 30 0>;
356 im-gpios = <&gpio5 4 0 &gpio5 5 0 &gpio5 6 0>;
357 };
358 };
359
360 spi3 {
361 compatible = "spi-gpio";
362 pinctrl-names = "default";
363 pinctrl-0 = <&spi3_pins_cfa10049>;
364 status = "okay";
365 gpio-sck = <&gpio0 24 0>;
366 gpio-mosi = <&gpio0 28 0>;
367 cs-gpios = <&gpio0 17 0 &gpio0 26 0 &gpio0 27 0>;
368 num-chipselects = <3>;
369 #address-cells = <1>;
370 #size-cells = <0>;
371
372 gpio5: gpio5@0 {
373 compatible = "fairchild,74hc595";
374 gpio-controller;
375 #gpio-cells = <2>;
376 reg = <0>;
377 registers-number = <2>;
378 spi-max-frequency = <100000>;
379 };
380
381 gpio6: gpio6@1 {
382 compatible = "fairchild,74hc595";
383 gpio-controller;
384 #gpio-cells = <2>;
385 reg = <1>;
386 registers-number = <4>;
387 spi-max-frequency = <100000>;
388 };
389
390 dac0: dh2228@2 {
391 compatible = "rohm,dh2228fv";
392 reg = <2>;
393 spi-max-frequency = <100000>;
394 };
395 };
396
397 gpio_keys {
398 compatible = "gpio-keys";
399 pinctrl-names = "default";
400 pinctrl-0 = <&rotary_btn_pins_cfa10049>;
401 #address-cells = <1>;
402 #size-cells = <0>;
403
404 rotary_button {
405 label = "rotary_button";
406 gpios = <&gpio3 26 1>;
407 debounce-interval = <10>;
408 linux,code = <28>;
409 };
410 };
411
412 rotary {
413 compatible = "rotary-encoder";
414 pinctrl-names = "default";
415 pinctrl-0 = <&rotary_pins_cfa10049>;
416 gpios = <&gpio3 24 1>, <&gpio3 25 1>;
417 linux,axis = <1>; /* REL_Y */
418 rotary-encoder,relative-axis;
419 };
420
421 backlight {
422 compatible = "pwm-backlight";
423 pwms = <&pwm 3 5000000>;
424 brightness-levels = <0 4 8 16 32 64 128 255>;
425 default-brightness-level = <6>;
426
427 };
428
429 onewire {
430 compatible = "w1-gpio";
431 pinctrl-names = "default";
432 pinctrl-0 = <&w1_gpio_pins>;
433 status = "okay";
434 gpios = <&gpio1 21 0>;
435 };
436};
1// SPDX-License-Identifier: GPL-2.0-or-later
2/*
3 * Copyright 2012 Free Electrons
4 */
5
6/*
7 * The CFA-10049 is an expansion board for the CFA-10036 module, thus we
8 * need to include the CFA-10036 DTS.
9 */
10#include "imx28-cfa10036.dts"
11
12/ {
13 model = "Crystalfontz CFA-10049 Board";
14 compatible = "crystalfontz,cfa10049", "crystalfontz,cfa10036", "fsl,imx28";
15
16 i2cmux {
17 compatible = "i2c-mux-gpio";
18 #address-cells = <1>;
19 #size-cells = <0>;
20 pinctrl-names = "default";
21 pinctrl-0 = <&i2cmux_pins_cfa10049>;
22 mux-gpios = <&gpio1 22 0 &gpio1 23 0>;
23 i2c-parent = <&i2c1>;
24
25 i2c@0 {
26 #address-cells = <1>;
27 #size-cells = <0>;
28 reg = <0>;
29
30 adc0: nau7802@2a {
31 compatible = "nuvoton,nau7802";
32 reg = <0x2a>;
33 nuvoton,vldo = <3000>;
34 };
35 };
36
37 i2c@1 {
38 #address-cells = <1>;
39 #size-cells = <0>;
40 reg = <1>;
41
42 adc1: nau7802@2a {
43 compatible = "nuvoton,nau7802";
44 reg = <0x2a>;
45 nuvoton,vldo = <3000>;
46 };
47 };
48
49 i2c@2 {
50 #address-cells = <1>;
51 #size-cells = <0>;
52 reg = <2>;
53
54 adc2: nau7802@2a {
55 compatible = "nuvoton,nau7802";
56 reg = <0x2a>;
57 nuvoton,vldo = <3000>;
58 };
59 };
60
61 i2c@3 {
62 reg = <3>;
63 #address-cells = <1>;
64 #size-cells = <0>;
65
66 pca9555: pca9555@20 {
67 compatible = "nxp,pca9555";
68 pinctrl-names = "default";
69 pinctrl-0 = <&pca_pins_cfa10049>;
70 interrupt-parent = <&gpio2>;
71 interrupts = <19 0x2>;
72 gpio-controller;
73 #gpio-cells = <2>;
74 interrupt-controller;
75 #interrupt-cells = <2>;
76 reg = <0x20>;
77 };
78 };
79 };
80
81 apb@80000000 {
82 apbh@80000000 {
83 pinctrl@80018000 {
84 usb_pins_cfa10049: usb-10049@0 {
85 reg = <0>;
86 fsl,pinmux-ids = <
87 MX28_PAD_GPMI_D07__GPIO_0_7
88 >;
89 fsl,drive-strength = <MXS_DRIVE_4mA>;
90 fsl,voltage = <MXS_VOLTAGE_HIGH>;
91 fsl,pull-up = <MXS_PULL_DISABLE>;
92 };
93
94 i2cmux_pins_cfa10049: i2cmux-10049@0 {
95 reg = <0>;
96 fsl,pinmux-ids = <
97 MX28_PAD_LCD_D22__GPIO_1_22
98 MX28_PAD_LCD_D23__GPIO_1_23
99 >;
100 fsl,drive-strength = <MXS_DRIVE_4mA>;
101 fsl,voltage = <MXS_VOLTAGE_HIGH>;
102 fsl,pull-up = <MXS_PULL_DISABLE>;
103 };
104
105 mac0_pins_cfa10049: mac0-10049@0 {
106 reg = <0>;
107 fsl,pinmux-ids = <
108 MX28_PAD_SSP2_SS2__GPIO_2_21
109 >;
110 fsl,drive-strength = <MXS_DRIVE_4mA>;
111 fsl,voltage = <MXS_VOLTAGE_HIGH>;
112 fsl,pull-up = <MXS_PULL_DISABLE>;
113 };
114
115 pca_pins_cfa10049: pca-10049@0 {
116 reg = <0>;
117 fsl,pinmux-ids = <
118 MX28_PAD_SSP2_SS0__GPIO_2_19
119 >;
120 fsl,drive-strength = <MXS_DRIVE_4mA>;
121 fsl,voltage = <MXS_VOLTAGE_HIGH>;
122 fsl,pull-up = <MXS_PULL_ENABLE>;
123 };
124
125 rotary_pins_cfa10049: rotary-10049@0 {
126 reg = <0>;
127 fsl,pinmux-ids = <
128 MX28_PAD_I2C0_SCL__GPIO_3_24
129 MX28_PAD_I2C0_SDA__GPIO_3_25
130 >;
131 fsl,drive-strength = <MXS_DRIVE_4mA>;
132 fsl,voltage = <MXS_VOLTAGE_HIGH>;
133 fsl,pull-up = <MXS_PULL_ENABLE>;
134 };
135
136 rotary_btn_pins_cfa10049: rotary-btn-10049@0 {
137 reg = <0>;
138 fsl,pinmux-ids = <
139 MX28_PAD_SAIF1_SDATA0__GPIO_3_26
140 >;
141 fsl,drive-strength = <MXS_DRIVE_4mA>;
142 fsl,voltage = <MXS_VOLTAGE_HIGH>;
143 fsl,pull-up = <MXS_PULL_ENABLE>;
144 };
145
146 spi2_pins_cfa10049: spi2-cfa10049@0 {
147 reg = <0>;
148 fsl,pinmux-ids = <
149 MX28_PAD_SSP2_SCK__GPIO_2_16
150 MX28_PAD_SSP2_MOSI__GPIO_2_17
151 MX28_PAD_SSP2_MISO__GPIO_2_18
152 MX28_PAD_AUART1_TX__GPIO_3_5
153 >;
154 fsl,drive-strength = <MXS_DRIVE_8mA>;
155 fsl,voltage = <MXS_VOLTAGE_HIGH>;
156 fsl,pull-up = <MXS_PULL_ENABLE>;
157 };
158
159 spi3_pins_cfa10049: spi3-cfa10049@0 {
160 reg = <0>;
161 fsl,pinmux-ids = <
162 MX28_PAD_GPMI_RDN__GPIO_0_24
163 MX28_PAD_GPMI_RESETN__GPIO_0_28
164 MX28_PAD_GPMI_CE1N__GPIO_0_17
165 MX28_PAD_GPMI_ALE__GPIO_0_26
166 MX28_PAD_GPMI_CLE__GPIO_0_27
167 >;
168 fsl,drive-strength = <MXS_DRIVE_8mA>;
169 fsl,voltage = <MXS_VOLTAGE_HIGH>;
170 fsl,pull-up = <MXS_PULL_ENABLE>;
171 };
172
173 lcdif_18bit_pins_cfa10049: lcdif-18bit@0 {
174 reg = <0>;
175 fsl,pinmux-ids = <
176 MX28_PAD_LCD_D00__LCD_D0
177 MX28_PAD_LCD_D01__LCD_D1
178 MX28_PAD_LCD_D02__LCD_D2
179 MX28_PAD_LCD_D03__LCD_D3
180 MX28_PAD_LCD_D04__LCD_D4
181 MX28_PAD_LCD_D05__LCD_D5
182 MX28_PAD_LCD_D06__LCD_D6
183 MX28_PAD_LCD_D07__LCD_D7
184 MX28_PAD_LCD_D08__LCD_D8
185 MX28_PAD_LCD_D09__LCD_D9
186 MX28_PAD_LCD_D10__LCD_D10
187 MX28_PAD_LCD_D11__LCD_D11
188 MX28_PAD_LCD_D12__LCD_D12
189 MX28_PAD_LCD_D13__LCD_D13
190 MX28_PAD_LCD_D14__LCD_D14
191 MX28_PAD_LCD_D15__LCD_D15
192 MX28_PAD_LCD_D16__LCD_D16
193 MX28_PAD_LCD_D17__LCD_D17
194 >;
195 fsl,drive-strength = <MXS_DRIVE_4mA>;
196 fsl,voltage = <MXS_VOLTAGE_HIGH>;
197 fsl,pull-up = <MXS_PULL_DISABLE>;
198 };
199
200 lcdif_pins_cfa10049: lcdif-evk@0 {
201 reg = <0>;
202 fsl,pinmux-ids = <
203 MX28_PAD_LCD_RD_E__LCD_VSYNC
204 MX28_PAD_LCD_WR_RWN__LCD_HSYNC
205 MX28_PAD_LCD_RS__LCD_DOTCLK
206 MX28_PAD_LCD_CS__LCD_ENABLE
207 >;
208 fsl,drive-strength = <MXS_DRIVE_4mA>;
209 fsl,voltage = <MXS_VOLTAGE_HIGH>;
210 fsl,pull-up = <MXS_PULL_DISABLE>;
211 };
212
213 lcdif_pins_cfa10049_pullup: lcdif-10049-pullup@0 {
214 reg = <0>;
215 fsl,pinmux-ids = <
216 MX28_PAD_LCD_RESET__GPIO_3_30
217 >;
218 fsl,drive-strength = <MXS_DRIVE_4mA>;
219 fsl,voltage = <MXS_VOLTAGE_HIGH>;
220 fsl,pull-up = <MXS_PULL_ENABLE>;
221 };
222
223 w1_gpio_pins: w1-gpio@0 {
224 reg = <0>;
225 fsl,pinmux-ids = <
226 MX28_PAD_LCD_D21__GPIO_1_21
227 >;
228 fsl,drive-strength = <MXS_DRIVE_8mA>;
229 fsl,voltage = <MXS_VOLTAGE_HIGH>;
230 fsl,pull-up = <MXS_PULL_DISABLE>; /* 0 will enable the keeper */
231 };
232 };
233
234 lcdif@80030000 {
235 pinctrl-names = "default";
236 pinctrl-0 = <&lcdif_18bit_pins_cfa10049
237 &lcdif_pins_cfa10049
238 &lcdif_pins_cfa10049_pullup>;
239 display = <&display0>;
240 status = "okay";
241
242 display0: display0 {
243 bits-per-pixel = <32>;
244 bus-width = <18>;
245
246 display-timings {
247 native-mode = <&timing0>;
248 timing0: timing0 {
249 clock-frequency = <9216000>;
250 hactive = <320>;
251 vactive = <480>;
252 hback-porch = <2>;
253 hfront-porch = <2>;
254 vback-porch = <2>;
255 vfront-porch = <2>;
256 hsync-len = <15>;
257 vsync-len = <15>;
258 hsync-active = <0>;
259 vsync-active = <0>;
260 de-active = <1>;
261 pixelclk-active = <1>;
262 };
263 };
264 };
265 };
266 };
267
268 apbx@80040000 {
269 pwm: pwm@80064000 {
270 pinctrl-names = "default";
271 pinctrl-0 = <&pwm3_pins_b>;
272 status = "okay";
273 };
274
275 i2c1: i2c@8005a000 {
276 pinctrl-names = "default";
277 pinctrl-0 = <&i2c1_pins_a>;
278 status = "okay";
279 };
280
281 usbphy1: usbphy@8007e000 {
282 status = "okay";
283 };
284
285 lradc@80050000 {
286 status = "okay";
287 fsl,lradc-touchscreen-wires = <4>;
288 };
289 };
290 };
291
292 ahb@80080000 {
293 usb1: usb@80090000 {
294 vbus-supply = <®_usb1_vbus>;
295 pinctrl-0 = <&usb1_pins_a>;
296 pinctrl-names = "default";
297 status = "okay";
298 };
299 };
300
301 regulators {
302 compatible = "simple-bus";
303 #address-cells = <1>;
304 #size-cells = <0>;
305
306 reg_usb1_vbus: regulator@0 {
307 compatible = "regulator-fixed";
308 reg = <0>;
309 pinctrl-names = "default";
310 pinctrl-0 = <&usb_pins_cfa10049>;
311 regulator-name = "usb1_vbus";
312 regulator-min-microvolt = <5000000>;
313 regulator-max-microvolt = <5000000>;
314 gpio = <&gpio0 7 1>;
315 };
316 };
317
318 ahb@80080000 {
319 mac0: ethernet@800f0000 {
320 phy-mode = "rmii";
321 pinctrl-names = "default";
322 pinctrl-0 = <&mac0_pins_a
323 &mac0_pins_cfa10049>;
324 phy-reset-gpios = <&gpio2 21 GPIO_ACTIVE_LOW>;
325 phy-reset-duration = <100>;
326 status = "okay";
327 };
328 };
329
330 spi2 {
331 compatible = "spi-gpio";
332 pinctrl-names = "default";
333 pinctrl-0 = <&spi2_pins_cfa10049>;
334 status = "okay";
335 gpio-sck = <&gpio2 16 0>;
336 gpio-mosi = <&gpio2 17 0>;
337 gpio-miso = <&gpio2 18 0>;
338 cs-gpios = <&gpio3 5 0>;
339 num-chipselects = <1>;
340 #address-cells = <1>;
341 #size-cells = <0>;
342
343 hx8357: hx8357@0 {
344 compatible = "himax,hx8357b", "himax,hx8357";
345 reg = <0>;
346 spi-max-frequency = <100000>;
347 spi-cpol;
348 spi-cpha;
349 gpios-reset = <&gpio3 30 0>;
350 im-gpios = <&gpio5 4 0 &gpio5 5 0 &gpio5 6 0>;
351 };
352 };
353
354 spi3 {
355 compatible = "spi-gpio";
356 pinctrl-names = "default";
357 pinctrl-0 = <&spi3_pins_cfa10049>;
358 status = "okay";
359 gpio-sck = <&gpio0 24 0>;
360 gpio-mosi = <&gpio0 28 0>;
361 cs-gpios = <&gpio0 17 0 &gpio0 26 0 &gpio0 27 0>;
362 num-chipselects = <3>;
363 #address-cells = <1>;
364 #size-cells = <0>;
365
366 gpio5: gpio5@0 {
367 compatible = "fairchild,74hc595";
368 gpio-controller;
369 #gpio-cells = <2>;
370 reg = <0>;
371 registers-number = <2>;
372 spi-max-frequency = <100000>;
373 };
374
375 gpio6: gpio6@1 {
376 compatible = "fairchild,74hc595";
377 gpio-controller;
378 #gpio-cells = <2>;
379 reg = <1>;
380 registers-number = <4>;
381 spi-max-frequency = <100000>;
382 };
383
384 dac0: dh2228@2 {
385 compatible = "rohm,dh2228fv";
386 reg = <2>;
387 spi-max-frequency = <100000>;
388 };
389 };
390
391 gpio_keys {
392 compatible = "gpio-keys";
393 pinctrl-names = "default";
394 pinctrl-0 = <&rotary_btn_pins_cfa10049>;
395
396 rotary_button {
397 label = "rotary_button";
398 gpios = <&gpio3 26 1>;
399 debounce-interval = <10>;
400 linux,code = <28>;
401 };
402 };
403
404 rotary {
405 compatible = "rotary-encoder";
406 pinctrl-names = "default";
407 pinctrl-0 = <&rotary_pins_cfa10049>;
408 gpios = <&gpio3 24 1>, <&gpio3 25 1>;
409 linux,axis = <1>; /* REL_Y */
410 rotary-encoder,relative-axis;
411 };
412
413 backlight {
414 compatible = "pwm-backlight";
415 pwms = <&pwm 3 5000000>;
416 brightness-levels = <0 4 8 16 32 64 128 255>;
417 default-brightness-level = <6>;
418
419 };
420
421 onewire {
422 compatible = "w1-gpio";
423 pinctrl-names = "default";
424 pinctrl-0 = <&w1_gpio_pins>;
425 status = "okay";
426 gpios = <&gpio1 21 0>;
427 };
428};