xref: /OK3568_Linux_fs/kernel/arch/arm/boot/dts/imx6qdl-apalis.dtsi (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun// SPDX-License-Identifier: GPL-2.0+ OR MIT
2*4882a593Smuzhiyun/*
3*4882a593Smuzhiyun * Copyright 2014-2020 Toradex
4*4882a593Smuzhiyun * Copyright 2012 Freescale Semiconductor, Inc.
5*4882a593Smuzhiyun * Copyright 2011 Linaro Ltd.
6*4882a593Smuzhiyun */
7*4882a593Smuzhiyun
8*4882a593Smuzhiyun#include <dt-bindings/gpio/gpio.h>
9*4882a593Smuzhiyun
10*4882a593Smuzhiyun/ {
11*4882a593Smuzhiyun	model = "Toradex Apalis iMX6Q/D Module";
12*4882a593Smuzhiyun	compatible = "toradex,apalis_imx6q", "fsl,imx6q";
13*4882a593Smuzhiyun
14*4882a593Smuzhiyun	/* Will be filled by the bootloader */
15*4882a593Smuzhiyun	memory@10000000 {
16*4882a593Smuzhiyun		device_type = "memory";
17*4882a593Smuzhiyun		reg = <0x10000000 0>;
18*4882a593Smuzhiyun	};
19*4882a593Smuzhiyun
20*4882a593Smuzhiyun	backlight: backlight {
21*4882a593Smuzhiyun		compatible = "pwm-backlight";
22*4882a593Smuzhiyun		pinctrl-names = "default";
23*4882a593Smuzhiyun		pinctrl-0 = <&pinctrl_gpio_bl_on>;
24*4882a593Smuzhiyun		pwms = <&pwm4 0 5000000>;
25*4882a593Smuzhiyun		enable-gpios = <&gpio3 13 GPIO_ACTIVE_HIGH>;
26*4882a593Smuzhiyun		status = "disabled";
27*4882a593Smuzhiyun	};
28*4882a593Smuzhiyun
29*4882a593Smuzhiyun	reg_module_3v3: regulator-module-3v3 {
30*4882a593Smuzhiyun		compatible = "regulator-fixed";
31*4882a593Smuzhiyun		regulator-name = "+V3.3";
32*4882a593Smuzhiyun		regulator-min-microvolt = <3300000>;
33*4882a593Smuzhiyun		regulator-max-microvolt = <3300000>;
34*4882a593Smuzhiyun		regulator-always-on;
35*4882a593Smuzhiyun	};
36*4882a593Smuzhiyun
37*4882a593Smuzhiyun	reg_module_3v3_audio: regulator-module-3v3-audio {
38*4882a593Smuzhiyun		compatible = "regulator-fixed";
39*4882a593Smuzhiyun		regulator-name = "+V3.3_AUDIO";
40*4882a593Smuzhiyun		regulator-min-microvolt = <3300000>;
41*4882a593Smuzhiyun		regulator-max-microvolt = <3300000>;
42*4882a593Smuzhiyun		regulator-always-on;
43*4882a593Smuzhiyun	};
44*4882a593Smuzhiyun
45*4882a593Smuzhiyun	reg_usb_otg_vbus: regulator-usb-otg-vbus {
46*4882a593Smuzhiyun		compatible = "regulator-fixed";
47*4882a593Smuzhiyun		pinctrl-names = "default";
48*4882a593Smuzhiyun		pinctrl-0 = <&pinctrl_regulator_usbotg_pwr>;
49*4882a593Smuzhiyun		regulator-name = "usb_otg_vbus";
50*4882a593Smuzhiyun		regulator-min-microvolt = <5000000>;
51*4882a593Smuzhiyun		regulator-max-microvolt = <5000000>;
52*4882a593Smuzhiyun		gpio = <&gpio3 22 GPIO_ACTIVE_HIGH>;
53*4882a593Smuzhiyun		enable-active-high;
54*4882a593Smuzhiyun		status = "disabled";
55*4882a593Smuzhiyun	};
56*4882a593Smuzhiyun
57*4882a593Smuzhiyun	/* on module USB hub */
58*4882a593Smuzhiyun	reg_usb_host_vbus_hub: regulator-usb-host-vbus-hub {
59*4882a593Smuzhiyun		compatible = "regulator-fixed";
60*4882a593Smuzhiyun		pinctrl-names = "default";
61*4882a593Smuzhiyun		pinctrl-0 = <&pinctrl_regulator_usbhub_pwr>;
62*4882a593Smuzhiyun		regulator-name = "usb_host_vbus_hub";
63*4882a593Smuzhiyun		regulator-min-microvolt = <5000000>;
64*4882a593Smuzhiyun		regulator-max-microvolt = <5000000>;
65*4882a593Smuzhiyun		gpio = <&gpio3 28 GPIO_ACTIVE_HIGH>;
66*4882a593Smuzhiyun		startup-delay-us = <2000>;
67*4882a593Smuzhiyun		enable-active-high;
68*4882a593Smuzhiyun		status = "okay";
69*4882a593Smuzhiyun	};
70*4882a593Smuzhiyun
71*4882a593Smuzhiyun	reg_usb_host_vbus: regulator-usb-host-vbus {
72*4882a593Smuzhiyun		compatible = "regulator-fixed";
73*4882a593Smuzhiyun		pinctrl-names = "default";
74*4882a593Smuzhiyun		pinctrl-0 = <&pinctrl_regulator_usbh_pwr>;
75*4882a593Smuzhiyun		regulator-name = "usb_host_vbus";
76*4882a593Smuzhiyun		regulator-min-microvolt = <5000000>;
77*4882a593Smuzhiyun		regulator-max-microvolt = <5000000>;
78*4882a593Smuzhiyun		gpio =  <&gpio1 0 GPIO_ACTIVE_HIGH>;
79*4882a593Smuzhiyun		enable-active-high;
80*4882a593Smuzhiyun		vin-supply = <&reg_usb_host_vbus_hub>;
81*4882a593Smuzhiyun		status = "disabled";
82*4882a593Smuzhiyun	};
83*4882a593Smuzhiyun
84*4882a593Smuzhiyun	sound {
85*4882a593Smuzhiyun		compatible = "fsl,imx-audio-sgtl5000";
86*4882a593Smuzhiyun		model = "imx6q-apalis-sgtl5000";
87*4882a593Smuzhiyun		ssi-controller = <&ssi1>;
88*4882a593Smuzhiyun		audio-codec = <&codec>;
89*4882a593Smuzhiyun		audio-routing =
90*4882a593Smuzhiyun			"LINE_IN", "Line In Jack",
91*4882a593Smuzhiyun			"MIC_IN", "Mic Jack",
92*4882a593Smuzhiyun			"Mic Jack", "Mic Bias",
93*4882a593Smuzhiyun			"Headphone Jack", "HP_OUT";
94*4882a593Smuzhiyun		mux-int-port = <1>;
95*4882a593Smuzhiyun		mux-ext-port = <4>;
96*4882a593Smuzhiyun	};
97*4882a593Smuzhiyun
98*4882a593Smuzhiyun	sound_spdif: sound-spdif {
99*4882a593Smuzhiyun		compatible = "fsl,imx-audio-spdif";
100*4882a593Smuzhiyun		model = "imx-spdif";
101*4882a593Smuzhiyun		spdif-controller = <&spdif>;
102*4882a593Smuzhiyun		spdif-in;
103*4882a593Smuzhiyun		spdif-out;
104*4882a593Smuzhiyun		status = "disabled";
105*4882a593Smuzhiyun	};
106*4882a593Smuzhiyun};
107*4882a593Smuzhiyun
108*4882a593Smuzhiyun&audmux {
109*4882a593Smuzhiyun	pinctrl-names = "default";
110*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_audmux>;
111*4882a593Smuzhiyun	status = "okay";
112*4882a593Smuzhiyun};
113*4882a593Smuzhiyun
114*4882a593Smuzhiyun&can1 {
115*4882a593Smuzhiyun	pinctrl-names = "default", "sleep";
116*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_flexcan1_default>;
117*4882a593Smuzhiyun	pinctrl-1 = <&pinctrl_flexcan1_sleep>;
118*4882a593Smuzhiyun	status = "disabled";
119*4882a593Smuzhiyun};
120*4882a593Smuzhiyun
121*4882a593Smuzhiyun&can2 {
122*4882a593Smuzhiyun	pinctrl-names = "default", "sleep";
123*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_flexcan2_default>;
124*4882a593Smuzhiyun	pinctrl-1 = <&pinctrl_flexcan2_sleep>;
125*4882a593Smuzhiyun	status = "disabled";
126*4882a593Smuzhiyun};
127*4882a593Smuzhiyun
128*4882a593Smuzhiyun/* Apalis SPI1 */
129*4882a593Smuzhiyun&ecspi1 {
130*4882a593Smuzhiyun	cs-gpios = <&gpio5 25 GPIO_ACTIVE_LOW>;
131*4882a593Smuzhiyun	pinctrl-names = "default";
132*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_ecspi1>;
133*4882a593Smuzhiyun	status = "disabled";
134*4882a593Smuzhiyun};
135*4882a593Smuzhiyun
136*4882a593Smuzhiyun/* Apalis SPI2 */
137*4882a593Smuzhiyun&ecspi2 {
138*4882a593Smuzhiyun	cs-gpios = <&gpio2 26 GPIO_ACTIVE_LOW>;
139*4882a593Smuzhiyun	pinctrl-names = "default";
140*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_ecspi2>;
141*4882a593Smuzhiyun	status = "disabled";
142*4882a593Smuzhiyun};
143*4882a593Smuzhiyun
144*4882a593Smuzhiyun&fec {
145*4882a593Smuzhiyun	pinctrl-names = "default";
146*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_enet>;
147*4882a593Smuzhiyun	phy-mode = "rgmii-id";
148*4882a593Smuzhiyun	phy-handle = <&ethphy>;
149*4882a593Smuzhiyun	phy-reset-duration = <10>;
150*4882a593Smuzhiyun	phy-reset-gpios = <&gpio1 25 GPIO_ACTIVE_LOW>;
151*4882a593Smuzhiyun	status = "okay";
152*4882a593Smuzhiyun
153*4882a593Smuzhiyun	mdio {
154*4882a593Smuzhiyun		#address-cells = <1>;
155*4882a593Smuzhiyun		#size-cells = <0>;
156*4882a593Smuzhiyun
157*4882a593Smuzhiyun		ethphy: ethernet-phy@7 {
158*4882a593Smuzhiyun			interrupt-parent = <&gpio1>;
159*4882a593Smuzhiyun			interrupts = <30 IRQ_TYPE_LEVEL_LOW>;
160*4882a593Smuzhiyun			reg = <7>;
161*4882a593Smuzhiyun		};
162*4882a593Smuzhiyun	};
163*4882a593Smuzhiyun};
164*4882a593Smuzhiyun
165*4882a593Smuzhiyun&hdmi {
166*4882a593Smuzhiyun	pinctrl-names = "default";
167*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_hdmi_ddc &pinctrl_hdmi_cec>;
168*4882a593Smuzhiyun	status = "disabled";
169*4882a593Smuzhiyun};
170*4882a593Smuzhiyun
171*4882a593Smuzhiyun/* I2C1_SDA/SCL on MXM3 209/211 (e.g. RTC on carrier board) */
172*4882a593Smuzhiyun&i2c1 {
173*4882a593Smuzhiyun	clock-frequency = <100000>;
174*4882a593Smuzhiyun	pinctrl-names = "default", "gpio";
175*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_i2c1>;
176*4882a593Smuzhiyun	pinctrl-1 = <&pinctrl_i2c1_gpio>;
177*4882a593Smuzhiyun	scl-gpios = <&gpio5 27 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
178*4882a593Smuzhiyun	sda-gpios = <&gpio5 26 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
179*4882a593Smuzhiyun	status = "disabled";
180*4882a593Smuzhiyun};
181*4882a593Smuzhiyun
182*4882a593Smuzhiyun/*
183*4882a593Smuzhiyun * PWR_I2C: power I2C to audio codec, PMIC, temperature sensor and
184*4882a593Smuzhiyun * touch screen controller
185*4882a593Smuzhiyun */
186*4882a593Smuzhiyun&i2c2 {
187*4882a593Smuzhiyun	clock-frequency = <100000>;
188*4882a593Smuzhiyun	pinctrl-names = "default", "gpio";
189*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_i2c2>;
190*4882a593Smuzhiyun	pinctrl-1 = <&pinctrl_i2c2_gpio>;
191*4882a593Smuzhiyun	scl-gpios = <&gpio4 12 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
192*4882a593Smuzhiyun	sda-gpios = <&gpio4 13 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
193*4882a593Smuzhiyun	status = "okay";
194*4882a593Smuzhiyun
195*4882a593Smuzhiyun	pmic: pfuze100@8 {
196*4882a593Smuzhiyun		compatible = "fsl,pfuze100";
197*4882a593Smuzhiyun		reg = <0x08>;
198*4882a593Smuzhiyun
199*4882a593Smuzhiyun		regulators {
200*4882a593Smuzhiyun			sw1a_reg: sw1ab {
201*4882a593Smuzhiyun				regulator-min-microvolt = <300000>;
202*4882a593Smuzhiyun				regulator-max-microvolt = <1875000>;
203*4882a593Smuzhiyun				regulator-boot-on;
204*4882a593Smuzhiyun				regulator-always-on;
205*4882a593Smuzhiyun				regulator-ramp-delay = <6250>;
206*4882a593Smuzhiyun			};
207*4882a593Smuzhiyun
208*4882a593Smuzhiyun			sw1c_reg: sw1c {
209*4882a593Smuzhiyun				regulator-min-microvolt = <300000>;
210*4882a593Smuzhiyun				regulator-max-microvolt = <1875000>;
211*4882a593Smuzhiyun				regulator-boot-on;
212*4882a593Smuzhiyun				regulator-always-on;
213*4882a593Smuzhiyun				regulator-ramp-delay = <6250>;
214*4882a593Smuzhiyun			};
215*4882a593Smuzhiyun
216*4882a593Smuzhiyun			sw3a_reg: sw3a {
217*4882a593Smuzhiyun				regulator-min-microvolt = <400000>;
218*4882a593Smuzhiyun				regulator-max-microvolt = <1975000>;
219*4882a593Smuzhiyun				regulator-boot-on;
220*4882a593Smuzhiyun				regulator-always-on;
221*4882a593Smuzhiyun			};
222*4882a593Smuzhiyun
223*4882a593Smuzhiyun			swbst_reg: swbst {
224*4882a593Smuzhiyun				regulator-min-microvolt = <5000000>;
225*4882a593Smuzhiyun				regulator-max-microvolt = <5150000>;
226*4882a593Smuzhiyun				regulator-boot-on;
227*4882a593Smuzhiyun				regulator-always-on;
228*4882a593Smuzhiyun			};
229*4882a593Smuzhiyun
230*4882a593Smuzhiyun			snvs_reg: vsnvs {
231*4882a593Smuzhiyun				regulator-min-microvolt = <1000000>;
232*4882a593Smuzhiyun				regulator-max-microvolt = <3000000>;
233*4882a593Smuzhiyun				regulator-boot-on;
234*4882a593Smuzhiyun				regulator-always-on;
235*4882a593Smuzhiyun			};
236*4882a593Smuzhiyun
237*4882a593Smuzhiyun			vref_reg: vrefddr {
238*4882a593Smuzhiyun				regulator-boot-on;
239*4882a593Smuzhiyun				regulator-always-on;
240*4882a593Smuzhiyun			};
241*4882a593Smuzhiyun
242*4882a593Smuzhiyun			vgen1_reg: vgen1 {
243*4882a593Smuzhiyun				regulator-min-microvolt = <800000>;
244*4882a593Smuzhiyun				regulator-max-microvolt = <1550000>;
245*4882a593Smuzhiyun				regulator-boot-on;
246*4882a593Smuzhiyun				regulator-always-on;
247*4882a593Smuzhiyun			};
248*4882a593Smuzhiyun
249*4882a593Smuzhiyun			vgen2_reg: vgen2 {
250*4882a593Smuzhiyun				regulator-min-microvolt = <800000>;
251*4882a593Smuzhiyun				regulator-max-microvolt = <1550000>;
252*4882a593Smuzhiyun				regulator-boot-on;
253*4882a593Smuzhiyun				regulator-always-on;
254*4882a593Smuzhiyun			};
255*4882a593Smuzhiyun
256*4882a593Smuzhiyun			vgen3_reg: vgen3 {
257*4882a593Smuzhiyun				regulator-min-microvolt = <1800000>;
258*4882a593Smuzhiyun				regulator-max-microvolt = <3300000>;
259*4882a593Smuzhiyun				regulator-boot-on;
260*4882a593Smuzhiyun				regulator-always-on;
261*4882a593Smuzhiyun			};
262*4882a593Smuzhiyun
263*4882a593Smuzhiyun			vgen4_reg: vgen4 {
264*4882a593Smuzhiyun				regulator-min-microvolt = <1800000>;
265*4882a593Smuzhiyun				regulator-max-microvolt = <1800000>;
266*4882a593Smuzhiyun				regulator-boot-on;
267*4882a593Smuzhiyun				regulator-always-on;
268*4882a593Smuzhiyun			};
269*4882a593Smuzhiyun
270*4882a593Smuzhiyun			vgen5_reg: vgen5 {
271*4882a593Smuzhiyun				regulator-min-microvolt = <1800000>;
272*4882a593Smuzhiyun				regulator-max-microvolt = <3300000>;
273*4882a593Smuzhiyun				regulator-boot-on;
274*4882a593Smuzhiyun				regulator-always-on;
275*4882a593Smuzhiyun			};
276*4882a593Smuzhiyun
277*4882a593Smuzhiyun			vgen6_reg: vgen6 {
278*4882a593Smuzhiyun				regulator-min-microvolt = <1800000>;
279*4882a593Smuzhiyun				regulator-max-microvolt = <3300000>;
280*4882a593Smuzhiyun				regulator-boot-on;
281*4882a593Smuzhiyun				regulator-always-on;
282*4882a593Smuzhiyun			};
283*4882a593Smuzhiyun		};
284*4882a593Smuzhiyun	};
285*4882a593Smuzhiyun
286*4882a593Smuzhiyun	codec: sgtl5000@a {
287*4882a593Smuzhiyun		compatible = "fsl,sgtl5000";
288*4882a593Smuzhiyun		reg = <0x0a>;
289*4882a593Smuzhiyun		pinctrl-names = "default";
290*4882a593Smuzhiyun		pinctrl-0 = <&pinctrl_sgtl5000>;
291*4882a593Smuzhiyun		clocks = <&clks IMX6QDL_CLK_CKO>;
292*4882a593Smuzhiyun		VDDA-supply = <&reg_module_3v3_audio>;
293*4882a593Smuzhiyun		VDDIO-supply = <&reg_module_3v3>;
294*4882a593Smuzhiyun		VDDD-supply = <&vgen4_reg>;
295*4882a593Smuzhiyun	};
296*4882a593Smuzhiyun
297*4882a593Smuzhiyun	/* STMPE811 touch screen controller */
298*4882a593Smuzhiyun	stmpe811@41 {
299*4882a593Smuzhiyun		compatible = "st,stmpe811";
300*4882a593Smuzhiyun		pinctrl-names = "default";
301*4882a593Smuzhiyun		pinctrl-0 = <&pinctrl_touch_int>;
302*4882a593Smuzhiyun		reg = <0x41>;
303*4882a593Smuzhiyun		interrupts = <10 IRQ_TYPE_LEVEL_LOW>;
304*4882a593Smuzhiyun		interrupt-parent = <&gpio4>;
305*4882a593Smuzhiyun		interrupt-controller;
306*4882a593Smuzhiyun		id = <0>;
307*4882a593Smuzhiyun		blocks = <0x5>;
308*4882a593Smuzhiyun		irq-trigger = <0x1>;
309*4882a593Smuzhiyun		/* 3.25 MHz ADC clock speed */
310*4882a593Smuzhiyun		st,adc-freq = <1>;
311*4882a593Smuzhiyun		/* 12-bit ADC */
312*4882a593Smuzhiyun		st,mod-12b = <1>;
313*4882a593Smuzhiyun		/* internal ADC reference */
314*4882a593Smuzhiyun		st,ref-sel = <0>;
315*4882a593Smuzhiyun		/* ADC converstion time: 80 clocks */
316*4882a593Smuzhiyun		st,sample-time = <4>;
317*4882a593Smuzhiyun
318*4882a593Smuzhiyun		stmpe_touchscreen {
319*4882a593Smuzhiyun			compatible = "st,stmpe-ts";
320*4882a593Smuzhiyun			/* 8 sample average control */
321*4882a593Smuzhiyun			st,ave-ctrl = <3>;
322*4882a593Smuzhiyun			/* 7 length fractional part in z */
323*4882a593Smuzhiyun			st,fraction-z = <7>;
324*4882a593Smuzhiyun			/*
325*4882a593Smuzhiyun			 * 50 mA typical 80 mA max touchscreen drivers
326*4882a593Smuzhiyun			 * current limit value
327*4882a593Smuzhiyun			 */
328*4882a593Smuzhiyun			st,i-drive = <1>;
329*4882a593Smuzhiyun			/* 1 ms panel driver settling time */
330*4882a593Smuzhiyun			st,settling = <3>;
331*4882a593Smuzhiyun			/* 5 ms touch detect interrupt delay */
332*4882a593Smuzhiyun			st,touch-det-delay = <5>;
333*4882a593Smuzhiyun		};
334*4882a593Smuzhiyun
335*4882a593Smuzhiyun		stmpe_adc {
336*4882a593Smuzhiyun			compatible = "st,stmpe-adc";
337*4882a593Smuzhiyun			/* forbid to use ADC channels 3-0 (touch) */
338*4882a593Smuzhiyun			st,norequest-mask = <0x0F>;
339*4882a593Smuzhiyun		};
340*4882a593Smuzhiyun	};
341*4882a593Smuzhiyun};
342*4882a593Smuzhiyun
343*4882a593Smuzhiyun/*
344*4882a593Smuzhiyun * I2C3_SDA/SCL (CAM) on MXM3 pin 201/203 (e.g. camera sensor on carrier
345*4882a593Smuzhiyun * board)
346*4882a593Smuzhiyun */
347*4882a593Smuzhiyun&i2c3 {
348*4882a593Smuzhiyun	clock-frequency = <100000>;
349*4882a593Smuzhiyun	pinctrl-names = "default", "gpio";
350*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_i2c3>;
351*4882a593Smuzhiyun	pinctrl-1 = <&pinctrl_i2c3_gpio>;
352*4882a593Smuzhiyun	scl-gpios = <&gpio3 17 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
353*4882a593Smuzhiyun	sda-gpios = <&gpio3 18 (GPIO_ACTIVE_HIGH | GPIO_OPEN_DRAIN)>;
354*4882a593Smuzhiyun	status = "disabled";
355*4882a593Smuzhiyun};
356*4882a593Smuzhiyun
357*4882a593Smuzhiyun&pwm1 {
358*4882a593Smuzhiyun	pinctrl-names = "default";
359*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_pwm1>;
360*4882a593Smuzhiyun	status = "disabled";
361*4882a593Smuzhiyun};
362*4882a593Smuzhiyun
363*4882a593Smuzhiyun&pwm2 {
364*4882a593Smuzhiyun	pinctrl-names = "default";
365*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_pwm2>;
366*4882a593Smuzhiyun	status = "disabled";
367*4882a593Smuzhiyun};
368*4882a593Smuzhiyun
369*4882a593Smuzhiyun&pwm3 {
370*4882a593Smuzhiyun	pinctrl-names = "default";
371*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_pwm3>;
372*4882a593Smuzhiyun	status = "disabled";
373*4882a593Smuzhiyun};
374*4882a593Smuzhiyun
375*4882a593Smuzhiyun&pwm4 {
376*4882a593Smuzhiyun	#pwm-cells = <2>;
377*4882a593Smuzhiyun	pinctrl-names = "default";
378*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_pwm4>;
379*4882a593Smuzhiyun	status = "disabled";
380*4882a593Smuzhiyun};
381*4882a593Smuzhiyun
382*4882a593Smuzhiyun&spdif {
383*4882a593Smuzhiyun	pinctrl-names = "default";
384*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_spdif>;
385*4882a593Smuzhiyun	status = "disabled";
386*4882a593Smuzhiyun};
387*4882a593Smuzhiyun
388*4882a593Smuzhiyun&ssi1 {
389*4882a593Smuzhiyun	status = "okay";
390*4882a593Smuzhiyun};
391*4882a593Smuzhiyun
392*4882a593Smuzhiyun&uart1 {
393*4882a593Smuzhiyun	pinctrl-names = "default";
394*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_uart1_dte &pinctrl_uart1_ctrl>;
395*4882a593Smuzhiyun	fsl,dte-mode;
396*4882a593Smuzhiyun	uart-has-rtscts;
397*4882a593Smuzhiyun	status = "disabled";
398*4882a593Smuzhiyun};
399*4882a593Smuzhiyun
400*4882a593Smuzhiyun&uart2 {
401*4882a593Smuzhiyun	pinctrl-names = "default";
402*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_uart2_dte>;
403*4882a593Smuzhiyun	fsl,dte-mode;
404*4882a593Smuzhiyun	uart-has-rtscts;
405*4882a593Smuzhiyun	status = "disabled";
406*4882a593Smuzhiyun};
407*4882a593Smuzhiyun
408*4882a593Smuzhiyun&uart4 {
409*4882a593Smuzhiyun	pinctrl-names = "default";
410*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_uart4_dte>;
411*4882a593Smuzhiyun	fsl,dte-mode;
412*4882a593Smuzhiyun	status = "disabled";
413*4882a593Smuzhiyun};
414*4882a593Smuzhiyun
415*4882a593Smuzhiyun&uart5 {
416*4882a593Smuzhiyun	pinctrl-names = "default";
417*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_uart5_dte>;
418*4882a593Smuzhiyun	fsl,dte-mode;
419*4882a593Smuzhiyun	status = "disabled";
420*4882a593Smuzhiyun};
421*4882a593Smuzhiyun
422*4882a593Smuzhiyun&usbotg {
423*4882a593Smuzhiyun	pinctrl-names = "default";
424*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_usbotg>;
425*4882a593Smuzhiyun	disable-over-current;
426*4882a593Smuzhiyun	status = "disabled";
427*4882a593Smuzhiyun};
428*4882a593Smuzhiyun
429*4882a593Smuzhiyun/* MMC1 */
430*4882a593Smuzhiyun&usdhc1 {
431*4882a593Smuzhiyun	pinctrl-names = "default";
432*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_usdhc1_4bit &pinctrl_usdhc1_8bit>;
433*4882a593Smuzhiyun	vqmmc-supply = <&reg_module_3v3>;
434*4882a593Smuzhiyun	bus-width = <8>;
435*4882a593Smuzhiyun	disable-wp;
436*4882a593Smuzhiyun	no-1-8-v;
437*4882a593Smuzhiyun	status = "disabled";
438*4882a593Smuzhiyun};
439*4882a593Smuzhiyun
440*4882a593Smuzhiyun/* SD1 */
441*4882a593Smuzhiyun&usdhc2 {
442*4882a593Smuzhiyun	pinctrl-names = "default";
443*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_usdhc2>;
444*4882a593Smuzhiyun	vqmmc-supply = <&reg_module_3v3>;
445*4882a593Smuzhiyun	bus-width = <4>;
446*4882a593Smuzhiyun	disable-wp;
447*4882a593Smuzhiyun	no-1-8-v;
448*4882a593Smuzhiyun	status = "disabled";
449*4882a593Smuzhiyun};
450*4882a593Smuzhiyun
451*4882a593Smuzhiyun/* eMMC */
452*4882a593Smuzhiyun&usdhc3 {
453*4882a593Smuzhiyun	pinctrl-names = "default";
454*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_usdhc3>;
455*4882a593Smuzhiyun	vqmmc-supply = <&reg_module_3v3>;
456*4882a593Smuzhiyun	bus-width = <8>;
457*4882a593Smuzhiyun	no-1-8-v;
458*4882a593Smuzhiyun	non-removable;
459*4882a593Smuzhiyun	status = "okay";
460*4882a593Smuzhiyun};
461*4882a593Smuzhiyun
462*4882a593Smuzhiyun&weim {
463*4882a593Smuzhiyun	status = "disabled";
464*4882a593Smuzhiyun};
465*4882a593Smuzhiyun
466*4882a593Smuzhiyun&iomuxc {
467*4882a593Smuzhiyun	pinctrl_apalis_gpio1: gpio2io04grp {
468*4882a593Smuzhiyun		fsl,pins = <
469*4882a593Smuzhiyun			MX6QDL_PAD_NANDF_D4__GPIO2_IO04 0x130b0
470*4882a593Smuzhiyun		>;
471*4882a593Smuzhiyun	};
472*4882a593Smuzhiyun
473*4882a593Smuzhiyun	pinctrl_apalis_gpio2: gpio2io05grp {
474*4882a593Smuzhiyun		fsl,pins = <
475*4882a593Smuzhiyun			MX6QDL_PAD_NANDF_D5__GPIO2_IO05 0x130b0
476*4882a593Smuzhiyun		>;
477*4882a593Smuzhiyun	};
478*4882a593Smuzhiyun
479*4882a593Smuzhiyun	pinctrl_apalis_gpio3: gpio2io06grp {
480*4882a593Smuzhiyun		fsl,pins = <
481*4882a593Smuzhiyun			MX6QDL_PAD_NANDF_D6__GPIO2_IO06 0x130b0
482*4882a593Smuzhiyun		>;
483*4882a593Smuzhiyun	};
484*4882a593Smuzhiyun
485*4882a593Smuzhiyun	pinctrl_apalis_gpio4: gpio2io07grp {
486*4882a593Smuzhiyun		fsl,pins = <
487*4882a593Smuzhiyun			MX6QDL_PAD_NANDF_D7__GPIO2_IO07 0x130b0
488*4882a593Smuzhiyun		>;
489*4882a593Smuzhiyun	};
490*4882a593Smuzhiyun
491*4882a593Smuzhiyun	pinctrl_apalis_gpio5: gpio6io10grp {
492*4882a593Smuzhiyun		fsl,pins = <
493*4882a593Smuzhiyun			MX6QDL_PAD_NANDF_RB0__GPIO6_IO10 0x130b0
494*4882a593Smuzhiyun		>;
495*4882a593Smuzhiyun	};
496*4882a593Smuzhiyun
497*4882a593Smuzhiyun	pinctrl_apalis_gpio6: gpio6io09grp {
498*4882a593Smuzhiyun		fsl,pins = <
499*4882a593Smuzhiyun			MX6QDL_PAD_NANDF_WP_B__GPIO6_IO09 0x130b0
500*4882a593Smuzhiyun		>;
501*4882a593Smuzhiyun	};
502*4882a593Smuzhiyun
503*4882a593Smuzhiyun	pinctrl_apalis_gpio7: gpio1io02grp {
504*4882a593Smuzhiyun		fsl,pins = <
505*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_2__GPIO1_IO02 0x130b0
506*4882a593Smuzhiyun		>;
507*4882a593Smuzhiyun	};
508*4882a593Smuzhiyun
509*4882a593Smuzhiyun	pinctrl_apalis_gpio8: gpio1io06grp {
510*4882a593Smuzhiyun		fsl,pins = <
511*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_6__GPIO1_IO06 0x130b0
512*4882a593Smuzhiyun		>;
513*4882a593Smuzhiyun	};
514*4882a593Smuzhiyun
515*4882a593Smuzhiyun	pinctrl_audmux: audmuxgrp {
516*4882a593Smuzhiyun		fsl,pins = <
517*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT20__AUD4_TXC	0x130b0
518*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT21__AUD4_TXD	0x130b0
519*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT22__AUD4_TXFS	0x130b0
520*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT23__AUD4_RXD	0x130b0
521*4882a593Smuzhiyun		>;
522*4882a593Smuzhiyun	};
523*4882a593Smuzhiyun
524*4882a593Smuzhiyun	pinctrl_cam_mclk: cammclkgrp {
525*4882a593Smuzhiyun		fsl,pins = <
526*4882a593Smuzhiyun			/* CAM sys_mclk */
527*4882a593Smuzhiyun			MX6QDL_PAD_NANDF_CS2__CCM_CLKO2 0x00b0
528*4882a593Smuzhiyun		>;
529*4882a593Smuzhiyun	};
530*4882a593Smuzhiyun
531*4882a593Smuzhiyun	pinctrl_ecspi1: ecspi1grp {
532*4882a593Smuzhiyun		fsl,pins = <
533*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT6__ECSPI1_MISO 0x100b1
534*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT5__ECSPI1_MOSI 0x100b1
535*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT4__ECSPI1_SCLK 0x100b1
536*4882a593Smuzhiyun			/* SPI1 cs */
537*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT7__GPIO5_IO25 0x000b1
538*4882a593Smuzhiyun		>;
539*4882a593Smuzhiyun	};
540*4882a593Smuzhiyun
541*4882a593Smuzhiyun	pinctrl_ecspi2: ecspi2grp {
542*4882a593Smuzhiyun		fsl,pins = <
543*4882a593Smuzhiyun			MX6QDL_PAD_EIM_OE__ECSPI2_MISO 0x100b1
544*4882a593Smuzhiyun			MX6QDL_PAD_EIM_CS1__ECSPI2_MOSI 0x100b1
545*4882a593Smuzhiyun			MX6QDL_PAD_EIM_CS0__ECSPI2_SCLK 0x100b1
546*4882a593Smuzhiyun			/* SPI2 cs */
547*4882a593Smuzhiyun			MX6QDL_PAD_EIM_RW__GPIO2_IO26 0x000b1
548*4882a593Smuzhiyun		>;
549*4882a593Smuzhiyun	};
550*4882a593Smuzhiyun
551*4882a593Smuzhiyun	pinctrl_enet: enetgrp {
552*4882a593Smuzhiyun		fsl,pins = <
553*4882a593Smuzhiyun			MX6QDL_PAD_ENET_MDIO__ENET_MDIO		0x100b0
554*4882a593Smuzhiyun			MX6QDL_PAD_ENET_MDC__ENET_MDC		0x100b0
555*4882a593Smuzhiyun			MX6QDL_PAD_RGMII_TXC__RGMII_TXC		0x10030
556*4882a593Smuzhiyun			MX6QDL_PAD_RGMII_TD0__RGMII_TD0		0x10030
557*4882a593Smuzhiyun			MX6QDL_PAD_RGMII_TD1__RGMII_TD1		0x10030
558*4882a593Smuzhiyun			MX6QDL_PAD_RGMII_TD2__RGMII_TD2		0x10030
559*4882a593Smuzhiyun			MX6QDL_PAD_RGMII_TD3__RGMII_TD3		0x10030
560*4882a593Smuzhiyun			MX6QDL_PAD_RGMII_TX_CTL__RGMII_TX_CTL	0x10030
561*4882a593Smuzhiyun			MX6QDL_PAD_ENET_REF_CLK__ENET_TX_CLK	0x100b0
562*4882a593Smuzhiyun			MX6QDL_PAD_RGMII_RXC__RGMII_RXC		0x1b030
563*4882a593Smuzhiyun			MX6QDL_PAD_RGMII_RD0__RGMII_RD0		0x1b030
564*4882a593Smuzhiyun			MX6QDL_PAD_RGMII_RD1__RGMII_RD1		0x1b030
565*4882a593Smuzhiyun			MX6QDL_PAD_RGMII_RD2__RGMII_RD2		0x1b030
566*4882a593Smuzhiyun			MX6QDL_PAD_RGMII_RD3__RGMII_RD3		0x1b030
567*4882a593Smuzhiyun			MX6QDL_PAD_RGMII_RX_CTL__RGMII_RX_CTL	0x1b030
568*4882a593Smuzhiyun			/* Ethernet PHY reset */
569*4882a593Smuzhiyun			MX6QDL_PAD_ENET_CRS_DV__GPIO1_IO25	0x000b0
570*4882a593Smuzhiyun			/* Ethernet PHY interrupt */
571*4882a593Smuzhiyun			MX6QDL_PAD_ENET_TXD0__GPIO1_IO30	0x000b1
572*4882a593Smuzhiyun		>;
573*4882a593Smuzhiyun	};
574*4882a593Smuzhiyun
575*4882a593Smuzhiyun	pinctrl_flexcan1_default: flexcan1defgrp {
576*4882a593Smuzhiyun		fsl,pins = <
577*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_7__FLEXCAN1_TX 0x1b0b0
578*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_8__FLEXCAN1_RX 0x1b0b0
579*4882a593Smuzhiyun		>;
580*4882a593Smuzhiyun	};
581*4882a593Smuzhiyun
582*4882a593Smuzhiyun	pinctrl_flexcan1_sleep: flexcan1slpgrp {
583*4882a593Smuzhiyun		fsl,pins = <
584*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_7__GPIO1_IO07 0x0
585*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_8__GPIO1_IO08 0x0
586*4882a593Smuzhiyun		>;
587*4882a593Smuzhiyun	};
588*4882a593Smuzhiyun
589*4882a593Smuzhiyun	pinctrl_flexcan2_default: flexcan2defgrp {
590*4882a593Smuzhiyun		fsl,pins = <
591*4882a593Smuzhiyun			MX6QDL_PAD_KEY_COL4__FLEXCAN2_TX 0x1b0b0
592*4882a593Smuzhiyun			MX6QDL_PAD_KEY_ROW4__FLEXCAN2_RX 0x1b0b0
593*4882a593Smuzhiyun		>;
594*4882a593Smuzhiyun	};
595*4882a593Smuzhiyun	pinctrl_flexcan2_sleep: flexcan2slpgrp {
596*4882a593Smuzhiyun		fsl,pins = <
597*4882a593Smuzhiyun			MX6QDL_PAD_KEY_COL4__GPIO4_IO14 0x0
598*4882a593Smuzhiyun			MX6QDL_PAD_KEY_ROW4__GPIO4_IO15 0x0
599*4882a593Smuzhiyun		>;
600*4882a593Smuzhiyun	};
601*4882a593Smuzhiyun
602*4882a593Smuzhiyun	pinctrl_gpio_bl_on: gpioblon {
603*4882a593Smuzhiyun		fsl,pins = <
604*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA13__GPIO3_IO13 0x1b0b0
605*4882a593Smuzhiyun		>;
606*4882a593Smuzhiyun	};
607*4882a593Smuzhiyun
608*4882a593Smuzhiyun	pinctrl_gpio_keys: gpio1io04grp {
609*4882a593Smuzhiyun		fsl,pins = <
610*4882a593Smuzhiyun			/* Power button */
611*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_4__GPIO1_IO04 0x1b0b0
612*4882a593Smuzhiyun		>;
613*4882a593Smuzhiyun	};
614*4882a593Smuzhiyun
615*4882a593Smuzhiyun	pinctrl_hdmi_cec: hdmicecgrp {
616*4882a593Smuzhiyun		fsl,pins = <
617*4882a593Smuzhiyun			MX6QDL_PAD_KEY_ROW2__HDMI_TX_CEC_LINE 0x1f8b0
618*4882a593Smuzhiyun		>;
619*4882a593Smuzhiyun	};
620*4882a593Smuzhiyun
621*4882a593Smuzhiyun	pinctrl_hdmi_ddc: hdmiddcgrp {
622*4882a593Smuzhiyun		fsl,pins = <
623*4882a593Smuzhiyun			MX6QDL_PAD_EIM_EB2__HDMI_TX_DDC_SCL 0x4001b8b1
624*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D16__HDMI_TX_DDC_SDA 0x4001b8b1
625*4882a593Smuzhiyun		>;
626*4882a593Smuzhiyun	};
627*4882a593Smuzhiyun
628*4882a593Smuzhiyun	pinctrl_i2c1: i2c1grp {
629*4882a593Smuzhiyun		fsl,pins = <
630*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT8__I2C1_SDA 0x4001b8b1
631*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT9__I2C1_SCL 0x4001b8b1
632*4882a593Smuzhiyun		>;
633*4882a593Smuzhiyun	};
634*4882a593Smuzhiyun
635*4882a593Smuzhiyun	pinctrl_i2c1_gpio: i2c1gpiogrp {
636*4882a593Smuzhiyun		fsl,pins = <
637*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT8__GPIO5_IO26 0x4001b8b1
638*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT9__GPIO5_IO27 0x4001b8b1
639*4882a593Smuzhiyun		>;
640*4882a593Smuzhiyun	};
641*4882a593Smuzhiyun
642*4882a593Smuzhiyun	pinctrl_i2c2: i2c2grp {
643*4882a593Smuzhiyun		fsl,pins = <
644*4882a593Smuzhiyun			MX6QDL_PAD_KEY_COL3__I2C2_SCL 0x4001b8b1
645*4882a593Smuzhiyun			MX6QDL_PAD_KEY_ROW3__I2C2_SDA 0x4001b8b1
646*4882a593Smuzhiyun		>;
647*4882a593Smuzhiyun	};
648*4882a593Smuzhiyun
649*4882a593Smuzhiyun	pinctrl_i2c2_gpio: i2c2gpiogrp {
650*4882a593Smuzhiyun		fsl,pins = <
651*4882a593Smuzhiyun			MX6QDL_PAD_KEY_COL3__GPIO4_IO12 0x4001b8b1
652*4882a593Smuzhiyun			MX6QDL_PAD_KEY_ROW3__GPIO4_IO13 0x4001b8b1
653*4882a593Smuzhiyun		>;
654*4882a593Smuzhiyun	};
655*4882a593Smuzhiyun
656*4882a593Smuzhiyun	pinctrl_i2c3: i2c3grp {
657*4882a593Smuzhiyun		fsl,pins = <
658*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D17__I2C3_SCL 0x4001b8b1
659*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D18__I2C3_SDA 0x4001b8b1
660*4882a593Smuzhiyun		>;
661*4882a593Smuzhiyun	};
662*4882a593Smuzhiyun
663*4882a593Smuzhiyun	pinctrl_i2c3_gpio: i2c3gpiogrp {
664*4882a593Smuzhiyun		fsl,pins = <
665*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D17__GPIO3_IO17 0x4001b8b1
666*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D18__GPIO3_IO18 0x4001b8b1
667*4882a593Smuzhiyun		>;
668*4882a593Smuzhiyun	};
669*4882a593Smuzhiyun
670*4882a593Smuzhiyun	pinctrl_ipu1_csi0: ipu1csi0grp { /* parallel camera */
671*4882a593Smuzhiyun		fsl,pins = <
672*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT12__IPU1_CSI0_DATA12  0xb0b1
673*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT13__IPU1_CSI0_DATA13  0xb0b1
674*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT14__IPU1_CSI0_DATA14  0xb0b1
675*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT15__IPU1_CSI0_DATA15  0xb0b1
676*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT16__IPU1_CSI0_DATA16  0xb0b1
677*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT17__IPU1_CSI0_DATA17  0xb0b1
678*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT18__IPU1_CSI0_DATA18  0xb0b1
679*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT19__IPU1_CSI0_DATA19  0xb0b1
680*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_PIXCLK__IPU1_CSI0_PIXCLK 0xb0b1
681*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_MCLK__IPU1_CSI0_HSYNC    0xb0b1
682*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_VSYNC__IPU1_CSI0_VSYNC   0xb0b1
683*4882a593Smuzhiyun		>;
684*4882a593Smuzhiyun	};
685*4882a593Smuzhiyun
686*4882a593Smuzhiyun	pinctrl_ipu1_lcdif: ipu1lcdifgrp {
687*4882a593Smuzhiyun		fsl,pins = <
688*4882a593Smuzhiyun			MX6QDL_PAD_EIM_A16__IPU1_DI1_DISP_CLK	0x61
689*4882a593Smuzhiyun			/* DE */
690*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA10__IPU1_DI1_PIN15	0x61
691*4882a593Smuzhiyun			/* HSync */
692*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA11__IPU1_DI1_PIN02	0x61
693*4882a593Smuzhiyun			/* VSync */
694*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA12__IPU1_DI1_PIN03	0x61
695*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA9__IPU1_DISP1_DATA00	0x61
696*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA8__IPU1_DISP1_DATA01	0x61
697*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA7__IPU1_DISP1_DATA02	0x61
698*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA6__IPU1_DISP1_DATA03	0x61
699*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA5__IPU1_DISP1_DATA04	0x61
700*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA4__IPU1_DISP1_DATA05	0x61
701*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA3__IPU1_DISP1_DATA06	0x61
702*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA2__IPU1_DISP1_DATA07	0x61
703*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA1__IPU1_DISP1_DATA08	0x61
704*4882a593Smuzhiyun			MX6QDL_PAD_EIM_DA0__IPU1_DISP1_DATA09	0x61
705*4882a593Smuzhiyun			MX6QDL_PAD_EIM_EB1__IPU1_DISP1_DATA10	0x61
706*4882a593Smuzhiyun			MX6QDL_PAD_EIM_EB0__IPU1_DISP1_DATA11	0x61
707*4882a593Smuzhiyun			MX6QDL_PAD_EIM_A17__IPU1_DISP1_DATA12	0x61
708*4882a593Smuzhiyun			MX6QDL_PAD_EIM_A18__IPU1_DISP1_DATA13	0x61
709*4882a593Smuzhiyun			MX6QDL_PAD_EIM_A19__IPU1_DISP1_DATA14	0x61
710*4882a593Smuzhiyun			MX6QDL_PAD_EIM_A20__IPU1_DISP1_DATA15	0x61
711*4882a593Smuzhiyun			MX6QDL_PAD_EIM_A21__IPU1_DISP1_DATA16	0x61
712*4882a593Smuzhiyun			MX6QDL_PAD_EIM_A22__IPU1_DISP1_DATA17	0x61
713*4882a593Smuzhiyun			MX6QDL_PAD_EIM_A23__IPU1_DISP1_DATA18	0x61
714*4882a593Smuzhiyun			MX6QDL_PAD_EIM_A24__IPU1_DISP1_DATA19	0x61
715*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D31__IPU1_DISP1_DATA20	0x61
716*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D30__IPU1_DISP1_DATA21	0x61
717*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D26__IPU1_DISP1_DATA22	0x61
718*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D27__IPU1_DISP1_DATA23	0x61
719*4882a593Smuzhiyun		>;
720*4882a593Smuzhiyun	};
721*4882a593Smuzhiyun
722*4882a593Smuzhiyun	pinctrl_ipu2_vdac: ipu2vdacgrp {
723*4882a593Smuzhiyun		fsl,pins = <
724*4882a593Smuzhiyun			MX6QDL_PAD_DI0_DISP_CLK__IPU2_DI0_DISP_CLK 0xd1
725*4882a593Smuzhiyun			MX6QDL_PAD_DI0_PIN15__IPU2_DI0_PIN15       0xd1
726*4882a593Smuzhiyun			MX6QDL_PAD_DI0_PIN2__IPU2_DI0_PIN02        0xd1
727*4882a593Smuzhiyun			MX6QDL_PAD_DI0_PIN3__IPU2_DI0_PIN03        0xd1
728*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT0__IPU2_DISP0_DATA00   0xf9
729*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT1__IPU2_DISP0_DATA01   0xf9
730*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT2__IPU2_DISP0_DATA02   0xf9
731*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT3__IPU2_DISP0_DATA03   0xf9
732*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT4__IPU2_DISP0_DATA04   0xf9
733*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT5__IPU2_DISP0_DATA05   0xf9
734*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT6__IPU2_DISP0_DATA06   0xf9
735*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT7__IPU2_DISP0_DATA07   0xf9
736*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT8__IPU2_DISP0_DATA08   0xf9
737*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT9__IPU2_DISP0_DATA09   0xf9
738*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT10__IPU2_DISP0_DATA10  0xf9
739*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT11__IPU2_DISP0_DATA11  0xf9
740*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT12__IPU2_DISP0_DATA12  0xf9
741*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT13__IPU2_DISP0_DATA13  0xf9
742*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT14__IPU2_DISP0_DATA14  0xf9
743*4882a593Smuzhiyun			MX6QDL_PAD_DISP0_DAT15__IPU2_DISP0_DATA15  0xf9
744*4882a593Smuzhiyun		>;
745*4882a593Smuzhiyun	};
746*4882a593Smuzhiyun
747*4882a593Smuzhiyun	pinctrl_mmc_cd: gpiommccdgrp {
748*4882a593Smuzhiyun		fsl,pins = <
749*4882a593Smuzhiyun			 /* MMC1 CD */
750*4882a593Smuzhiyun			MX6QDL_PAD_DI0_PIN4__GPIO4_IO20 0x000b0
751*4882a593Smuzhiyun		>;
752*4882a593Smuzhiyun	};
753*4882a593Smuzhiyun
754*4882a593Smuzhiyun	pinctrl_pwm1: pwm1grp {
755*4882a593Smuzhiyun		fsl,pins = <
756*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_9__PWM1_OUT 0x1b0b1
757*4882a593Smuzhiyun		>;
758*4882a593Smuzhiyun	};
759*4882a593Smuzhiyun
760*4882a593Smuzhiyun	pinctrl_pwm2: pwm2grp {
761*4882a593Smuzhiyun		fsl,pins = <
762*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_1__PWM2_OUT 0x1b0b1
763*4882a593Smuzhiyun		>;
764*4882a593Smuzhiyun	};
765*4882a593Smuzhiyun
766*4882a593Smuzhiyun	pinctrl_pwm3: pwm3grp {
767*4882a593Smuzhiyun		fsl,pins = <
768*4882a593Smuzhiyun			MX6QDL_PAD_SD4_DAT1__PWM3_OUT 0x1b0b1
769*4882a593Smuzhiyun		>;
770*4882a593Smuzhiyun	};
771*4882a593Smuzhiyun
772*4882a593Smuzhiyun	pinctrl_pwm4: pwm4grp {
773*4882a593Smuzhiyun		fsl,pins = <
774*4882a593Smuzhiyun			MX6QDL_PAD_SD4_DAT2__PWM4_OUT 0x1b0b1
775*4882a593Smuzhiyun		>;
776*4882a593Smuzhiyun	};
777*4882a593Smuzhiyun
778*4882a593Smuzhiyun	pinctrl_regulator_usbh_pwr: gpioregusbhpwrgrp {
779*4882a593Smuzhiyun		fsl,pins = <
780*4882a593Smuzhiyun			/* USBH_EN */
781*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_0__GPIO1_IO00 0x0f058
782*4882a593Smuzhiyun		>;
783*4882a593Smuzhiyun	};
784*4882a593Smuzhiyun
785*4882a593Smuzhiyun	pinctrl_regulator_usbhub_pwr: gpioregusbhubpwrgrp {
786*4882a593Smuzhiyun		fsl,pins = <
787*4882a593Smuzhiyun			/* USBH_HUB_EN */
788*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D28__GPIO3_IO28 0x0f058
789*4882a593Smuzhiyun		>;
790*4882a593Smuzhiyun	};
791*4882a593Smuzhiyun
792*4882a593Smuzhiyun	pinctrl_regulator_usbotg_pwr: gpioregusbotgpwrgrp {
793*4882a593Smuzhiyun		fsl,pins = <
794*4882a593Smuzhiyun			/* USBO1 power en */
795*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D22__GPIO3_IO22 0x0f058
796*4882a593Smuzhiyun		>;
797*4882a593Smuzhiyun	};
798*4882a593Smuzhiyun
799*4882a593Smuzhiyun	pinctrl_reset_moci: gpioresetmocigrp {
800*4882a593Smuzhiyun		fsl,pins = <
801*4882a593Smuzhiyun			/* RESET_MOCI control */
802*4882a593Smuzhiyun			MX6QDL_PAD_ENET_TX_EN__GPIO1_IO28 0x0f058
803*4882a593Smuzhiyun		>;
804*4882a593Smuzhiyun	};
805*4882a593Smuzhiyun
806*4882a593Smuzhiyun	pinctrl_sd_cd: gpiosdcdgrp {
807*4882a593Smuzhiyun		fsl,pins = <
808*4882a593Smuzhiyun			/* SD1 CD */
809*4882a593Smuzhiyun			MX6QDL_PAD_NANDF_CS1__GPIO6_IO14 0x000b0
810*4882a593Smuzhiyun		>;
811*4882a593Smuzhiyun	};
812*4882a593Smuzhiyun
813*4882a593Smuzhiyun	pinctrl_sgtl5000: sgtl5000grp {
814*4882a593Smuzhiyun		fsl,pins = <
815*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_5__CCM_CLKO1	0x130b0
816*4882a593Smuzhiyun		>;
817*4882a593Smuzhiyun	};
818*4882a593Smuzhiyun
819*4882a593Smuzhiyun	pinctrl_spdif: spdifgrp {
820*4882a593Smuzhiyun		fsl,pins = <
821*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_16__SPDIF_IN  0x1b0b0
822*4882a593Smuzhiyun			MX6QDL_PAD_GPIO_17__SPDIF_OUT 0x1b0b0
823*4882a593Smuzhiyun		>;
824*4882a593Smuzhiyun	};
825*4882a593Smuzhiyun
826*4882a593Smuzhiyun	pinctrl_touch_int: gpiotouchintgrp {
827*4882a593Smuzhiyun		fsl,pins = <
828*4882a593Smuzhiyun			/* STMPE811 interrupt */
829*4882a593Smuzhiyun			MX6QDL_PAD_KEY_COL2__GPIO4_IO10 0x1b0b0
830*4882a593Smuzhiyun		>;
831*4882a593Smuzhiyun	};
832*4882a593Smuzhiyun
833*4882a593Smuzhiyun	pinctrl_uart1_dce: uart1dcegrp {
834*4882a593Smuzhiyun		fsl,pins = <
835*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT10__UART1_TX_DATA 0x1b0b1
836*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT11__UART1_RX_DATA 0x1b0b1
837*4882a593Smuzhiyun		>;
838*4882a593Smuzhiyun	};
839*4882a593Smuzhiyun
840*4882a593Smuzhiyun	/* DTE mode */
841*4882a593Smuzhiyun	pinctrl_uart1_dte: uart1dtegrp {
842*4882a593Smuzhiyun		fsl,pins = <
843*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT10__UART1_RX_DATA 0x1b0b1
844*4882a593Smuzhiyun			MX6QDL_PAD_CSI0_DAT11__UART1_TX_DATA 0x1b0b1
845*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D19__UART1_RTS_B 0x1b0b1
846*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D20__UART1_CTS_B 0x1b0b1
847*4882a593Smuzhiyun		>;
848*4882a593Smuzhiyun	};
849*4882a593Smuzhiyun
850*4882a593Smuzhiyun	/* Additional DTR, DSR, DCD */
851*4882a593Smuzhiyun	pinctrl_uart1_ctrl: uart1ctrlgrp {
852*4882a593Smuzhiyun		fsl,pins = <
853*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D23__UART1_DCD_B 0x1b0b0
854*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D24__UART1_DTR_B 0x1b0b0
855*4882a593Smuzhiyun			MX6QDL_PAD_EIM_D25__UART1_DSR_B 0x1b0b0
856*4882a593Smuzhiyun		>;
857*4882a593Smuzhiyun	};
858*4882a593Smuzhiyun
859*4882a593Smuzhiyun	pinctrl_uart2_dce: uart2dcegrp {
860*4882a593Smuzhiyun		fsl,pins = <
861*4882a593Smuzhiyun			MX6QDL_PAD_SD4_DAT4__UART2_RX_DATA	0x1b0b1
862*4882a593Smuzhiyun			MX6QDL_PAD_SD4_DAT7__UART2_TX_DATA	0x1b0b1
863*4882a593Smuzhiyun		>;
864*4882a593Smuzhiyun	};
865*4882a593Smuzhiyun
866*4882a593Smuzhiyun	/* DTE mode */
867*4882a593Smuzhiyun	pinctrl_uart2_dte: uart2dtegrp {
868*4882a593Smuzhiyun		fsl,pins = <
869*4882a593Smuzhiyun			MX6QDL_PAD_SD4_DAT4__UART2_TX_DATA	0x1b0b1
870*4882a593Smuzhiyun			MX6QDL_PAD_SD4_DAT7__UART2_RX_DATA	0x1b0b1
871*4882a593Smuzhiyun			MX6QDL_PAD_SD4_DAT6__UART2_RTS_B	0x1b0b1
872*4882a593Smuzhiyun			MX6QDL_PAD_SD4_DAT5__UART2_CTS_B	0x1b0b1
873*4882a593Smuzhiyun		>;
874*4882a593Smuzhiyun	};
875*4882a593Smuzhiyun
876*4882a593Smuzhiyun	pinctrl_uart4_dce: uart4dcegrp {
877*4882a593Smuzhiyun		fsl,pins = <
878*4882a593Smuzhiyun			MX6QDL_PAD_KEY_COL0__UART4_TX_DATA 0x1b0b1
879*4882a593Smuzhiyun			MX6QDL_PAD_KEY_ROW0__UART4_RX_DATA 0x1b0b1
880*4882a593Smuzhiyun		>;
881*4882a593Smuzhiyun	};
882*4882a593Smuzhiyun
883*4882a593Smuzhiyun	/* DTE mode */
884*4882a593Smuzhiyun	pinctrl_uart4_dte: uart4dtegrp {
885*4882a593Smuzhiyun		fsl,pins = <
886*4882a593Smuzhiyun			MX6QDL_PAD_KEY_COL0__UART4_RX_DATA 0x1b0b1
887*4882a593Smuzhiyun			MX6QDL_PAD_KEY_ROW0__UART4_TX_DATA 0x1b0b1
888*4882a593Smuzhiyun		>;
889*4882a593Smuzhiyun	};
890*4882a593Smuzhiyun
891*4882a593Smuzhiyun	pinctrl_uart5_dce: uart5dcegrp {
892*4882a593Smuzhiyun		fsl,pins = <
893*4882a593Smuzhiyun			MX6QDL_PAD_KEY_COL1__UART5_TX_DATA 0x1b0b1
894*4882a593Smuzhiyun			MX6QDL_PAD_KEY_ROW1__UART5_RX_DATA 0x1b0b1
895*4882a593Smuzhiyun		>;
896*4882a593Smuzhiyun	};
897*4882a593Smuzhiyun
898*4882a593Smuzhiyun	/* DTE mode */
899*4882a593Smuzhiyun	pinctrl_uart5_dte: uart5dtegrp {
900*4882a593Smuzhiyun		fsl,pins = <
901*4882a593Smuzhiyun			MX6QDL_PAD_KEY_COL1__UART5_RX_DATA 0x1b0b1
902*4882a593Smuzhiyun			MX6QDL_PAD_KEY_ROW1__UART5_TX_DATA 0x1b0b1
903*4882a593Smuzhiyun		>;
904*4882a593Smuzhiyun	};
905*4882a593Smuzhiyun
906*4882a593Smuzhiyun	pinctrl_usbotg: usbotggrp {
907*4882a593Smuzhiyun		fsl,pins = <
908*4882a593Smuzhiyun			MX6QDL_PAD_ENET_RX_ER__USB_OTG_ID 0x17059
909*4882a593Smuzhiyun		>;
910*4882a593Smuzhiyun	};
911*4882a593Smuzhiyun
912*4882a593Smuzhiyun	pinctrl_usdhc1_4bit: usdhc1grp_4bit {
913*4882a593Smuzhiyun		fsl,pins = <
914*4882a593Smuzhiyun			MX6QDL_PAD_SD1_CMD__SD1_CMD    0x17071
915*4882a593Smuzhiyun			MX6QDL_PAD_SD1_CLK__SD1_CLK    0x10071
916*4882a593Smuzhiyun			MX6QDL_PAD_SD1_DAT0__SD1_DATA0 0x17071
917*4882a593Smuzhiyun			MX6QDL_PAD_SD1_DAT1__SD1_DATA1 0x17071
918*4882a593Smuzhiyun			MX6QDL_PAD_SD1_DAT2__SD1_DATA2 0x17071
919*4882a593Smuzhiyun			MX6QDL_PAD_SD1_DAT3__SD1_DATA3 0x17071
920*4882a593Smuzhiyun		>;
921*4882a593Smuzhiyun	};
922*4882a593Smuzhiyun
923*4882a593Smuzhiyun	pinctrl_usdhc1_8bit: usdhc1grp_8bit {
924*4882a593Smuzhiyun		fsl,pins = <
925*4882a593Smuzhiyun			MX6QDL_PAD_NANDF_D0__SD1_DATA4 0x17071
926*4882a593Smuzhiyun			MX6QDL_PAD_NANDF_D1__SD1_DATA5 0x17071
927*4882a593Smuzhiyun			MX6QDL_PAD_NANDF_D2__SD1_DATA6 0x17071
928*4882a593Smuzhiyun			MX6QDL_PAD_NANDF_D3__SD1_DATA7 0x17071
929*4882a593Smuzhiyun		>;
930*4882a593Smuzhiyun	};
931*4882a593Smuzhiyun
932*4882a593Smuzhiyun	pinctrl_usdhc2: usdhc2grp {
933*4882a593Smuzhiyun		fsl,pins = <
934*4882a593Smuzhiyun			MX6QDL_PAD_SD2_CMD__SD2_CMD    0x17071
935*4882a593Smuzhiyun			MX6QDL_PAD_SD2_CLK__SD2_CLK    0x10071
936*4882a593Smuzhiyun			MX6QDL_PAD_SD2_DAT0__SD2_DATA0 0x17071
937*4882a593Smuzhiyun			MX6QDL_PAD_SD2_DAT1__SD2_DATA1 0x17071
938*4882a593Smuzhiyun			MX6QDL_PAD_SD2_DAT2__SD2_DATA2 0x17071
939*4882a593Smuzhiyun			MX6QDL_PAD_SD2_DAT3__SD2_DATA3 0x17071
940*4882a593Smuzhiyun		>;
941*4882a593Smuzhiyun	};
942*4882a593Smuzhiyun
943*4882a593Smuzhiyun	pinctrl_usdhc3: usdhc3grp {
944*4882a593Smuzhiyun		fsl,pins = <
945*4882a593Smuzhiyun			MX6QDL_PAD_SD3_CMD__SD3_CMD    0x17059
946*4882a593Smuzhiyun			MX6QDL_PAD_SD3_CLK__SD3_CLK    0x10059
947*4882a593Smuzhiyun			MX6QDL_PAD_SD3_DAT0__SD3_DATA0 0x17059
948*4882a593Smuzhiyun			MX6QDL_PAD_SD3_DAT1__SD3_DATA1 0x17059
949*4882a593Smuzhiyun			MX6QDL_PAD_SD3_DAT2__SD3_DATA2 0x17059
950*4882a593Smuzhiyun			MX6QDL_PAD_SD3_DAT3__SD3_DATA3 0x17059
951*4882a593Smuzhiyun			MX6QDL_PAD_SD3_DAT4__SD3_DATA4 0x17059
952*4882a593Smuzhiyun			MX6QDL_PAD_SD3_DAT5__SD3_DATA5 0x17059
953*4882a593Smuzhiyun			MX6QDL_PAD_SD3_DAT6__SD3_DATA6 0x17059
954*4882a593Smuzhiyun			MX6QDL_PAD_SD3_DAT7__SD3_DATA7 0x17059
955*4882a593Smuzhiyun			/* eMMC reset */
956*4882a593Smuzhiyun			MX6QDL_PAD_SD3_RST__SD3_RESET  0x17059
957*4882a593Smuzhiyun		>;
958*4882a593Smuzhiyun	};
959*4882a593Smuzhiyun};
960