xref: /OK3568_Linux_fs/u-boot/arch/arm/dts/rk3288-popmetal.dtsi (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun/*
2*4882a593Smuzhiyun * This file is dual-licensed: you can use it either under the terms
3*4882a593Smuzhiyun * of the GPL or the X11 license, at your option. Note that this dual
4*4882a593Smuzhiyun * licensing only applies to this file, and not this project as a
5*4882a593Smuzhiyun * whole.
6*4882a593Smuzhiyun *
7*4882a593Smuzhiyun *  a) This file is free software; you can redistribute it and/or
8*4882a593Smuzhiyun *     modify it under the terms of the GNU General Public License as
9*4882a593Smuzhiyun *     published by the Free Software Foundation; either version 2 of the
10*4882a593Smuzhiyun *     License, or (at your option) any later version.
11*4882a593Smuzhiyun *
12*4882a593Smuzhiyun *     This file is distributed in the hope that it will be useful,
13*4882a593Smuzhiyun *     but WITHOUT ANY WARRANTY; without even the implied warranty of
14*4882a593Smuzhiyun *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15*4882a593Smuzhiyun *     GNU General Public License for more details.
16*4882a593Smuzhiyun *
17*4882a593Smuzhiyun *  Or, alternatively,
18*4882a593Smuzhiyun *
19*4882a593Smuzhiyun *  b) Permission is hereby granted, free of charge, to any person
20*4882a593Smuzhiyun *     obtaining a copy of this software and associated documentation
21*4882a593Smuzhiyun *     files (the "Software"), to deal in the Software without
22*4882a593Smuzhiyun *     restriction, including without limitation the rights to use,
23*4882a593Smuzhiyun *     copy, modify, merge, publish, distribute, sublicense, and/or
24*4882a593Smuzhiyun *     sell copies of the Software, and to permit persons to whom the
25*4882a593Smuzhiyun *     Software is furnished to do so, subject to the following
26*4882a593Smuzhiyun *     conditions:
27*4882a593Smuzhiyun *
28*4882a593Smuzhiyun *     The above copyright notice and this permission notice shall be
29*4882a593Smuzhiyun *     included in all copies or substantial portions of the Software.
30*4882a593Smuzhiyun *
31*4882a593Smuzhiyun *     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
32*4882a593Smuzhiyun *     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
33*4882a593Smuzhiyun *     OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
34*4882a593Smuzhiyun *     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
35*4882a593Smuzhiyun *     HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
36*4882a593Smuzhiyun *     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
37*4882a593Smuzhiyun *     FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
38*4882a593Smuzhiyun *     OTHER DEALINGS IN THE SOFTWARE.
39*4882a593Smuzhiyun */
40*4882a593Smuzhiyun
41*4882a593Smuzhiyun#include "rk3288.dtsi"
42*4882a593Smuzhiyun#include "rk3288-u-boot.dtsi"
43*4882a593Smuzhiyun
44*4882a593Smuzhiyun/ {
45*4882a593Smuzhiyun	memory{
46*4882a593Smuzhiyun		device_type = "memory";
47*4882a593Smuzhiyun		reg = <0 0x80000000>;
48*4882a593Smuzhiyun	};
49*4882a593Smuzhiyun
50*4882a593Smuzhiyun	ext_gmac: external-gmac-clock {
51*4882a593Smuzhiyun		compatible = "fixed-clock";
52*4882a593Smuzhiyun		clock-frequency = <125000000>;
53*4882a593Smuzhiyun		clock-output-names = "ext_gmac";
54*4882a593Smuzhiyun		#clock-cells = <0>;
55*4882a593Smuzhiyun	};
56*4882a593Smuzhiyun
57*4882a593Smuzhiyun	gpio-keys {
58*4882a593Smuzhiyun		compatible = "gpio-keys";
59*4882a593Smuzhiyun		autorepeat;
60*4882a593Smuzhiyun
61*4882a593Smuzhiyun		pinctrl-names = "default";
62*4882a593Smuzhiyun		pinctrl-0 = <&pwrbtn>;
63*4882a593Smuzhiyun
64*4882a593Smuzhiyun		power {
65*4882a593Smuzhiyun			gpios = <&gpio0 5 GPIO_ACTIVE_LOW>;
66*4882a593Smuzhiyun			label = "GPIO Key Power";
67*4882a593Smuzhiyun			linux,input-type = <1>;
68*4882a593Smuzhiyun			wakeup-source;
69*4882a593Smuzhiyun			debounce-interval = <100>;
70*4882a593Smuzhiyun		};
71*4882a593Smuzhiyun	};
72*4882a593Smuzhiyun
73*4882a593Smuzhiyun	io_domains: io-domains {
74*4882a593Smuzhiyun		compatible = "rockchip,rk3288-io-voltage-domain";
75*4882a593Smuzhiyun		rockchip,grf = <&grf>;
76*4882a593Smuzhiyun
77*4882a593Smuzhiyun		audio-supply = <&vcca_33>;
78*4882a593Smuzhiyun		bb-supply = <&vcc_io>;
79*4882a593Smuzhiyun		dvp-supply = <&vcc18_dvp>;
80*4882a593Smuzhiyun		flash0-supply = <&vcc_flash>;
81*4882a593Smuzhiyun		flash1-supply = <&vcc_lan>;
82*4882a593Smuzhiyun		gpio30-supply = <&vcc_io>;
83*4882a593Smuzhiyun		gpio1830-supply = <&vcc_io>;
84*4882a593Smuzhiyun		lcdc-supply = <&vcc_io>;
85*4882a593Smuzhiyun		sdcard-supply = <&vccio_sd>;
86*4882a593Smuzhiyun		wifi-supply = <&vccio_wl>;
87*4882a593Smuzhiyun	};
88*4882a593Smuzhiyun
89*4882a593Smuzhiyun	ir: ir-receiver {
90*4882a593Smuzhiyun		compatible = "gpio-ir-receiver";
91*4882a593Smuzhiyun		gpios = <&gpio0 6 GPIO_ACTIVE_LOW>;
92*4882a593Smuzhiyun		pinctrl-names = "default";
93*4882a593Smuzhiyun		pinctrl-0 = <&ir_int>;
94*4882a593Smuzhiyun	};
95*4882a593Smuzhiyun
96*4882a593Smuzhiyun	vcc_flash: flash-regulator {
97*4882a593Smuzhiyun		compatible = "regulator-fixed";
98*4882a593Smuzhiyun		regulator-name = "vcc_flash";
99*4882a593Smuzhiyun		regulator-min-microvolt = <1800000>;
100*4882a593Smuzhiyun		regulator-max-microvolt = <1800000>;
101*4882a593Smuzhiyun		vin-supply = <&vcc_io>;
102*4882a593Smuzhiyun	};
103*4882a593Smuzhiyun
104*4882a593Smuzhiyun	vcc_sd: sdmmc-regulator {
105*4882a593Smuzhiyun		compatible = "regulator-fixed";
106*4882a593Smuzhiyun		gpio = <&gpio7 11 GPIO_ACTIVE_LOW>;
107*4882a593Smuzhiyun		pinctrl-names = "default";
108*4882a593Smuzhiyun		pinctrl-0 = <&sdmmc_pwr>;
109*4882a593Smuzhiyun		regulator-name = "vcc_sd";
110*4882a593Smuzhiyun		regulator-min-microvolt = <3300000>;
111*4882a593Smuzhiyun		regulator-max-microvolt = <3300000>;
112*4882a593Smuzhiyun		startup-delay-us = <100000>;
113*4882a593Smuzhiyun		vin-supply = <&vcc_io>;
114*4882a593Smuzhiyun	};
115*4882a593Smuzhiyun
116*4882a593Smuzhiyun	vcc_sys: vsys-regulator {
117*4882a593Smuzhiyun		compatible = "regulator-fixed";
118*4882a593Smuzhiyun		regulator-name = "vcc_sys";
119*4882a593Smuzhiyun		regulator-min-microvolt = <5000000>;
120*4882a593Smuzhiyun		regulator-max-microvolt = <5000000>;
121*4882a593Smuzhiyun		regulator-always-on;
122*4882a593Smuzhiyun		regulator-boot-on;
123*4882a593Smuzhiyun	};
124*4882a593Smuzhiyun
125*4882a593Smuzhiyun	/*
126*4882a593Smuzhiyun	 * A PT5128 creates both dovdd_1v8 and vcc28_dvp, controlled
127*4882a593Smuzhiyun	 * by the dvp_pwr pin.
128*4882a593Smuzhiyun	 */
129*4882a593Smuzhiyun	vcc18_dvp: vcc18-dvp-regulator {
130*4882a593Smuzhiyun		compatible = "regulator-fixed";
131*4882a593Smuzhiyun		regulator-name = "vcc18-dvp";
132*4882a593Smuzhiyun		regulator-min-microvolt = <1800000>;
133*4882a593Smuzhiyun		regulator-max-microvolt = <1800000>;
134*4882a593Smuzhiyun		vin-supply = <&vcc28_dvp>;
135*4882a593Smuzhiyun	};
136*4882a593Smuzhiyun
137*4882a593Smuzhiyun	vcc28_dvp: vcc28-dvp-regulator {
138*4882a593Smuzhiyun		compatible = "regulator-fixed";
139*4882a593Smuzhiyun		enable-active-high;
140*4882a593Smuzhiyun		gpio = <&gpio0 17 GPIO_ACTIVE_HIGH>;
141*4882a593Smuzhiyun		pinctrl-names = "default";
142*4882a593Smuzhiyun		pinctrl-0 = <&dvp_pwr>;
143*4882a593Smuzhiyun		regulator-name = "vcc28_dvp";
144*4882a593Smuzhiyun		regulator-min-microvolt = <2800000>;
145*4882a593Smuzhiyun		regulator-max-microvolt = <2800000>;
146*4882a593Smuzhiyun		regulator-always-on;
147*4882a593Smuzhiyun		vin-supply = <&vcc_io>;
148*4882a593Smuzhiyun	};
149*4882a593Smuzhiyun
150*4882a593Smuzhiyun	vcc5v0_host: usb-host-regulator {
151*4882a593Smuzhiyun		compatible = "regulator-fixed";
152*4882a593Smuzhiyun		enable-active-high;
153*4882a593Smuzhiyun		gpio = <&gpio0 14 GPIO_ACTIVE_HIGH>;
154*4882a593Smuzhiyun		pinctrl-names = "default";
155*4882a593Smuzhiyun		pinctrl-0 = <&host_vbus_drv>;
156*4882a593Smuzhiyun		regulator-name = "vcc5v0_host";
157*4882a593Smuzhiyun		regulator-min-microvolt = <5000000>;
158*4882a593Smuzhiyun		regulator-max-microvolt = <5000000>;
159*4882a593Smuzhiyun		regulator-always-on;
160*4882a593Smuzhiyun	};
161*4882a593Smuzhiyun};
162*4882a593Smuzhiyun
163*4882a593Smuzhiyun&cpu0 {
164*4882a593Smuzhiyun	cpu0-supply = <&vdd_cpu>;
165*4882a593Smuzhiyun};
166*4882a593Smuzhiyun
167*4882a593Smuzhiyun&emmc {
168*4882a593Smuzhiyun	bus-width = <8>;
169*4882a593Smuzhiyun	cap-mmc-highspeed;
170*4882a593Smuzhiyun	disable-wp;
171*4882a593Smuzhiyun	non-removable;
172*4882a593Smuzhiyun	num-slots = <1>;
173*4882a593Smuzhiyun	pinctrl-names = "default";
174*4882a593Smuzhiyun	pinctrl-0 = <&emmc_clk &emmc_cmd &emmc_pwr &emmc_bus8>;
175*4882a593Smuzhiyun	vmmc-supply = <&vcc_io>;
176*4882a593Smuzhiyun	vqmmc-supply = <&vcc_flash>;
177*4882a593Smuzhiyun	status = "okay";
178*4882a593Smuzhiyun};
179*4882a593Smuzhiyun
180*4882a593Smuzhiyun&sdmmc {
181*4882a593Smuzhiyun	bus-width = <4>;
182*4882a593Smuzhiyun	cap-mmc-highspeed;
183*4882a593Smuzhiyun	cap-sd-highspeed;
184*4882a593Smuzhiyun	card-detect-delay = <200>;
185*4882a593Smuzhiyun	disable-wp;
186*4882a593Smuzhiyun	num-slots = <1>;
187*4882a593Smuzhiyun	pinctrl-names = "default";
188*4882a593Smuzhiyun	pinctrl-0 = <&sdmmc_clk &sdmmc_cmd &sdmmc_cd &sdmmc_bus4>;
189*4882a593Smuzhiyun	vmmc-supply = <&vcc_sd>;
190*4882a593Smuzhiyun	vqmmc-supply = <&vccio_sd>;
191*4882a593Smuzhiyun	status = "okay";
192*4882a593Smuzhiyun};
193*4882a593Smuzhiyun
194*4882a593Smuzhiyun&gmac {
195*4882a593Smuzhiyun	phy-supply = <&vcc_lan>;
196*4882a593Smuzhiyun	phy-mode = "rgmii";
197*4882a593Smuzhiyun	clock_in_out = "input";
198*4882a593Smuzhiyun	snps,reset-gpio = <&gpio4 7 0>;
199*4882a593Smuzhiyun	snps,reset-active-low;
200*4882a593Smuzhiyun	snps,reset-delays-us = <0 10000 1000000>;
201*4882a593Smuzhiyun	assigned-clocks = <&cru SCLK_MAC>;
202*4882a593Smuzhiyun	assigned-clock-parents = <&ext_gmac>;
203*4882a593Smuzhiyun	pinctrl-names = "default";
204*4882a593Smuzhiyun	pinctrl-0 = <&rgmii_pins>;
205*4882a593Smuzhiyun	tx_delay = <0x30>;
206*4882a593Smuzhiyun	rx_delay = <0x10>;
207*4882a593Smuzhiyun	status = "okay";
208*4882a593Smuzhiyun};
209*4882a593Smuzhiyun
210*4882a593Smuzhiyun&hdmi {
211*4882a593Smuzhiyun	ddc-i2c-bus = <&i2c5>;
212*4882a593Smuzhiyun	status = "okay";
213*4882a593Smuzhiyun};
214*4882a593Smuzhiyun
215*4882a593Smuzhiyun&i2c0 {
216*4882a593Smuzhiyun	status = "okay";
217*4882a593Smuzhiyun	clock-frequency = <400000>;
218*4882a593Smuzhiyun
219*4882a593Smuzhiyun	rk808: pmic@1b {
220*4882a593Smuzhiyun		compatible = "rockchip,rk808";
221*4882a593Smuzhiyun		reg = <0x1b>;
222*4882a593Smuzhiyun		interrupt-parent = <&gpio0>;
223*4882a593Smuzhiyun		interrupts = <4 IRQ_TYPE_LEVEL_LOW>;
224*4882a593Smuzhiyun		pinctrl-names = "default";
225*4882a593Smuzhiyun		pinctrl-0 = <&pmic_int &global_pwroff>;
226*4882a593Smuzhiyun		rockchip,system-power-controller;
227*4882a593Smuzhiyun		wakeup-source;
228*4882a593Smuzhiyun		#clock-cells = <1>;
229*4882a593Smuzhiyun		clock-output-names = "xin32k", "rk808-clkout2";
230*4882a593Smuzhiyun
231*4882a593Smuzhiyun		vcc1-supply = <&vcc_sys>;
232*4882a593Smuzhiyun		vcc2-supply = <&vcc_sys>;
233*4882a593Smuzhiyun		vcc3-supply = <&vcc_sys>;
234*4882a593Smuzhiyun		vcc4-supply = <&vcc_sys>;
235*4882a593Smuzhiyun		vcc6-supply = <&vcc_sys>;
236*4882a593Smuzhiyun		vcc7-supply = <&vcc_sys>;
237*4882a593Smuzhiyun		vcc8-supply = <&vcc_18>;
238*4882a593Smuzhiyun		vcc9-supply = <&vcc_io>;
239*4882a593Smuzhiyun		vcc10-supply = <&vcc_io>;
240*4882a593Smuzhiyun		vcc11-supply = <&vcc_sys>;
241*4882a593Smuzhiyun		vcc12-supply = <&vcc_io>;
242*4882a593Smuzhiyun		vddio-supply = <&vcc_io>;
243*4882a593Smuzhiyun
244*4882a593Smuzhiyun		regulators {
245*4882a593Smuzhiyun			vdd_cpu: DCDC_REG1 {
246*4882a593Smuzhiyun				regulator-always-on;
247*4882a593Smuzhiyun				regulator-boot-on;
248*4882a593Smuzhiyun				regulator-min-microvolt = <750000>;
249*4882a593Smuzhiyun				regulator-max-microvolt = <1350000>;
250*4882a593Smuzhiyun				regulator-name = "vdd_arm";
251*4882a593Smuzhiyun				regulator-state-mem {
252*4882a593Smuzhiyun					regulator-off-in-suspend;
253*4882a593Smuzhiyun				};
254*4882a593Smuzhiyun			};
255*4882a593Smuzhiyun
256*4882a593Smuzhiyun			vdd_gpu: DCDC_REG2 {
257*4882a593Smuzhiyun				regulator-always-on;
258*4882a593Smuzhiyun				regulator-boot-on;
259*4882a593Smuzhiyun				regulator-min-microvolt = <850000>;
260*4882a593Smuzhiyun				regulator-max-microvolt = <1250000>;
261*4882a593Smuzhiyun				regulator-name = "vdd_gpu";
262*4882a593Smuzhiyun				regulator-state-mem {
263*4882a593Smuzhiyun					regulator-on-in-suspend;
264*4882a593Smuzhiyun					regulator-suspend-microvolt = <1000000>;
265*4882a593Smuzhiyun				};
266*4882a593Smuzhiyun			};
267*4882a593Smuzhiyun
268*4882a593Smuzhiyun			vcc_ddr: DCDC_REG3 {
269*4882a593Smuzhiyun				regulator-always-on;
270*4882a593Smuzhiyun				regulator-boot-on;
271*4882a593Smuzhiyun				regulator-name = "vcc_ddr";
272*4882a593Smuzhiyun				regulator-state-mem {
273*4882a593Smuzhiyun					regulator-on-in-suspend;
274*4882a593Smuzhiyun				};
275*4882a593Smuzhiyun			};
276*4882a593Smuzhiyun
277*4882a593Smuzhiyun			vcc_io: DCDC_REG4 {
278*4882a593Smuzhiyun				regulator-always-on;
279*4882a593Smuzhiyun				regulator-boot-on;
280*4882a593Smuzhiyun				regulator-min-microvolt = <3300000>;
281*4882a593Smuzhiyun				regulator-max-microvolt = <3300000>;
282*4882a593Smuzhiyun				regulator-name = "vcc_io";
283*4882a593Smuzhiyun				regulator-state-mem {
284*4882a593Smuzhiyun					regulator-on-in-suspend;
285*4882a593Smuzhiyun					regulator-suspend-microvolt = <3300000>;
286*4882a593Smuzhiyun				};
287*4882a593Smuzhiyun			};
288*4882a593Smuzhiyun
289*4882a593Smuzhiyun			vcc_lan: LDO_REG1 {
290*4882a593Smuzhiyun				regulator-always-on;
291*4882a593Smuzhiyun				regulator-boot-on;
292*4882a593Smuzhiyun				regulator-min-microvolt = <3300000>;
293*4882a593Smuzhiyun				regulator-max-microvolt = <3300000>;
294*4882a593Smuzhiyun				regulator-name = "vcc_lan";
295*4882a593Smuzhiyun				regulator-state-mem {
296*4882a593Smuzhiyun					regulator-on-in-suspend;
297*4882a593Smuzhiyun					regulator-suspend-microvolt = <3300000>;
298*4882a593Smuzhiyun				};
299*4882a593Smuzhiyun			};
300*4882a593Smuzhiyun
301*4882a593Smuzhiyun			vccio_sd: LDO_REG2 {
302*4882a593Smuzhiyun				regulator-always-on;
303*4882a593Smuzhiyun				regulator-boot-on;
304*4882a593Smuzhiyun				regulator-min-microvolt = <3300000>;
305*4882a593Smuzhiyun				regulator-max-microvolt = <3300000>;
306*4882a593Smuzhiyun				regulator-name = "vccio_sd";
307*4882a593Smuzhiyun				regulator-state-mem {
308*4882a593Smuzhiyun					regulator-off-in-suspend;
309*4882a593Smuzhiyun				};
310*4882a593Smuzhiyun			};
311*4882a593Smuzhiyun
312*4882a593Smuzhiyun			vdd_10: LDO_REG3 {
313*4882a593Smuzhiyun				regulator-always-on;
314*4882a593Smuzhiyun				regulator-boot-on;
315*4882a593Smuzhiyun				regulator-min-microvolt = <1000000>;
316*4882a593Smuzhiyun				regulator-max-microvolt = <1000000>;
317*4882a593Smuzhiyun				regulator-name = "vdd_10";
318*4882a593Smuzhiyun				regulator-state-mem {
319*4882a593Smuzhiyun					regulator-on-in-suspend;
320*4882a593Smuzhiyun					regulator-suspend-microvolt = <1000000>;
321*4882a593Smuzhiyun				};
322*4882a593Smuzhiyun			};
323*4882a593Smuzhiyun
324*4882a593Smuzhiyun			vcc18_lcd: LDO_REG4 {
325*4882a593Smuzhiyun				regulator-always-on;
326*4882a593Smuzhiyun				regulator-boot-on;
327*4882a593Smuzhiyun				regulator-min-microvolt = <1800000>;
328*4882a593Smuzhiyun				regulator-max-microvolt = <1800000>;
329*4882a593Smuzhiyun				regulator-name = "vcc18_lcd";
330*4882a593Smuzhiyun				regulator-state-mem {
331*4882a593Smuzhiyun					regulator-on-in-suspend;
332*4882a593Smuzhiyun					regulator-suspend-microvolt = <1800000>;
333*4882a593Smuzhiyun				};
334*4882a593Smuzhiyun			};
335*4882a593Smuzhiyun
336*4882a593Smuzhiyun			ldo5: LDO_REG5 {
337*4882a593Smuzhiyun				regulator-always-on;
338*4882a593Smuzhiyun				regulator-min-microvolt = <1800000>;
339*4882a593Smuzhiyun				regulator-max-microvolt = <3300000>;
340*4882a593Smuzhiyun				regulator-name = "ldo5";
341*4882a593Smuzhiyun			};
342*4882a593Smuzhiyun
343*4882a593Smuzhiyun			vdd10_lcd: LDO_REG6 {
344*4882a593Smuzhiyun				regulator-always-on;
345*4882a593Smuzhiyun				regulator-boot-on;
346*4882a593Smuzhiyun				regulator-min-microvolt = <1000000>;
347*4882a593Smuzhiyun				regulator-max-microvolt = <1000000>;
348*4882a593Smuzhiyun				regulator-name = "vdd10_lcd";
349*4882a593Smuzhiyun				regulator-state-mem {
350*4882a593Smuzhiyun					regulator-on-in-suspend;
351*4882a593Smuzhiyun					regulator-suspend-microvolt = <1000000>;
352*4882a593Smuzhiyun				};
353*4882a593Smuzhiyun			};
354*4882a593Smuzhiyun
355*4882a593Smuzhiyun			vcc_18: LDO_REG7 {
356*4882a593Smuzhiyun				regulator-always-on;
357*4882a593Smuzhiyun				regulator-boot-on;
358*4882a593Smuzhiyun				regulator-min-microvolt = <1800000>;
359*4882a593Smuzhiyun				regulator-max-microvolt = <1800000>;
360*4882a593Smuzhiyun				regulator-name = "vcc_18";
361*4882a593Smuzhiyun				regulator-state-mem {
362*4882a593Smuzhiyun					regulator-on-in-suspend;
363*4882a593Smuzhiyun					regulator-suspend-microvolt = <1800000>;
364*4882a593Smuzhiyun				};
365*4882a593Smuzhiyun			};
366*4882a593Smuzhiyun
367*4882a593Smuzhiyun			vcca_33: LDO_REG8 {
368*4882a593Smuzhiyun				regulator-always-on;
369*4882a593Smuzhiyun				regulator-boot-on;
370*4882a593Smuzhiyun				regulator-min-microvolt = <3300000>;
371*4882a593Smuzhiyun				regulator-max-microvolt = <3300000>;
372*4882a593Smuzhiyun				regulator-name = "vcca_33";
373*4882a593Smuzhiyun				regulator-state-mem {
374*4882a593Smuzhiyun					regulator-on-in-suspend;
375*4882a593Smuzhiyun					regulator-suspend-microvolt = <3300000>;
376*4882a593Smuzhiyun				};
377*4882a593Smuzhiyun			};
378*4882a593Smuzhiyun
379*4882a593Smuzhiyun			vccio_wl: SWITCH_REG1 {
380*4882a593Smuzhiyun				regulator-always-on;
381*4882a593Smuzhiyun				regulator-boot-on;
382*4882a593Smuzhiyun				regulator-name = "vccio_wl";
383*4882a593Smuzhiyun				regulator-state-mem {
384*4882a593Smuzhiyun					regulator-on-in-suspend;
385*4882a593Smuzhiyun				};
386*4882a593Smuzhiyun			};
387*4882a593Smuzhiyun
388*4882a593Smuzhiyun			vcc_lcd: SWITCH_REG2 {
389*4882a593Smuzhiyun				regulator-always-on;
390*4882a593Smuzhiyun				regulator-boot-on;
391*4882a593Smuzhiyun				regulator-name = "vcc_lcd";
392*4882a593Smuzhiyun				regulator-state-mem {
393*4882a593Smuzhiyun					regulator-on-in-suspend;
394*4882a593Smuzhiyun				};
395*4882a593Smuzhiyun			};
396*4882a593Smuzhiyun		};
397*4882a593Smuzhiyun	};
398*4882a593Smuzhiyun};
399*4882a593Smuzhiyun
400*4882a593Smuzhiyun&i2c1 {
401*4882a593Smuzhiyun	status = "okay";
402*4882a593Smuzhiyun	clock-frequency = <400000>;
403*4882a593Smuzhiyun
404*4882a593Smuzhiyun	ak8963: ak8963@0d {
405*4882a593Smuzhiyun		compatible = "asahi-kasei,ak8975";
406*4882a593Smuzhiyun		reg = <0x0d>;
407*4882a593Smuzhiyun		interrupt-parent = <&gpio8>;
408*4882a593Smuzhiyun		interrupts = <1 IRQ_TYPE_EDGE_RISING>;
409*4882a593Smuzhiyun		pinctrl-names = "default";
410*4882a593Smuzhiyun		pinctrl-0 = <&comp_int>;
411*4882a593Smuzhiyun	};
412*4882a593Smuzhiyun
413*4882a593Smuzhiyun	l3g4200d: l3g4200d@68 {
414*4882a593Smuzhiyun		compatible = "st,l3g4200d-gyro";
415*4882a593Smuzhiyun		st,drdy-int-pin = <2>;
416*4882a593Smuzhiyun		reg = <0x6b>;
417*4882a593Smuzhiyun	};
418*4882a593Smuzhiyun
419*4882a593Smuzhiyun	mma8452: mma8452@1d {
420*4882a593Smuzhiyun		compatible = "fsl,mma8452";
421*4882a593Smuzhiyun		reg = <0x1d>;
422*4882a593Smuzhiyun		interrupt-parent = <&gpio8>;
423*4882a593Smuzhiyun		interrupts = <0 IRQ_TYPE_EDGE_RISING>;
424*4882a593Smuzhiyun		pinctrl-names = "default";
425*4882a593Smuzhiyun		pinctrl-0 = <&gsensor_int>;
426*4882a593Smuzhiyun	};
427*4882a593Smuzhiyun};
428*4882a593Smuzhiyun
429*4882a593Smuzhiyun&i2c2 {
430*4882a593Smuzhiyun	status = "okay";
431*4882a593Smuzhiyun};
432*4882a593Smuzhiyun
433*4882a593Smuzhiyun&i2c3 {
434*4882a593Smuzhiyun	status = "okay";
435*4882a593Smuzhiyun};
436*4882a593Smuzhiyun
437*4882a593Smuzhiyun&i2c4 {
438*4882a593Smuzhiyun	status = "okay";
439*4882a593Smuzhiyun};
440*4882a593Smuzhiyun
441*4882a593Smuzhiyun&i2c5 {
442*4882a593Smuzhiyun	status = "okay";
443*4882a593Smuzhiyun};
444*4882a593Smuzhiyun
445*4882a593Smuzhiyun&pinctrl {
446*4882a593Smuzhiyun	ak8963 {
447*4882a593Smuzhiyun		comp_int: comp-int {
448*4882a593Smuzhiyun			rockchip,pins = <8 1 RK_FUNC_GPIO &pcfg_pull_up>;
449*4882a593Smuzhiyun		};
450*4882a593Smuzhiyun	};
451*4882a593Smuzhiyun
452*4882a593Smuzhiyun	buttons {
453*4882a593Smuzhiyun		pwrbtn: pwrbtn {
454*4882a593Smuzhiyun			rockchip,pins = <0 5 RK_FUNC_GPIO &pcfg_pull_up>;
455*4882a593Smuzhiyun		};
456*4882a593Smuzhiyun	};
457*4882a593Smuzhiyun
458*4882a593Smuzhiyun	dvp {
459*4882a593Smuzhiyun		dvp_pwr: dvp-pwr {
460*4882a593Smuzhiyun			rockchip,pins = <0 17 RK_FUNC_GPIO &pcfg_pull_none>;
461*4882a593Smuzhiyun		};
462*4882a593Smuzhiyun	};
463*4882a593Smuzhiyun
464*4882a593Smuzhiyun	ir {
465*4882a593Smuzhiyun		ir_int: ir-int {
466*4882a593Smuzhiyun			rockchip,pins = <0 6 RK_FUNC_GPIO &pcfg_pull_up>;
467*4882a593Smuzhiyun		};
468*4882a593Smuzhiyun	};
469*4882a593Smuzhiyun
470*4882a593Smuzhiyun	mma8452 {
471*4882a593Smuzhiyun		gsensor_int: gsensor-int {
472*4882a593Smuzhiyun			rockchip,pins = <8 0 RK_FUNC_GPIO &pcfg_pull_up>;
473*4882a593Smuzhiyun		};
474*4882a593Smuzhiyun	};
475*4882a593Smuzhiyun
476*4882a593Smuzhiyun	pmic {
477*4882a593Smuzhiyun		pmic_int: pmic-int {
478*4882a593Smuzhiyun			rockchip,pins = <RK_GPIO0 4 RK_FUNC_GPIO &pcfg_pull_up>;
479*4882a593Smuzhiyun		};
480*4882a593Smuzhiyun	};
481*4882a593Smuzhiyun
482*4882a593Smuzhiyun	sdmmc {
483*4882a593Smuzhiyun		sdmmc_pwr: sdmmc-pwr {
484*4882a593Smuzhiyun			rockchip,pins = <7 11 RK_FUNC_GPIO &pcfg_pull_none>;
485*4882a593Smuzhiyun		};
486*4882a593Smuzhiyun	};
487*4882a593Smuzhiyun
488*4882a593Smuzhiyun	usb_host {
489*4882a593Smuzhiyun		host_vbus_drv: host-vbus-drv {
490*4882a593Smuzhiyun			rockchip,pins = <0 14 RK_FUNC_GPIO &pcfg_pull_none>;
491*4882a593Smuzhiyun		};
492*4882a593Smuzhiyun	};
493*4882a593Smuzhiyun};
494*4882a593Smuzhiyun
495*4882a593Smuzhiyun&saradc {
496*4882a593Smuzhiyun	status = "okay";
497*4882a593Smuzhiyun};
498*4882a593Smuzhiyun
499*4882a593Smuzhiyun&tsadc {
500*4882a593Smuzhiyun	rockchip,hw-tshut-mode = <0>;
501*4882a593Smuzhiyun	rockchip,hw-tshut-polarity = <0>;
502*4882a593Smuzhiyun	status = "okay";
503*4882a593Smuzhiyun};
504*4882a593Smuzhiyun
505*4882a593Smuzhiyun&vopb {
506*4882a593Smuzhiyun	status = "okay";
507*4882a593Smuzhiyun};
508*4882a593Smuzhiyun
509*4882a593Smuzhiyun&vopb_mmu {
510*4882a593Smuzhiyun	status = "okay";
511*4882a593Smuzhiyun};
512*4882a593Smuzhiyun
513*4882a593Smuzhiyun&vopl {
514*4882a593Smuzhiyun	status = "okay";
515*4882a593Smuzhiyun};
516*4882a593Smuzhiyun
517*4882a593Smuzhiyun&vopl_mmu {
518*4882a593Smuzhiyun	status = "okay";
519*4882a593Smuzhiyun};
520*4882a593Smuzhiyun
521*4882a593Smuzhiyun&uart0 {
522*4882a593Smuzhiyun	status = "okay";
523*4882a593Smuzhiyun};
524*4882a593Smuzhiyun
525*4882a593Smuzhiyun&uart1 {
526*4882a593Smuzhiyun	status = "okay";
527*4882a593Smuzhiyun};
528*4882a593Smuzhiyun
529*4882a593Smuzhiyun&uart2 {
530*4882a593Smuzhiyun	status = "okay";
531*4882a593Smuzhiyun};
532*4882a593Smuzhiyun
533*4882a593Smuzhiyun&uart3 {
534*4882a593Smuzhiyun	status = "okay";
535*4882a593Smuzhiyun};
536*4882a593Smuzhiyun
537*4882a593Smuzhiyun&uart4 {
538*4882a593Smuzhiyun	status = "okay";
539*4882a593Smuzhiyun};
540*4882a593Smuzhiyun
541*4882a593Smuzhiyun&usb_host1 {
542*4882a593Smuzhiyun	vbus-supply = <&vcc5v0_host>;
543*4882a593Smuzhiyun	status = "okay";
544*4882a593Smuzhiyun};
545*4882a593Smuzhiyun
546*4882a593Smuzhiyun&usbphy {
547*4882a593Smuzhiyun	status = "okay";
548*4882a593Smuzhiyun};
549