17053e06bSLiang Chen// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
27053e06bSLiang Chen/*
37053e06bSLiang Chen * Copyright (c) 2018 Fuzhou Rockchip Electronics Co., Ltd
47053e06bSLiang Chen */
57053e06bSLiang Chen
67053e06bSLiang Chen#include <dt-bindings/clock/px30-cru.h>
77053e06bSLiang Chen#include <dt-bindings/gpio/gpio.h>
87053e06bSLiang Chen#include <dt-bindings/interrupt-controller/arm-gic.h>
97053e06bSLiang Chen#include <dt-bindings/interrupt-controller/irq.h>
107053e06bSLiang Chen#include <dt-bindings/pinctrl/rockchip.h>
117053e06bSLiang Chen#include <dt-bindings/power/px30-power.h>
127053e06bSLiang Chen#include <dt-bindings/soc/rockchip,boot-mode.h>
137053e06bSLiang Chen
147053e06bSLiang Chen/ {
157053e06bSLiang Chen	compatible = "rockchip,px30";
167053e06bSLiang Chen
177053e06bSLiang Chen	interrupt-parent = <&gic>;
187053e06bSLiang Chen	#address-cells = <2>;
197053e06bSLiang Chen	#size-cells = <2>;
207053e06bSLiang Chen
217053e06bSLiang Chen	aliases {
227053e06bSLiang Chen		ethernet0 = &gmac;
237053e06bSLiang Chen		i2c0 = &i2c0;
247053e06bSLiang Chen		i2c1 = &i2c1;
257053e06bSLiang Chen		i2c2 = &i2c2;
267053e06bSLiang Chen		i2c3 = &i2c3;
277053e06bSLiang Chen		serial0 = &uart0;
287053e06bSLiang Chen		serial1 = &uart1;
297053e06bSLiang Chen		serial2 = &uart2;
307053e06bSLiang Chen		serial3 = &uart3;
317053e06bSLiang Chen		serial4 = &uart4;
327053e06bSLiang Chen		serial5 = &uart5;
337053e06bSLiang Chen		spi0 = &spi0;
347053e06bSLiang Chen		spi1 = &spi1;
357053e06bSLiang Chen	};
367053e06bSLiang Chen
377053e06bSLiang Chen	cpus {
387053e06bSLiang Chen		#address-cells = <2>;
397053e06bSLiang Chen		#size-cells = <0>;
407053e06bSLiang Chen
417053e06bSLiang Chen		cpu0: cpu@0 {
427053e06bSLiang Chen			device_type = "cpu";
4331af04cdSRob Herring			compatible = "arm,cortex-a35";
447053e06bSLiang Chen			reg = <0x0 0x0>;
457053e06bSLiang Chen			enable-method = "psci";
467053e06bSLiang Chen			clocks = <&cru ARMCLK>;
477053e06bSLiang Chen			#cooling-cells = <2>;
487053e06bSLiang Chen			cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>;
497053e06bSLiang Chen			dynamic-power-coefficient = <90>;
507053e06bSLiang Chen			operating-points-v2 = <&cpu0_opp_table>;
517053e06bSLiang Chen		};
527053e06bSLiang Chen
537053e06bSLiang Chen		cpu1: cpu@1 {
547053e06bSLiang Chen			device_type = "cpu";
5531af04cdSRob Herring			compatible = "arm,cortex-a35";
567053e06bSLiang Chen			reg = <0x0 0x1>;
577053e06bSLiang Chen			enable-method = "psci";
587053e06bSLiang Chen			clocks = <&cru ARMCLK>;
597053e06bSLiang Chen			#cooling-cells = <2>;
607053e06bSLiang Chen			cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>;
617053e06bSLiang Chen			dynamic-power-coefficient = <90>;
627053e06bSLiang Chen			operating-points-v2 = <&cpu0_opp_table>;
637053e06bSLiang Chen		};
647053e06bSLiang Chen
657053e06bSLiang Chen		cpu2: cpu@2 {
667053e06bSLiang Chen			device_type = "cpu";
6731af04cdSRob Herring			compatible = "arm,cortex-a35";
687053e06bSLiang Chen			reg = <0x0 0x2>;
697053e06bSLiang Chen			enable-method = "psci";
707053e06bSLiang Chen			clocks = <&cru ARMCLK>;
717053e06bSLiang Chen			#cooling-cells = <2>;
727053e06bSLiang Chen			cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>;
737053e06bSLiang Chen			dynamic-power-coefficient = <90>;
747053e06bSLiang Chen			operating-points-v2 = <&cpu0_opp_table>;
757053e06bSLiang Chen		};
767053e06bSLiang Chen
777053e06bSLiang Chen		cpu3: cpu@3 {
787053e06bSLiang Chen			device_type = "cpu";
7931af04cdSRob Herring			compatible = "arm,cortex-a35";
807053e06bSLiang Chen			reg = <0x0 0x3>;
817053e06bSLiang Chen			enable-method = "psci";
827053e06bSLiang Chen			clocks = <&cru ARMCLK>;
837053e06bSLiang Chen			#cooling-cells = <2>;
847053e06bSLiang Chen			cpu-idle-states = <&CPU_SLEEP &CLUSTER_SLEEP>;
857053e06bSLiang Chen			dynamic-power-coefficient = <90>;
867053e06bSLiang Chen			operating-points-v2 = <&cpu0_opp_table>;
877053e06bSLiang Chen		};
887053e06bSLiang Chen
897053e06bSLiang Chen		idle-states {
907053e06bSLiang Chen			entry-method = "psci";
917053e06bSLiang Chen
927053e06bSLiang Chen			CPU_SLEEP: cpu-sleep {
937053e06bSLiang Chen				compatible = "arm,idle-state";
947053e06bSLiang Chen				local-timer-stop;
957053e06bSLiang Chen				arm,psci-suspend-param = <0x0010000>;
967053e06bSLiang Chen				entry-latency-us = <120>;
977053e06bSLiang Chen				exit-latency-us = <250>;
987053e06bSLiang Chen				min-residency-us = <900>;
997053e06bSLiang Chen			};
1007053e06bSLiang Chen
1017053e06bSLiang Chen			CLUSTER_SLEEP: cluster-sleep {
1027053e06bSLiang Chen				compatible = "arm,idle-state";
1037053e06bSLiang Chen				local-timer-stop;
1047053e06bSLiang Chen				arm,psci-suspend-param = <0x1010000>;
1057053e06bSLiang Chen				entry-latency-us = <400>;
1067053e06bSLiang Chen				exit-latency-us = <500>;
1077053e06bSLiang Chen				min-residency-us = <2000>;
1087053e06bSLiang Chen			};
1097053e06bSLiang Chen		};
1107053e06bSLiang Chen	};
1117053e06bSLiang Chen
1127053e06bSLiang Chen	cpu0_opp_table: cpu0-opp-table {
1137053e06bSLiang Chen		compatible = "operating-points-v2";
1147053e06bSLiang Chen		opp-shared;
1157053e06bSLiang Chen
1167053e06bSLiang Chen		opp-408000000 {
1177053e06bSLiang Chen			opp-hz = /bits/ 64 <408000000>;
1187053e06bSLiang Chen			opp-microvolt = <950000 950000 1350000>;
1197053e06bSLiang Chen			clock-latency-ns = <40000>;
1207053e06bSLiang Chen			opp-suspend;
1217053e06bSLiang Chen		};
1227053e06bSLiang Chen		opp-600000000 {
1237053e06bSLiang Chen			opp-hz = /bits/ 64 <600000000>;
1247053e06bSLiang Chen			opp-microvolt = <950000 950000 1350000>;
1257053e06bSLiang Chen			clock-latency-ns = <40000>;
1267053e06bSLiang Chen		};
1277053e06bSLiang Chen		opp-816000000 {
1287053e06bSLiang Chen			opp-hz = /bits/ 64 <816000000>;
1297053e06bSLiang Chen			opp-microvolt = <1050000 1050000 1350000>;
1307053e06bSLiang Chen			clock-latency-ns = <40000>;
1317053e06bSLiang Chen		};
1327053e06bSLiang Chen		opp-1008000000 {
1337053e06bSLiang Chen			opp-hz = /bits/ 64 <1008000000>;
1347053e06bSLiang Chen			opp-microvolt = <1175000 1175000 1350000>;
1357053e06bSLiang Chen			clock-latency-ns = <40000>;
1367053e06bSLiang Chen		};
1377053e06bSLiang Chen		opp-1200000000 {
1387053e06bSLiang Chen			opp-hz = /bits/ 64 <1200000000>;
1397053e06bSLiang Chen			opp-microvolt = <1300000 1300000 1350000>;
1407053e06bSLiang Chen			clock-latency-ns = <40000>;
1417053e06bSLiang Chen		};
1427053e06bSLiang Chen		opp-1296000000 {
1437053e06bSLiang Chen			opp-hz = /bits/ 64 <1296000000>;
1447053e06bSLiang Chen			opp-microvolt = <1350000 1350000 1350000>;
1457053e06bSLiang Chen			clock-latency-ns = <40000>;
1467053e06bSLiang Chen		};
1477053e06bSLiang Chen	};
1487053e06bSLiang Chen
1497053e06bSLiang Chen	arm-pmu {
1507053e06bSLiang Chen		compatible = "arm,cortex-a53-pmu";
1517053e06bSLiang Chen		interrupts = <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>,
1527053e06bSLiang Chen			     <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>,
1537053e06bSLiang Chen			     <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>,
1547053e06bSLiang Chen			     <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
1557053e06bSLiang Chen		interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>;
1567053e06bSLiang Chen	};
1577053e06bSLiang Chen
1587053e06bSLiang Chen	display_subsystem: display-subsystem {
1597053e06bSLiang Chen		compatible = "rockchip,display-subsystem";
160967c1464SSandy Huang		ports = <&vopb_out>, <&vopl_out>;
1617053e06bSLiang Chen		status = "disabled";
1627053e06bSLiang Chen	};
1637053e06bSLiang Chen
1647053e06bSLiang Chen	firmware {
1657053e06bSLiang Chen		optee {
1667053e06bSLiang Chen			compatible = "linaro,optee-tz";
1677053e06bSLiang Chen			method = "smc";
1687053e06bSLiang Chen		};
1697053e06bSLiang Chen	};
1707053e06bSLiang Chen
1717053e06bSLiang Chen	gmac_clkin: external-gmac-clock {
1727053e06bSLiang Chen		compatible = "fixed-clock";
1737053e06bSLiang Chen		clock-frequency = <50000000>;
1747053e06bSLiang Chen		clock-output-names = "gmac_clkin";
1757053e06bSLiang Chen		#clock-cells = <0>;
1767053e06bSLiang Chen	};
1777053e06bSLiang Chen
1787053e06bSLiang Chen	psci {
1797053e06bSLiang Chen		compatible = "arm,psci-1.0";
1807053e06bSLiang Chen		method = "smc";
1817053e06bSLiang Chen	};
1827053e06bSLiang Chen
1837053e06bSLiang Chen	timer {
1847053e06bSLiang Chen		compatible = "arm,armv8-timer";
1857053e06bSLiang Chen		interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
1867053e06bSLiang Chen			     <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
1877053e06bSLiang Chen			     <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
1887053e06bSLiang Chen			     <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
1897053e06bSLiang Chen	};
1907053e06bSLiang Chen
1917053e06bSLiang Chen	xin24m: xin24m {
1927053e06bSLiang Chen		compatible = "fixed-clock";
1937053e06bSLiang Chen		#clock-cells = <0>;
1947053e06bSLiang Chen		clock-frequency = <24000000>;
1957053e06bSLiang Chen		clock-output-names = "xin24m";
1967053e06bSLiang Chen	};
1977053e06bSLiang Chen
1987053e06bSLiang Chen	pmu: power-management@ff000000 {
1997053e06bSLiang Chen		compatible = "rockchip,px30-pmu", "syscon", "simple-mfd";
2007053e06bSLiang Chen		reg = <0x0 0xff000000 0x0 0x1000>;
2017053e06bSLiang Chen
2027053e06bSLiang Chen		power: power-controller {
2037053e06bSLiang Chen			compatible = "rockchip,px30-power-controller";
2047053e06bSLiang Chen			#power-domain-cells = <1>;
2057053e06bSLiang Chen			#address-cells = <1>;
2067053e06bSLiang Chen			#size-cells = <0>;
2077053e06bSLiang Chen
2087053e06bSLiang Chen			/* These power domains are grouped by VD_LOGIC */
2097053e06bSLiang Chen			pd_usb@PX30_PD_USB {
2107053e06bSLiang Chen				reg = <PX30_PD_USB>;
2117053e06bSLiang Chen				clocks = <&cru HCLK_HOST>,
2127053e06bSLiang Chen					 <&cru HCLK_OTG>,
2137053e06bSLiang Chen					 <&cru SCLK_OTG_ADP>;
2147053e06bSLiang Chen				pm_qos = <&qos_usb_host>, <&qos_usb_otg>;
2157053e06bSLiang Chen			};
2167053e06bSLiang Chen			pd_sdcard@PX30_PD_SDCARD {
2177053e06bSLiang Chen				reg = <PX30_PD_SDCARD>;
2187053e06bSLiang Chen				clocks = <&cru HCLK_SDMMC>,
2197053e06bSLiang Chen					 <&cru SCLK_SDMMC>;
2207053e06bSLiang Chen				pm_qos = <&qos_sdmmc>;
2217053e06bSLiang Chen			};
2227053e06bSLiang Chen			pd_gmac@PX30_PD_GMAC {
2237053e06bSLiang Chen				reg = <PX30_PD_GMAC>;
2247053e06bSLiang Chen				clocks = <&cru ACLK_GMAC>,
2257053e06bSLiang Chen					 <&cru PCLK_GMAC>,
2267053e06bSLiang Chen					 <&cru SCLK_MAC_REF>,
2277053e06bSLiang Chen					 <&cru SCLK_GMAC_RX_TX>;
2287053e06bSLiang Chen				pm_qos = <&qos_gmac>;
2297053e06bSLiang Chen			};
2307053e06bSLiang Chen			pd_mmc_nand@PX30_PD_MMC_NAND {
2317053e06bSLiang Chen				reg = <PX30_PD_MMC_NAND>;
2327053e06bSLiang Chen				clocks =  <&cru HCLK_NANDC>,
2337053e06bSLiang Chen					  <&cru HCLK_EMMC>,
2347053e06bSLiang Chen					  <&cru HCLK_SDIO>,
2357053e06bSLiang Chen					  <&cru HCLK_SFC>,
2367053e06bSLiang Chen					  <&cru SCLK_EMMC>,
2377053e06bSLiang Chen					  <&cru SCLK_NANDC>,
2387053e06bSLiang Chen					  <&cru SCLK_SDIO>,
2397053e06bSLiang Chen					  <&cru SCLK_SFC>;
2407053e06bSLiang Chen				pm_qos = <&qos_emmc>, <&qos_nand>,
2417053e06bSLiang Chen					 <&qos_sdio>, <&qos_sfc>;
2427053e06bSLiang Chen			};
2437053e06bSLiang Chen			pd_vpu@PX30_PD_VPU {
2447053e06bSLiang Chen				reg = <PX30_PD_VPU>;
2457053e06bSLiang Chen				clocks = <&cru ACLK_VPU>,
2467053e06bSLiang Chen					 <&cru HCLK_VPU>,
2477053e06bSLiang Chen					 <&cru SCLK_CORE_VPU>;
2487053e06bSLiang Chen				pm_qos = <&qos_vpu>, <&qos_vpu_r128>;
2497053e06bSLiang Chen			};
2507053e06bSLiang Chen			pd_vo@PX30_PD_VO {
2517053e06bSLiang Chen				reg = <PX30_PD_VO>;
2527053e06bSLiang Chen				clocks = <&cru ACLK_RGA>,
2537053e06bSLiang Chen					 <&cru ACLK_VOPB>,
2547053e06bSLiang Chen					 <&cru ACLK_VOPL>,
2557053e06bSLiang Chen					 <&cru DCLK_VOPB>,
2567053e06bSLiang Chen					 <&cru DCLK_VOPL>,
2577053e06bSLiang Chen					 <&cru HCLK_RGA>,
2587053e06bSLiang Chen					 <&cru HCLK_VOPB>,
2597053e06bSLiang Chen					 <&cru HCLK_VOPL>,
2607053e06bSLiang Chen					 <&cru PCLK_MIPI_DSI>,
2617053e06bSLiang Chen					 <&cru SCLK_RGA_CORE>,
2627053e06bSLiang Chen					 <&cru SCLK_VOPB_PWM>;
2637053e06bSLiang Chen				pm_qos = <&qos_rga_rd>, <&qos_rga_wr>,
2647053e06bSLiang Chen					 <&qos_vop_m0>, <&qos_vop_m1>;
2657053e06bSLiang Chen			};
2667053e06bSLiang Chen			pd_vi@PX30_PD_VI {
2677053e06bSLiang Chen				reg = <PX30_PD_VI>;
2687053e06bSLiang Chen				clocks = <&cru ACLK_CIF>,
2697053e06bSLiang Chen					 <&cru ACLK_ISP>,
2707053e06bSLiang Chen					 <&cru HCLK_CIF>,
2717053e06bSLiang Chen					 <&cru HCLK_ISP>,
2727053e06bSLiang Chen					 <&cru SCLK_ISP>;
2737053e06bSLiang Chen				pm_qos = <&qos_isp_128>, <&qos_isp_rd>,
2747053e06bSLiang Chen					 <&qos_isp_wr>, <&qos_isp_m1>,
2757053e06bSLiang Chen					 <&qos_vip>;
2767053e06bSLiang Chen			};
2777053e06bSLiang Chen			pd_gpu@PX30_PD_GPU {
2787053e06bSLiang Chen				reg = <PX30_PD_GPU>;
2797053e06bSLiang Chen				clocks = <&cru SCLK_GPU>;
2807053e06bSLiang Chen				pm_qos = <&qos_gpu>;
2817053e06bSLiang Chen			};
2827053e06bSLiang Chen		};
2837053e06bSLiang Chen	};
2847053e06bSLiang Chen
2857053e06bSLiang Chen	pmugrf: syscon@ff010000 {
2867053e06bSLiang Chen		compatible = "rockchip,px30-pmugrf", "syscon", "simple-mfd";
2877053e06bSLiang Chen		reg = <0x0 0xff010000 0x0 0x1000>;
2887053e06bSLiang Chen		#address-cells = <1>;
2897053e06bSLiang Chen		#size-cells = <1>;
2907053e06bSLiang Chen
2917053e06bSLiang Chen		pmu_io_domains: io-domains {
2927053e06bSLiang Chen			compatible = "rockchip,px30-pmu-io-voltage-domain";
2937053e06bSLiang Chen			status = "disabled";
2947053e06bSLiang Chen		};
2957053e06bSLiang Chen
2967053e06bSLiang Chen		reboot-mode {
2977053e06bSLiang Chen			compatible = "syscon-reboot-mode";
2987053e06bSLiang Chen			offset = <0x200>;
2997053e06bSLiang Chen			mode-bootloader = <BOOT_BL_DOWNLOAD>;
3007053e06bSLiang Chen			mode-fastboot = <BOOT_FASTBOOT>;
3017053e06bSLiang Chen			mode-loader = <BOOT_BL_DOWNLOAD>;
3027053e06bSLiang Chen			mode-normal = <BOOT_NORMAL>;
3037053e06bSLiang Chen			mode-recovery = <BOOT_RECOVERY>;
3047053e06bSLiang Chen		};
3057053e06bSLiang Chen	};
3067053e06bSLiang Chen
3077053e06bSLiang Chen	uart0: serial@ff030000 {
3087053e06bSLiang Chen		compatible = "rockchip,px30-uart", "snps,dw-apb-uart";
3097053e06bSLiang Chen		reg = <0x0 0xff030000 0x0 0x100>;
3107053e06bSLiang Chen		interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
3117053e06bSLiang Chen		clocks = <&pmucru SCLK_UART0_PMU>, <&pmucru PCLK_UART0_PMU>;
3127053e06bSLiang Chen		clock-names = "baudclk", "apb_pclk";
3137053e06bSLiang Chen		dmas = <&dmac 0>, <&dmac 1>;
3147053e06bSLiang Chen		dma-names = "tx", "rx";
3157053e06bSLiang Chen		reg-shift = <2>;
3167053e06bSLiang Chen		reg-io-width = <4>;
3177053e06bSLiang Chen		pinctrl-names = "default";
3187053e06bSLiang Chen		pinctrl-0 = <&uart0_xfer &uart0_cts &uart0_rts>;
3197053e06bSLiang Chen		status = "disabled";
3207053e06bSLiang Chen	};
3217053e06bSLiang Chen
3227053e06bSLiang Chen	i2s1_2ch: i2s@ff070000 {
3237053e06bSLiang Chen		compatible = "rockchip,px30-i2s", "rockchip,rk3066-i2s";
3247053e06bSLiang Chen		reg = <0x0 0xff070000 0x0 0x1000>;
3257053e06bSLiang Chen		interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
3267053e06bSLiang Chen		clocks = <&cru SCLK_I2S1>, <&cru HCLK_I2S1>;
3277053e06bSLiang Chen		clock-names = "i2s_clk", "i2s_hclk";
3287053e06bSLiang Chen		dmas = <&dmac 18>, <&dmac 19>;
3297053e06bSLiang Chen		dma-names = "tx", "rx";
3307053e06bSLiang Chen		pinctrl-names = "default";
3317053e06bSLiang Chen		pinctrl-0 = <&i2s1_2ch_sclk &i2s1_2ch_lrck
3327053e06bSLiang Chen			     &i2s1_2ch_sdi &i2s1_2ch_sdo>;
3337053e06bSLiang Chen		#sound-dai-cells = <0>;
3347053e06bSLiang Chen		status = "disabled";
3357053e06bSLiang Chen	};
3367053e06bSLiang Chen
3377053e06bSLiang Chen	i2s2_2ch: i2s@ff080000 {
3387053e06bSLiang Chen		compatible = "rockchip,px30-i2s", "rockchip,rk3066-i2s";
3397053e06bSLiang Chen		reg = <0x0 0xff080000 0x0 0x1000>;
3407053e06bSLiang Chen		interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
3417053e06bSLiang Chen		clocks = <&cru SCLK_I2S2>, <&cru HCLK_I2S2>;
3427053e06bSLiang Chen		clock-names = "i2s_clk", "i2s_hclk";
3437053e06bSLiang Chen		dmas = <&dmac 20>, <&dmac 21>;
3447053e06bSLiang Chen		dma-names = "tx", "rx";
3457053e06bSLiang Chen		pinctrl-names = "default";
3467053e06bSLiang Chen		pinctrl-0 = <&i2s2_2ch_sclk &i2s2_2ch_lrck
3477053e06bSLiang Chen			     &i2s2_2ch_sdi &i2s2_2ch_sdo>;
3487053e06bSLiang Chen		#sound-dai-cells = <0>;
3497053e06bSLiang Chen		status = "disabled";
3507053e06bSLiang Chen	};
3517053e06bSLiang Chen
3527053e06bSLiang Chen	gic: interrupt-controller@ff131000 {
3537053e06bSLiang Chen		compatible = "arm,gic-400";
3547053e06bSLiang Chen		#interrupt-cells = <3>;
3557053e06bSLiang Chen		#address-cells = <0>;
3567053e06bSLiang Chen		interrupt-controller;
3577053e06bSLiang Chen		reg = <0x0 0xff131000 0 0x1000>,
3587053e06bSLiang Chen		      <0x0 0xff132000 0 0x2000>,
3597053e06bSLiang Chen		      <0x0 0xff134000 0 0x2000>,
3607053e06bSLiang Chen		      <0x0 0xff136000 0 0x2000>;
3617053e06bSLiang Chen		interrupts = <GIC_PPI 9
3627053e06bSLiang Chen		      (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
3637053e06bSLiang Chen	};
3647053e06bSLiang Chen
3657053e06bSLiang Chen	grf: syscon@ff140000 {
3667053e06bSLiang Chen		compatible = "rockchip,px30-grf", "syscon", "simple-mfd";
3677053e06bSLiang Chen		reg = <0x0 0xff140000 0x0 0x1000>;
3687053e06bSLiang Chen		#address-cells = <1>;
3697053e06bSLiang Chen		#size-cells = <1>;
3707053e06bSLiang Chen
3717053e06bSLiang Chen		io_domains: io-domains {
3727053e06bSLiang Chen			compatible = "rockchip,px30-io-voltage-domain";
3737053e06bSLiang Chen			status = "disabled";
3747053e06bSLiang Chen		};
3757053e06bSLiang Chen	};
3767053e06bSLiang Chen
3777053e06bSLiang Chen	uart1: serial@ff158000 {
3787053e06bSLiang Chen		compatible = "rockchip,px30-uart", "snps,dw-apb-uart";
3797053e06bSLiang Chen		reg = <0x0 0xff158000 0x0 0x100>;
3807053e06bSLiang Chen		interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>;
3817053e06bSLiang Chen		clocks = <&cru SCLK_UART1>, <&cru PCLK_UART1>;
3827053e06bSLiang Chen		clock-names = "baudclk", "apb_pclk";
3837053e06bSLiang Chen		dmas = <&dmac 2>, <&dmac 3>;
3847053e06bSLiang Chen		dma-names = "tx", "rx";
3857053e06bSLiang Chen		reg-shift = <2>;
3867053e06bSLiang Chen		reg-io-width = <4>;
3877053e06bSLiang Chen		pinctrl-names = "default";
3887053e06bSLiang Chen		pinctrl-0 = <&uart1_xfer &uart1_cts &uart1_rts>;
3897053e06bSLiang Chen		status = "disabled";
3907053e06bSLiang Chen	};
3917053e06bSLiang Chen
3927053e06bSLiang Chen	uart2: serial@ff160000 {
3937053e06bSLiang Chen		compatible = "rockchip,px30-uart", "snps,dw-apb-uart";
3947053e06bSLiang Chen		reg = <0x0 0xff160000 0x0 0x100>;
3957053e06bSLiang Chen		interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
3967053e06bSLiang Chen		clocks = <&cru SCLK_UART2>, <&cru PCLK_UART2>;
3977053e06bSLiang Chen		clock-names = "baudclk", "apb_pclk";
3987053e06bSLiang Chen		dmas = <&dmac 4>, <&dmac 5>;
3997053e06bSLiang Chen		dma-names = "tx", "rx";
4007053e06bSLiang Chen		reg-shift = <2>;
4017053e06bSLiang Chen		reg-io-width = <4>;
4027053e06bSLiang Chen		pinctrl-names = "default";
4037053e06bSLiang Chen		pinctrl-0 = <&uart2m0_xfer>;
4047053e06bSLiang Chen		status = "disabled";
4057053e06bSLiang Chen	};
4067053e06bSLiang Chen
4077053e06bSLiang Chen	uart3: serial@ff168000 {
4087053e06bSLiang Chen		compatible = "rockchip,px30-uart", "snps,dw-apb-uart";
4097053e06bSLiang Chen		reg = <0x0 0xff168000 0x0 0x100>;
4107053e06bSLiang Chen		interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>;
4117053e06bSLiang Chen		clocks = <&cru SCLK_UART3>, <&cru PCLK_UART3>;
4127053e06bSLiang Chen		clock-names = "baudclk", "apb_pclk";
4137053e06bSLiang Chen		dmas = <&dmac 6>, <&dmac 7>;
4147053e06bSLiang Chen		dma-names = "tx", "rx";
4157053e06bSLiang Chen		reg-shift = <2>;
4167053e06bSLiang Chen		reg-io-width = <4>;
4177053e06bSLiang Chen		pinctrl-names = "default";
4187053e06bSLiang Chen		pinctrl-0 = <&uart3m1_xfer &uart3m1_cts &uart3m1_rts>;
4197053e06bSLiang Chen		status = "disabled";
4207053e06bSLiang Chen	};
4217053e06bSLiang Chen
4227053e06bSLiang Chen	uart4: serial@ff170000 {
4237053e06bSLiang Chen		compatible = "rockchip,px30-uart", "snps,dw-apb-uart";
4247053e06bSLiang Chen		reg = <0x0 0xff170000 0x0 0x100>;
4257053e06bSLiang Chen		interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
4267053e06bSLiang Chen		clocks = <&cru SCLK_UART4>, <&cru PCLK_UART4>;
4277053e06bSLiang Chen		clock-names = "baudclk", "apb_pclk";
4287053e06bSLiang Chen		dmas = <&dmac 8>, <&dmac 9>;
4297053e06bSLiang Chen		dma-names = "tx", "rx";
4307053e06bSLiang Chen		reg-shift = <2>;
4317053e06bSLiang Chen		reg-io-width = <4>;
4327053e06bSLiang Chen		pinctrl-names = "default";
4337053e06bSLiang Chen		pinctrl-0 = <&uart4_xfer &uart4_cts &uart4_rts>;
4347053e06bSLiang Chen		status = "disabled";
4357053e06bSLiang Chen	};
4367053e06bSLiang Chen
4377053e06bSLiang Chen	uart5: serial@ff178000 {
4387053e06bSLiang Chen		compatible = "rockchip,px30-uart", "snps,dw-apb-uart";
4397053e06bSLiang Chen		reg = <0x0 0xff178000 0x0 0x100>;
4407053e06bSLiang Chen		interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
4417053e06bSLiang Chen		clocks = <&cru SCLK_UART5>, <&cru PCLK_UART5>;
4427053e06bSLiang Chen		clock-names = "baudclk", "apb_pclk";
4437053e06bSLiang Chen		dmas = <&dmac 10>, <&dmac 11>;
4447053e06bSLiang Chen		dma-names = "tx", "rx";
4457053e06bSLiang Chen		reg-shift = <2>;
4467053e06bSLiang Chen		reg-io-width = <4>;
4477053e06bSLiang Chen		pinctrl-names = "default";
4487053e06bSLiang Chen		pinctrl-0 = <&uart5_xfer &uart5_cts &uart5_rts>;
4497053e06bSLiang Chen		status = "disabled";
4507053e06bSLiang Chen	};
4517053e06bSLiang Chen
4527053e06bSLiang Chen	i2c0: i2c@ff180000 {
4537053e06bSLiang Chen		compatible = "rockchip,px30-i2c", "rockchip,rk3399-i2c";
4547053e06bSLiang Chen		reg = <0x0 0xff180000 0x0 0x1000>;
4557053e06bSLiang Chen		clocks =  <&cru SCLK_I2C0>, <&cru PCLK_I2C0>;
4567053e06bSLiang Chen		clock-names = "i2c", "pclk";
4577053e06bSLiang Chen		interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
4587053e06bSLiang Chen		pinctrl-names = "default";
4597053e06bSLiang Chen		pinctrl-0 = <&i2c0_xfer>;
4607053e06bSLiang Chen		#address-cells = <1>;
4617053e06bSLiang Chen		#size-cells = <0>;
4627053e06bSLiang Chen		status = "disabled";
4637053e06bSLiang Chen	};
4647053e06bSLiang Chen
4657053e06bSLiang Chen	i2c1: i2c@ff190000 {
4667053e06bSLiang Chen		compatible = "rockchip,px30-i2c", "rockchip,rk3399-i2c";
4677053e06bSLiang Chen		reg = <0x0 0xff190000 0x0 0x1000>;
4687053e06bSLiang Chen		clocks = <&cru SCLK_I2C1>, <&cru PCLK_I2C1>;
4697053e06bSLiang Chen		clock-names = "i2c", "pclk";
4707053e06bSLiang Chen		interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
4717053e06bSLiang Chen		pinctrl-names = "default";
4727053e06bSLiang Chen		pinctrl-0 = <&i2c1_xfer>;
4737053e06bSLiang Chen		#address-cells = <1>;
4747053e06bSLiang Chen		#size-cells = <0>;
4757053e06bSLiang Chen		status = "disabled";
4767053e06bSLiang Chen	};
4777053e06bSLiang Chen
4787053e06bSLiang Chen	i2c2: i2c@ff1a0000 {
4797053e06bSLiang Chen		compatible = "rockchip,px30-i2c", "rockchip,rk3399-i2c";
4807053e06bSLiang Chen		reg = <0x0 0xff1a0000 0x0 0x1000>;
4817053e06bSLiang Chen		clocks = <&cru SCLK_I2C2>, <&cru PCLK_I2C2>;
4827053e06bSLiang Chen		clock-names = "i2c", "pclk";
4837053e06bSLiang Chen		interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
4847053e06bSLiang Chen		pinctrl-names = "default";
4857053e06bSLiang Chen		pinctrl-0 = <&i2c2_xfer>;
4867053e06bSLiang Chen		#address-cells = <1>;
4877053e06bSLiang Chen		#size-cells = <0>;
4887053e06bSLiang Chen		status = "disabled";
4897053e06bSLiang Chen	};
4907053e06bSLiang Chen
4917053e06bSLiang Chen	i2c3: i2c@ff1b0000 {
4927053e06bSLiang Chen		compatible = "rockchip,px30-i2c", "rockchip,rk3399-i2c";
4937053e06bSLiang Chen		reg = <0x0 0xff1b0000 0x0 0x1000>;
4947053e06bSLiang Chen		clocks = <&cru SCLK_I2C3>, <&cru PCLK_I2C3>;
4957053e06bSLiang Chen		clock-names = "i2c", "pclk";
4967053e06bSLiang Chen		interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
4977053e06bSLiang Chen		pinctrl-names = "default";
4987053e06bSLiang Chen		pinctrl-0 = <&i2c3_xfer>;
4997053e06bSLiang Chen		#address-cells = <1>;
5007053e06bSLiang Chen		#size-cells = <0>;
5017053e06bSLiang Chen		status = "disabled";
5027053e06bSLiang Chen	};
5037053e06bSLiang Chen
5047053e06bSLiang Chen	spi0: spi@ff1d0000 {
5057053e06bSLiang Chen		compatible = "rockchip,px30-spi", "rockchip,rk3066-spi";
5067053e06bSLiang Chen		reg = <0x0 0xff1d0000 0x0 0x1000>;
5077053e06bSLiang Chen		interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
5087053e06bSLiang Chen		clocks = <&cru SCLK_SPI0>, <&cru PCLK_SPI0>;
5097053e06bSLiang Chen		clock-names = "spiclk", "apb_pclk";
5107053e06bSLiang Chen		dmas = <&dmac 12>, <&dmac 13>;
5117053e06bSLiang Chen		dma-names = "tx", "rx";
5127053e06bSLiang Chen		pinctrl-names = "default";
5137053e06bSLiang Chen		pinctrl-0 = <&spi0_clk &spi0_csn &spi0_miso &spi0_mosi>;
5147053e06bSLiang Chen		#address-cells = <1>;
5157053e06bSLiang Chen		#size-cells = <0>;
5167053e06bSLiang Chen		status = "disabled";
5177053e06bSLiang Chen	};
5187053e06bSLiang Chen
5197053e06bSLiang Chen	spi1: spi@ff1d8000 {
5207053e06bSLiang Chen		compatible = "rockchip,px30-spi", "rockchip,rk3066-spi";
5217053e06bSLiang Chen		reg = <0x0 0xff1d8000 0x0 0x1000>;
5227053e06bSLiang Chen		interrupts = <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>;
5237053e06bSLiang Chen		clocks = <&cru SCLK_SPI1>, <&cru PCLK_SPI1>;
5247053e06bSLiang Chen		clock-names = "spiclk", "apb_pclk";
5257053e06bSLiang Chen		dmas = <&dmac 14>, <&dmac 15>;
5267053e06bSLiang Chen		dma-names = "tx", "rx";
5277053e06bSLiang Chen		pinctrl-names = "default";
5287053e06bSLiang Chen		pinctrl-0 = <&spi1_clk &spi1_csn0 &spi1_csn1 &spi1_miso &spi1_mosi>;
5297053e06bSLiang Chen		#address-cells = <1>;
5307053e06bSLiang Chen		#size-cells = <0>;
5317053e06bSLiang Chen		status = "disabled";
5327053e06bSLiang Chen	};
5337053e06bSLiang Chen
5347053e06bSLiang Chen	wdt: watchdog@ff1e0000 {
5357053e06bSLiang Chen		compatible = "snps,dw-wdt";
5367053e06bSLiang Chen		reg = <0x0 0xff1e0000 0x0 0x100>;
5377053e06bSLiang Chen		clocks = <&cru PCLK_WDT_NS>;
5387053e06bSLiang Chen		interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
5397053e06bSLiang Chen		status = "disabled";
5407053e06bSLiang Chen	};
5417053e06bSLiang Chen
5427053e06bSLiang Chen	pwm0: pwm@ff200000 {
5437053e06bSLiang Chen		compatible = "rockchip,px30-pwm", "rockchip,rk3328-pwm";
5447053e06bSLiang Chen		reg = <0x0 0xff200000 0x0 0x10>;
5457053e06bSLiang Chen		clocks = <&cru SCLK_PWM0>, <&cru PCLK_PWM0>;
5467053e06bSLiang Chen		clock-names = "pwm", "pclk";
5477053e06bSLiang Chen		pinctrl-names = "default";
5487053e06bSLiang Chen		pinctrl-0 = <&pwm0_pin>;
5497053e06bSLiang Chen		#pwm-cells = <3>;
5507053e06bSLiang Chen		status = "disabled";
5517053e06bSLiang Chen	};
5527053e06bSLiang Chen
5537053e06bSLiang Chen	pwm1: pwm@ff200010 {
5547053e06bSLiang Chen		compatible = "rockchip,px30-pwm", "rockchip,rk3328-pwm";
5557053e06bSLiang Chen		reg = <0x0 0xff200010 0x0 0x10>;
5567053e06bSLiang Chen		clocks = <&cru SCLK_PWM0>, <&cru PCLK_PWM0>;
5577053e06bSLiang Chen		clock-names = "pwm", "pclk";
5587053e06bSLiang Chen		pinctrl-names = "default";
5597053e06bSLiang Chen		pinctrl-0 = <&pwm1_pin>;
5607053e06bSLiang Chen		#pwm-cells = <3>;
5617053e06bSLiang Chen		status = "disabled";
5627053e06bSLiang Chen	};
5637053e06bSLiang Chen
5647053e06bSLiang Chen	pwm2: pwm@ff200020 {
5657053e06bSLiang Chen		compatible = "rockchip,px30-pwm", "rockchip,rk3328-pwm";
5667053e06bSLiang Chen		reg = <0x0 0xff200020 0x0 0x10>;
5677053e06bSLiang Chen		clocks = <&cru SCLK_PWM0>, <&cru PCLK_PWM0>;
5687053e06bSLiang Chen		clock-names = "pwm", "pclk";
5697053e06bSLiang Chen		pinctrl-names = "default";
5707053e06bSLiang Chen		pinctrl-0 = <&pwm2_pin>;
5717053e06bSLiang Chen		#pwm-cells = <3>;
5727053e06bSLiang Chen		status = "disabled";
5737053e06bSLiang Chen	};
5747053e06bSLiang Chen
5757053e06bSLiang Chen	pwm3: pwm@ff200030 {
5767053e06bSLiang Chen		compatible = "rockchip,px30-pwm", "rockchip,rk3328-pwm";
5777053e06bSLiang Chen		reg = <0x0 0xff200030 0x0 0x10>;
5787053e06bSLiang Chen		clocks = <&cru SCLK_PWM0>, <&cru PCLK_PWM0>;
5797053e06bSLiang Chen		clock-names = "pwm", "pclk";
5807053e06bSLiang Chen		pinctrl-names = "default";
5817053e06bSLiang Chen		pinctrl-0 = <&pwm3_pin>;
5827053e06bSLiang Chen		#pwm-cells = <3>;
5837053e06bSLiang Chen		status = "disabled";
5847053e06bSLiang Chen	};
5857053e06bSLiang Chen
5867053e06bSLiang Chen	pwm4: pwm@ff208000 {
5877053e06bSLiang Chen		compatible = "rockchip,px30-pwm", "rockchip,rk3328-pwm";
5887053e06bSLiang Chen		reg = <0x0 0xff208000 0x0 0x10>;
5897053e06bSLiang Chen		clocks = <&cru SCLK_PWM1>, <&cru PCLK_PWM1>;
5907053e06bSLiang Chen		clock-names = "pwm", "pclk";
5917053e06bSLiang Chen		pinctrl-names = "default";
5927053e06bSLiang Chen		pinctrl-0 = <&pwm4_pin>;
5937053e06bSLiang Chen		#pwm-cells = <3>;
5947053e06bSLiang Chen		status = "disabled";
5957053e06bSLiang Chen	};
5967053e06bSLiang Chen
5977053e06bSLiang Chen	pwm5: pwm@ff208010 {
5987053e06bSLiang Chen		compatible = "rockchip,px30-pwm", "rockchip,rk3328-pwm";
5997053e06bSLiang Chen		reg = <0x0 0xff208010 0x0 0x10>;
6007053e06bSLiang Chen		clocks = <&cru SCLK_PWM1>, <&cru PCLK_PWM1>;
6017053e06bSLiang Chen		clock-names = "pwm", "pclk";
6027053e06bSLiang Chen		pinctrl-names = "default";
6037053e06bSLiang Chen		pinctrl-0 = <&pwm5_pin>;
6047053e06bSLiang Chen		#pwm-cells = <3>;
6057053e06bSLiang Chen		status = "disabled";
6067053e06bSLiang Chen	};
6077053e06bSLiang Chen
6087053e06bSLiang Chen	pwm6: pwm@ff208020 {
6097053e06bSLiang Chen		compatible = "rockchip,px30-pwm", "rockchip,rk3328-pwm";
6107053e06bSLiang Chen		reg = <0x0 0xff208020 0x0 0x10>;
6117053e06bSLiang Chen		clocks = <&cru SCLK_PWM1>, <&cru PCLK_PWM1>;
6127053e06bSLiang Chen		clock-names = "pwm", "pclk";
6137053e06bSLiang Chen		pinctrl-names = "default";
6147053e06bSLiang Chen		pinctrl-0 = <&pwm6_pin>;
6157053e06bSLiang Chen		#pwm-cells = <3>;
6167053e06bSLiang Chen		status = "disabled";
6177053e06bSLiang Chen	};
6187053e06bSLiang Chen
6197053e06bSLiang Chen	pwm7: pwm@ff208030 {
6207053e06bSLiang Chen		compatible = "rockchip,px30-pwm", "rockchip,rk3328-pwm";
6217053e06bSLiang Chen		reg = <0x0 0xff208030 0x0 0x10>;
6227053e06bSLiang Chen		clocks = <&cru SCLK_PWM1>, <&cru PCLK_PWM1>;
6237053e06bSLiang Chen		clock-names = "pwm", "pclk";
6247053e06bSLiang Chen		pinctrl-names = "default";
6257053e06bSLiang Chen		pinctrl-0 = <&pwm7_pin>;
6267053e06bSLiang Chen		#pwm-cells = <3>;
6277053e06bSLiang Chen		status = "disabled";
6287053e06bSLiang Chen	};
6297053e06bSLiang Chen
6307053e06bSLiang Chen	rktimer: timer@ff210000 {
6317053e06bSLiang Chen		compatible = "rockchip,px30-timer", "rockchip,rk3288-timer";
6327053e06bSLiang Chen		reg = <0x0 0xff210000 0x0 0x1000>;
6337053e06bSLiang Chen		interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
6347053e06bSLiang Chen		clocks = <&cru PCLK_TIMER>, <&cru SCLK_TIMER0>;
6357053e06bSLiang Chen		clock-names = "pclk", "timer";
6367053e06bSLiang Chen	};
6377053e06bSLiang Chen
6387053e06bSLiang Chen	amba {
6397053e06bSLiang Chen		compatible = "simple-bus";
6407053e06bSLiang Chen		#address-cells = <2>;
6417053e06bSLiang Chen		#size-cells = <2>;
6427053e06bSLiang Chen		ranges;
6437053e06bSLiang Chen
6447053e06bSLiang Chen		dmac: dmac@ff240000 {
6457053e06bSLiang Chen			compatible = "arm,pl330", "arm,primecell";
6467053e06bSLiang Chen			reg = <0x0 0xff240000 0x0 0x4000>;
6477053e06bSLiang Chen			interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>,
6487053e06bSLiang Chen				     <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
6497053e06bSLiang Chen			clocks = <&cru ACLK_DMAC>;
6507053e06bSLiang Chen			clock-names = "apb_pclk";
6517053e06bSLiang Chen			#dma-cells = <1>;
6527053e06bSLiang Chen		};
6537053e06bSLiang Chen	};
6547053e06bSLiang Chen
6557053e06bSLiang Chen	saradc: saradc@ff288000 {
6567053e06bSLiang Chen		compatible = "rockchip,px30-saradc", "rockchip,rk3399-saradc";
6577053e06bSLiang Chen		reg = <0x0 0xff288000 0x0 0x100>;
6587053e06bSLiang Chen		interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
6597053e06bSLiang Chen		#io-channel-cells = <1>;
6607053e06bSLiang Chen		clocks = <&cru SCLK_SARADC>, <&cru PCLK_SARADC>;
6617053e06bSLiang Chen		clock-names = "saradc", "apb_pclk";
6627053e06bSLiang Chen		resets = <&cru SRST_SARADC_P>;
6637053e06bSLiang Chen		reset-names = "saradc-apb";
6647053e06bSLiang Chen		status = "disabled";
6657053e06bSLiang Chen	};
6667053e06bSLiang Chen
667fbb78418SHeiko Stuebner	otp: nvmem@ff290000 {
668fbb78418SHeiko Stuebner		compatible = "rockchip,px30-otp";
669fbb78418SHeiko Stuebner		reg = <0x0 0xff290000 0x0 0x4000>;
670fbb78418SHeiko Stuebner		clocks = <&cru SCLK_OTP_USR>, <&cru PCLK_OTP_NS>,
671fbb78418SHeiko Stuebner			 <&cru PCLK_OTP_PHY>;
672fbb78418SHeiko Stuebner		clock-names = "otp", "apb_pclk", "phy";
673fbb78418SHeiko Stuebner		resets = <&cru SRST_OTP_PHY>;
674fbb78418SHeiko Stuebner		reset-names = "phy";
675fbb78418SHeiko Stuebner		#address-cells = <1>;
676fbb78418SHeiko Stuebner		#size-cells = <1>;
677fbb78418SHeiko Stuebner
678fbb78418SHeiko Stuebner		/* Data cells */
679fbb78418SHeiko Stuebner		cpu_id: id@7 {
680fbb78418SHeiko Stuebner			reg = <0x07 0x10>;
681fbb78418SHeiko Stuebner		};
682fbb78418SHeiko Stuebner		cpu_leakage: cpu-leakage@17 {
683fbb78418SHeiko Stuebner			reg = <0x17 0x1>;
684fbb78418SHeiko Stuebner		};
685fbb78418SHeiko Stuebner		performance: performance@1e {
686fbb78418SHeiko Stuebner			reg = <0x1e 0x1>;
687fbb78418SHeiko Stuebner			bits = <4 3>;
688fbb78418SHeiko Stuebner		};
689fbb78418SHeiko Stuebner	};
690fbb78418SHeiko Stuebner
6917053e06bSLiang Chen	cru: clock-controller@ff2b0000 {
6927053e06bSLiang Chen		compatible = "rockchip,px30-cru";
6937053e06bSLiang Chen		reg = <0x0 0xff2b0000 0x0 0x1000>;
69445cb61b4SHeiko Stuebner		clocks = <&xin24m>, <&pmucru PLL_GPLL>;
69545cb61b4SHeiko Stuebner		clock-names = "xin24m", "gpll";
6967053e06bSLiang Chen		rockchip,grf = <&grf>;
6977053e06bSLiang Chen		#clock-cells = <1>;
6987053e06bSLiang Chen		#reset-cells = <1>;
6997053e06bSLiang Chen
70045cb61b4SHeiko Stuebner		assigned-clocks = <&cru PLL_NPLL>,
70145cb61b4SHeiko Stuebner			<&cru ACLK_BUS_PRE>, <&cru ACLK_PERI_PRE>,
70245cb61b4SHeiko Stuebner			<&cru HCLK_BUS_PRE>, <&cru HCLK_PERI_PRE>,
70345cb61b4SHeiko Stuebner			<&cru PCLK_BUS_PRE>, <&cru SCLK_GPU>;
70445cb61b4SHeiko Stuebner
70545cb61b4SHeiko Stuebner		assigned-clock-rates = <1188000000>,
70645cb61b4SHeiko Stuebner			<200000000>, <200000000>,
70745cb61b4SHeiko Stuebner			<150000000>, <150000000>,
70845cb61b4SHeiko Stuebner			<100000000>, <200000000>;
7097053e06bSLiang Chen	};
7107053e06bSLiang Chen
7117053e06bSLiang Chen	pmucru: clock-controller@ff2bc000 {
7127053e06bSLiang Chen		compatible = "rockchip,px30-pmucru";
7137053e06bSLiang Chen		reg = <0x0 0xff2bc000 0x0 0x1000>;
71445cb61b4SHeiko Stuebner		clocks = <&xin24m>;
71545cb61b4SHeiko Stuebner		clock-names = "xin24m";
7167053e06bSLiang Chen		rockchip,grf = <&grf>;
7177053e06bSLiang Chen		#clock-cells = <1>;
7187053e06bSLiang Chen		#reset-cells = <1>;
7197053e06bSLiang Chen
7207053e06bSLiang Chen		assigned-clocks =
7217053e06bSLiang Chen			<&pmucru PLL_GPLL>, <&pmucru PCLK_PMU_PRE>,
72245cb61b4SHeiko Stuebner			<&pmucru SCLK_WIFI_PMU>;
7237053e06bSLiang Chen		assigned-clock-rates =
7247053e06bSLiang Chen			<1200000000>, <100000000>,
72545cb61b4SHeiko Stuebner			<26000000>;
7267053e06bSLiang Chen	};
7277053e06bSLiang Chen
728bb598133SHeiko Stuebner	usb20_otg: usb@ff300000 {
729bb598133SHeiko Stuebner		compatible = "rockchip,px30-usb", "rockchip,rk3066-usb",
730bb598133SHeiko Stuebner			     "snps,dwc2";
731bb598133SHeiko Stuebner		reg = <0x0 0xff300000 0x0 0x40000>;
732bb598133SHeiko Stuebner		interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>;
733bb598133SHeiko Stuebner		clocks = <&cru HCLK_OTG>;
734bb598133SHeiko Stuebner		clock-names = "otg";
735bb598133SHeiko Stuebner		dr_mode = "otg";
736bb598133SHeiko Stuebner		g-np-tx-fifo-size = <16>;
737bb598133SHeiko Stuebner		g-rx-fifo-size = <280>;
738bb598133SHeiko Stuebner		g-tx-fifo-size = <256 128 128 64 32 16>;
739bb598133SHeiko Stuebner		g-use-dma;
740bb598133SHeiko Stuebner		power-domains = <&power PX30_PD_USB>;
741bb598133SHeiko Stuebner		status = "disabled";
742bb598133SHeiko Stuebner	};
743bb598133SHeiko Stuebner
7447053e06bSLiang Chen	usb_host0_ehci: usb@ff340000 {
7457053e06bSLiang Chen		compatible = "generic-ehci";
7467053e06bSLiang Chen		reg = <0x0 0xff340000 0x0 0x10000>;
7477053e06bSLiang Chen		interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>;
7487053e06bSLiang Chen		clocks = <&cru HCLK_HOST>;
7497053e06bSLiang Chen		clock-names = "usbhost";
7507053e06bSLiang Chen		power-domains = <&power PX30_PD_USB>;
7517053e06bSLiang Chen		status = "disabled";
7527053e06bSLiang Chen	};
7537053e06bSLiang Chen
7547053e06bSLiang Chen	usb_host0_ohci: usb@ff350000 {
7557053e06bSLiang Chen		compatible = "generic-ohci";
7567053e06bSLiang Chen		reg = <0x0 0xff350000 0x0 0x10000>;
7577053e06bSLiang Chen		interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
7587053e06bSLiang Chen		clocks = <&cru HCLK_HOST>;
7597053e06bSLiang Chen		clock-names = "usbhost";
7607053e06bSLiang Chen		power-domains = <&power PX30_PD_USB>;
7617053e06bSLiang Chen		status = "disabled";
7627053e06bSLiang Chen	};
7637053e06bSLiang Chen
7647053e06bSLiang Chen	gmac: ethernet@ff360000 {
7657053e06bSLiang Chen		compatible = "rockchip,px30-gmac";
7667053e06bSLiang Chen		reg = <0x0 0xff360000 0x0 0x10000>;
7677053e06bSLiang Chen		interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
7687053e06bSLiang Chen		interrupt-names = "macirq";
7697053e06bSLiang Chen		clocks = <&cru SCLK_GMAC>, <&cru SCLK_GMAC_RX_TX>,
7707053e06bSLiang Chen			 <&cru SCLK_GMAC_RX_TX>, <&cru SCLK_MAC_REF>,
7717053e06bSLiang Chen			 <&cru SCLK_MAC_REFOUT>, <&cru ACLK_GMAC>,
7727053e06bSLiang Chen			 <&cru PCLK_GMAC>, <&cru SCLK_GMAC_RMII>;
7737053e06bSLiang Chen		clock-names = "stmmaceth", "mac_clk_rx",
7747053e06bSLiang Chen			      "mac_clk_tx", "clk_mac_ref",
7757053e06bSLiang Chen			      "clk_mac_refout", "aclk_mac",
7767053e06bSLiang Chen			      "pclk_mac", "clk_mac_speed";
7777053e06bSLiang Chen		rockchip,grf = <&grf>;
7787053e06bSLiang Chen		phy-mode = "rmii";
7797053e06bSLiang Chen		pinctrl-names = "default";
7807053e06bSLiang Chen		pinctrl-0 = <&rmii_pins &mac_refclk_12ma>;
7817053e06bSLiang Chen		power-domains = <&power PX30_PD_GMAC>;
7827053e06bSLiang Chen		resets = <&cru SRST_GMAC_A>;
7837053e06bSLiang Chen		reset-names = "stmmaceth";
7847053e06bSLiang Chen		status = "disabled";
7857053e06bSLiang Chen	};
7867053e06bSLiang Chen
7877053e06bSLiang Chen	sdmmc: dwmmc@ff370000 {
7887053e06bSLiang Chen		compatible = "rockchip,px30-dw-mshc", "rockchip,rk3288-dw-mshc";
7897053e06bSLiang Chen		reg = <0x0 0xff370000 0x0 0x4000>;
7907053e06bSLiang Chen		interrupts = <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>;
7917053e06bSLiang Chen		clocks = <&cru HCLK_SDMMC>, <&cru SCLK_SDMMC>,
7927053e06bSLiang Chen			 <&cru SCLK_SDMMC_DRV>, <&cru SCLK_SDMMC_SAMPLE>;
7937053e06bSLiang Chen		clock-names = "biu", "ciu", "ciu-drv", "ciu-sample";
7947053e06bSLiang Chen		fifo-depth = <0x100>;
7957053e06bSLiang Chen		max-frequency = <150000000>;
7967053e06bSLiang Chen		pinctrl-names = "default";
7977053e06bSLiang Chen		pinctrl-0 = <&sdmmc_clk &sdmmc_cmd &sdmmc_det &sdmmc_bus4>;
7987053e06bSLiang Chen		power-domains = <&power PX30_PD_SDCARD>;
7997053e06bSLiang Chen		status = "disabled";
8007053e06bSLiang Chen	};
8017053e06bSLiang Chen
8027053e06bSLiang Chen	sdio: dwmmc@ff380000 {
8037053e06bSLiang Chen		compatible = "rockchip,px30-dw-mshc", "rockchip,rk3288-dw-mshc";
8047053e06bSLiang Chen		reg = <0x0 0xff380000 0x0 0x4000>;
8057053e06bSLiang Chen		interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;
8067053e06bSLiang Chen		clocks = <&cru HCLK_SDIO>, <&cru SCLK_SDIO>,
8077053e06bSLiang Chen			 <&cru SCLK_SDIO_DRV>, <&cru SCLK_SDIO_SAMPLE>;
8087053e06bSLiang Chen		clock-names = "biu", "ciu", "ciu-drv", "ciu-sample";
8097053e06bSLiang Chen		fifo-depth = <0x100>;
8107053e06bSLiang Chen		max-frequency = <150000000>;
8117053e06bSLiang Chen		pinctrl-names = "default";
8127053e06bSLiang Chen		pinctrl-0 = <&sdio_bus4 &sdio_cmd &sdio_clk>;
8137053e06bSLiang Chen		power-domains = <&power PX30_PD_MMC_NAND>;
8147053e06bSLiang Chen		status = "disabled";
8157053e06bSLiang Chen	};
8167053e06bSLiang Chen
8177053e06bSLiang Chen	emmc: dwmmc@ff390000 {
8187053e06bSLiang Chen		compatible = "rockchip,px30-dw-mshc", "rockchip,rk3288-dw-mshc";
8197053e06bSLiang Chen		reg = <0x0 0xff390000 0x0 0x4000>;
8207053e06bSLiang Chen		interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>;
8217053e06bSLiang Chen		clocks = <&cru HCLK_EMMC>, <&cru SCLK_EMMC>,
8227053e06bSLiang Chen			 <&cru SCLK_EMMC_DRV>, <&cru SCLK_EMMC_SAMPLE>;
8237053e06bSLiang Chen		clock-names = "biu", "ciu", "ciu-drv", "ciu-sample";
8247053e06bSLiang Chen		fifo-depth = <0x100>;
8257053e06bSLiang Chen		max-frequency = <150000000>;
826cdfebb27SHeiko Stuebner		pinctrl-names = "default";
827cdfebb27SHeiko Stuebner		pinctrl-0 = <&emmc_clk &emmc_cmd &emmc_bus8>;
8287053e06bSLiang Chen		power-domains = <&power PX30_PD_MMC_NAND>;
8297053e06bSLiang Chen		status = "disabled";
8307053e06bSLiang Chen	};
8317053e06bSLiang Chen
8327053e06bSLiang Chen	vopb: vop@ff460000 {
8337053e06bSLiang Chen		compatible = "rockchip,px30-vop-big";
8347053e06bSLiang Chen		reg = <0x0 0xff460000 0x0 0xefc>;
8357053e06bSLiang Chen		interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
8367053e06bSLiang Chen		clocks = <&cru ACLK_VOPB>, <&cru DCLK_VOPB>,
8377053e06bSLiang Chen			 <&cru HCLK_VOPB>;
8387053e06bSLiang Chen		clock-names = "aclk_vop", "dclk_vop", "hclk_vop";
839967c1464SSandy Huang		resets = <&cru SRST_VOPB_A>, <&cru SRST_VOPB_H>, <&cru SRST_VOPB>;
840967c1464SSandy Huang		reset-names = "axi", "ahb", "dclk";
8417053e06bSLiang Chen		iommus = <&vopb_mmu>;
8427053e06bSLiang Chen		power-domains = <&power PX30_PD_VO>;
8437053e06bSLiang Chen		rockchip,grf = <&grf>;
8447053e06bSLiang Chen		status = "disabled";
845967c1464SSandy Huang
846967c1464SSandy Huang		vopb_out: port {
847967c1464SSandy Huang			#address-cells = <1>;
848967c1464SSandy Huang			#size-cells = <0>;
849967c1464SSandy Huang		};
8507053e06bSLiang Chen	};
8517053e06bSLiang Chen
8527053e06bSLiang Chen	vopb_mmu: iommu@ff460f00 {
8537053e06bSLiang Chen		compatible = "rockchip,iommu";
8547053e06bSLiang Chen		reg = <0x0 0xff460f00 0x0 0x100>;
8557053e06bSLiang Chen		interrupts = <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
8567053e06bSLiang Chen		interrupt-names = "vopb_mmu";
8577053e06bSLiang Chen		clocks = <&cru ACLK_VOPB>, <&cru HCLK_VOPB>;
8588e57eed2SHeiko Stuebner		clock-names = "aclk", "iface";
8597053e06bSLiang Chen		power-domains = <&power PX30_PD_VO>;
8607053e06bSLiang Chen		#iommu-cells = <0>;
8617053e06bSLiang Chen		status = "disabled";
8627053e06bSLiang Chen	};
8637053e06bSLiang Chen
8647053e06bSLiang Chen	vopl: vop@ff470000 {
8657053e06bSLiang Chen		compatible = "rockchip,px30-vop-lit";
8667053e06bSLiang Chen		reg = <0x0 0xff470000 0x0 0xefc>;
8677053e06bSLiang Chen		interrupts = <GIC_SPI 78 IRQ_TYPE_LEVEL_HIGH>;
8687053e06bSLiang Chen		clocks = <&cru ACLK_VOPL>, <&cru DCLK_VOPL>,
8697053e06bSLiang Chen			 <&cru HCLK_VOPL>;
8707053e06bSLiang Chen		clock-names = "aclk_vop", "dclk_vop", "hclk_vop";
871967c1464SSandy Huang		resets = <&cru SRST_VOPL_A>, <&cru SRST_VOPL_H>, <&cru SRST_VOPL>;
872967c1464SSandy Huang		reset-names = "axi", "ahb", "dclk";
8737053e06bSLiang Chen		iommus = <&vopl_mmu>;
8747053e06bSLiang Chen		power-domains = <&power PX30_PD_VO>;
8757053e06bSLiang Chen		rockchip,grf = <&grf>;
8767053e06bSLiang Chen		status = "disabled";
877967c1464SSandy Huang
878967c1464SSandy Huang		vopl_out: port {
879967c1464SSandy Huang			#address-cells = <1>;
880967c1464SSandy Huang			#size-cells = <0>;
881967c1464SSandy Huang		};
8827053e06bSLiang Chen	};
8837053e06bSLiang Chen
8847053e06bSLiang Chen	vopl_mmu: iommu@ff470f00 {
8857053e06bSLiang Chen		compatible = "rockchip,iommu";
8867053e06bSLiang Chen		reg = <0x0 0xff470f00 0x0 0x100>;
8877053e06bSLiang Chen		interrupts = <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
8887053e06bSLiang Chen		interrupt-names = "vopl_mmu";
8897053e06bSLiang Chen		clocks = <&cru ACLK_VOPL>, <&cru HCLK_VOPL>;
8908e57eed2SHeiko Stuebner		clock-names = "aclk", "iface";
8917053e06bSLiang Chen		power-domains = <&power PX30_PD_VO>;
8927053e06bSLiang Chen		#iommu-cells = <0>;
8937053e06bSLiang Chen		status = "disabled";
8947053e06bSLiang Chen	};
8957053e06bSLiang Chen
8967053e06bSLiang Chen	qos_gmac: qos@ff518000 {
8977053e06bSLiang Chen		compatible = "syscon";
8987053e06bSLiang Chen		reg = <0x0 0xff518000 0x0 0x20>;
8997053e06bSLiang Chen	};
9007053e06bSLiang Chen
9017053e06bSLiang Chen	qos_gpu: qos@ff520000 {
9027053e06bSLiang Chen		compatible = "syscon";
9037053e06bSLiang Chen		reg = <0x0 0xff520000 0x0 0x20>;
9047053e06bSLiang Chen	};
9057053e06bSLiang Chen
9067053e06bSLiang Chen	qos_sdmmc: qos@ff52c000 {
9077053e06bSLiang Chen		compatible = "syscon";
9087053e06bSLiang Chen		reg = <0x0 0xff52c000 0x0 0x20>;
9097053e06bSLiang Chen	};
9107053e06bSLiang Chen
9117053e06bSLiang Chen	qos_emmc: qos@ff538000 {
9127053e06bSLiang Chen		compatible = "syscon";
9137053e06bSLiang Chen		reg = <0x0 0xff538000 0x0 0x20>;
9147053e06bSLiang Chen	};
9157053e06bSLiang Chen
9167053e06bSLiang Chen	qos_nand: qos@ff538080 {
9177053e06bSLiang Chen		compatible = "syscon";
9187053e06bSLiang Chen		reg = <0x0 0xff538080 0x0 0x20>;
9197053e06bSLiang Chen	};
9207053e06bSLiang Chen
9217053e06bSLiang Chen	qos_sdio: qos@ff538100 {
9227053e06bSLiang Chen		compatible = "syscon";
9237053e06bSLiang Chen		reg = <0x0 0xff538100 0x0 0x20>;
9247053e06bSLiang Chen	};
9257053e06bSLiang Chen
9267053e06bSLiang Chen	qos_sfc: qos@ff538180 {
9277053e06bSLiang Chen		compatible = "syscon";
9287053e06bSLiang Chen		reg = <0x0 0xff538180 0x0 0x20>;
9297053e06bSLiang Chen	};
9307053e06bSLiang Chen
9317053e06bSLiang Chen	qos_usb_host: qos@ff540000 {
9327053e06bSLiang Chen		compatible = "syscon";
9337053e06bSLiang Chen		reg = <0x0 0xff540000 0x0 0x20>;
9347053e06bSLiang Chen	};
9357053e06bSLiang Chen
9367053e06bSLiang Chen	qos_usb_otg: qos@ff540080 {
9377053e06bSLiang Chen		compatible = "syscon";
9387053e06bSLiang Chen		reg = <0x0 0xff540080 0x0 0x20>;
9397053e06bSLiang Chen	};
9407053e06bSLiang Chen
9417053e06bSLiang Chen	qos_isp_128: qos@ff548000 {
9427053e06bSLiang Chen		compatible = "syscon";
9437053e06bSLiang Chen		reg = <0x0 0xff548000 0x0 0x20>;
9447053e06bSLiang Chen	};
9457053e06bSLiang Chen
9467053e06bSLiang Chen	qos_isp_rd: qos@ff548080 {
9477053e06bSLiang Chen		compatible = "syscon";
9487053e06bSLiang Chen		reg = <0x0 0xff548080 0x0 0x20>;
9497053e06bSLiang Chen	};
9507053e06bSLiang Chen
9517053e06bSLiang Chen	qos_isp_wr: qos@ff548100 {
9527053e06bSLiang Chen		compatible = "syscon";
9537053e06bSLiang Chen		reg = <0x0 0xff548100 0x0 0x20>;
9547053e06bSLiang Chen	};
9557053e06bSLiang Chen
9567053e06bSLiang Chen	qos_isp_m1: qos@ff548180 {
9577053e06bSLiang Chen		compatible = "syscon";
9587053e06bSLiang Chen		reg = <0x0 0xff548180 0x0 0x20>;
9597053e06bSLiang Chen	};
9607053e06bSLiang Chen
9617053e06bSLiang Chen	qos_vip: qos@ff548200 {
9627053e06bSLiang Chen		compatible = "syscon";
9637053e06bSLiang Chen		reg = <0x0 0xff548200 0x0 0x20>;
9647053e06bSLiang Chen	};
9657053e06bSLiang Chen
9667053e06bSLiang Chen	qos_rga_rd: qos@ff550000 {
9677053e06bSLiang Chen		compatible = "syscon";
9687053e06bSLiang Chen		reg = <0x0 0xff550000 0x0 0x20>;
9697053e06bSLiang Chen	};
9707053e06bSLiang Chen
9717053e06bSLiang Chen	qos_rga_wr: qos@ff550080 {
9727053e06bSLiang Chen		compatible = "syscon";
9737053e06bSLiang Chen		reg = <0x0 0xff550080 0x0 0x20>;
9747053e06bSLiang Chen	};
9757053e06bSLiang Chen
9767053e06bSLiang Chen	qos_vop_m0: qos@ff550100 {
9777053e06bSLiang Chen		compatible = "syscon";
9787053e06bSLiang Chen		reg = <0x0 0xff550100 0x0 0x20>;
9797053e06bSLiang Chen	};
9807053e06bSLiang Chen
9817053e06bSLiang Chen	qos_vop_m1: qos@ff550180 {
9827053e06bSLiang Chen		compatible = "syscon";
9837053e06bSLiang Chen		reg = <0x0 0xff550180 0x0 0x20>;
9847053e06bSLiang Chen	};
9857053e06bSLiang Chen
9867053e06bSLiang Chen	qos_vpu: qos@ff558000 {
9877053e06bSLiang Chen		compatible = "syscon";
9887053e06bSLiang Chen		reg = <0x0 0xff558000 0x0 0x20>;
9897053e06bSLiang Chen	};
9907053e06bSLiang Chen
9917053e06bSLiang Chen	qos_vpu_r128: qos@ff558080 {
9927053e06bSLiang Chen		compatible = "syscon";
9937053e06bSLiang Chen		reg = <0x0 0xff558080 0x0 0x20>;
9947053e06bSLiang Chen	};
9957053e06bSLiang Chen
9967053e06bSLiang Chen	pinctrl: pinctrl {
9977053e06bSLiang Chen		compatible = "rockchip,px30-pinctrl";
9987053e06bSLiang Chen		rockchip,grf = <&grf>;
9997053e06bSLiang Chen		rockchip,pmu = <&pmugrf>;
10007053e06bSLiang Chen		#address-cells = <2>;
10017053e06bSLiang Chen		#size-cells = <2>;
10027053e06bSLiang Chen		ranges;
10037053e06bSLiang Chen
10047053e06bSLiang Chen		gpio0: gpio0@ff040000 {
10057053e06bSLiang Chen			compatible = "rockchip,gpio-bank";
10067053e06bSLiang Chen			reg = <0x0 0xff040000 0x0 0x100>;
10077053e06bSLiang Chen			interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
10087053e06bSLiang Chen			clocks = <&pmucru PCLK_GPIO0_PMU>;
10097053e06bSLiang Chen			gpio-controller;
10107053e06bSLiang Chen			#gpio-cells = <2>;
10117053e06bSLiang Chen
10127053e06bSLiang Chen			interrupt-controller;
10137053e06bSLiang Chen			#interrupt-cells = <2>;
10147053e06bSLiang Chen		};
10157053e06bSLiang Chen
10167053e06bSLiang Chen		gpio1: gpio1@ff250000 {
10177053e06bSLiang Chen			compatible = "rockchip,gpio-bank";
10187053e06bSLiang Chen			reg = <0x0 0xff250000 0x0 0x100>;
10197053e06bSLiang Chen			interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
10207053e06bSLiang Chen			clocks = <&cru PCLK_GPIO1>;
10217053e06bSLiang Chen			gpio-controller;
10227053e06bSLiang Chen			#gpio-cells = <2>;
10237053e06bSLiang Chen
10247053e06bSLiang Chen			interrupt-controller;
10257053e06bSLiang Chen			#interrupt-cells = <2>;
10267053e06bSLiang Chen		};
10277053e06bSLiang Chen
10287053e06bSLiang Chen		gpio2: gpio2@ff260000 {
10297053e06bSLiang Chen			compatible = "rockchip,gpio-bank";
10307053e06bSLiang Chen			reg = <0x0 0xff260000 0x0 0x100>;
10317053e06bSLiang Chen			interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
10327053e06bSLiang Chen			clocks = <&cru PCLK_GPIO2>;
10337053e06bSLiang Chen			gpio-controller;
10347053e06bSLiang Chen			#gpio-cells = <2>;
10357053e06bSLiang Chen
10367053e06bSLiang Chen			interrupt-controller;
10377053e06bSLiang Chen			#interrupt-cells = <2>;
10387053e06bSLiang Chen		};
10397053e06bSLiang Chen
10407053e06bSLiang Chen		gpio3: gpio3@ff270000 {
10417053e06bSLiang Chen			compatible = "rockchip,gpio-bank";
10427053e06bSLiang Chen			reg = <0x0 0xff270000 0x0 0x100>;
10437053e06bSLiang Chen			interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
10447053e06bSLiang Chen			clocks = <&cru PCLK_GPIO3>;
10457053e06bSLiang Chen			gpio-controller;
10467053e06bSLiang Chen			#gpio-cells = <2>;
10477053e06bSLiang Chen
10487053e06bSLiang Chen			interrupt-controller;
10497053e06bSLiang Chen			#interrupt-cells = <2>;
10507053e06bSLiang Chen		};
10517053e06bSLiang Chen
10527053e06bSLiang Chen		pcfg_pull_up: pcfg-pull-up {
10537053e06bSLiang Chen			bias-pull-up;
10547053e06bSLiang Chen		};
10557053e06bSLiang Chen
10567053e06bSLiang Chen		pcfg_pull_down: pcfg-pull-down {
10577053e06bSLiang Chen			bias-pull-down;
10587053e06bSLiang Chen		};
10597053e06bSLiang Chen
10607053e06bSLiang Chen		pcfg_pull_none: pcfg-pull-none {
10617053e06bSLiang Chen			bias-disable;
10627053e06bSLiang Chen		};
10637053e06bSLiang Chen
10647053e06bSLiang Chen		pcfg_pull_none_2ma: pcfg-pull-none-2ma {
10657053e06bSLiang Chen			bias-disable;
10667053e06bSLiang Chen			drive-strength = <2>;
10677053e06bSLiang Chen		};
10687053e06bSLiang Chen
10697053e06bSLiang Chen		pcfg_pull_up_2ma: pcfg-pull-up-2ma {
10707053e06bSLiang Chen			bias-pull-up;
10717053e06bSLiang Chen			drive-strength = <2>;
10727053e06bSLiang Chen		};
10737053e06bSLiang Chen
10747053e06bSLiang Chen		pcfg_pull_up_4ma: pcfg-pull-up-4ma {
10757053e06bSLiang Chen			bias-pull-up;
10767053e06bSLiang Chen			drive-strength = <4>;
10777053e06bSLiang Chen		};
10787053e06bSLiang Chen
10797053e06bSLiang Chen		pcfg_pull_none_4ma: pcfg-pull-none-4ma {
10807053e06bSLiang Chen			bias-disable;
10817053e06bSLiang Chen			drive-strength = <4>;
10827053e06bSLiang Chen		};
10837053e06bSLiang Chen
10847053e06bSLiang Chen		pcfg_pull_down_4ma: pcfg-pull-down-4ma {
10857053e06bSLiang Chen			bias-pull-down;
10867053e06bSLiang Chen			drive-strength = <4>;
10877053e06bSLiang Chen		};
10887053e06bSLiang Chen
10897053e06bSLiang Chen		pcfg_pull_none_8ma: pcfg-pull-none-8ma {
10907053e06bSLiang Chen			bias-disable;
10917053e06bSLiang Chen			drive-strength = <8>;
10927053e06bSLiang Chen		};
10937053e06bSLiang Chen
10947053e06bSLiang Chen		pcfg_pull_up_8ma: pcfg-pull-up-8ma {
10957053e06bSLiang Chen			bias-pull-up;
10967053e06bSLiang Chen			drive-strength = <8>;
10977053e06bSLiang Chen		};
10987053e06bSLiang Chen
10997053e06bSLiang Chen		pcfg_pull_none_12ma: pcfg-pull-none-12ma {
11007053e06bSLiang Chen			bias-disable;
11017053e06bSLiang Chen			drive-strength = <12>;
11027053e06bSLiang Chen		};
11037053e06bSLiang Chen
11047053e06bSLiang Chen		pcfg_pull_up_12ma: pcfg-pull-up-12ma {
11057053e06bSLiang Chen			bias-pull-up;
11067053e06bSLiang Chen			drive-strength = <12>;
11077053e06bSLiang Chen		};
11087053e06bSLiang Chen
11097053e06bSLiang Chen		pcfg_pull_none_smt: pcfg-pull-none-smt {
11107053e06bSLiang Chen			bias-disable;
11117053e06bSLiang Chen			input-schmitt-enable;
11127053e06bSLiang Chen		};
11137053e06bSLiang Chen
11147053e06bSLiang Chen		pcfg_output_high: pcfg-output-high {
11157053e06bSLiang Chen			output-high;
11167053e06bSLiang Chen		};
11177053e06bSLiang Chen
11187053e06bSLiang Chen		pcfg_output_low: pcfg-output-low {
11197053e06bSLiang Chen			output-low;
11207053e06bSLiang Chen		};
11217053e06bSLiang Chen
11227053e06bSLiang Chen		pcfg_input_high: pcfg-input-high {
11237053e06bSLiang Chen			bias-pull-up;
11247053e06bSLiang Chen			input-enable;
11257053e06bSLiang Chen		};
11267053e06bSLiang Chen
11277053e06bSLiang Chen		pcfg_input: pcfg-input {
11287053e06bSLiang Chen			input-enable;
11297053e06bSLiang Chen		};
11307053e06bSLiang Chen
11317053e06bSLiang Chen		i2c0 {
11327053e06bSLiang Chen			i2c0_xfer: i2c0-xfer {
11337053e06bSLiang Chen				rockchip,pins =
11347053e06bSLiang Chen					<0 RK_PB0 1 &pcfg_pull_none_smt>,
11357053e06bSLiang Chen					<0 RK_PB1 1 &pcfg_pull_none_smt>;
11367053e06bSLiang Chen			};
11377053e06bSLiang Chen		};
11387053e06bSLiang Chen
11397053e06bSLiang Chen		i2c1 {
11407053e06bSLiang Chen			i2c1_xfer: i2c1-xfer {
11417053e06bSLiang Chen				rockchip,pins =
11427053e06bSLiang Chen					<0 RK_PC2 1 &pcfg_pull_none_smt>,
11437053e06bSLiang Chen					<0 RK_PC3 1 &pcfg_pull_none_smt>;
11447053e06bSLiang Chen			};
11457053e06bSLiang Chen		};
11467053e06bSLiang Chen
11477053e06bSLiang Chen		i2c2 {
11487053e06bSLiang Chen			i2c2_xfer: i2c2-xfer {
11497053e06bSLiang Chen				rockchip,pins =
11507053e06bSLiang Chen					<2 RK_PB7 2 &pcfg_pull_none_smt>,
11517053e06bSLiang Chen					<2 RK_PC0 2 &pcfg_pull_none_smt>;
11527053e06bSLiang Chen			};
11537053e06bSLiang Chen		};
11547053e06bSLiang Chen
11557053e06bSLiang Chen		i2c3 {
11567053e06bSLiang Chen			i2c3_xfer: i2c3-xfer {
11577053e06bSLiang Chen				rockchip,pins =
11587053e06bSLiang Chen					<1 RK_PB4 4 &pcfg_pull_none_smt>,
11597053e06bSLiang Chen					<1 RK_PB5 4 &pcfg_pull_none_smt>;
11607053e06bSLiang Chen			};
11617053e06bSLiang Chen		};
11627053e06bSLiang Chen
11637053e06bSLiang Chen		tsadc {
11647053e06bSLiang Chen			tsadc_otp_gpio: tsadc-otp-gpio {
11657053e06bSLiang Chen				rockchip,pins =
11667053e06bSLiang Chen					<0 RK_PA6 RK_FUNC_GPIO &pcfg_pull_none>;
11677053e06bSLiang Chen			};
11687053e06bSLiang Chen
11697053e06bSLiang Chen			tsadc_otp_out: tsadc-otp-out {
11707053e06bSLiang Chen				rockchip,pins =
11717053e06bSLiang Chen					<0 RK_PA6 1 &pcfg_pull_none>;
11727053e06bSLiang Chen			};
11737053e06bSLiang Chen		};
11747053e06bSLiang Chen
11757053e06bSLiang Chen		uart0 {
11767053e06bSLiang Chen			uart0_xfer: uart0-xfer {
11777053e06bSLiang Chen				rockchip,pins =
11787053e06bSLiang Chen					<0 RK_PB2 1 &pcfg_pull_up>,
11797053e06bSLiang Chen					<0 RK_PB3 1 &pcfg_pull_up>;
11807053e06bSLiang Chen			};
11817053e06bSLiang Chen
11827053e06bSLiang Chen			uart0_cts: uart0-cts {
11837053e06bSLiang Chen				rockchip,pins =
11847053e06bSLiang Chen					<0 RK_PB4 1 &pcfg_pull_none>;
11857053e06bSLiang Chen			};
11867053e06bSLiang Chen
11877053e06bSLiang Chen			uart0_rts: uart0-rts {
11887053e06bSLiang Chen				rockchip,pins =
11897053e06bSLiang Chen					<0 RK_PB5 1 &pcfg_pull_none>;
11907053e06bSLiang Chen			};
11917053e06bSLiang Chen		};
11927053e06bSLiang Chen
11937053e06bSLiang Chen		uart1 {
11947053e06bSLiang Chen			uart1_xfer: uart1-xfer {
11957053e06bSLiang Chen				rockchip,pins =
11967053e06bSLiang Chen					<1 RK_PC1 1 &pcfg_pull_up>,
11977053e06bSLiang Chen					<1 RK_PC0 1 &pcfg_pull_up>;
11987053e06bSLiang Chen			};
11997053e06bSLiang Chen
12007053e06bSLiang Chen			uart1_cts: uart1-cts {
12017053e06bSLiang Chen				rockchip,pins =
12027053e06bSLiang Chen					<1 RK_PC2 1 &pcfg_pull_none>;
12037053e06bSLiang Chen			};
12047053e06bSLiang Chen
12057053e06bSLiang Chen			uart1_rts: uart1-rts {
12067053e06bSLiang Chen				rockchip,pins =
12077053e06bSLiang Chen					<1 RK_PC3 1 &pcfg_pull_none>;
12087053e06bSLiang Chen			};
12097053e06bSLiang Chen		};
12107053e06bSLiang Chen
12117053e06bSLiang Chen		uart2-m0 {
12127053e06bSLiang Chen			uart2m0_xfer: uart2m0-xfer {
12137053e06bSLiang Chen				rockchip,pins =
12147053e06bSLiang Chen					<1 RK_PD2 2 &pcfg_pull_up>,
12157053e06bSLiang Chen					<1 RK_PD3 2 &pcfg_pull_up>;
12167053e06bSLiang Chen			};
12177053e06bSLiang Chen		};
12187053e06bSLiang Chen
12197053e06bSLiang Chen		uart2-m1 {
12207053e06bSLiang Chen			uart2m1_xfer: uart2m1-xfer {
12217053e06bSLiang Chen				rockchip,pins =
12227053e06bSLiang Chen					<2 RK_PB4 2 &pcfg_pull_up>,
12237053e06bSLiang Chen					<2 RK_PB6 2 &pcfg_pull_up>;
12247053e06bSLiang Chen			};
12257053e06bSLiang Chen		};
12267053e06bSLiang Chen
12277053e06bSLiang Chen		uart3-m0 {
12287053e06bSLiang Chen			uart3m0_xfer: uart3m0-xfer {
12297053e06bSLiang Chen				rockchip,pins =
12307053e06bSLiang Chen					<0 RK_PC0 2 &pcfg_pull_up>,
12317053e06bSLiang Chen					<0 RK_PC1 2 &pcfg_pull_up>;
12327053e06bSLiang Chen			};
12337053e06bSLiang Chen
12347053e06bSLiang Chen			uart3m0_cts: uart3m0-cts {
12357053e06bSLiang Chen				rockchip,pins =
12367053e06bSLiang Chen					<0 RK_PC2 2 &pcfg_pull_none>;
12377053e06bSLiang Chen			};
12387053e06bSLiang Chen
12397053e06bSLiang Chen			uart3m0_rts: uart3m0-rts {
12407053e06bSLiang Chen				rockchip,pins =
12417053e06bSLiang Chen					<0 RK_PC3 2 &pcfg_pull_none>;
12427053e06bSLiang Chen			};
12437053e06bSLiang Chen		};
12447053e06bSLiang Chen
12457053e06bSLiang Chen		uart3-m1 {
12467053e06bSLiang Chen			uart3m1_xfer: uart3m1-xfer {
12477053e06bSLiang Chen				rockchip,pins =
12487053e06bSLiang Chen					<1 RK_PB6 2 &pcfg_pull_up>,
12497053e06bSLiang Chen					<1 RK_PB7 2 &pcfg_pull_up>;
12507053e06bSLiang Chen			};
12517053e06bSLiang Chen
12527053e06bSLiang Chen			uart3m1_cts: uart3m1-cts {
12537053e06bSLiang Chen				rockchip,pins =
12547053e06bSLiang Chen					<1 RK_PB4 2 &pcfg_pull_none>;
12557053e06bSLiang Chen			};
12567053e06bSLiang Chen
12577053e06bSLiang Chen			uart3m1_rts: uart3m1-rts {
12587053e06bSLiang Chen				rockchip,pins =
12597053e06bSLiang Chen					<1 RK_PB5 2 &pcfg_pull_none>;
12607053e06bSLiang Chen			};
12617053e06bSLiang Chen		};
12627053e06bSLiang Chen
12637053e06bSLiang Chen		uart4 {
12647053e06bSLiang Chen			uart4_xfer: uart4-xfer {
12657053e06bSLiang Chen				rockchip,pins =
12667053e06bSLiang Chen					<1 RK_PD4 2 &pcfg_pull_up>,
12677053e06bSLiang Chen					<1 RK_PD5 2 &pcfg_pull_up>;
12687053e06bSLiang Chen			};
12697053e06bSLiang Chen
12707053e06bSLiang Chen			uart4_cts: uart4-cts {
12717053e06bSLiang Chen				rockchip,pins =
12727053e06bSLiang Chen					<1 RK_PD6 2 &pcfg_pull_none>;
12737053e06bSLiang Chen			};
12747053e06bSLiang Chen
12757053e06bSLiang Chen			uart4_rts: uart4-rts {
12767053e06bSLiang Chen				rockchip,pins =
12777053e06bSLiang Chen					<1 RK_PD7 2 &pcfg_pull_none>;
12787053e06bSLiang Chen			};
12797053e06bSLiang Chen		};
12807053e06bSLiang Chen
12817053e06bSLiang Chen		uart5 {
12827053e06bSLiang Chen			uart5_xfer: uart5-xfer {
12837053e06bSLiang Chen				rockchip,pins =
12847053e06bSLiang Chen					<3 RK_PA2 4 &pcfg_pull_up>,
12857053e06bSLiang Chen					<3 RK_PA1 4 &pcfg_pull_up>;
12867053e06bSLiang Chen			};
12877053e06bSLiang Chen
12887053e06bSLiang Chen			uart5_cts: uart5-cts {
12897053e06bSLiang Chen				rockchip,pins =
12907053e06bSLiang Chen					<3 RK_PA3 4 &pcfg_pull_none>;
12917053e06bSLiang Chen			};
12927053e06bSLiang Chen
12937053e06bSLiang Chen			uart5_rts: uart5-rts {
12947053e06bSLiang Chen				rockchip,pins =
12957053e06bSLiang Chen					<3 RK_PA5 4 &pcfg_pull_none>;
12967053e06bSLiang Chen			};
12977053e06bSLiang Chen		};
12987053e06bSLiang Chen
12997053e06bSLiang Chen		spi0 {
13007053e06bSLiang Chen			spi0_clk: spi0-clk {
13017053e06bSLiang Chen				rockchip,pins =
13027053e06bSLiang Chen					<1 RK_PB7 3 &pcfg_pull_up_4ma>;
13037053e06bSLiang Chen			};
13047053e06bSLiang Chen
13057053e06bSLiang Chen			spi0_csn: spi0-csn {
13067053e06bSLiang Chen				rockchip,pins =
13077053e06bSLiang Chen					<1 RK_PB6 3 &pcfg_pull_up_4ma>;
13087053e06bSLiang Chen			};
13097053e06bSLiang Chen
13107053e06bSLiang Chen			spi0_miso: spi0-miso {
13117053e06bSLiang Chen				rockchip,pins =
13127053e06bSLiang Chen					<1 RK_PB5 3 &pcfg_pull_up_4ma>;
13137053e06bSLiang Chen			};
13147053e06bSLiang Chen
13157053e06bSLiang Chen			spi0_mosi: spi0-mosi {
13167053e06bSLiang Chen				rockchip,pins =
13177053e06bSLiang Chen					<1 RK_PB4 3 &pcfg_pull_up_4ma>;
13187053e06bSLiang Chen			};
13197053e06bSLiang Chen
13207053e06bSLiang Chen			spi0_clk_hs: spi0-clk-hs {
13217053e06bSLiang Chen				rockchip,pins =
13227053e06bSLiang Chen					<1 RK_PB7 3 &pcfg_pull_up_8ma>;
13237053e06bSLiang Chen			};
13247053e06bSLiang Chen
13257053e06bSLiang Chen			spi0_miso_hs: spi0-miso-hs {
13267053e06bSLiang Chen				rockchip,pins =
13277053e06bSLiang Chen					<1 RK_PB5 3 &pcfg_pull_up_8ma>;
13287053e06bSLiang Chen			};
13297053e06bSLiang Chen
13307053e06bSLiang Chen			spi0_mosi_hs: spi0-mosi-hs {
13317053e06bSLiang Chen				rockchip,pins =
13327053e06bSLiang Chen					<1 RK_PB4 3 &pcfg_pull_up_8ma>;
13337053e06bSLiang Chen			};
13347053e06bSLiang Chen		};
13357053e06bSLiang Chen
13367053e06bSLiang Chen		spi1 {
13377053e06bSLiang Chen			spi1_clk: spi1-clk {
13387053e06bSLiang Chen				rockchip,pins =
13397053e06bSLiang Chen					<3 RK_PB7 4 &pcfg_pull_up_4ma>;
13407053e06bSLiang Chen			};
13417053e06bSLiang Chen
13427053e06bSLiang Chen			spi1_csn0: spi1-csn0 {
13437053e06bSLiang Chen				rockchip,pins =
13447053e06bSLiang Chen					<3 RK_PB1 4 &pcfg_pull_up_4ma>;
13457053e06bSLiang Chen			};
13467053e06bSLiang Chen
13477053e06bSLiang Chen			spi1_csn1: spi1-csn1 {
13487053e06bSLiang Chen				rockchip,pins =
13497053e06bSLiang Chen					<3 RK_PB2 2 &pcfg_pull_up_4ma>;
13507053e06bSLiang Chen			};
13517053e06bSLiang Chen
13527053e06bSLiang Chen			spi1_miso: spi1-miso {
13537053e06bSLiang Chen				rockchip,pins =
13547053e06bSLiang Chen					<3 RK_PB6 4 &pcfg_pull_up_4ma>;
13557053e06bSLiang Chen			};
13567053e06bSLiang Chen
13577053e06bSLiang Chen			spi1_mosi: spi1-mosi {
13587053e06bSLiang Chen				rockchip,pins =
13597053e06bSLiang Chen					<3 RK_PB4 4 &pcfg_pull_up_4ma>;
13607053e06bSLiang Chen			};
13617053e06bSLiang Chen
13627053e06bSLiang Chen			spi1_clk_hs: spi1-clk-hs {
13637053e06bSLiang Chen				rockchip,pins =
13647053e06bSLiang Chen					<3 RK_PB7 4 &pcfg_pull_up_8ma>;
13657053e06bSLiang Chen			};
13667053e06bSLiang Chen
13677053e06bSLiang Chen			spi1_miso_hs: spi1-miso-hs {
13687053e06bSLiang Chen				rockchip,pins =
13697053e06bSLiang Chen					<3 RK_PB6 4 &pcfg_pull_up_8ma>;
13707053e06bSLiang Chen			};
13717053e06bSLiang Chen
13727053e06bSLiang Chen			spi1_mosi_hs: spi1-mosi-hs {
13737053e06bSLiang Chen				rockchip,pins =
13747053e06bSLiang Chen					<3 RK_PB4 4 &pcfg_pull_up_8ma>;
13757053e06bSLiang Chen			};
13767053e06bSLiang Chen		};
13777053e06bSLiang Chen
13787053e06bSLiang Chen		pdm {
13797053e06bSLiang Chen			pdm_clk0m0: pdm-clk0m0 {
13807053e06bSLiang Chen				rockchip,pins =
13817053e06bSLiang Chen					<3 RK_PC6 2 &pcfg_pull_none>;
13827053e06bSLiang Chen			};
13837053e06bSLiang Chen
13847053e06bSLiang Chen			pdm_clk0m1: pdm-clk0m1 {
13857053e06bSLiang Chen				rockchip,pins =
13867053e06bSLiang Chen					<2 RK_PC6 1 &pcfg_pull_none>;
13877053e06bSLiang Chen			};
13887053e06bSLiang Chen
13897053e06bSLiang Chen			pdm_clk1: pdm-clk1 {
13907053e06bSLiang Chen				rockchip,pins =
13917053e06bSLiang Chen					<3 RK_PC7 2 &pcfg_pull_none>;
13927053e06bSLiang Chen			};
13937053e06bSLiang Chen
13947053e06bSLiang Chen			pdm_sdi0m0: pdm-sdi0m0 {
13957053e06bSLiang Chen				rockchip,pins =
13967053e06bSLiang Chen					<3 RK_PD3 2 &pcfg_pull_none>;
13977053e06bSLiang Chen			};
13987053e06bSLiang Chen
13997053e06bSLiang Chen			pdm_sdi0m1: pdm-sdi0m1 {
14007053e06bSLiang Chen				rockchip,pins =
14017053e06bSLiang Chen					<2 RK_PC5 2 &pcfg_pull_none>;
14027053e06bSLiang Chen			};
14037053e06bSLiang Chen
14047053e06bSLiang Chen			pdm_sdi1: pdm-sdi1 {
14057053e06bSLiang Chen				rockchip,pins =
14067053e06bSLiang Chen					<3 RK_PD0 2 &pcfg_pull_none>;
14077053e06bSLiang Chen			};
14087053e06bSLiang Chen
14097053e06bSLiang Chen			pdm_sdi2: pdm-sdi2 {
14107053e06bSLiang Chen				rockchip,pins =
14117053e06bSLiang Chen					<3 RK_PD1 2 &pcfg_pull_none>;
14127053e06bSLiang Chen			};
14137053e06bSLiang Chen
14147053e06bSLiang Chen			pdm_sdi3: pdm-sdi3 {
14157053e06bSLiang Chen				rockchip,pins =
14167053e06bSLiang Chen					<3 RK_PD2 2 &pcfg_pull_none>;
14177053e06bSLiang Chen			};
14187053e06bSLiang Chen
14197053e06bSLiang Chen			pdm_clk0m0_sleep: pdm-clk0m0-sleep {
14207053e06bSLiang Chen				rockchip,pins =
14217053e06bSLiang Chen					<3 RK_PC6 RK_FUNC_GPIO &pcfg_input_high>;
14227053e06bSLiang Chen			};
14237053e06bSLiang Chen
14247053e06bSLiang Chen			pdm_clk0m_sleep1: pdm-clk0m1-sleep {
14257053e06bSLiang Chen				rockchip,pins =
14267053e06bSLiang Chen					<2 RK_PC6 RK_FUNC_GPIO &pcfg_input_high>;
14277053e06bSLiang Chen			};
14287053e06bSLiang Chen
14297053e06bSLiang Chen			pdm_clk1_sleep: pdm-clk1-sleep {
14307053e06bSLiang Chen				rockchip,pins =
14317053e06bSLiang Chen					<3 RK_PC7 RK_FUNC_GPIO &pcfg_input_high>;
14327053e06bSLiang Chen			};
14337053e06bSLiang Chen
14347053e06bSLiang Chen			pdm_sdi0m0_sleep: pdm-sdi0m0-sleep {
14357053e06bSLiang Chen				rockchip,pins =
14367053e06bSLiang Chen					<3 RK_PD3 RK_FUNC_GPIO &pcfg_input_high>;
14377053e06bSLiang Chen			};
14387053e06bSLiang Chen
14397053e06bSLiang Chen			pdm_sdi0m1_sleep: pdm-sdi0m1-sleep {
14407053e06bSLiang Chen				rockchip,pins =
14417053e06bSLiang Chen					<2 RK_PC5 RK_FUNC_GPIO &pcfg_input_high>;
14427053e06bSLiang Chen			};
14437053e06bSLiang Chen
14447053e06bSLiang Chen			pdm_sdi1_sleep: pdm-sdi1-sleep {
14457053e06bSLiang Chen				rockchip,pins =
14467053e06bSLiang Chen					<3 RK_PD0 RK_FUNC_GPIO &pcfg_input_high>;
14477053e06bSLiang Chen			};
14487053e06bSLiang Chen
14497053e06bSLiang Chen			pdm_sdi2_sleep: pdm-sdi2-sleep {
14507053e06bSLiang Chen				rockchip,pins =
14517053e06bSLiang Chen					<3 RK_PD1 RK_FUNC_GPIO &pcfg_input_high>;
14527053e06bSLiang Chen			};
14537053e06bSLiang Chen
14547053e06bSLiang Chen			pdm_sdi3_sleep: pdm-sdi3-sleep {
14557053e06bSLiang Chen				rockchip,pins =
14567053e06bSLiang Chen					<3 RK_PD2 RK_FUNC_GPIO &pcfg_input_high>;
14577053e06bSLiang Chen			};
14587053e06bSLiang Chen		};
14597053e06bSLiang Chen
14607053e06bSLiang Chen		i2s0 {
14617053e06bSLiang Chen			i2s0_8ch_mclk: i2s0-8ch-mclk {
14627053e06bSLiang Chen				rockchip,pins =
14637053e06bSLiang Chen					<3 RK_PC1 2 &pcfg_pull_none>;
14647053e06bSLiang Chen			};
14657053e06bSLiang Chen
14667053e06bSLiang Chen			i2s0_8ch_sclktx: i2s0-8ch-sclktx {
14677053e06bSLiang Chen				rockchip,pins =
14687053e06bSLiang Chen					<3 RK_PC3 2 &pcfg_pull_none>;
14697053e06bSLiang Chen			};
14707053e06bSLiang Chen
14717053e06bSLiang Chen			i2s0_8ch_sclkrx: i2s0-8ch-sclkrx {
14727053e06bSLiang Chen				rockchip,pins =
14737053e06bSLiang Chen					<3 RK_PB4 2 &pcfg_pull_none>;
14747053e06bSLiang Chen			};
14757053e06bSLiang Chen
14767053e06bSLiang Chen			i2s0_8ch_lrcktx: i2s0-8ch-lrcktx {
14777053e06bSLiang Chen				rockchip,pins =
14787053e06bSLiang Chen					<3 RK_PC2 2 &pcfg_pull_none>;
14797053e06bSLiang Chen			};
14807053e06bSLiang Chen
14817053e06bSLiang Chen			i2s0_8ch_lrckrx: i2s0-8ch-lrckrx {
14827053e06bSLiang Chen				rockchip,pins =
14837053e06bSLiang Chen					<3 RK_PB5 2 &pcfg_pull_none>;
14847053e06bSLiang Chen			};
14857053e06bSLiang Chen
14867053e06bSLiang Chen			i2s0_8ch_sdo0: i2s0-8ch-sdo0 {
14877053e06bSLiang Chen				rockchip,pins =
14887053e06bSLiang Chen					<3 RK_PC4 2 &pcfg_pull_none>;
14897053e06bSLiang Chen			};
14907053e06bSLiang Chen
14917053e06bSLiang Chen			i2s0_8ch_sdo1: i2s0-8ch-sdo1 {
14927053e06bSLiang Chen				rockchip,pins =
14937053e06bSLiang Chen					<3 RK_PC0 2 &pcfg_pull_none>;
14947053e06bSLiang Chen			};
14957053e06bSLiang Chen
14967053e06bSLiang Chen			i2s0_8ch_sdo2: i2s0-8ch-sdo2 {
14977053e06bSLiang Chen				rockchip,pins =
14987053e06bSLiang Chen					<3 RK_PB7 2 &pcfg_pull_none>;
14997053e06bSLiang Chen			};
15007053e06bSLiang Chen
15017053e06bSLiang Chen			i2s0_8ch_sdo3: i2s0-8ch-sdo3 {
15027053e06bSLiang Chen				rockchip,pins =
15037053e06bSLiang Chen					<3 RK_PB6 2 &pcfg_pull_none>;
15047053e06bSLiang Chen			};
15057053e06bSLiang Chen
15067053e06bSLiang Chen			i2s0_8ch_sdi0: i2s0-8ch-sdi0 {
15077053e06bSLiang Chen				rockchip,pins =
15087053e06bSLiang Chen					<3 RK_PC5 2 &pcfg_pull_none>;
15097053e06bSLiang Chen			};
15107053e06bSLiang Chen
15117053e06bSLiang Chen			i2s0_8ch_sdi1: i2s0-8ch-sdi1 {
15127053e06bSLiang Chen				rockchip,pins =
15137053e06bSLiang Chen					<3 RK_PB3 2 &pcfg_pull_none>;
15147053e06bSLiang Chen			};
15157053e06bSLiang Chen
15167053e06bSLiang Chen			i2s0_8ch_sdi2: i2s0-8ch-sdi2 {
15177053e06bSLiang Chen				rockchip,pins =
15187053e06bSLiang Chen					<3 RK_PB1 2 &pcfg_pull_none>;
15197053e06bSLiang Chen			};
15207053e06bSLiang Chen
15217053e06bSLiang Chen			i2s0_8ch_sdi3: i2s0-8ch-sdi3 {
15227053e06bSLiang Chen				rockchip,pins =
15237053e06bSLiang Chen					<3 RK_PB0 2 &pcfg_pull_none>;
15247053e06bSLiang Chen			};
15257053e06bSLiang Chen		};
15267053e06bSLiang Chen
15277053e06bSLiang Chen		i2s1 {
15287053e06bSLiang Chen			i2s1_2ch_mclk: i2s1-2ch-mclk {
15297053e06bSLiang Chen				rockchip,pins =
15307053e06bSLiang Chen					<2 RK_PC3 1 &pcfg_pull_none>;
15317053e06bSLiang Chen			};
15327053e06bSLiang Chen
15337053e06bSLiang Chen			i2s1_2ch_sclk: i2s1-2ch-sclk {
15347053e06bSLiang Chen				rockchip,pins =
15357053e06bSLiang Chen					<2 RK_PC2 1 &pcfg_pull_none>;
15367053e06bSLiang Chen			};
15377053e06bSLiang Chen
15387053e06bSLiang Chen			i2s1_2ch_lrck: i2s1-2ch-lrck {
15397053e06bSLiang Chen				rockchip,pins =
15407053e06bSLiang Chen					<2 RK_PC1 1 &pcfg_pull_none>;
15417053e06bSLiang Chen			};
15427053e06bSLiang Chen
15437053e06bSLiang Chen			i2s1_2ch_sdi: i2s1-2ch-sdi {
15447053e06bSLiang Chen				rockchip,pins =
15457053e06bSLiang Chen					<2 RK_PC5 1 &pcfg_pull_none>;
15467053e06bSLiang Chen			};
15477053e06bSLiang Chen
15487053e06bSLiang Chen			i2s1_2ch_sdo: i2s1-2ch-sdo {
15497053e06bSLiang Chen				rockchip,pins =
15507053e06bSLiang Chen					<2 RK_PC4 1 &pcfg_pull_none>;
15517053e06bSLiang Chen			};
15527053e06bSLiang Chen		};
15537053e06bSLiang Chen
15547053e06bSLiang Chen		i2s2 {
15557053e06bSLiang Chen			i2s2_2ch_mclk: i2s2-2ch-mclk {
15567053e06bSLiang Chen				rockchip,pins =
15577053e06bSLiang Chen					<3 RK_PA1 2 &pcfg_pull_none>;
15587053e06bSLiang Chen			};
15597053e06bSLiang Chen
15607053e06bSLiang Chen			i2s2_2ch_sclk: i2s2-2ch-sclk {
15617053e06bSLiang Chen				rockchip,pins =
15627053e06bSLiang Chen					<3 RK_PA2 2 &pcfg_pull_none>;
15637053e06bSLiang Chen			};
15647053e06bSLiang Chen
15657053e06bSLiang Chen			i2s2_2ch_lrck: i2s2-2ch-lrck {
15667053e06bSLiang Chen				rockchip,pins =
15677053e06bSLiang Chen					<3 RK_PA3 2 &pcfg_pull_none>;
15687053e06bSLiang Chen			};
15697053e06bSLiang Chen
15707053e06bSLiang Chen			i2s2_2ch_sdi: i2s2-2ch-sdi {
15717053e06bSLiang Chen				rockchip,pins =
15727053e06bSLiang Chen					<3 RK_PA5 2 &pcfg_pull_none>;
15737053e06bSLiang Chen			};
15747053e06bSLiang Chen
15757053e06bSLiang Chen			i2s2_2ch_sdo: i2s2-2ch-sdo {
15767053e06bSLiang Chen				rockchip,pins =
15777053e06bSLiang Chen					<3 RK_PA7 2 &pcfg_pull_none>;
15787053e06bSLiang Chen			};
15797053e06bSLiang Chen		};
15807053e06bSLiang Chen
15817053e06bSLiang Chen		sdmmc {
15827053e06bSLiang Chen			sdmmc_clk: sdmmc-clk {
15837053e06bSLiang Chen				rockchip,pins =
15847053e06bSLiang Chen					<1 RK_PD6 1 &pcfg_pull_none_8ma>;
15857053e06bSLiang Chen			};
15867053e06bSLiang Chen
15877053e06bSLiang Chen			sdmmc_cmd: sdmmc-cmd {
15887053e06bSLiang Chen				rockchip,pins =
15897053e06bSLiang Chen					<1 RK_PD7 1 &pcfg_pull_up_8ma>;
15907053e06bSLiang Chen			};
15917053e06bSLiang Chen
15927053e06bSLiang Chen			sdmmc_det: sdmmc-det {
15937053e06bSLiang Chen				rockchip,pins =
15947053e06bSLiang Chen					<0 RK_PA3 1 &pcfg_pull_up_8ma>;
15957053e06bSLiang Chen			};
15967053e06bSLiang Chen
15977053e06bSLiang Chen			sdmmc_bus1: sdmmc-bus1 {
15987053e06bSLiang Chen				rockchip,pins =
15997053e06bSLiang Chen					<1 RK_PD2 1 &pcfg_pull_up_8ma>;
16007053e06bSLiang Chen			};
16017053e06bSLiang Chen
16027053e06bSLiang Chen			sdmmc_bus4: sdmmc-bus4 {
16037053e06bSLiang Chen				rockchip,pins =
16047053e06bSLiang Chen					<1 RK_PD2 1 &pcfg_pull_up_8ma>,
16057053e06bSLiang Chen					<1 RK_PD3 1 &pcfg_pull_up_8ma>,
16067053e06bSLiang Chen					<1 RK_PD4 1 &pcfg_pull_up_8ma>,
16077053e06bSLiang Chen					<1 RK_PD5 1 &pcfg_pull_up_8ma>;
16087053e06bSLiang Chen			};
16097053e06bSLiang Chen		};
16107053e06bSLiang Chen
16117053e06bSLiang Chen		sdio {
16127053e06bSLiang Chen			sdio_clk: sdio-clk {
16137053e06bSLiang Chen				rockchip,pins =
16147053e06bSLiang Chen					<1 RK_PC5 1 &pcfg_pull_none>;
16157053e06bSLiang Chen			};
16167053e06bSLiang Chen
16177053e06bSLiang Chen			sdio_cmd: sdio-cmd {
16187053e06bSLiang Chen				rockchip,pins =
16197053e06bSLiang Chen					<1 RK_PC4 1 &pcfg_pull_up>;
16207053e06bSLiang Chen			};
16217053e06bSLiang Chen
16227053e06bSLiang Chen			sdio_bus4: sdio-bus4 {
16237053e06bSLiang Chen				rockchip,pins =
16247053e06bSLiang Chen					<1 RK_PC6 1 &pcfg_pull_up>,
16257053e06bSLiang Chen					<1 RK_PC7 1 &pcfg_pull_up>,
16267053e06bSLiang Chen					<1 RK_PD0 1 &pcfg_pull_up>,
16277053e06bSLiang Chen					<1 RK_PD1 1 &pcfg_pull_up>;
16287053e06bSLiang Chen			};
16297053e06bSLiang Chen		};
16307053e06bSLiang Chen
16317053e06bSLiang Chen		emmc {
16327053e06bSLiang Chen			emmc_clk: emmc-clk {
16337053e06bSLiang Chen				rockchip,pins =
16347053e06bSLiang Chen					<1 RK_PB1 2 &pcfg_pull_none_8ma>;
16357053e06bSLiang Chen			};
16367053e06bSLiang Chen
16377053e06bSLiang Chen			emmc_cmd: emmc-cmd {
16387053e06bSLiang Chen				rockchip,pins =
16397053e06bSLiang Chen					<1 RK_PB2 2 &pcfg_pull_up_8ma>;
16407053e06bSLiang Chen			};
16417053e06bSLiang Chen
16427053e06bSLiang Chen			emmc_rstnout: emmc-rstnout {
16437053e06bSLiang Chen				rockchip,pins =
16447053e06bSLiang Chen					<1 RK_PB3 2 &pcfg_pull_none>;
16457053e06bSLiang Chen			};
16467053e06bSLiang Chen
16477053e06bSLiang Chen			emmc_bus1: emmc-bus1 {
16487053e06bSLiang Chen				rockchip,pins =
16497053e06bSLiang Chen					<1 RK_PA0 2 &pcfg_pull_up_8ma>;
16507053e06bSLiang Chen			};
16517053e06bSLiang Chen
16527053e06bSLiang Chen			emmc_bus4: emmc-bus4 {
16537053e06bSLiang Chen				rockchip,pins =
16547053e06bSLiang Chen					<1 RK_PA0 2 &pcfg_pull_up_8ma>,
16557053e06bSLiang Chen					<1 RK_PA1 2 &pcfg_pull_up_8ma>,
16567053e06bSLiang Chen					<1 RK_PA2 2 &pcfg_pull_up_8ma>,
16577053e06bSLiang Chen					<1 RK_PA3 2 &pcfg_pull_up_8ma>;
16587053e06bSLiang Chen			};
16597053e06bSLiang Chen
16607053e06bSLiang Chen			emmc_bus8: emmc-bus8 {
16617053e06bSLiang Chen				rockchip,pins =
16627053e06bSLiang Chen					<1 RK_PA0 2 &pcfg_pull_up_8ma>,
16637053e06bSLiang Chen					<1 RK_PA1 2 &pcfg_pull_up_8ma>,
16647053e06bSLiang Chen					<1 RK_PA2 2 &pcfg_pull_up_8ma>,
16657053e06bSLiang Chen					<1 RK_PA3 2 &pcfg_pull_up_8ma>,
16667053e06bSLiang Chen					<1 RK_PA4 2 &pcfg_pull_up_8ma>,
16677053e06bSLiang Chen					<1 RK_PA5 2 &pcfg_pull_up_8ma>,
16687053e06bSLiang Chen					<1 RK_PA6 2 &pcfg_pull_up_8ma>,
16697053e06bSLiang Chen					<1 RK_PA7 2 &pcfg_pull_up_8ma>;
16707053e06bSLiang Chen			};
16717053e06bSLiang Chen		};
16727053e06bSLiang Chen
16737053e06bSLiang Chen		flash {
16747053e06bSLiang Chen			flash_cs0: flash-cs0 {
16757053e06bSLiang Chen				rockchip,pins =
16767053e06bSLiang Chen					<1 RK_PB0 1 &pcfg_pull_none>;
16777053e06bSLiang Chen			};
16787053e06bSLiang Chen
16797053e06bSLiang Chen			flash_rdy: flash-rdy {
16807053e06bSLiang Chen				rockchip,pins =
16817053e06bSLiang Chen					<1 RK_PB1 1 &pcfg_pull_none>;
16827053e06bSLiang Chen			};
16837053e06bSLiang Chen
16847053e06bSLiang Chen			flash_dqs: flash-dqs {
16857053e06bSLiang Chen				rockchip,pins =
16867053e06bSLiang Chen					<1 RK_PB2 1 &pcfg_pull_none>;
16877053e06bSLiang Chen			};
16887053e06bSLiang Chen
16897053e06bSLiang Chen			flash_ale: flash-ale {
16907053e06bSLiang Chen				rockchip,pins =
16917053e06bSLiang Chen					<1 RK_PB3 1 &pcfg_pull_none>;
16927053e06bSLiang Chen			};
16937053e06bSLiang Chen
16947053e06bSLiang Chen			flash_cle: flash-cle {
16957053e06bSLiang Chen				rockchip,pins =
16967053e06bSLiang Chen					<1 RK_PB4 1 &pcfg_pull_none>;
16977053e06bSLiang Chen			};
16987053e06bSLiang Chen
16997053e06bSLiang Chen			flash_wrn: flash-wrn {
17007053e06bSLiang Chen				rockchip,pins =
17017053e06bSLiang Chen					<1 RK_PB5 1 &pcfg_pull_none>;
17027053e06bSLiang Chen			};
17037053e06bSLiang Chen
17047053e06bSLiang Chen			flash_csl: flash-csl {
17057053e06bSLiang Chen				rockchip,pins =
17067053e06bSLiang Chen					<1 RK_PB6 1 &pcfg_pull_none>;
17077053e06bSLiang Chen			};
17087053e06bSLiang Chen
17097053e06bSLiang Chen			flash_rdn: flash-rdn {
17107053e06bSLiang Chen				rockchip,pins =
17117053e06bSLiang Chen					<1 RK_PB7 1 &pcfg_pull_none>;
17127053e06bSLiang Chen			};
17137053e06bSLiang Chen
17147053e06bSLiang Chen			flash_bus8: flash-bus8 {
17157053e06bSLiang Chen				rockchip,pins =
17167053e06bSLiang Chen					<1 RK_PA0 1 &pcfg_pull_up_12ma>,
17177053e06bSLiang Chen					<1 RK_PA1 1 &pcfg_pull_up_12ma>,
17187053e06bSLiang Chen					<1 RK_PA2 1 &pcfg_pull_up_12ma>,
17197053e06bSLiang Chen					<1 RK_PA3 1 &pcfg_pull_up_12ma>,
17207053e06bSLiang Chen					<1 RK_PA4 1 &pcfg_pull_up_12ma>,
17217053e06bSLiang Chen					<1 RK_PA5 1 &pcfg_pull_up_12ma>,
17227053e06bSLiang Chen					<1 RK_PA6 1 &pcfg_pull_up_12ma>,
17237053e06bSLiang Chen					<1 RK_PA7 1 &pcfg_pull_up_12ma>;
17247053e06bSLiang Chen			};
17257053e06bSLiang Chen		};
17267053e06bSLiang Chen
17277053e06bSLiang Chen		lcdc {
17287053e06bSLiang Chen			lcdc_rgb_dclk_pin: lcdc-rgb-dclk-pin {
17297053e06bSLiang Chen				rockchip,pins =
17307053e06bSLiang Chen					<3 RK_PA0 1 &pcfg_pull_none_12ma>;
17317053e06bSLiang Chen			};
17327053e06bSLiang Chen
17337053e06bSLiang Chen			lcdc_rgb_m0_hsync_pin: lcdc-rgb-m0-hsync-pin {
17347053e06bSLiang Chen				rockchip,pins =
17357053e06bSLiang Chen					<3 RK_PA1 1 &pcfg_pull_none_12ma>;
17367053e06bSLiang Chen			};
17377053e06bSLiang Chen
17387053e06bSLiang Chen			lcdc_rgb_m0_vsync_pin: lcdc-rgb-m0-vsync-pin {
17397053e06bSLiang Chen				rockchip,pins =
17407053e06bSLiang Chen					<3 RK_PA2 1 &pcfg_pull_none_12ma>;
17417053e06bSLiang Chen			};
17427053e06bSLiang Chen
17437053e06bSLiang Chen			lcdc_rgb_m0_den_pin: lcdc-rgb-m0-den-pin {
17447053e06bSLiang Chen				rockchip,pins =
17457053e06bSLiang Chen					<3 RK_PA3 1 &pcfg_pull_none_12ma>;
17467053e06bSLiang Chen			};
17477053e06bSLiang Chen
17487053e06bSLiang Chen			lcdc_rgb888_m0_data_pins: lcdc-rgb888-m0-data-pins {
17497053e06bSLiang Chen				rockchip,pins =
17507053e06bSLiang Chen					<3 RK_PA7 1 &pcfg_pull_none_8ma>, /* lcdc_d3 */
17517053e06bSLiang Chen					<3 RK_PA6 1 &pcfg_pull_none_8ma>, /* lcdc_d2 */
17527053e06bSLiang Chen					<3 RK_PA5 1 &pcfg_pull_none_8ma>, /* lcdc_d1 */
17537053e06bSLiang Chen					<3 RK_PA4 1 &pcfg_pull_none_8ma>, /* lcdc_d0 */
17547053e06bSLiang Chen					<3 RK_PB3 1 &pcfg_pull_none_8ma>, /* lcdc_d7 */
17557053e06bSLiang Chen					<3 RK_PB2 1 &pcfg_pull_none_8ma>, /* lcdc_d6 */
17567053e06bSLiang Chen					<3 RK_PB1 1 &pcfg_pull_none_8ma>, /* lcdc_d5 */
17577053e06bSLiang Chen					<3 RK_PB0 1 &pcfg_pull_none_8ma>, /* lcdc_d4 */
17587053e06bSLiang Chen					<3 RK_PB7 1 &pcfg_pull_none_8ma>, /* lcdc_d11 */
17597053e06bSLiang Chen					<3 RK_PB6 1 &pcfg_pull_none_8ma>, /* lcdc_d10 */
17607053e06bSLiang Chen					<3 RK_PB5 1 &pcfg_pull_none_8ma>, /* lcdc_d9 */
17617053e06bSLiang Chen					<3 RK_PB4 1 &pcfg_pull_none_8ma>, /* lcdc_d8 */
17627053e06bSLiang Chen					<3 RK_PC3 1 &pcfg_pull_none_8ma>, /* lcdc_d15 */
17637053e06bSLiang Chen					<3 RK_PC2 1 &pcfg_pull_none_8ma>, /* lcdc_d14 */
17647053e06bSLiang Chen					<3 RK_PC1 1 &pcfg_pull_none_8ma>, /* lcdc_d13 */
17657053e06bSLiang Chen					<3 RK_PC0 1 &pcfg_pull_none_8ma>, /* lcdc_d12 */
17667053e06bSLiang Chen					<3 RK_PC7 1 &pcfg_pull_none_8ma>, /* lcdc_d19 */
17677053e06bSLiang Chen					<3 RK_PC6 1 &pcfg_pull_none_8ma>, /* lcdc_d18 */
17687053e06bSLiang Chen					<3 RK_PC5 1 &pcfg_pull_none_8ma>, /* lcdc_d17 */
17697053e06bSLiang Chen					<3 RK_PC4 1 &pcfg_pull_none_8ma>, /* lcdc_d16 */
17707053e06bSLiang Chen					<3 RK_PD3 1 &pcfg_pull_none_8ma>, /* lcdc_d23 */
17717053e06bSLiang Chen					<3 RK_PD2 1 &pcfg_pull_none_8ma>, /* lcdc_d22 */
17727053e06bSLiang Chen					<3 RK_PD1 1 &pcfg_pull_none_8ma>, /* lcdc_d21 */
17737053e06bSLiang Chen					<3 RK_PD0 1 &pcfg_pull_none_8ma>; /* lcdc_d20 */
17747053e06bSLiang Chen			};
17757053e06bSLiang Chen
17767053e06bSLiang Chen			lcdc_rgb666_m0_data_pins: lcdc-rgb666-m0-data-pins {
17777053e06bSLiang Chen				rockchip,pins =
17787053e06bSLiang Chen					<3 RK_PA7 1 &pcfg_pull_none_8ma>, /* lcdc_d3 */
17797053e06bSLiang Chen					<3 RK_PA6 1 &pcfg_pull_none_8ma>, /* lcdc_d2 */
17807053e06bSLiang Chen					<3 RK_PA5 1 &pcfg_pull_none_8ma>, /* lcdc_d1 */
17817053e06bSLiang Chen					<3 RK_PA4 1 &pcfg_pull_none_8ma>, /* lcdc_d0 */
17827053e06bSLiang Chen					<3 RK_PB3 1 &pcfg_pull_none_8ma>, /* lcdc_d7 */
17837053e06bSLiang Chen					<3 RK_PB2 1 &pcfg_pull_none_8ma>, /* lcdc_d6 */
17847053e06bSLiang Chen					<3 RK_PB1 1 &pcfg_pull_none_8ma>, /* lcdc_d5 */
17857053e06bSLiang Chen					<3 RK_PB0 1 &pcfg_pull_none_8ma>, /* lcdc_d4 */
17867053e06bSLiang Chen					<3 RK_PB7 1 &pcfg_pull_none_8ma>, /* lcdc_d11 */
17877053e06bSLiang Chen					<3 RK_PB6 1 &pcfg_pull_none_8ma>, /* lcdc_d10 */
17887053e06bSLiang Chen					<3 RK_PB5 1 &pcfg_pull_none_8ma>, /* lcdc_d9 */
17897053e06bSLiang Chen					<3 RK_PB4 1 &pcfg_pull_none_8ma>, /* lcdc_d8 */
17907053e06bSLiang Chen					<3 RK_PC3 1 &pcfg_pull_none_8ma>, /* lcdc_d15 */
17917053e06bSLiang Chen					<3 RK_PC2 1 &pcfg_pull_none_8ma>, /* lcdc_d14 */
17927053e06bSLiang Chen					<3 RK_PC1 1 &pcfg_pull_none_8ma>, /* lcdc_d13 */
17937053e06bSLiang Chen					<3 RK_PC0 1 &pcfg_pull_none_8ma>, /* lcdc_d12 */
17947053e06bSLiang Chen					<3 RK_PC5 1 &pcfg_pull_none_8ma>, /* lcdc_d17 */
17957053e06bSLiang Chen					<3 RK_PC4 1 &pcfg_pull_none_8ma>; /* lcdc_d16 */
17967053e06bSLiang Chen			};
17977053e06bSLiang Chen
17987053e06bSLiang Chen			lcdc_rgb565_m0_data_pins: lcdc-rgb565-m0-data-pins {
17997053e06bSLiang Chen				rockchip,pins =
18007053e06bSLiang Chen					<3 RK_PA7 1 &pcfg_pull_none_8ma>, /* lcdc_d3 */
18017053e06bSLiang Chen					<3 RK_PA6 1 &pcfg_pull_none_8ma>, /* lcdc_d2 */
18027053e06bSLiang Chen					<3 RK_PA5 1 &pcfg_pull_none_8ma>, /* lcdc_d1 */
18037053e06bSLiang Chen					<3 RK_PA4 1 &pcfg_pull_none_8ma>, /* lcdc_d0 */
18047053e06bSLiang Chen					<3 RK_PB3 1 &pcfg_pull_none_8ma>, /* lcdc_d7 */
18057053e06bSLiang Chen					<3 RK_PB2 1 &pcfg_pull_none_8ma>, /* lcdc_d6 */
18067053e06bSLiang Chen					<3 RK_PB1 1 &pcfg_pull_none_8ma>, /* lcdc_d5 */
18077053e06bSLiang Chen					<3 RK_PB0 1 &pcfg_pull_none_8ma>, /* lcdc_d4 */
18087053e06bSLiang Chen					<3 RK_PB7 1 &pcfg_pull_none_8ma>, /* lcdc_d11 */
18097053e06bSLiang Chen					<3 RK_PB6 1 &pcfg_pull_none_8ma>, /* lcdc_d10 */
18107053e06bSLiang Chen					<3 RK_PB5 1 &pcfg_pull_none_8ma>, /* lcdc_d9 */
18117053e06bSLiang Chen					<3 RK_PB4 1 &pcfg_pull_none_8ma>, /* lcdc_d8 */
18127053e06bSLiang Chen					<3 RK_PC3 1 &pcfg_pull_none_8ma>, /* lcdc_d15 */
18137053e06bSLiang Chen					<3 RK_PC2 1 &pcfg_pull_none_8ma>, /* lcdc_d14 */
18147053e06bSLiang Chen					<3 RK_PC1 1 &pcfg_pull_none_8ma>, /* lcdc_d13 */
18157053e06bSLiang Chen					<3 RK_PC0 1 &pcfg_pull_none_8ma>; /* lcdc_d12 */
18167053e06bSLiang Chen			};
18177053e06bSLiang Chen
18187053e06bSLiang Chen			lcdc_rgb888_m1_data_pins: lcdc-rgb888-m1-data-pins {
18197053e06bSLiang Chen				rockchip,pins =
18207053e06bSLiang Chen					<3 RK_PA6 1 &pcfg_pull_none_8ma>, /* lcdc_d2 */
18217053e06bSLiang Chen					<3 RK_PA4 1 &pcfg_pull_none_8ma>, /* lcdc_d0 */
18227053e06bSLiang Chen					<3 RK_PB3 1 &pcfg_pull_none_8ma>, /* lcdc_d7 */
18237053e06bSLiang Chen					<3 RK_PB2 1 &pcfg_pull_none_8ma>, /* lcdc_d6 */
18247053e06bSLiang Chen					<3 RK_PB5 1 &pcfg_pull_none_8ma>, /* lcdc_d9 */
18257053e06bSLiang Chen					<3 RK_PC3 1 &pcfg_pull_none_8ma>, /* lcdc_d15 */
18267053e06bSLiang Chen					<3 RK_PC2 1 &pcfg_pull_none_8ma>, /* lcdc_d14 */
18277053e06bSLiang Chen					<3 RK_PC1 1 &pcfg_pull_none_8ma>, /* lcdc_d13 */
18287053e06bSLiang Chen					<3 RK_PC0 1 &pcfg_pull_none_8ma>, /* lcdc_d12 */
18297053e06bSLiang Chen					<3 RK_PC7 1 &pcfg_pull_none_8ma>, /* lcdc_d19 */
18307053e06bSLiang Chen					<3 RK_PC6 1 &pcfg_pull_none_8ma>, /* lcdc_d18 */
18317053e06bSLiang Chen					<3 RK_PC5 1 &pcfg_pull_none_8ma>, /* lcdc_d17 */
18327053e06bSLiang Chen					<3 RK_PC4 1 &pcfg_pull_none_8ma>, /* lcdc_d16 */
18337053e06bSLiang Chen					<3 RK_PD3 1 &pcfg_pull_none_8ma>, /* lcdc_d23 */
18347053e06bSLiang Chen					<3 RK_PD2 1 &pcfg_pull_none_8ma>, /* lcdc_d22 */
18357053e06bSLiang Chen					<3 RK_PD1 1 &pcfg_pull_none_8ma>, /* lcdc_d21 */
18367053e06bSLiang Chen					<3 RK_PD0 1 &pcfg_pull_none_8ma>; /* lcdc_d20 */
18377053e06bSLiang Chen			};
18387053e06bSLiang Chen
18397053e06bSLiang Chen			lcdc_rgb666_m1_data_pins: lcdc-rgb666-m1-data-pins {
18407053e06bSLiang Chen				rockchip,pins =
18417053e06bSLiang Chen					<3 RK_PA6 1 &pcfg_pull_none_8ma>, /* lcdc_d2 */
18427053e06bSLiang Chen					<3 RK_PA4 1 &pcfg_pull_none_8ma>, /* lcdc_d0 */
18437053e06bSLiang Chen					<3 RK_PB3 1 &pcfg_pull_none_8ma>, /* lcdc_d7 */
18447053e06bSLiang Chen					<3 RK_PB2 1 &pcfg_pull_none_8ma>, /* lcdc_d6 */
18457053e06bSLiang Chen					<3 RK_PB5 1 &pcfg_pull_none_8ma>, /* lcdc_d9 */
18467053e06bSLiang Chen					<3 RK_PC3 1 &pcfg_pull_none_8ma>, /* lcdc_d15 */
18477053e06bSLiang Chen					<3 RK_PC2 1 &pcfg_pull_none_8ma>, /* lcdc_d14 */
18487053e06bSLiang Chen					<3 RK_PC1 1 &pcfg_pull_none_8ma>, /* lcdc_d13 */
18497053e06bSLiang Chen					<3 RK_PC0 1 &pcfg_pull_none_8ma>, /* lcdc_d12 */
18507053e06bSLiang Chen					<3 RK_PC5 1 &pcfg_pull_none_8ma>, /* lcdc_d17 */
18517053e06bSLiang Chen					<3 RK_PC4 1 &pcfg_pull_none_8ma>; /* lcdc_d16 */
18527053e06bSLiang Chen			};
18537053e06bSLiang Chen
18547053e06bSLiang Chen			lcdc_rgb565_m1_data_pins: lcdc-rgb565-m1-data-pins {
18557053e06bSLiang Chen				rockchip,pins =
18567053e06bSLiang Chen					<3 RK_PA6 1 &pcfg_pull_none_8ma>, /* lcdc_d2 */
18577053e06bSLiang Chen					<3 RK_PA4 1 &pcfg_pull_none_8ma>, /* lcdc_d0 */
18587053e06bSLiang Chen					<3 RK_PB3 1 &pcfg_pull_none_8ma>, /* lcdc_d7 */
18597053e06bSLiang Chen					<3 RK_PB2 1 &pcfg_pull_none_8ma>, /* lcdc_d6 */
18607053e06bSLiang Chen					<3 RK_PB5 1 &pcfg_pull_none_8ma>, /* lcdc_d9 */
18617053e06bSLiang Chen					<3 RK_PC3 1 &pcfg_pull_none_8ma>, /* lcdc_d15 */
18627053e06bSLiang Chen					<3 RK_PC2 1 &pcfg_pull_none_8ma>, /* lcdc_d14 */
18637053e06bSLiang Chen					<3 RK_PC1 1 &pcfg_pull_none_8ma>, /* lcdc_d13 */
18647053e06bSLiang Chen					<3 RK_PC0 1 &pcfg_pull_none_8ma>; /* lcdc_d12 */
18657053e06bSLiang Chen			};
18667053e06bSLiang Chen		};
18677053e06bSLiang Chen
18687053e06bSLiang Chen		pwm0 {
18697053e06bSLiang Chen			pwm0_pin: pwm0-pin {
18707053e06bSLiang Chen				rockchip,pins =
18717053e06bSLiang Chen					<0 RK_PB7 1 &pcfg_pull_none>;
18727053e06bSLiang Chen			};
18737053e06bSLiang Chen		};
18747053e06bSLiang Chen
18757053e06bSLiang Chen		pwm1 {
18767053e06bSLiang Chen			pwm1_pin: pwm1-pin {
18777053e06bSLiang Chen				rockchip,pins =
18787053e06bSLiang Chen					<0 RK_PC0 1 &pcfg_pull_none>;
18797053e06bSLiang Chen			};
18807053e06bSLiang Chen		};
18817053e06bSLiang Chen
18827053e06bSLiang Chen		pwm2 {
18837053e06bSLiang Chen			pwm2_pin: pwm2-pin {
18847053e06bSLiang Chen				rockchip,pins =
18857053e06bSLiang Chen					<2 RK_PB5 1 &pcfg_pull_none>;
18867053e06bSLiang Chen			};
18877053e06bSLiang Chen		};
18887053e06bSLiang Chen
18897053e06bSLiang Chen		pwm3 {
18907053e06bSLiang Chen			pwm3_pin: pwm3-pin {
18917053e06bSLiang Chen				rockchip,pins =
18927053e06bSLiang Chen					<0 RK_PC1 1 &pcfg_pull_none>;
18937053e06bSLiang Chen			};
18947053e06bSLiang Chen		};
18957053e06bSLiang Chen
18967053e06bSLiang Chen		pwm4 {
18977053e06bSLiang Chen			pwm4_pin: pwm4-pin {
18987053e06bSLiang Chen				rockchip,pins =
18997053e06bSLiang Chen					<3 RK_PC2 3 &pcfg_pull_none>;
19007053e06bSLiang Chen			};
19017053e06bSLiang Chen		};
19027053e06bSLiang Chen
19037053e06bSLiang Chen		pwm5 {
19047053e06bSLiang Chen			pwm5_pin: pwm5-pin {
19057053e06bSLiang Chen				rockchip,pins =
19067053e06bSLiang Chen					<3 RK_PC3 3 &pcfg_pull_none>;
19077053e06bSLiang Chen			};
19087053e06bSLiang Chen		};
19097053e06bSLiang Chen
19107053e06bSLiang Chen		pwm6 {
19117053e06bSLiang Chen			pwm6_pin: pwm6-pin {
19127053e06bSLiang Chen				rockchip,pins =
19137053e06bSLiang Chen					<3 RK_PC4 3 &pcfg_pull_none>;
19147053e06bSLiang Chen			};
19157053e06bSLiang Chen		};
19167053e06bSLiang Chen
19177053e06bSLiang Chen		pwm7 {
19187053e06bSLiang Chen			pwm7_pin: pwm7-pin {
19197053e06bSLiang Chen				rockchip,pins =
19207053e06bSLiang Chen					<3 RK_PC5 3 &pcfg_pull_none>;
19217053e06bSLiang Chen			};
19227053e06bSLiang Chen		};
19237053e06bSLiang Chen
19247053e06bSLiang Chen		gmac {
19257053e06bSLiang Chen			rmii_pins: rmii-pins {
19267053e06bSLiang Chen				rockchip,pins =
19277053e06bSLiang Chen					<2 RK_PA0 2 &pcfg_pull_none_12ma>, /* mac_txen */
19287053e06bSLiang Chen					<2 RK_PA1 2 &pcfg_pull_none_12ma>, /* mac_txd1 */
19297053e06bSLiang Chen					<2 RK_PA2 2 &pcfg_pull_none_12ma>, /* mac_txd0 */
19307053e06bSLiang Chen					<2 RK_PA3 2 &pcfg_pull_none>, /* mac_rxd0 */
19317053e06bSLiang Chen					<2 RK_PA4 2 &pcfg_pull_none>, /* mac_rxd1 */
19327053e06bSLiang Chen					<2 RK_PA5 2 &pcfg_pull_none>, /* mac_rxer */
19337053e06bSLiang Chen					<2 RK_PA6 2 &pcfg_pull_none>, /* mac_rxdv */
19347053e06bSLiang Chen					<2 RK_PA7 2 &pcfg_pull_none>, /* mac_mdio */
19357053e06bSLiang Chen					<2 RK_PB1 2 &pcfg_pull_none>; /* mac_mdc */
19367053e06bSLiang Chen			};
19377053e06bSLiang Chen
19387053e06bSLiang Chen			mac_refclk_12ma: mac-refclk-12ma {
19397053e06bSLiang Chen				rockchip,pins =
19407053e06bSLiang Chen					<2 RK_PB2 2 &pcfg_pull_none_12ma>;
19417053e06bSLiang Chen			};
19427053e06bSLiang Chen
19437053e06bSLiang Chen			mac_refclk: mac-refclk {
19447053e06bSLiang Chen				rockchip,pins =
19457053e06bSLiang Chen					<2 RK_PB2 2 &pcfg_pull_none>;
19467053e06bSLiang Chen			};
19477053e06bSLiang Chen		};
19487053e06bSLiang Chen
19497053e06bSLiang Chen		cif-m0 {
19507053e06bSLiang Chen			cif_clkout_m0: cif-clkout-m0 {
19517053e06bSLiang Chen				rockchip,pins =
19527053e06bSLiang Chen					<2 RK_PB3 1 &pcfg_pull_none>;
19537053e06bSLiang Chen			};
19547053e06bSLiang Chen
19557053e06bSLiang Chen			dvp_d2d9_m0: dvp-d2d9-m0 {
19567053e06bSLiang Chen				rockchip,pins =
19577053e06bSLiang Chen					<2 RK_PA0 1 &pcfg_pull_none>, /* cif_data2 */
19587053e06bSLiang Chen					<2 RK_PA1 1 &pcfg_pull_none>, /* cif_data3 */
19597053e06bSLiang Chen					<2 RK_PA2 1 &pcfg_pull_none>, /* cif_data4 */
19607053e06bSLiang Chen					<2 RK_PA3 1 &pcfg_pull_none>, /* cif_data5 */
19617053e06bSLiang Chen					<2 RK_PA4 1 &pcfg_pull_none>, /* cif_data6 */
19627053e06bSLiang Chen					<2 RK_PA5 1 &pcfg_pull_none>, /* cif_data7 */
19637053e06bSLiang Chen					<2 RK_PA6 1 &pcfg_pull_none>, /* cif_data8 */
19647053e06bSLiang Chen					<2 RK_PA7 1 &pcfg_pull_none>, /* cif_data9 */
19657053e06bSLiang Chen					<2 RK_PB0 1 &pcfg_pull_none>, /* cif_sync */
19667053e06bSLiang Chen					<2 RK_PB1 1 &pcfg_pull_none>, /* cif_href */
19677053e06bSLiang Chen					<2 RK_PB2 1 &pcfg_pull_none>, /* cif_clkin */
19687053e06bSLiang Chen					<2 RK_PB3 1 &pcfg_pull_none>; /* cif_clkout */
19697053e06bSLiang Chen			};
19707053e06bSLiang Chen
19717053e06bSLiang Chen			dvp_d0d1_m0: dvp-d0d1-m0 {
19727053e06bSLiang Chen				rockchip,pins =
19737053e06bSLiang Chen					<2 RK_PB4 1 &pcfg_pull_none>, /* cif_data0 */
19747053e06bSLiang Chen					<2 RK_PB6 1 &pcfg_pull_none>; /* cif_data1 */
19757053e06bSLiang Chen			};
19767053e06bSLiang Chen
19777053e06bSLiang Chen			dvp_d10d11_m0:d10-d11-m0 {
19787053e06bSLiang Chen				rockchip,pins =
19797053e06bSLiang Chen					<2 RK_PB7 1 &pcfg_pull_none>, /* cif_data10 */
19807053e06bSLiang Chen					<2 RK_PC0 1 &pcfg_pull_none>; /* cif_data11 */
19817053e06bSLiang Chen			};
19827053e06bSLiang Chen		};
19837053e06bSLiang Chen
19847053e06bSLiang Chen		cif-m1 {
19857053e06bSLiang Chen			cif_clkout_m1: cif-clkout-m1 {
19867053e06bSLiang Chen				rockchip,pins =
19877053e06bSLiang Chen					<3 RK_PD0 3 &pcfg_pull_none>;
19887053e06bSLiang Chen			};
19897053e06bSLiang Chen
19907053e06bSLiang Chen			dvp_d2d9_m1: dvp-d2d9-m1 {
19917053e06bSLiang Chen				rockchip,pins =
19927053e06bSLiang Chen					<3 RK_PA3 3 &pcfg_pull_none>, /* cif_data2 */
19937053e06bSLiang Chen					<3 RK_PA5 3 &pcfg_pull_none>, /* cif_data3 */
19947053e06bSLiang Chen					<3 RK_PA7 3 &pcfg_pull_none>, /* cif_data4 */
19957053e06bSLiang Chen					<3 RK_PB0 3 &pcfg_pull_none>, /* cif_data5 */
19967053e06bSLiang Chen					<3 RK_PB1 3 &pcfg_pull_none>, /* cif_data6 */
19977053e06bSLiang Chen					<3 RK_PB4 3 &pcfg_pull_none>, /* cif_data7 */
19987053e06bSLiang Chen					<3 RK_PB6 3 &pcfg_pull_none>, /* cif_data8 */
19997053e06bSLiang Chen					<3 RK_PB7 3 &pcfg_pull_none>, /* cif_data9 */
20007053e06bSLiang Chen					<3 RK_PD1 3 &pcfg_pull_none>, /* cif_sync */
20017053e06bSLiang Chen					<3 RK_PD2 3 &pcfg_pull_none>, /* cif_href */
20027053e06bSLiang Chen					<3 RK_PD3 3 &pcfg_pull_none>, /* cif_clkin */
20037053e06bSLiang Chen					<3 RK_PD0 3 &pcfg_pull_none>; /* cif_clkout */
20047053e06bSLiang Chen			};
20057053e06bSLiang Chen
20067053e06bSLiang Chen			dvp_d0d1_m1: dvp-d0d1-m1 {
20077053e06bSLiang Chen				rockchip,pins =
20087053e06bSLiang Chen					<3 RK_PA1 3 &pcfg_pull_none>, /* cif_data0 */
20097053e06bSLiang Chen					<3 RK_PA2 3 &pcfg_pull_none>; /* cif_data1 */
20107053e06bSLiang Chen			};
20117053e06bSLiang Chen
20127053e06bSLiang Chen			dvp_d10d11_m1:d10-d11-m1 {
20137053e06bSLiang Chen				rockchip,pins =
20147053e06bSLiang Chen					<3 RK_PC6 3 &pcfg_pull_none>, /* cif_data10 */
20157053e06bSLiang Chen					<3 RK_PC7 3 &pcfg_pull_none>; /* cif_data11 */
20167053e06bSLiang Chen			};
20177053e06bSLiang Chen		};
20187053e06bSLiang Chen
20197053e06bSLiang Chen		isp {
20207053e06bSLiang Chen			isp_prelight: isp-prelight {
20217053e06bSLiang Chen				rockchip,pins =
20227053e06bSLiang Chen					<3 RK_PD1 4 &pcfg_pull_none>;
20237053e06bSLiang Chen			};
20247053e06bSLiang Chen		};
20257053e06bSLiang Chen	};
20267053e06bSLiang Chen};
2027