Linux Audio

Check our new training course

Loading...
v4.17
 
  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 = <&reg_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};
v6.2
  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 = <&reg_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	spi-2 {
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	spi-3 {
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};