diff --git a/device/device-pine-a64lts/APKBUILD b/device/device-pine-a64lts/APKBUILD
index 1b87a08ab0cad241215891a89b3335997497e97b..ea4a13cc66fc732247b8f8ca3f87d17d2be6ab5c 100644
--- a/device/device-pine-a64lts/APKBUILD
+++ b/device/device-pine-a64lts/APKBUILD
@@ -26,5 +26,5 @@ package() {
 
 }
 
-sha512sums="f462e07c7f3795f80b7f97ae0c6745d0807680dc021a866fd0450a0f17535efdaec2a19a5907a44d440b1bb870515db233824096a757c3b4a7b93ec354736a54  deviceinfo
-995c26ac0422f3c9067f23e0cdd5bee004de18836a316337ffc359c379c51caae841deea3e185ea0e1fb61eab30639fe5155d2d3beea4ee9550aa0a8788da27f  uboot-script.cmd"
+sha512sums="8891ab307e9e2272ae250c1d3b20900c44c433513ac2dd3abeb01de042e26844fea264f15024312c3447931643e828f9f2c8e06905e91a31e1bb38143f8135c0  deviceinfo
+e9ce432acbb455929be2f61cda7605110b16f0a9ed7bce07624a11974bf9b8a498528c23aa6536ec2ad6a60330faf9b8627a81428b98491a7477d30d6e444163  uboot-script.cmd"
diff --git a/device/device-pine-a64lts/deviceinfo b/device/device-pine-a64lts/deviceinfo
index 43cc41793c389f33916a8149a9d10051e63bb311..475df36036e980be08ec2814541de3ad21de22f1 100644
--- a/device/device-pine-a64lts/deviceinfo
+++ b/device/device-pine-a64lts/deviceinfo
@@ -8,6 +8,7 @@ deviceinfo_date=""
 deviceinfo_dtb="sun50iw1p1-pine64so"
 deviceinfo_modules_initfs=""
 deviceinfo_arch="aarch64"
+deviceinfo_disable_dhcpd="true"
 
 # Device related
 deviceinfo_keyboard="true"
diff --git a/device/device-pine-a64lts/uboot-script.cmd b/device/device-pine-a64lts/uboot-script.cmd
index a981fa1ff9b9853c4e7b756563d30d9d6a1815b8..09c8a59d2a945818246995edd32af3f1d350fa7d 100644
--- a/device/device-pine-a64lts/uboot-script.cmd
+++ b/device/device-pine-a64lts/uboot-script.cmd
@@ -1,9 +1,9 @@
-setenv bootargs init=/init.sh rw console=tty0 console=ttyS0,115200 no_console_suspend earlycon=uart,mmio32,0x01c28000 panic=10 consoleblank=0 loglevel=1
+setenv bootargs init=/init.sh rw console=tty0 console=ttyS0,115200 no_console_suspend earlycon=uart,mmio32,0x01c28000 panic=10 consoleblank=0 loglevel=1 PMOS_NO_OUTPUT_REDIRECT
 
 printenv
 
 echo Loading DTB
-load mmc ${mmc_bootdev}:1 ${fdt_addr_r} dtb-pine-a64lts.dtb
+load mmc ${mmc_bootdev}:1 ${fdt_addr_r} sun50iw1p1-pine64so.dtb
 
 echo Loading Initramfs
 load mmc ${mmc_bootdev}:1 ${ramdisk_addr_r} uInitrd-pine-a64lts
diff --git a/device/linux-pine-a64lts/0001-add-pine64-DT-files.patch b/device/linux-pine-a64lts/0001-add-pine64-DT-files.patch
new file mode 100644
index 0000000000000000000000000000000000000000..8e7292283cfc15739e75306a8c8cd724b4b57d8b
--- /dev/null
+++ b/device/linux-pine-a64lts/0001-add-pine64-DT-files.patch
@@ -0,0 +1,13777 @@
+diff --git a/arch/arm64/boot/dts/Makefile b/arch/arm64/boot/dts/Makefile
+index ba2bd2cc..1ecfec5a 100755
+--- a/arch/arm64/boot/dts/Makefile
++++ b/arch/arm64/boot/dts/Makefile
+@@ -2,7 +2,12 @@ dtb-$(CONFIG_ARCH_VEXPRESS) += rtsm_ve-aemv8a.dtb foundation-v8.dtb \
+ 				fvp-base-gicv2-psci.dtb
+ dtb-$(CONFIG_ARCH_VEXPRESS) += juno.dtb
+ dtb-$(CONFIG_ARCH_XGENE) += apm-mustang.dtb
+-dtb-$(CONFIG_ARCH_SUN50I) += sun50iw1p1-fpga.dtb sun50iw1p1-soc.dtb
++dtb-$(CONFIG_ARCH_SUN50I) += sun50iw1p1-fpga.dtb \
++				sun50iw1p1-soc.dtb \
++				sun50iw1p1-pine64.dtb \
++				sun50iw1p1-pine64-plus.dtb \
++				sun50iw1p1-pine64-pinebook.dtb \
++				sun50iw1p1-pine64so.dtb
+ 
+ targets += dtbs
+ 
+diff --git a/arch/arm64/boot/dts/sun50iw1p1-pine64-pinebook.dts b/arch/arm64/boot/dts/sun50iw1p1-pine64-pinebook.dts
+new file mode 100644
+index 00000000..bfd2bc8a
+--- /dev/null
++++ b/arch/arm64/boot/dts/sun50iw1p1-pine64-pinebook.dts
+@@ -0,0 +1,3441 @@
++/dts-v1/;
++
++/memreserve/	0x0000000045000000 0x0000000000200000;
++/memreserve/	0x0000000041010000 0x0000000000010000;
++/memreserve/	0x0000000041020000 0x0000000000000800;
++/memreserve/	0x0000000040100000 0x0000000000004000;
++/memreserve/	0x0000000040104000 0x0000000000001000;
++/memreserve/	0x0000000040105000 0x0000000000001000;
++/ {
++	model = "Pinebook";
++	compatible = "pine64,pine64-plus,pinebook64";
++	interrupt-parent = <0x1>;
++	#address-cells = <0x2>;
++	#size-cells = <0x2>;
++
++	clocks {
++		compatible = "allwinner,sunxi-clk-init";
++		device_type = "clocks";
++		#address-cells = <0x2>;
++		#size-cells = <0x2>;
++		ranges;
++		reg = <0x0 0x1c20000 0x0 0x320 0x0 0x1f01400 0x0 0xb0 0x0 0x1f00060 0x0 0x4>;
++
++		losc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-clock";
++			clock-frequency = <0x8000>;
++			clock-output-names = "losc";
++			linux,phandle = <0xc>;
++			phandle = <0xc>;
++		};
++
++		iosc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-clock";
++			clock-frequency = <0xf42400>;
++			clock-output-names = "iosc";
++			linux,phandle = <0xd>;
++			phandle = <0xd>;
++		};
++
++		hosc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-clock";
++			clock-frequency = <0x16e3600>;
++			clock-output-names = "hosc";
++			linux,phandle = <0x6>;
++			phandle = <0x6>;
++		};
++
++		pll_cpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_cpu";
++		};
++
++		pll_audio {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x1770000>;
++			clock-output-names = "pll_audio";
++			linux,phandle = <0x2>;
++			phandle = <0x2>;
++		};
++
++		pll_video0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "pll_video0";
++			linux,phandle = <0x3>;
++			phandle = <0x3>;
++		};
++
++		pll_ve {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_ve";
++			linux,phandle = <0x16>;
++			phandle = <0x16>;
++		};
++
++		pll_ddr0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_ddr0";
++			linux,phandle = <0x93>;
++			phandle = <0x93>;
++		};
++
++		pll_periph0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_periph0";
++			linux,phandle = <0x4>;
++			phandle = <0x4>;
++		};
++
++		pll_periph1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_periph1";
++			linux,phandle = <0x5>;
++			phandle = <0x5>;
++		};
++
++		pll_video1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "pll_video1";
++		};
++
++		pll_gpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_gpu";
++			linux,phandle = <0x96>;
++			phandle = <0x96>;
++		};
++
++		pll_mipi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_mipi";
++			linux,phandle = <0x8>;
++			phandle = <0x8>;
++		};
++
++		pll_hsic {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_hsic";
++			linux,phandle = <0x3a>;
++			phandle = <0x3a>;
++		};
++
++		pll_de {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "pll_de";
++			linux,phandle = <0x7>;
++			phandle = <0x7>;
++		};
++
++		pll_ddr1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_ddr1";
++			linux,phandle = <0x94>;
++			phandle = <0x94>;
++		};
++
++		pll_audiox8 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x2>;
++			clock-mult = <0x8>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_audiox8";
++		};
++
++		pll_audiox4 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x2>;
++			clock-mult = <0x8>;
++			clock-div = <0x2>;
++			clock-output-names = "pll_audiox4";
++			linux,phandle = <0x3c>;
++			phandle = <0x3c>;
++		};
++
++		pll_audiox2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x2>;
++			clock-mult = <0x8>;
++			clock-div = <0x4>;
++			clock-output-names = "pll_audiox2";
++		};
++
++		pll_video0x2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x3>;
++			clock-mult = <0x2>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_video0x2";
++		};
++
++		pll_periph0x2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x4>;
++			clock-mult = <0x2>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_periph0x2";
++			linux,phandle = <0x7b>;
++			phandle = <0x7b>;
++		};
++
++		pll_periph1x2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x5>;
++			clock-mult = <0x2>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_periph1x2";
++			linux,phandle = <0x5a>;
++			phandle = <0x5a>;
++		};
++
++		pll_periph0d2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x4>;
++			clock-mult = <0x1>;
++			clock-div = <0x2>;
++			clock-output-names = "pll_periph0d2";
++		};
++
++		hoscd2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x6>;
++			clock-mult = <0x1>;
++			clock-div = <0x2>;
++			clock-output-names = "hoscd2";
++		};
++
++		cpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "cpu";
++		};
++
++		cpuapb {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "cpuapb";
++		};
++
++		axi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "axi";
++		};
++
++		pll_periphahb0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "pll_periphahb0";
++		};
++
++		ahb1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ahb1";
++			linux,phandle = <0x95>;
++			phandle = <0x95>;
++		};
++
++		apb1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "apb1";
++		};
++
++		apb2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "apb2";
++			linux,phandle = <0x7e>;
++			phandle = <0x7e>;
++		};
++
++		ahb2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ahb2";
++		};
++
++		ths {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ths";
++			linux,phandle = <0x84>;
++			phandle = <0x84>;
++		};
++
++		nand {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "nand";
++			linux,phandle = <0x80>;
++			phandle = <0x80>;
++		};
++
++		sdmmc0_mod {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc0_mod";
++			linux,phandle = <0x60>;
++			phandle = <0x60>;
++		};
++
++		sdmmc0_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc0_bus";
++			linux,phandle = <0x61>;
++			phandle = <0x61>;
++		};
++
++		sdmmc0_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc0_rst";
++			linux,phandle = <0x62>;
++			phandle = <0x62>;
++		};
++
++		sdmmc1_mod {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc1_mod";
++			linux,phandle = <0x65>;
++			phandle = <0x65>;
++		};
++
++		sdmmc1_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc1_bus";
++			linux,phandle = <0x66>;
++			phandle = <0x66>;
++		};
++
++		sdmmc1_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc1_rst";
++			linux,phandle = <0x67>;
++			phandle = <0x67>;
++		};
++
++		sdmmc2_mod {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc2_mod";
++			linux,phandle = <0x5b>;
++			phandle = <0x5b>;
++		};
++
++		sdmmc2_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc2_bus";
++			linux,phandle = <0x5c>;
++			phandle = <0x5c>;
++		};
++
++		sdmmc2_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc2_rst";
++			linux,phandle = <0x5d>;
++			phandle = <0x5d>;
++		};
++
++		ts {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ts";
++		};
++
++		ce {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ce";
++			linux,phandle = <0x7a>;
++			phandle = <0x7a>;
++		};
++
++		spi0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "spi0";
++			linux,phandle = <0x52>;
++			phandle = <0x52>;
++		};
++
++		spi1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "spi1";
++			linux,phandle = <0x56>;
++			phandle = <0x56>;
++		};
++
++		i2s0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "i2s0";
++			linux,phandle = <0x42>;
++			phandle = <0x42>;
++		};
++
++		i2s1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "i2s1";
++			linux,phandle = <0x47>;
++			phandle = <0x47>;
++		};
++
++		i2s2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "i2s2";
++			linux,phandle = <0x48>;
++			phandle = <0x48>;
++		};
++
++		spdif {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "spdif";
++			linux,phandle = <0x49>;
++			phandle = <0x49>;
++		};
++
++		usbphy0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbphy0";
++			linux,phandle = <0x32>;
++			phandle = <0x32>;
++		};
++
++		usbphy1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbphy1";
++			linux,phandle = <0x36>;
++			phandle = <0x36>;
++		};
++
++		usbhsic {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbhsic";
++			linux,phandle = <0x38>;
++			phandle = <0x38>;
++		};
++
++		usbhsic12m {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbhsic12m";
++			linux,phandle = <0x39>;
++			phandle = <0x39>;
++		};
++
++		usbohci1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbohci1";
++			linux,phandle = <0x3b>;
++			phandle = <0x3b>;
++		};
++
++		usbohci0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbohci0";
++			linux,phandle = <0x35>;
++			phandle = <0x35>;
++		};
++
++		de {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x7>;
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "de";
++			linux,phandle = <0x6a>;
++			phandle = <0x6a>;
++		};
++
++		tcon0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x8>;
++			clock-output-names = "tcon0";
++			linux,phandle = <0x6b>;
++			phandle = <0x6b>;
++		};
++
++		tcon1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x3>;
++			clock-output-names = "tcon1";
++			linux,phandle = <0x6e>;
++			phandle = <0x6e>;
++		};
++
++		deinterlace {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "deinterlace";
++			linux,phandle = <0x7c>;
++			phandle = <0x7c>;
++		};
++
++		csi_s {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "csi_s";
++			linux,phandle = <0x73>;
++			phandle = <0x73>;
++		};
++
++		csi_m {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "csi_m";
++			linux,phandle = <0x74>;
++			phandle = <0x74>;
++		};
++
++		csi_misc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "csi_misc";
++			linux,phandle = <0x75>;
++			phandle = <0x75>;
++		};
++
++		ve {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ve";
++			linux,phandle = <0x17>;
++			phandle = <0x17>;
++		};
++
++		adda {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "adda";
++			linux,phandle = <0x41>;
++			phandle = <0x41>;
++		};
++
++		addax4 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "addax4";
++		};
++
++		avs {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "avs";
++		};
++
++		hdmi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x3>;
++			clock-output-names = "hdmi";
++			linux,phandle = <0x6f>;
++			phandle = <0x6f>;
++		};
++
++		hdmi_slow {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "hdmi_slow";
++			linux,phandle = <0x70>;
++			phandle = <0x70>;
++		};
++
++		mbus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "mbus";
++		};
++
++		mipidsi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "mipidsi";
++			linux,phandle = <0x6d>;
++			phandle = <0x6d>;
++		};
++
++		gpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "gpu";
++			linux,phandle = <0x97>;
++			phandle = <0x97>;
++		};
++
++		usbehci_16 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbohci_16";
++		};
++
++		usbehci1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbehci1";
++			linux,phandle = <0x37>;
++			phandle = <0x37>;
++		};
++
++		usbehci0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbehci0";
++			linux,phandle = <0x34>;
++			phandle = <0x34>;
++		};
++
++		usbotg {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbotg";
++			linux,phandle = <0x33>;
++			phandle = <0x33>;
++		};
++
++		gmac {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "gmac";
++			linux,phandle = <0x8f>;
++			phandle = <0x8f>;
++		};
++
++		sdram {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdram";
++		};
++
++		dma {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "dma";
++			linux,phandle = <0xb>;
++			phandle = <0xb>;
++		};
++
++		hwspinlock_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "hwspinlock_rst";
++			linux,phandle = <0xf>;
++			phandle = <0xf>;
++		};
++
++		hwspinlock_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "hwspinlock_bus";
++			linux,phandle = <0x10>;
++			phandle = <0x10>;
++		};
++
++		msgbox {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "msgbox";
++			linux,phandle = <0xe>;
++			phandle = <0xe>;
++		};
++
++		lvds {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "lvds";
++			linux,phandle = <0x6c>;
++			phandle = <0x6c>;
++		};
++
++		uart0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart0";
++			linux,phandle = <0x18>;
++			phandle = <0x18>;
++		};
++
++		uart1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart1";
++			linux,phandle = <0x1b>;
++			phandle = <0x1b>;
++		};
++
++		uart2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart2";
++			linux,phandle = <0x1e>;
++			phandle = <0x1e>;
++		};
++
++		uart3 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart3";
++			linux,phandle = <0x21>;
++			phandle = <0x21>;
++		};
++
++		uart4 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart4";
++			linux,phandle = <0x24>;
++			phandle = <0x24>;
++		};
++
++		scr {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "scr";
++			linux,phandle = <0x7d>;
++			phandle = <0x7d>;
++		};
++
++		twi0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi0";
++			linux,phandle = <0x27>;
++			phandle = <0x27>;
++		};
++
++		twi1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi1";
++			linux,phandle = <0x2a>;
++			phandle = <0x2a>;
++		};
++
++		twi2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi2";
++			linux,phandle = <0x2d>;
++			phandle = <0x2d>;
++		};
++
++		twi3 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi3";
++		};
++
++		pio {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "pio";
++			linux,phandle = <0xa>;
++			phandle = <0xa>;
++		};
++
++		cpurcir {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurcir";
++			linux,phandle = <0x12>;
++			phandle = <0x12>;
++		};
++
++		cpurpio {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurpio";
++			linux,phandle = <0x9>;
++			phandle = <0x9>;
++		};
++
++		cpurpll_peri0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurpll_peri0";
++		};
++
++		cpurcpus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurcpus";
++		};
++
++		cpurahbs {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurahbs";
++		};
++
++		cpurapbs {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurapbs";
++		};
++
++		losc_out {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "losc_out";
++			linux,phandle = <0x98>;
++			phandle = <0x98>;
++		};
++	};
++
++	soc@01c00000 {
++		compatible = "simple-bus";
++		#address-cells = <0x2>;
++		#size-cells = <0x2>;
++		ranges;
++		device_type = "soc";
++
++		pinctrl@01f02c00 {
++			compatible = "allwinner,sun50i-r-pinctrl";
++			reg = <0x0 0x1f02c00 0x0 0x400>;
++			interrupts = <0x0 0x2d 0x4>;
++			clocks = <0x9>;
++			device_type = "r_pio";
++			gpio-controller;
++			interrupt-controller;
++			#interrupt-cells = <0x2>;
++			#size-cells = <0x0>;
++			#gpio-cells = <0x6>;
++			linux,phandle = <0x79>;
++			phandle = <0x79>;
++
++			s_cir0@0 {
++				allwinner,pins = "PL11";
++				allwinner,function = "s_cir0";
++				allwinner,muxsel = <0x2>;
++				allwinner,drive = <0x2>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x11>;
++				phandle = <0x11>;
++			};
++
++			s_uart0@0 {
++				linux,phandle = <0xb5>;
++				phandle = <0xb5>;
++				allwinner,pins = "PL2", "PL3";
++				allwinner,function = "s_uart0";
++				allwinner,pname = "s_uart0_tx", "s_uart0_rx";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_rsb0@0 {
++				linux,phandle = <0xb6>;
++				phandle = <0xb6>;
++				allwinner,pins = "PL0", "PL1";
++				allwinner,function = "s_rsb0";
++				allwinner,pname = "s_rsb0_sck", "s_rsb0_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_jtag0@0 {
++				linux,phandle = <0xb7>;
++				phandle = <0xb7>;
++				allwinner,pins = "PL4", "PL5", "PL6", "PL7";
++				allwinner,function = "s_jtag0";
++				allwinner,pname = "s_jtag0_tms", "s_jtag0_tck", "s_jtag0_tdo", "s_jtag0_tdi";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++		};
++
++		pinctrl@01c20800 {
++			compatible = "allwinner,sun50i-pinctrl";
++			reg = <0x0 0x1c20800 0x0 0x400>;
++			interrupts = <0x0 0xb 0x4 0x0 0x11 0x4 0x0 0x15 0x4>;
++			device_type = "pio";
++			clocks = <0xa>;
++			gpio-controller;
++			interrupt-controller;
++			#interrupt-cells = <0x2>;
++			#size-cells = <0x0>;
++			#gpio-cells = <0x6>;
++			linux,phandle = <0x30>;
++			phandle = <0x30>;
++
++			uart0@1 {
++				allwinner,pins = "PB8", "PB9";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x1a>;
++				phandle = <0x1a>;
++			};
++
++			uart1@1 {
++				allwinner,pins = "PG6", "PG7", "PG8", "PG9";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x1d>;
++				phandle = <0x1d>;
++			};
++
++			uart2@1 {
++				allwinner,pins = "PB0", "PB1", "PB2", "PB3";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x20>;
++				phandle = <0x20>;
++			};
++
++			uart3@1 {
++				allwinner,pins = "PH4", "PH5", "PH6", "PH7";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x23>;
++				phandle = <0x23>;
++			};
++
++			uart4@1 {
++				allwinner,pins = "PD2", "PD3", "PD4", "PD5";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x26>;
++				phandle = <0x26>;
++			};
++
++			twi0@1 {
++				allwinner,pins = "PH0", "PH1";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x29>;
++				phandle = <0x29>;
++			};
++
++			twi1@1 {
++				allwinner,pins = "PH2", "PH3";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x2c>;
++				phandle = <0x2c>;
++			};
++
++			twi2@0 {
++				allwinner,pins = "PE14", "PE15";
++				allwinner,pname = "twi2_scl", "twi2_sda";
++				allwinner,function = "twi2";
++				allwinner,muxsel = <0x3>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x2e>;
++				phandle = <0x2e>;
++			};
++
++			twi2@1 {
++				allwinner,pins = "PE14", "PE15";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x2f>;
++				phandle = <0x2f>;
++			};
++
++			spi0@2 {
++				allwinner,pins = "PC3", "PC2", "PC0", "PC1";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x55>;
++				phandle = <0x55>;
++			};
++
++			spi1@2 {
++				allwinner,pins = "PD0", "PD1", "PD2", "PD3";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x59>;
++				phandle = <0x59>;
++			};
++
++			sdc0@1 {
++				allwinner,pins = "PF0", "PF1", "PF2", "PF3", "PF4", "PF5";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x64>;
++				phandle = <0x64>;
++			};
++
++			sdc1@1 {
++				allwinner,pins = "PG0", "PG1", "PG2", "PG3", "PG4", "PG5";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x69>;
++				phandle = <0x69>;
++			};
++
++			sdc2@1 {
++				allwinner,pins = "PC1", "PC5", "PC6", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x5f>;
++				phandle = <0x5f>;
++			};
++
++			daudio0@0 {
++				allwinner,pins = "PB6", "PB3", "PB4", "PB5", "PB7";
++				allwinner,function = "pcm0";
++				allwinner,muxsel = <0x3>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x43>;
++				phandle = <0x43>;
++			};
++
++			daudio0_sleep@0 {
++				allwinner,pins = "PB6", "PB3", "PB4", "PB5", "PB7";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x44>;
++				phandle = <0x44>;
++			};
++
++			daudio1@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "pcm1";
++				allwinner,muxsel = <0x3>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x45>;
++				phandle = <0x45>;
++			};
++
++			daudio1_sleep@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x46>;
++				phandle = <0x46>;
++			};
++
++			aif3@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "aif3";
++				allwinner,muxsel = <0x2>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x3e>;
++				phandle = <0x3e>;
++			};
++
++			aif2_sleep@0 {
++				allwinner,pins = "PB6", "PB4", "PB5", "PB7";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x3f>;
++				phandle = <0x3f>;
++			};
++
++			aif3_sleep@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x40>;
++				phandle = <0x40>;
++			};
++
++			spdif@0 {
++				allwinner,pins = "PH8";
++				allwinner,function = "spdif0";
++				allwinner,muxsel = <0x2>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x4a>;
++				phandle = <0x4a>;
++			};
++
++			spdif_sleep@0 {
++				allwinner,pins = "PH8";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x4b>;
++				phandle = <0x4b>;
++			};
++
++			csi0_sleep@0 {
++				allwinner,pins = "PE0", "PE2", "PE3", "PE4", "PE5", "PE6", "PE7", "PE8", "PE9", "PE10", "PE11", "PE12", "PE13";
++				allwinner,pname = "csi0_pck", "csi0_hsync", "csi0_vsync", "csi0_d0", "csi0_d1", "csi0_d2", "csi0_d3", "csi0_d4", "csi0_d5", "csi0_d6", "csi0_d7", "csi0_sck", "csi0_sda";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				allwinner,data = <0x0>;
++				linux,phandle = <0x77>;
++				phandle = <0x77>;
++			};
++
++			smartcard@0 {
++				allwinner,pins = "PB1", "PB4", "PB5", "PB6", "PB7";
++				allwinner,function = "sim0";
++				allwinner,muxsel = <0x5>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x7f>;
++				phandle = <0x7f>;
++			};
++
++			nand0@2 {
++				allwinner,pins = "PC0", "PC1", "PC2", "PC3", "PC4", "PC5", "PC6", "PC7", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16", "PC17", "PC18";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x83>;
++				phandle = <0x83>;
++			};
++
++			gmac@0 {
++				allwinner,pins = "PD8", "PD9", "PD10", "PD11", "PD12", "PD13", "PD14", "PD15", "PD16", "PD17", "PD18", "PD19", "PD20", "PD21", "PD22", "PD23";
++				allwinner,function = "gmac0";
++				allwinner,muxsel = <0x4>;
++				allwinner,drive = <0x3>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x8e>;
++				phandle = <0x8e>;
++			};
++
++			card0_boot_para@0 {
++				linux,phandle = <0x99>;
++				phandle = <0x99>;
++				allwinner,pins = "PF0", "PF1", "PF2", "PF3", "PF4", "PF5";
++				allwinner,function = "card0_boot_para";
++				allwinner,pname = "sdc_d1", "sdc_d0", "sdc_clk", "sdc_cmd", "sdc_d3", "sdc_d2";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			card2_boot_para@0 {
++				linux,phandle = <0x9a>;
++				phandle = <0x9a>;
++				allwinner,pins = "PC1", "PC5", "PC6", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "card2_boot_para";
++				allwinner,pname = "sdc_ds", "sdc_clk", "sdc_cmd", "sdc_d0", "sdc_d1", "sdc_d2", "sdc_d3", "sdc_d4", "sdc_d5", "sdc_d6", "sdc_d7", "sdc_emmc_rst";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi_para@0 {
++				linux,phandle = <0x9b>;
++				phandle = <0x9b>;
++				allwinner,pins = "PH0", "PH1";
++				allwinner,function = "twi_para";
++				allwinner,pname = "twi_scl", "twi_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart_para@0 {
++				linux,phandle = <0x9c>;
++				phandle = <0x9c>;
++				allwinner,pins = "PB8", "PB9";
++				allwinner,function = "uart_para";
++				allwinner,pname = "uart_debug_tx", "uart_debug_rx";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			jtag_para@0 {
++				linux,phandle = <0x9d>;
++				phandle = <0x9d>;
++				allwinner,pins = "PB0", "PB1", "PB2", "PB3";
++				allwinner,function = "jtag_para";
++				allwinner,pname = "jtag_ms", "jtag_ck", "jtag_do", "jtag_di";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			gmac_para@0 {
++				linux,phandle = <0x9e>;
++				phandle = <0x9e>;
++				allwinner,pins = "PA0", "PA1", "PA2", "PA3", "PA4", "PA5", "PA6", "PA7", "PA8", "PA9", "PA10", "PA11", "PA12", "PA13", "PA14", "PA15", "PA16", "PA17", "PA18", "PA19", "PA20", "PA21", "PA22", "PA23", "PA24", "PA25", "PA26", "PA27";
++				allwinner,function = "gmac_para";
++				allwinner,pname = "gmac_txd0", "gmac_txd1", "gmac_txd2", "gmac_txd3", "gmac_txd4", "gmac_txd5", "gmac_txd6", "gmac_txd7", "gmac_txclk", "gmac_txen", "gmac_gtxclk", "gmac_rxd0", "gmac_rxd1", "gmac_rxd2", "gmac_rxd3", "gmac_rxd4", "gmac_rxd5", "gmac_rxd6", "gmac_rxd7", "gmac_rxdv", "gmac_rxclk", "gmac_txerr", "gmac_rxerr", "gmac_col", "gmac_crs", "gmac_clkin", "gmac_mdc", "gmac_mdio";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi0@0 {
++				linux,phandle = <0x9f>;
++				phandle = <0x9f>;
++				allwinner,pins = "PH0", "PH1";
++				allwinner,function = "twi0";
++				allwinner,pname = "twi0_scl", "twi0_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi1@0 {
++				linux,phandle = <0xa0>;
++				phandle = <0xa0>;
++				allwinner,pins = "PH2", "PH3";
++				allwinner,function = "twi1";
++				allwinner,pname = "twi1_scl", "twi1_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart0@0 {
++				linux,phandle = <0xa1>;
++				phandle = <0xa1>;
++				allwinner,pins = "PB8", "PB9";
++				allwinner,function = "uart0";
++				allwinner,pname = "uart0_tx", "uart0_rx";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart1@0 {
++				linux,phandle = <0xa2>;
++				phandle = <0xa2>;
++				allwinner,pins = "PG6", "PG7", "PG8", "PG9";
++				allwinner,function = "uart1";
++				allwinner,pname = "uart1_tx", "uart1_rx", "uart1_rts", "uart1_cts";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart2@0 {
++				linux,phandle = <0xa3>;
++				phandle = <0xa3>;
++				allwinner,pins = "PB0", "PB1", "PB2", "PB3";
++				allwinner,function = "uart2";
++				allwinner,pname = "uart2_tx", "uart2_rx", "uart2_rts", "uart2_cts";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart3@0 {
++				linux,phandle = <0xa4>;
++				phandle = <0xa4>;
++				allwinner,pins = "PH4", "PH5", "PH6", "PH7";
++				allwinner,function = "uart3";
++				allwinner,pname = "uart3_tx", "uart3_rx", "uart3_rts", "uart3_cts";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart4@0 {
++				linux,phandle = <0xa5>;
++				phandle = <0xa5>;
++				allwinner,pins = "PD2", "PD3", "PD4", "PD5";
++				allwinner,function = "uart4";
++				allwinner,pname = "uart4_tx", "uart4_rx", "uart4_rts", "uart4_cts";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi0@0 {
++				linux,phandle = <0xa6>;
++				phandle = <0xa6>;
++				allwinner,pins = "PC3";
++				allwinner,function = "spi0";
++				allwinner,pname = "spi0_cs0";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi0@1 {
++				linux,phandle = <0xa7>;
++				phandle = <0xa7>;
++				allwinner,pins = "PC2", "PC0", "PC1";
++				allwinner,function = "spi0";
++				allwinner,pname = "spi0_sclk", "spi0_mosi", "spi0_miso";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi1@0 {
++				linux,phandle = <0xa8>;
++				phandle = <0xa8>;
++				allwinner,pins = "PD0";
++				allwinner,function = "spi1";
++				allwinner,pname = "spi1_cs0";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi1@1 {
++				linux,phandle = <0xa9>;
++				phandle = <0xa9>;
++				allwinner,pins = "PD1", "PD2", "PD3";
++				allwinner,function = "spi1";
++				allwinner,pname = "spi1_sclk", "spi1_mosi", "spi1_miso";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			nand0@0 {
++				linux,phandle = <0xaa>;
++				phandle = <0xaa>;
++				allwinner,pins = "PC0", "PC1", "PC2", "PC5", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "nand0";
++				allwinner,pname = "nand0_we", "nand0_ale", "nand0_cle", "nand0_nre", "nand0_d0", "nand0_d1", "nand0_d2", "nand0_d3", "nand0_d4", "nand0_d5", "nand0_d6", "nand0_d7", "nand0_ndqs";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0x1>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			nand0@1 {
++				linux,phandle = <0xab>;
++				phandle = <0xab>;
++				allwinner,pins = "PC3", "PC4", "PC6", "PC7", "PC17", "PC18";
++				allwinner,function = "nand0";
++				allwinner,pname = "nand0_ce1", "nand0_ce0", "nand0_rb0", "nand0_rb1", "nand0_ce2", "nand0_ce3";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x1>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			lcd0@0 {
++				linux,phandle = <0xac>;
++				phandle = <0xac>;
++				allwinner,pins = "PD0", "PD1", "PD2", "PD3", "PD4", "PD5", "PD6", "PD7", "PD8", "PD9", "PD10", "PD11", "PD12", "PD13", "PD14", "PD15", "PD16", "PD17", "PD18", "PD19", "PD20", "PD21";
++				allwinner,function = "lcd0";
++				allwinner,pname = "lcdd2", "lcdd3", "lcdd4", "lcdd5", "lcdd6", "lcdd7", "lcdd10", "lcdd11", "lcdd12", "lcdd13", "lcdd14", "lcdd15", "lcdd18", "lcdd19", "lcdd20", "lcdd21", "lcdd22", "lcdd23", "lcdclk", "lcdde", "lcdhsync", "lcdvsync";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			lcd0@1 {
++				linux,phandle = <0xad>;
++				phandle = <0xad>;
++				allwinner,pins = "PD12", "PD13", "PD14", "PD15", "PD16", "PD17", "PD18", "PD19", "PD20", "PD21";
++				allwinner,function = "lcd0";
++				allwinner,pname = "lcdd0", "lcdd1", "lcdd2", "lcdd3", "lcdd4", "lcdd5", "lcdd6", "lcdd7", "lcdd8", "lcdd9";
++				allwinner,muxsel = <0x7>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			pwm0@0 {
++				linux,phandle = <0xae>;
++				phandle = <0xae>;
++				allwinner,pins = "PD22";
++				allwinner,function = "pwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			pwm0@1 {
++				linux,phandle = <0xaf>;
++				phandle = <0xaf>;
++				allwinner,pins = "PD22";
++				allwinner,function = "pwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x7>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			csi0@0 {
++				linux,phandle = <0xb0>;
++				phandle = <0xb0>;
++				allwinner,pins = "PE0", "PE2", "PE3", "PE4", "PE5", "PE6", "PE7", "PE8", "PE9", "PE10", "PE11", "PE12", "PE13";
++				allwinner,function = "csi0";
++				allwinner,pname = "csi0_pck", "csi0_hsync", "csi0_vsync", "csi0_d0", "csi0_d1", "csi0_d2", "csi0_d3", "csi0_d4", "csi0_d5", "csi0_d6", "csi0_d7", "csi0_sck", "csi0_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			sdc0@0 {
++				linux,phandle = <0xb1>;
++				phandle = <0xb1>;
++				allwinner,pins = "PF0", "PF1", "PF2", "PF3", "PF4", "PF5";
++				allwinner,function = "sdc0";
++				allwinner,pname = "sdc0_d1", "sdc0_d0", "sdc0_clk", "sdc0_cmd", "sdc0_d3", "sdc0_d2";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			sdc1@0 {
++				linux,phandle = <0xb2>;
++				phandle = <0xb2>;
++				allwinner,pins = "PG0", "PG1", "PG2", "PG3", "PG4", "PG5";
++				allwinner,function = "sdc1";
++				allwinner,pname = "sdc1_clk", "sdc1_cmd", "sdc1_d0", "sdc1_d1", "sdc1_d2", "sdc1_d3";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			sdc2@0 {
++				linux,phandle = <0xb3>;
++				phandle = <0xb3>;
++				allwinner,pins = "PC1", "PC5", "PC6", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "sdc2";
++				allwinner,pname = "sdc2_ds", "sdc2_clk", "sdc2_cmd", "sdc2_d0", "sdc2_d1", "sdc2_d2", "sdc2_d3", "sdc2_d4", "sdc2_d5", "sdc2_d6", "sdc2_d7", "sdc2_emmc_rst";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			codec@0 {
++				linux,phandle = <0xb4>;
++				phandle = <0xb4>;
++				allwinner,pins = "PH7";
++				allwinner,function = "codec";
++				allwinner,pname = "gpio-spk";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			Vdevice@0 {
++				linux,phandle = <0xb8>;
++				phandle = <0xb8>;
++				allwinner,pins = "PB1", "PB2";
++				allwinner,function = "Vdevice";
++				allwinner,pname = "Vdevice_0", "Vdevice_1";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++		};
++
++		pinctrl@0 {
++			compatible = "allwinner,axp-pinctrl";
++			gpio-controller;
++			#size-cells = <0x0>;
++			#gpio-cells = <0x6>;
++			device_type = "axp_pio";
++			linux,phandle = <0x31>;
++			phandle = <0x31>;
++		};
++
++		dma-controller@01c02000 {
++			compatible = "allwinner,sun50i-dma";
++			reg = <0x0 0x1c02000 0x0 0x1000>;
++			interrupts = <0x0 0x32 0x4>;
++			clocks = <0xb>;
++			#dma-cells = <0x1>;
++		};
++
++		mbus-controller@01c62000 {
++			compatible = "allwinner,sun50i-mbus";
++			reg = <0x0 0x1c62000 0x0 0x110>;
++			#mbus-cells = <0x1>;
++		};
++
++		arisc {
++			compatible = "allwinner,sunxi-arisc";
++			#address-cells = <0x2>;
++			#size-cells = <0x2>;
++			clocks = <0xc 0xd 0x6 0x4>;
++			clock-names = "losc", "iosc", "hosc", "pll_periph0";
++			powchk_used = <0x0>;
++			power_reg = <0x2309621>;
++			system_power = <0x32>;
++		};
++
++		arisc_space {
++			compatible = "allwinner,arisc_space";
++			space1 = <0x40000 0x0 0x14000>;
++			space2 = <0x40100000 0x18000 0x4000>;
++			space3 = <0x40104000 0x0 0x1000>;
++			space4 = <0x40105000 0x0 0x1000>;
++		};
++
++		standby_space {
++			compatible = "allwinner,standby_space";
++			space1 = <0x41020000 0x0 0x800>;
++		};
++
++		msgbox@1c17000 {
++			compatible = "allwinner,msgbox";
++			clocks = <0xe>;
++			clock-names = "clk_msgbox";
++			reg = <0x0 0x1c17000 0x0 0x1000>;
++			interrupts = <0x0 0x31 0x1>;
++			status = "okay";
++		};
++
++		hwspinlock@1c18000 {
++			compatible = "allwinner,sunxi-hwspinlock";
++			clocks = <0xf 0x10>;
++			clock-names = "clk_hwspinlock_rst", "clk_hwspinlock_bus";
++			reg = <0x0 0x1c18000 0x0 0x1000>;
++			status = "okay";
++			num-locks = <0x8>;
++		};
++
++		s_cir@1f02000 {
++			compatible = "allwinner,s_cir";
++			reg = <0x0 0x1f02000 0x0 0x400>;
++			interrupts = <0x0 0x25 0x4>;
++			pinctrl-names = "default";
++			pinctrl-0 = <0x11>;
++			clocks = <0x6 0x12>;
++			supply = "vcc-pl";
++			ir_power_key_code = <0x0>;
++			ir_addr_code = <0x0>;
++			status = "disabled";
++			device_type = "s_cir0";
++		};
++
++		s_uart@1f02800 {
++			compatible = "allwinner,s_uart";
++			reg = <0x0 0x1f02800 0x0 0x400>;
++			interrupts = <0x0 0x26 0x4>;
++			pinctrl-names = "default";
++			status = "okay";
++			device_type = "s_uart0";
++			pinctrl-0 = <0xb5>;
++		};
++
++		s_rsb@1f03400 {
++			compatible = "allwinner,s_rsb";
++			reg = <0x0 0x1f03400 0x0 0x400>;
++			interrupts = <0x0 0x27 0x4>;
++			pinctrl-names = "default";
++			status = "okay";
++			device_type = "s_rsb0";
++			pinctrl-0 = <0xb6>;
++		};
++
++		s_jtag0 {
++			compatible = "allwinner,s_jtag";
++			pinctrl-names = "default";
++			status = "disabled";
++			device_type = "s_jtag0";
++			pinctrl-0 = <0xb7>;
++		};
++
++		timer@1c20c00 {
++			compatible = "allwinner,sunxi-timer";
++			device_type = "timer";
++			reg = <0x0 0x1c20c00 0x0 0x90>;
++			interrupts = <0x0 0x12 0x1>;
++			clock-frequency = <0x16e3600>;
++			timer-prescale = <0x10>;
++		};
++
++		rtc@01f00000 {
++			compatible = "allwinner,sun50i-rtc";
++			device_type = "rtc";
++			reg = <0x0 0x1f00000 0x0 0x218>;
++			interrupts = <0x0 0x28 0x4>;
++			gpr_offset = <0x100>;
++			gpr_len = <0x4>;
++		};
++
++		ve@01c0e000 {
++			compatible = "allwinner,sunxi-cedar-ve";
++			reg = <0x0 0x1c0e000 0x0 0x1000 0x0 0x1c00000 0x0 0x10 0x0 0x1c20000 0x0 0x800>;
++			interrupts = <0x0 0x3a 0x4>;
++			clocks = <0x16 0x17>;
++		};
++
++		uart@01c28000 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart0";
++			reg = <0x0 0x1c28000 0x0 0x400>;
++			interrupts = <0x0 0x0 0x4>;
++			clocks = <0x18>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x1a>;
++			uart0_port = <0x0>;
++			uart0_type = <0x2>;
++			status = "okay";
++			pinctrl-0 = <0xa1>;
++		};
++
++		uart@01c28400 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart1";
++			reg = <0x0 0x1c28400 0x0 0x400>;
++			interrupts = <0x0 0x1 0x4>;
++			clocks = <0x1b>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x1d>;
++			uart1_port = <0x1>;
++			uart1_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa2>;
++		};
++
++		uart@01c28800 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart2";
++			reg = <0x0 0x1c28800 0x0 0x400>;
++			interrupts = <0x0 0x2 0x4>;
++			clocks = <0x1e>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x20>;
++			uart2_port = <0x2>;
++			uart2_type = <0x4>;
++			status = "disabled";
++			pinctrl-0 = <0xa3>;
++		};
++
++		uart@01c28c00 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart3";
++			reg = <0x0 0x1c28c00 0x0 0x400>;
++			interrupts = <0x0 0x3 0x4>;
++			clocks = <0x21>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x23>;
++			uart3_port = <0x3>;
++			uart3_type = <0x4>;
++			status = "disabled";
++			pinctrl-0 = <0xa4>;
++		};
++
++		uart@01c29000 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart4";
++			reg = <0x0 0x1c29000 0x0 0x400>;
++			interrupts = <0x0 0x4 0x4>;
++			clocks = <0x24>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x26>;
++			uart4_port = <0x4>;
++			uart4_type = <0x4>;
++			status = "disabled";
++			pinctrl-0 = <0xa5>;
++		};
++
++		twi@0x01c2ac00 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-twi";
++			device_type = "twi0";
++			reg = <0x0 0x1c2ac00 0x0 0x400>;
++			interrupts = <0x0 0x6 0x4>;
++			clocks = <0x27>;
++			clock-frequency = <0x61a80>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x29>;
++			status = "okay";
++			pinctrl-0 = <0x9f>;
++		};
++
++		twi@0x01c2b000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-twi";
++			device_type = "twi1";
++			reg = <0x0 0x1c2b000 0x0 0x400>;
++			interrupts = <0x0 0x7 0x4>;
++			clocks = <0x2a>;
++			clock-frequency = <0x30d40>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x2c>;
++			status = "okay";
++			pinctrl-0 = <0xa0>;
++		};
++
++		twi@0x01c2b400 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-twi";
++			device_type = "twi2";
++			reg = <0x0 0x1c2b400 0x0 0x400>;
++			interrupts = <0x0 0x8 0x4>;
++			clocks = <0x2d>;
++			clock-frequency = <0x30d40>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x2e>;
++			pinctrl-1 = <0x2f>;
++			status = "disabled";
++		};
++
++		usbc0@0 {
++			device_type = "usbc0";
++			compatible = "allwinner,sunxi-otg-manager";
++			usb_port_type = <0x1>;
++			usb_detect_type = <0x0>;
++			usb_det_vbus_gpio = "axp_ctrl";
++			usb_host_init_state = <0x0>;
++			usb_regulator_io = "nocare";
++			usb_wakeup_suspend = <0x0>;
++			usb_luns = <0x3>;
++			usb_serial_unique = <0x1>;
++			usb_serial_number = "20080411";
++			rndis_wceis = <0x1>;
++			status = "okay";
++			usb_id_gpio;
++			usb_drv_vbus_gpio = <0x31 0xfffe 0x3 0x1 0x0 0xffffffff 0x0>;
++		};
++
++		udc-controller@0x01c19000 {
++			compatible = "allwinner,sunxi-udc";
++			reg = <0x0 0x1c19000 0x0 0x1000 0x0 0x1c00000 0x0 0x100>;
++			interrupts = <0x0 0x47 0x4>;
++			clocks = <0x32 0x33>;
++			status = "okay";
++		};
++
++		ehci0-controller@0x01c1a000 {
++			compatible = "allwinner,sunxi-ehci0";
++			reg = <0x0 0x1c1a000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x48 0x4>;
++			clocks = <0x32 0x34>;
++			hci_ctrl_no = <0x0>;
++			status = "okay";
++		};
++
++		ohci0-controller@0x01c1a400 {
++			compatible = "allwinner,sunxi-ohci0";
++			reg = <0x0 0x1c1a000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x49 0x4>;
++			clocks = <0x32 0x35>;
++			hci_ctrl_no = <0x0>;
++			status = "okay";
++		};
++
++		usbc1@0 {
++			device_type = "usbc1";
++			usb_host_init_state = <0x1>;
++			usb_regulator_io = "nocare";
++			usb_wakeup_suspend = <0x0>;
++			usb_hsic_used = <0x0>;
++			usb_hsic_regulator_io = "vcc-hsic-12";
++			usb_hsic_ctrl = <0x0>;
++			usb_hsic_usb3503_flag = <0x0>;
++			status = "okay";
++			usb_port_type = <0x1>;
++			usb_detect_type = <0x0>;
++			usb_drv_vbus_gpio;
++			usb_hsic_rdy_gpio;
++			usb_hsic_hub_connect_gpio;
++			usb_hsic_int_n_gpio;
++			usb_hsic_reset_n_gpio;
++		};
++
++		ehci1-controller@0x01c1b000 {
++			compatible = "allwinner,sunxi-ehci1";
++			reg = <0x0 0x1c1b000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x4a 0x4>;
++			clocks = <0x36 0x37 0x38 0x39 0x3a>;
++			hci_ctrl_no = <0x1>;
++			status = "okay";
++		};
++
++		ohci1-controller@0x01c1b400 {
++			compatible = "allwinner,sunxi-ohci1";
++			reg = <0x0 0x1c1b000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x4b 0x4>;
++			clocks = <0x36 0x3b>;
++			hci_ctrl_no = <0x1>;
++			status = "okay";
++		};
++
++		codec@0x01c22c00 {
++			compatible = "allwinner,sunxi-internal-codec";
++			reg = <0x0 0x1c22c00 0x0 0x478 0x0 0x1f015c0 0x0 0x0>;
++			clocks = <0x3c>;
++			pinctrl-names = "aif2-default", "aif3-default", "aif2-sleep", "aif3-sleep";
++			pinctrl-1 = <0x3e>;
++			pinctrl-2 = <0x3f>;
++			pinctrl-3 = <0x40>;
++			gpio-spk = <0x30 0x7 0x7 0x1 0x1 0x1 0x1>;
++			headphonevol = <0x3b>;
++			spkervol = <0x1a>;
++			earpiecevol = <0x1e>;
++			maingain = <0x4>;
++			headsetmicgain = <0x4>;
++			adcagc_cfg = <0x0>;
++			adcdrc_cfg = <0x0>;
++			adchpf_cfg = <0x0>;
++			dacdrc_cfg = <0x0>;
++			dachpf_cfg = <0x0>;
++			aif1_lrlk_div = <0x40>;
++			aif2_lrlk_div = <0x40>;
++			aif2config = <0x0>;
++			aif3config = <0x0>;
++			pa_sleep_time = <0x15e>;
++			dac_digital_vol = <0xa0a0>;
++			status = "okay";
++			linux,phandle = <0x4d>;
++			phandle = <0x4d>;
++			device_type = "codec";
++			pinctrl-0 = <0xb4>;
++		};
++
++		i2s0-controller@0x01c22c00 {
++			compatible = "allwinner,sunxi-internal-i2s";
++			reg = <0x0 0x1c22c00 0x0 0x478>;
++			clocks = <0x2 0x41>;
++			status = "okay";
++			linux,phandle = <0x4c>;
++			phandle = <0x4c>;
++			device_type = "i2s";
++		};
++
++		daudio@0x01c22000 {
++			compatible = "allwinner,sunxi-daudio";
++			reg = <0x0 0x1c22000 0x0 0x58>;
++			clocks = <0x2 0x42>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x43>;
++			pinctrl-1 = <0x44>;
++			pcm_lrck_period = <0x20>;
++			pcm_lrckr_period = <0x1>;
++			slot_width_select = <0x20>;
++			pcm_lsb_first = <0x0>;
++			tx_data_mode = <0x0>;
++			rx_data_mode = <0x0>;
++			daudio_master = <0x4>;
++			audio_format = <0x1>;
++			signal_inversion = <0x1>;
++			frametype = <0x0>;
++			tdm_config = <0x1>;
++			tdm_num = <0x0>;
++			status = "disabled";
++			linux,phandle = <0x4e>;
++			phandle = <0x4e>;
++			device_type = "daudio0";
++		};
++
++		daudio@0x01c22400 {
++			compatible = "allwinner,sunxi-daudio";
++			reg = <0x0 0x1c22400 0x0 0x58>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x45>;
++			pinctrl-1 = <0x46>;
++			clocks = <0x2 0x47>;
++			pcm_lrck_period = <0x20>;
++			pcm_lrckr_period = <0x1>;
++			slot_width_select = <0x20>;
++			pcm_lsb_first = <0x0>;
++			tx_data_mode = <0x0>;
++			rx_data_mode = <0x0>;
++			daudio_master = <0x4>;
++			audio_format = <0x1>;
++			signal_inversion = <0x1>;
++			frametype = <0x0>;
++			tdm_config = <0x1>;
++			tdm_num = <0x1>;
++			status = "disabled";
++			linux,phandle = <0x4f>;
++			phandle = <0x4f>;
++			device_type = "daudio1";
++		};
++
++		daudio@0x01c22800 {
++			compatible = "allwinner,sunxi-tdmhdmi";
++			reg = <0x0 0x1c22800 0x0 0x58>;
++			clocks = <0x2 0x48>;
++			status = "okay";
++			linux,phandle = <0x50>;
++			phandle = <0x50>;
++			device_type = "daudio2";
++		};
++
++		spdif-controller@0x01c21000 {
++			compatible = "allwinner,sunxi-spdif";
++			reg = <0x0 0x1c21000 0x0 0x38>;
++			clocks = <0x2 0x49>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x4a>;
++			pinctrl-1 = <0x4b>;
++			status = "disabled";
++			linux,phandle = <0x51>;
++			phandle = <0x51>;
++			device_type = "spdif";
++		};
++
++		sound@0 {
++			compatible = "allwinner,sunxi-codec-machine";
++			interrupts = <0x0 0x1c 0x4>;
++			sunxi,i2s-controller = <0x4c>;
++			sunxi,audio-codec = <0x4d>;
++			aif2fmt = <0x3>;
++			aif3fmt = <0x3>;
++			aif2master = <0x1>;
++			hp_detect_case = <0x1>;
++			status = "okay";
++			device_type = "sndcodec";
++		};
++
++		sound@1 {
++			compatible = "allwinner,sunxi-daudio0-machine";
++			sunxi,daudio0-controller = <0x4e>;
++			status = "disabled";
++			device_type = "snddaudio0";
++		};
++
++		sound@2 {
++			compatible = "allwinner,sunxi-daudio1-machine";
++			sunxi,daudio1-controller = <0x4f>;
++			status = "disabled";
++			device_type = "snddaudio1";
++		};
++
++		sound@3 {
++			compatible = "allwinner,sunxi-hdmi-machine";
++			sunxi,hdmi-controller = <0x50>;
++			status = "okay";
++			device_type = "sndhdmi";
++		};
++
++		sound@4 {
++			compatible = "allwinner,sunxi-spdif-machine";
++			sunxi,spdif-controller = <0x51>;
++			status = "disabled";
++			device_type = "sndspdif";
++		};
++
++		spi@01c68000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-spi";
++			device_type = "spi0";
++			reg = <0x0 0x1c68000 0x0 0x1000>;
++			interrupts = <0x0 0x41 0x4>;
++			clocks = <0x4 0x52>;
++			clock-frequency = <0x5f5e100>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x55>;
++			spi0_cs_number = <0x1>;
++			spi0_cs_bitmap = <0x1>;
++			status = "disabled";
++			pinctrl-0 = <0xa6 0xa7>;
++		};
++
++		spi@01c69000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-spi";
++			device_type = "spi1";
++			reg = <0x0 0x1c69000 0x0 0x1000>;
++			interrupts = <0x0 0x42 0x4>;
++			clocks = <0x4 0x56>;
++			clock-frequency = <0x5f5e100>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x59>;
++			spi1_cs_number = <0x1>;
++			spi1_cs_bitmap = <0x1>;
++			status = "disabled";
++			pinctrl-0 = <0xa8 0xa9>;
++		};
++
++		sdmmc@01C11000 {
++			compatible = "allwinner,sun50i-sdmmc2";
++			device_type = "sdc2";
++			reg = <0x0 0x1c11000 0x0 0x1000>;
++			interrupts = <0x0 0x3e 0x104>;
++			clocks = <0x6 0x5a 0x5b 0x5c 0x5d>;
++			clock-names = "osc24m", "pll_periph", "mmc", "ahb", "rst";
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x5f>;
++			bus-width = <0x8>;
++			max-frequency = <0x5f5e100>;
++			sdc_tm4_sm0_freq0 = <0x0>;
++			sdc_tm4_sm0_freq1 = <0x0>;
++			sdc_tm4_sm1_freq0 = <0x0>;
++			sdc_tm4_sm1_freq1 = <0x0>;
++			sdc_tm4_sm2_freq0 = <0x0>;
++			sdc_tm4_sm2_freq1 = <0x0>;
++			sdc_tm4_sm3_freq0 = <0x5000000>;
++			sdc_tm4_sm3_freq1 = <0x405>;
++			sdc_tm4_sm4_freq0 = <0x50000>;
++			sdc_tm4_sm4_freq1 = <0x408>;
++			status = "okay";
++			non-removable;
++			pinctrl-0 = <0xb3>;
++			cd-gpios;
++			sunxi-power-save-mode;
++			sunxi-dis-signal-vol-sw;
++			mmc-ddr-1_8v;
++			mmc-hs200-1_8v;
++			mmc-hs400-1_8v;
++			vmmc = "vcc-emmc";
++			vqmmc = "vcc-lpddr";
++			vdmmc = "none";
++		};
++
++		sdmmc@01c0f000 {
++			compatible = "allwinner,sun50i-sdmmc0";
++			device_type = "sdc0";
++			reg = <0x0 0x1c0f000 0x0 0x1000>;
++			interrupts = <0x0 0x3c 0x104>;
++			clocks = <0x6 0x5a 0x60 0x61 0x62>;
++			clock-names = "osc24m", "pll_periph", "mmc", "ahb", "rst";
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x64>;
++			max-frequency = <0x2faf080>;
++			bus-width = <0x4>;
++			broken-cd;
++			status = "okay";
++			pinctrl-0 = <0xb1>;
++			cd-gpios = <0x30 0x5 0x6 0x0 0x1 0x2 0xffffffff>;
++			sunxi-power-save-mode;
++			vmmc = "none";
++			vqmmc = "none";
++			vdmmc = "vcc-sdc";
++		};
++
++		sdmmc@1C10000 {
++			compatible = "allwinner,sun50i-sdmmc1";
++			device_type = "sdc1";
++			reg = <0x0 0x1c10000 0x0 0x1000>;
++			interrupts = <0x0 0x3d 0x104>;
++			clocks = <0x6 0x5a 0x65 0x66 0x67>;
++			clock-names = "osc24m", "pll_periph", "mmc", "ahb", "rst";
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x69>;
++			max-frequency = <0x8f0d180>;
++			bus-width = <0x4>;
++			sunxi-dly-52M-ddr4 = <0x1 0x0 0x0 0x0 0x2>;
++			sunxi-dly-104M = <0x1 0x0 0x0 0x0 0x1>;
++			sunxi-dly-208M = <0x1 0x0 0x0 0x0 0x1>;
++			status = "okay";
++			pinctrl-0 = <0xb2>;
++			sd-uhs-sdr50;
++			sd-uhs-ddr50;
++			sd-uhs-sdr104;
++			cap-sdio-irq;
++			keep-power-in-suspend;
++			ignore-pm-notify;
++		};
++
++		disp@01000000 {
++			compatible = "allwinner,sun50i-disp";
++			reg = <0x0 0x1000000 0x0 0x300000 0x0 0x1c0c000 0x0 0x17fc 0x0 0x1ca0000 0x0 0x10fc>;
++			interrupts = <0x0 0x56 0x104 0x0 0x57 0x104 0x0 0x59 0x104>;
++			clocks = <0x6a 0x6b 0x6c 0x6d 0x6e>;
++			status = "okay";
++			device_type = "disp";
++			disp_init_enable = <0x1>;
++			disp_mode = <0x0>;
++			screen0_output_type = <0x1>;
++			screen0_output_mode = <0x4>;
++			screen1_output_type = <0x3>;
++			screen1_output_mode = <0xa>;
++			fb0_format = <0x0>;
++			fb0_width = <0x0>;
++			fb0_height = <0x0>;
++			fb1_format = <0x0>;
++			fb1_width = <0x0>;
++			fb1_height = <0x0>;
++		};
++
++		lcd0@01c0c000 {
++			compatible = "allwinner,sunxi-lcd0";
++			pinctrl-names = "active", "sleep";
++			status = "okay";
++			device_type = "lcd0";
++			lcd_used = <0x1>;
++			lcd_driver_name = "anx9804_panel";
++			lcd_model_name = <0x2>;
++			lcd_backlight = <0x32>;
++			lcd_if = <0x0>;
++			lcd_x = <0x556>;
++			lcd_y = <0x300>;
++			lcd_width = <0x100>;
++			lcd_height = <0x90>;
++			lcd_dclk_freq = <0x4d>;
++			lcd_pwm_used = <0x1>;
++			lcd_pwm_ch = <0x0>;
++			lcd_pwm_freq = <0x2ee0>;
++			lcd_pwm_pol = <0x0>;
++			lcd_pwm_max_limit = <0xfa>;
++			lcd_hbp = <0x40>;
++			lcd_ht = <0x640>;
++			lcd_hspw = <0x36>;
++			lcd_vbp = <0x14>;
++			lcd_vt = <0x35c>;
++			lcd_vspw = <0x5>;
++			lcd_lvds_if = <0x0>;
++			lcd_lvds_colordepth = <0x0>;
++			lcd_lvds_mode = <0x0>;
++			lcd_frm = <0x1>;
++			lcd_hv_clk_phase = <0x0>;
++			lcd_hv_sync_polarity = <0x0>;
++			lcd_dsi_if = <0x0>;
++			lcd_dsi_lane = <0x4>;
++			lcd_dsi_format = <0x0>;
++			lcd_dsi_te = <0x0>;
++			lcd_gamma_en = <0x0>;
++			lcd_bright_curve_en = <0x0>;
++			lcd_cmap_en = <0x0>;
++			lcd_edp_tx_rate = <0x2>;
++			lcd_edp_tx_lane = <0x2>;
++			lcd_edp_colordepth = <0x1>;
++			lcdgamma4iep = <0x16>;
++			lcd_bl_en = <0x30 0x3 0x17 0x1 0x0 0xffffffff 0x1>;
++			lcd_bl_en_power = "none";
++			lcd_power = "vcc-lvds";
++			lcd_power1 = "vcc-mipi";
++			lcd_power2 = "vcc-hsic-12";
++			lcd_gpio_0 = <0x30 0x3 0x18 0x1 0x0 0xffffffff 0x0>;
++			lcd_gpio_1 = <0x30 0x7 0x6 0x1 0x0 0xffffffff 0x1>;
++			lcd_gpio_2 = <0x30 0x0 0x8 0x0 0x1 0xffffffff 0x0>;
++			lcd_gpio_3 = <0x30 0x0 0x9 0x0 0x1 0xffffffff 0x0>;
++			pinctrl-0 = <0xac>;
++			lcd_pin_power = "vcc-pd";
++			pinctrl-1 = <0xad>;
++		};
++
++		hdmi@01ee0000 {
++			compatible = "allwinner,sunxi-hdmi";
++			reg = <0x0 0x1ee0000 0x0 0x20000>;
++			clocks = <0x6f 0x70>;
++			device_type = "hdmi";
++			status = "okay";
++			hdmi_power = "vcc-hdmi-33";
++			hdmi_hdcp_enable = <0x0>;
++			hdmi_cts_compatibility = <0x0>;
++		};
++
++		tr@01000000 {
++			compatible = "allwinner,sun50i-tr";
++			reg = <0x0 0x1000000 0x0 0x200bc>;
++			interrupts = <0x0 0x60 0x104>;
++			clocks = <0x6a>;
++			status = "okay";
++		};
++
++		pwm@01c21400 {
++			compatible = "allwinner,sunxi-pwm";
++			reg = <0x0 0x1c21400 0x0 0x3c>;
++			pwm-number = <0x1>;
++			pwm-base = <0x0>;
++			pwms = <0x71>;
++		};
++
++		pwm0@01c21400 {
++			compatible = "allwinner,sunxi-pwm0";
++			pinctrl-names = "active", "sleep";
++			reg_base = <0x1c21400>;
++			reg_busy_offset = <0x0>;
++			reg_busy_shift = <0x1c>;
++			reg_enable_offset = <0x0>;
++			reg_enable_shift = <0x4>;
++			reg_clk_gating_offset = <0x0>;
++			reg_clk_gating_shift = <0x6>;
++			reg_bypass_offset = <0x0>;
++			reg_bypass_shift = <0x9>;
++			reg_pulse_start_offset = <0x0>;
++			reg_pulse_start_shift = <0x8>;
++			reg_mode_offset = <0x0>;
++			reg_mode_shift = <0x7>;
++			reg_polarity_offset = <0x0>;
++			reg_polarity_shift = <0x5>;
++			reg_period_offset = <0x4>;
++			reg_period_shift = <0x10>;
++			reg_period_width = <0x10>;
++			reg_active_offset = <0x4>;
++			reg_active_shift = <0x0>;
++			reg_active_width = <0x10>;
++			reg_prescal_offset = <0x0>;
++			reg_prescal_shift = <0x0>;
++			reg_prescal_width = <0x4>;
++			linux,phandle = <0x71>;
++			phandle = <0x71>;
++			device_type = "pwm0";
++			pwm_used = <0x1>;
++			pinctrl-0 = <0xae>;
++			pinctrl-1 = <0xaf>;
++		};
++
++		s_pwm@1f03800 {
++			compatible = "allwinner,sunxi-s_pwm";
++			reg = <0x0 0x1f03800 0x0 0x3c>;
++			pwm-number = <0x1>;
++			pwm-base = <0x10>;
++			pwms = <0x72>;
++		};
++
++		spwm0@0x01f03800 {
++			compatible = "allwinner,sunxi-pwm16";
++			pinctrl-names = "active", "sleep";
++			reg_base = <0x1f03800>;
++			reg_busy_offset = <0x0>;
++			reg_busy_shift = <0x1c>;
++			reg_enable_offset = <0x0>;
++			reg_enable_shift = <0x4>;
++			reg_clk_gating_offset = <0x0>;
++			reg_clk_gating_shift = <0x6>;
++			reg_bypass_offset = <0x0>;
++			reg_bypass_shift = <0x9>;
++			reg_pulse_start_offset = <0x0>;
++			reg_pulse_start_shift = <0x8>;
++			reg_mode_offset = <0x0>;
++			reg_mode_shift = <0x7>;
++			reg_polarity_offset = <0x0>;
++			reg_polarity_shift = <0x5>;
++			reg_period_offset = <0x4>;
++			reg_period_shift = <0x10>;
++			reg_period_width = <0x10>;
++			reg_active_offset = <0x4>;
++			reg_active_shift = <0x0>;
++			reg_active_width = <0x10>;
++			reg_prescal_offset = <0x0>;
++			reg_prescal_shift = <0x0>;
++			reg_prescal_width = <0x4>;
++			linux,phandle = <0x72>;
++			phandle = <0x72>;
++		};
++
++		boot_disp {
++			compatible = "allwinner,boot_disp";
++			device_type = "boot_disp";
++			output_disp = <0x0>;
++			output_type = <0x1>;
++			output_mode = <0x4>;
++		};
++
++		cci@0x01cb3000 {
++			compatible = "allwinner,sunxi-csi_cci";
++			reg = <0x0 0x1cb3000 0x0 0x1000>;
++			interrupts = <0x0 0x55 0x4>;
++			status = "okay";
++		};
++
++		csi_res@0x01cb0000 {
++			compatible = "allwinner,sunxi-csi";
++			reg = <0x0 0x1cb0000 0x0 0x1000>;
++			status = "okay";
++		};
++
++		vfe@0 {
++			device_type = "csi0";
++			compatible = "allwinner,sunxi-vfe";
++			interrupts = <0x0 0x54 0x4>;
++			clocks = <0x73 0x74 0x75 0x4 0x6 0x5>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x77>;
++			csi0_sensor_list = <0x0>;
++			status = "okay";
++			pinctrl-0 = <0xb0>;
++			csi0_mck = <0x30 0x4 0x1 0x0 0x0 0x1 0x0>;
++
++			dev@0 {
++				csi0_dev0_mname = "bf3703";
++				csi0_dev0_twi_addr = <0x3e>;
++				csi0_dev0_pos = "rear";
++				csi0_dev0_isp_used = <0x1>;
++				csi0_dev0_fmt = <0x0>;
++				csi0_dev0_stby_mode = <0x1>;
++				csi0_dev0_vflip = <0x0>;
++				csi0_dev0_hflip = <0x0>;
++				csi0_dev0_iovdd = "iovdd-csi";
++				csi0_dev0_iovdd_vol = <0x2ab980>;
++				csi0_dev0_avdd = "avdd-csi";
++				csi0_dev0_avdd_vol = <0x2ab980>;
++				csi0_dev0_dvdd = "dvdd-csi-18";
++				csi0_dev0_dvdd_vol = <0x1b7740>;
++				csi0_dev0_flash_used = <0x0>;
++				csi0_dev0_flash_type = <0x2>;
++				csi0_dev0_flvdd = "vdd-csi-led";
++				csi0_dev0_flvdd_vol = <0x325aa0>;
++				csi0_dev0_act_used = <0x0>;
++				csi0_dev0_act_name = "ad5820_act";
++				csi0_dev0_act_slave = <0x18>;
++				status = "okay";
++				device_type = "csi0_dev0";
++				csi0_dev0_afvdd;
++				csi0_dev0_afvdd_vol;
++				csi0_dev0_power_en;
++				csi0_dev0_reset = <0x30 0x4 0xe 0x0 0x0 0x1 0x0>;
++				csi0_dev0_pwdn = <0x30 0x4 0xf 0x0 0x0 0x1 0x0>;
++				csi0_dev0_flash_en;
++				csi0_dev0_flash_mode;
++				csi0_dev0_af_pwdn;
++			};
++
++			dev@1 {
++				csi0_dev1_mname = "gc2145";
++				csi0_dev1_twi_addr = <0x78>;
++				csi0_dev1_pos = "front";
++				csi0_dev1_isp_used = <0x1>;
++				csi0_dev1_fmt = <0x0>;
++				csi0_dev1_stby_mode = <0x1>;
++				csi0_dev1_vflip = <0x0>;
++				csi0_dev1_hflip = <0x0>;
++				csi0_dev1_iovdd = "iovdd-csi";
++				csi0_dev1_iovdd_vol = <0x2ab980>;
++				csi0_dev1_avdd = "avdd-csi";
++				csi0_dev1_avdd_vol = <0x2ab980>;
++				csi0_dev1_dvdd = "dvdd-csi-18";
++				csi0_dev1_dvdd_vol = <0x1b7740>;
++				csi0_dev1_flash_used = <0x0>;
++				csi0_dev1_flash_type = <0x2>;
++				csi0_dev1_flvdd = "vdd-csi-led";
++				csi0_dev1_flvdd_vol = <0x325aa0>;
++				csi0_dev1_act_used = <0x0>;
++				csi0_dev1_act_name = "ad5820_act";
++				csi0_dev1_act_slave = <0x18>;
++				status = "disabled";
++				device_type = "csi0_dev1";
++				csi0_dev1_afvdd;
++				csi0_dev1_afvdd_vol;
++				csi0_dev1_power_en;
++				csi0_dev1_reset = <0x30 0x4 0x10 0x0 0x0 0x1 0x0>;
++				csi0_dev1_pwdn = <0x30 0x4 0x11 0x0 0x0 0x1 0x0>;
++				csi0_dev1_flash_en;
++				csi0_dev1_flash_mode;
++				csi0_dev1_af_pwdn;
++			};
++		};
++
++		vdevice@0 {
++			compatible = "allwinner,sun50i-vdevice";
++			pinctrl-names = "default";
++			test-gpios = <0x79 0xb 0x0 0x1 0x2 0x3 0x4>;
++			status = "okay";
++			device_type = "Vdevice";
++			pinctrl-0 = <0xb8>;
++		};
++
++		ce@1c15000 {
++			compatible = "allwinner,sunxi-ce";
++			reg = <0x0 0x1c15000 0x0 0x80 0x0 0x1c15800 0x0 0x80>;
++			interrupts = <0x0 0x5e 0xff01 0x0 0x50 0xff01>;
++			clock-frequency = <0x11e1a300 0xbebc200>;
++			clocks = <0x7a 0x7b>;
++		};
++
++		deinterlace@0x01e00000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sunxi-deinterlace";
++			reg = <0x0 0x1e00000 0x0 0x77c>;
++			interrupts = <0x0 0x5d 0x4>;
++			clocks = <0x7c 0x4>;
++			status = "okay";
++			device_type = "di";
++		};
++
++		smartcard@0x01c2c400 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sunxi-scr";
++			reg = <0x0 0x1c2c400 0x0 0x100>;
++			interrupts = <0x0 0x53 0x4>;
++			clocks = <0x7d 0x7e>;
++			clock-frequency = <0x16e3600>;
++			pinctrl-names = "default";
++			pinctrl-0 = <0x7f>;
++			status = "okay";
++			device_type = "smc";
++			smc_used;
++			smc_rst;
++			smc_vppen;
++			smc_vppp;
++			smc_det;
++			smc_vccen;
++			smc_sck;
++			smc_sda;
++		};
++
++		nmi@0x01f00c00 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sunxi-nmi";
++			reg = <0x0 0x1f00c00 0x0 0x50>;
++			nmi_irq_ctrl = <0xc>;
++			nmi_irq_en = <0x40>;
++			nmi_irq_status = <0x10>;
++			nmi_irq_mask = <0x50>;
++			status = "okay";
++		};
++
++		pmu0@0 {
++			compatible = "allwinner,pmu0";
++			device_type = "pmu0";
++			pmu_batdeten = <0x1>;
++			pmu_init_chgend_rate = <0x14>;
++			pmu_init_chg_enabled = <0x1>;
++			pmu_init_adc_freq = <0x320>;
++			pmu_init_adcts_freq = <0x320>;
++			pmu_init_chg_pretime = <0x46>;
++			pmu_init_chg_csttime = <0x2d0>;
++			pmu_batt_cap_correct = <0x1>;
++			pmu_chg_end_on_en = <0x0>;
++			pmu_pwroff_vol = <0xce4>;
++			pmu_pwron_vol = <0xa28>;
++			pmu_powkey_off_delay_time = <0x0>;
++			pmu_pwrok_time = <0x40>;
++			pmu_reset_shutdown_en = <0x1>;
++			pmu_restvol_adjust_time = <0x3c>;
++			pmu_ocv_cou_adjust_time = <0x3c>;
++			pmu_vbusen_func = <0x1>;
++			pmu_reset = <0x0>;
++			pmu_IRQ_wakeup = <0x1>;
++			pmu_hot_shutdowm = <0x1>;
++			pmu_inshort = <0x0>;
++			pmu_bat_shutdown_ltf = <0xc80>;
++			pmu_bat_shutdown_htf = <0xed>;
++			status = "okay";
++			pmu_id = <0x6>;
++			pmu_twi_addr = <0x34>;
++			pmu_twi_id = <0x1>;
++			pmu_irq_id = <0x40>;
++			pmu_chg_ic_temp = <0x0>;
++			pmu_battery_rdc = <0x79>;
++			pmu_battery_cap = <0x27dc>;
++			pmu_runtime_chgcur = <0x708>;
++			pmu_suspend_chgcur = <0x5dc>;
++			pmu_shutdown_chgcur = <0x5dc>;
++			pmu_init_chgvol = <0x1068>;
++			pmu_ac_vol = <0xfa0>;
++			pmu_ac_cur = <0xdac>;
++			pmu_usbpc_vol = <0x1130>;
++			pmu_usbpc_cur = <0x1f4>;
++			pmu_battery_warning_level1 = <0xf>;
++			pmu_battery_warning_level2 = <0x0>;
++			pmu_chgled_func = <0x1>;
++			pmu_chgled_type = <0x0>;
++			pmu_bat_para1 = <0x0>;
++			pmu_bat_para2 = <0x0>;
++			pmu_bat_para3 = <0x0>;
++			pmu_bat_para4 = <0x0>;
++			pmu_bat_para5 = <0x0>;
++			pmu_bat_para6 = <0x0>;
++			pmu_bat_para7 = <0x1>;
++			pmu_bat_para8 = <0x1>;
++			pmu_bat_para9 = <0x2>;
++			pmu_bat_para10 = <0x2>;
++			pmu_bat_para11 = <0x3>;
++			pmu_bat_para12 = <0xa>;
++			pmu_bat_para13 = <0x12>;
++			pmu_bat_para14 = <0x1e>;
++			pmu_bat_para15 = <0x2c>;
++			pmu_bat_para16 = <0x32>;
++			pmu_bat_para17 = <0x36>;
++			pmu_bat_para18 = <0x3a>;
++			pmu_bat_para19 = <0x3d>;
++			pmu_bat_para20 = <0x42>;
++			pmu_bat_para21 = <0x48>;
++			pmu_bat_para22 = <0x4d>;
++			pmu_bat_para23 = <0x52>;
++			pmu_bat_para24 = <0x55>;
++			pmu_bat_para25 = <0x5b>;
++			pmu_bat_para26 = <0x60>;
++			pmu_bat_para27 = <0x62>;
++			pmu_bat_para28 = <0x64>;
++			pmu_bat_para29 = <0x64>;
++			pmu_bat_para30 = <0x64>;
++			pmu_bat_para31 = <0x64>;
++			pmu_bat_para32 = <0x64>;
++			pmu_bat_charge_ltf = <0x8d5>;
++			pmu_bat_charge_htf = <0x184>;
++			pmu_powkey_off_time = <0x1770>;
++			pmu_powkey_off_func = <0x0>;
++			pmu_powkey_off_en = <0x1>;
++			pmu_powkey_long_time = <0x5dc>;
++			pmu_powkey_on_time = <0x3e8>;
++			power_start = <0x0>;
++		};
++
++		regu@0 {
++			compatible = "allwinner,pmu0_regu";
++			regulator_count = <0x17>;
++			status = "okay";
++			device_type = "pmu0_regu";
++			regulator1 = "axp81x_dcdc1 none vcc-nand vcc-emmc vcc-sdc vcc-usb-30 vcc-io vcc-pd";
++			regulator2 = "axp81x_dcdc2 none vdd-cpua";
++			regulator3 = "axp81x_dcdc3 none";
++			regulator4 = "axp81x_dcdc4 none";
++			regulator5 = "axp81x_dcdc5 none vcc-dram";
++			regulator6 = "axp81x_dcdc6 none vdd-sys";
++			regulator7 = "axp81x_dcdc7 none";
++			regulator8 = "axp81x_rtc none";
++			regulator9 = "axp81x_aldo1 none vdd-csi-led iovdd-csi vcc-pe";
++			regulator10 = "axp81x_aldo2 none vcc-pl";
++			regulator11 = "axp81x_aldo3 none vcc-avcc vcc-pll";
++			regulator12 = "axp81x_dldo1 none vcc-hdmi-33 vcc-dsi-33 vcc-sensor";
++			regulator13 = "axp81x_dldo2 none vcc-mipi";
++			regulator14 = "axp81x_dldo3 none avdd-csi";
++			regulator15 = "axp81x_dldo4 none vcc-wifi-io";
++			regulator16 = "axp81x_eldo1 none vcc-cpvdd vcc-pc vcc-pg";
++			regulator17 = "axp81x_eldo2 none vcc-lcd-0 hall-vcc-18";
++			regulator18 = "axp81x_eldo3 none dvdd-csi-18";
++			regulator19 = "axp81x_fldo1 none vcc-hsic-12";
++			regulator20 = "axp81x_fldo2 none vdd-cpus";
++			regulator21 = "axp81x_gpio0ldo none vcc-ctp";
++			regulator22 = "axp81x_gpio1ldo none";
++			regulator23 = "axp81x_dc1sw none vcc-lvds";
++		};
++
++		nand0@01c03000 {
++			compatible = "allwinner,sun50i-nand";
++			device_type = "nand0";
++			reg = <0x0 0x1c03000 0x0 0x1000>;
++			interrupts = <0x0 0x46 0x4>;
++			clocks = <0x4 0x80>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x83>;
++			nand0_regulator1 = "vcc-nand";
++			nand0_regulator2 = "none";
++			nand0_cache_level = <0x55aaaa55>;
++			nand0_flush_cache_num = <0x55aaaa55>;
++			nand0_capacity_level = <0x55aaaa55>;
++			nand0_id_number_ctl = <0x55aaaa55>;
++			nand0_print_level = <0x55aaaa55>;
++			nand0_p0 = <0x55aaaa55>;
++			nand0_p1 = <0x55aaaa55>;
++			nand0_p2 = <0x55aaaa55>;
++			nand0_p3 = <0x55aaaa55>;
++			status = "okay";
++			nand0_support_2ch = <0x0>;
++			pinctrl-0 = <0xaa 0xab>;
++		};
++
++		thermal_sensor {
++			compatible = "allwinner,thermal_sensor";
++			reg = <0x0 0x1c25000 0x0 0x400>;
++			interrupts = <0x0 0x1f 0x0>;
++			clocks = <0x6 0x84>;
++			sensor_num = <0x3>;
++			shut_temp = <0x78>;
++			status = "okay";
++
++			combine0 {
++				#thermal-sensor-cells = <0x1>;
++				combine_cnt = <0x3>;
++				combine_type = "max";
++				combine_chn = <0x0 0x1 0x2>;
++				linux,phandle = <0x85>;
++				phandle = <0x85>;
++			};
++		};
++
++		cpu_budget_cool {
++			compatible = "allwinner,budget_cooling";
++			#cooling-cells = <0x2>;
++			status = "okay";
++			state_cnt = <0xa>;
++			cluster_num = <0x1>;
++			state0 = <0x119400 0x4>;
++			state1 = <0x10d880 0x4>;
++			state2 = <0x101d00 0x4>;
++			state3 = <0xf6180 0x4>;
++			state4 = <0xea600 0x4>;
++			state5 = <0xdea80 0x4>;
++			state6 = <0xc7380 0x4>;
++			state7 = <0x9e340 0x4>;
++			state8 = <0x9e340 0x2>;
++			state9 = <0x9e340 0x1>;
++			linux,phandle = <0x87>;
++			phandle = <0x87>;
++		};
++
++		gpu_cooling {
++			compatible = "allwinner,gpu_cooling";
++			reg = <0x0 0x0 0x0 0x0>;
++			#cooling-cells = <0x2>;
++			status = "okay";
++			state_cnt = <0x3>;
++			state0 = <0x0>;
++			state1 = <0x168>;
++			state2 = <0x90>;
++			linux,phandle = <0x8c>;
++			phandle = <0x8c>;
++		};
++
++		thermal-zones {
++
++			soc_thermal {
++				polling-delay-passive = <0x1f4>;
++				polling-delay = <0x7d0>;
++				thermal-sensors = <0x85 0x0>;
++
++				trips {
++
++					t0 {
++						temperature = <0x50>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x86>;
++						phandle = <0x86>;
++					};
++
++					t1 {
++						temperature = <0x55>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x88>;
++						phandle = <0x88>;
++					};
++
++					t2 {
++						temperature = <0x5a>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x89>;
++						phandle = <0x89>;
++					};
++
++					t3 {
++						temperature = <0x5f>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x8a>;
++						phandle = <0x8a>;
++					};
++
++					t4 {
++						temperature = <0x55>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x8b>;
++						phandle = <0x8b>;
++					};
++
++					t5 {
++						temperature = <0x5f>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x8d>;
++						phandle = <0x8d>;
++					};
++
++					t6 {
++						temperature = <0x6e>;
++						type = "critical";
++						hysteresis = <0x0>;
++					};
++				};
++
++				cooling-maps {
++
++					bind0 {
++						contribution = <0x0>;
++						trip = <0x86>;
++						cooling-device = <0x87 0x1 0x1>;
++					};
++
++					bind1 {
++						contribution = <0x0>;
++						trip = <0x88>;
++						cooling-device = <0x87 0x2 0x2>;
++					};
++
++					bind2 {
++						contribution = <0x0>;
++						trip = <0x89>;
++						cooling-device = <0x87 0x3 0x6>;
++					};
++
++					bind3 {
++						contribution = <0x0>;
++						trip = <0x8a>;
++						cooling-device = <0x87 0x7 0x9>;
++					};
++
++					bind4 {
++						contribution = <0x0>;
++						trip = <0x8b>;
++						cooling-device = <0x8c 0x1 0x1>;
++					};
++
++					bind5 {
++						contribution = <0x0>;
++						trip = <0x8d>;
++						cooling-device = <0x8c 0x2 0x2>;
++					};
++				};
++			};
++		};
++
++		keyboard {
++			compatible = "allwinner,keyboard_2000mv";
++			reg = <0x0 0x1c21800 0x0 0x400>;
++			interrupts = <0x0 0x1e 0x0>;
++			status = "okay";
++			key_cnt = <0x5>;
++			key1 = <0xf0 0x73>;
++			key2 = <0x1f4 0x72>;
++			key3 = <0x2bc 0x8b>;
++			key4 = <0x37a 0x1c>;
++			key5 = <0x7d0 0x66>;
++		};
++
++		eth@01c30000 {
++			compatible = "allwinner,sunxi-gmac";
++			reg = <0x0 0x1c30000 0x0 0x40000 0x0 0x1c00000 0x0 0x30>;
++			pinctrl-names = "default";
++			pinctrl-0 = <0x8e>;
++			interrupts = <0x0 0x52 0x4>;
++			interrupt-names = "gmacirq";
++			clocks = <0x8f>;
++			clock-names = "gmac";
++			phy-mode = "rgmii";
++			tx-delay = <0x7>;
++			rx-delay = <0x1f>;
++			gmac_power1 = "axp81x_dldo2:2500000";
++			gmac_power2 = "axp81x_eldo2:1800000";
++			gmac_power3 = "axp81x_fldo1:1200000";
++			status = "disable";
++		};
++
++		product {
++			device_type = "product";
++			version = "100";
++			machine = "evb";
++		};
++
++		platform {
++			device_type = "platform";
++			eraseflag = <0x1>;
++		};
++
++		target {
++			device_type = "target";
++			boot_clock = <0x3f0>;
++			storage_type = <0xffffffff>;
++			burn_key = <0x0>;
++		};
++
++		power_sply {
++			device_type = "power_sply";
++			dcdc1_vol = <0xf4f24>;
++			dcdc2_vol = <0xf468c>;
++			dcdc6_vol = <0xf468c>;
++			aldo1_vol = <0xaf0>;
++			aldo2_vol = <0xf4948>;
++			aldo3_vol = <0xf4df8>;
++			dldo1_vol = <0xce4>;
++			dldo2_vol = <0x9c4>;
++			dldo3_vol = <0xaf0>;
++			dldo4_vol = <0xf4f24>;
++			eldo1_vol = <0xf4948>;
++			eldo2_vol = <0x708>;
++			eldo3_vol = <0x708>;
++			fldo1_vol = <0x4b0>;
++			fldo2_vol = <0xf468c>;
++			gpio0_vol = <0xf4e5c>;
++		};
++
++		card_boot {
++			device_type = "card_boot";
++			logical_start = <0xa000>;
++			sprite_gpio0;
++		};
++
++		pm_para {
++			device_type = "pm_para";
++			standby_mode = <0x1>;
++		};
++
++		card0_boot_para {
++			device_type = "card0_boot_para";
++			card_ctrl = <0x0>;
++			card_high_speed = <0x1>;
++			card_line = <0x4>;
++			pinctrl-0 = <0x99>;
++		};
++
++		card2_boot_para {
++			device_type = "card2_boot_para";
++			sdc_io_1v8 = <0x1>;
++			card_ctrl = <0x2>;
++			card_high_speed = <0x1>;
++			card_line = <0x8>;
++			pinctrl-0 = <0x9a>;
++			sdc_ex_dly_used = <0x2>;
++			tm4_smx_fx_0 = <0x0>;
++			tm4_smx_fx_1 = <0x0>;
++			tm4_smx_fx_2 = <0x2fffff>;
++			tm4_smx_fx_3 = <0x0>;
++			tm4_smx_fx_4 = <0xdffff>;
++			tm4_smx_fx_5 = <0x0>;
++			tm4_smx_fx_6 = <0xd2fffff>;
++			tm4_smx_fx_7 = <0xb2d>;
++			tm4_smx_fx_8 = <0x0>;
++			tm4_smx_fx_9 = <0x0>;
++		};
++
++		twi_para {
++			device_type = "twi_para";
++			twi_port = <0x0>;
++			pinctrl-0 = <0x9b>;
++		};
++
++		uart_para {
++			device_type = "uart_para";
++			uart_debug_port = <0x0>;
++			pinctrl-0 = <0x9c>;
++		};
++
++		jtag_para {
++			device_type = "jtag_para";
++			jtag_enable = <0x0>;
++			pinctrl-0 = <0x9d>;
++		};
++
++		clock {
++			device_type = "clock";
++			pll4 = <0x12c>;
++			pll6 = <0x258>;
++			pll8 = <0x168>;
++			pll9 = <0x129>;
++			pll10 = <0x108>;
++		};
++
++		gmac_para {
++			device_type = "gmac_para";
++			gmac_used = <0x0>;
++			pinctrl-0 = <0x9e>;
++		};
++
++		rtp_para {
++			device_type = "rtp_para";
++			rtp_used = <0x0>;
++			rtp_screen_size = <0x5>;
++			rtp_regidity_level = <0x5>;
++			rtp_press_threshold_enable = <0x0>;
++			rtp_press_threshold = <0x1f40>;
++			rtp_sensitive_level = <0xf>;
++			rtp_exchange_x_y_flag = <0x0>;
++		};
++
++		ctp {
++			device_type = "ctp";
++			compatible = "allwinner,sun50i-ctp-para";
++			status = "disabled";
++			ctp_name = "gt9271_D116";
++			ctp_twi_id = <0x0>;
++			ctp_twi_addr = <0x40>;
++			ctp_screen_max_x = <0x556>;
++			ctp_screen_max_y = <0x300>;
++			ctp_revert_x_flag = <0x0>;
++			ctp_revert_y_flag = <0x0>;
++			ctp_exchange_x_y_flag = <0x0>;
++			ctp_int_port = <0x30 0x7 0x4 0x6 0xffffffff 0xffffffff 0xffffffff>;
++			ctp_wakeup = <0x30 0x7 0x8 0x1 0xffffffff 0xffffffff 0x1>;
++			ctp_power_ldo_vol = <0xce4>;
++			ctp_power_io;
++		};
++
++		ctp_list {
++			device_type = "ctp_list";
++			compatible = "allwinner,sun50i-ctp-list";
++			status = "okay";
++			gslX680new = <0x1>;
++			gt9xx_ts = <0x0>;
++			gt9xxf_ts = <0x1>;
++			gt9xxnew_ts = <0x0>;
++			gt82x = <0x1>;
++			zet622x = <0x1>;
++			aw5306_ts = <0x1>;
++		};
++
++		tkey_para {
++			device_type = "tkey_para";
++			tkey_used = <0x0>;
++			tkey_twi_id;
++			tkey_twi_addr;
++			tkey_int;
++		};
++
++		motor_para {
++			device_type = "motor_para";
++			motor_used = <0x0>;
++			motor_shake = <0x31 0xfffe 0x3 0x1 0xffffffff 0xffffffff 0x1>;
++		};
++
++		tvout_para {
++			device_type = "tvout_para";
++			tvout_used;
++			tvout_channel_num;
++			tv_en;
++		};
++
++		tvin_para {
++			device_type = "tvin_para";
++			tvin_used;
++			tvin_channel_num;
++		};
++
++		serial_feature {
++			device_type = "serial_feature";
++			sn_filename = "sn.txt";
++		};
++
++		gsensor {
++			device_type = "gsensor";
++			compatible = "allwinner,sun50i-gsensor-para";
++			status = "disabled";
++			gsensor_twi_id = <0x1>;
++			gsensor_twi_addr = <0x1d>;
++			gsensor_vcc_io = "vcc-sensor";
++			gsensor_vcc_io_val = <0xce4>;
++			gsensor_int1 = <0x30 0x7 0x5 0x6 0x1 0xffffffff 0xffffffff>;
++			gsensor_int2 = <0x30 0x7 0x6 0x6 0x1 0xffffffff 0xffffffff>;
++		};
++
++		gsensor_list {
++			device_type = "gsensor_list";
++			compatible = "allwinner,sun50i-gsensor-list-para";
++			gsensor_list__used = <0x0>;
++			lsm9ds0_acc_mag = <0x1>;
++			bma250 = <0x1>;
++			mma8452 = <0x1>;
++			mma7660 = <0x1>;
++			mma865x = <0x1>;
++			afa750 = <0x1>;
++			lis3de_acc = <0x1>;
++			lis3dh_acc = <0x1>;
++			kxtik = <0x1>;
++			dmard10 = <0x0>;
++			dmard06 = <0x1>;
++			mxc622x = <0x1>;
++			fxos8700 = <0x1>;
++			lsm303d = <0x0>;
++			sc7a30 = <0x1>;
++		};
++
++		3g_para {
++			device_type = "3g_para";
++			3g_used = <0x0>;
++			3g_usbc_num = <0x2>;
++			3g_uart_num = <0x0>;
++			bb_vbat = <0x79 0xb 0x3 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_host_wake = <0x79 0xc 0x0 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_on = <0x79 0xc 0x1 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_pwr_on = <0x79 0xc 0x3 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_wake = <0x79 0xc 0x4 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_rf_dis = <0x79 0xc 0x5 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_rst = <0x79 0xc 0x6 0x1 0xffffffff 0xffffffff 0x0>;
++			3g_int;
++		};
++
++		gyroscopesensor {
++			device_type = "gyroscopesensor";
++			compatible = "allwinner,sun50i-gyr_sensors-para";
++			status = "disabled";
++			gy_twi_id = <0x2>;
++			gy_twi_addr = <0x6a>;
++			gy_int1 = <0x30 0x0 0xa 0x6 0x1 0xffffffff 0xffffffff>;
++			gy_int2;
++		};
++
++		gy_list {
++			device_type = "gy_list";
++			compatible = "allwinner,sun50i-gyr_sensors-list-para";
++			status = "disabled";
++			lsm9ds0_gyr = <0x1>;
++			l3gd20_gyr = <0x0>;
++			bmg160_gyr = <0x1>;
++		};
++
++		lightsensor {
++			device_type = "lightsensor";
++			compatible = "allwinner,sun50i-lsensors-para";
++			status = "disabled";
++			ls_twi_id = <0x2>;
++			ls_twi_addr = <0x23>;
++			ls_int = <0x30 0x0 0xc 0x6 0x1 0xffffffff 0xffffffff>;
++		};
++
++		ls_list {
++			device_type = "ls_list";
++			compatible = "allwinner,sun50i-lsensors-list-para";
++			status = "disabled";
++			ltr_501als = <0x1>;
++			jsa1212 = <0x0>;
++			jsa1127 = <0x1>;
++			stk3x1x = <0x0>;
++		};
++
++		compasssensor {
++			device_type = "compasssensor";
++			compatible = "allwinner,sun50i-compass-para";
++			status = "disabled";
++			compass_twi_id = <0x2>;
++			compass_twi_addr = <0xd>;
++			compass_int = <0x30 0x0 0xb 0x6 0x1 0xffffffff 0xffffffff>;
++		};
++
++		compass_list {
++			device_type = "compass_list";
++			compatible = "allwinner,sun50i-compass-list-para";
++			status = "disabled";
++			lsm9ds0 = <0x1>;
++			lsm303d = <0x0>;
++		};
++
++		recovery_key {
++			device_type = "recovery_key";
++			key_max = <0xa>;
++			key_min = <0xa>;
++		};
++
++		fastboot_key {
++			device_type = "fastboot_key";
++			key_max = <0x4>;
++			key_min = <0x4>;
++		};
++	};
++
++	aliases {
++		serial0 = "/soc@01c00000/uart@01c28000";
++		serial1 = "/soc@01c00000/uart@01c28400";
++		serial2 = "/soc@01c00000/uart@01c28800";
++		serial3 = "/soc@01c00000/uart@01c28c00";
++		serial4 = "/soc@01c00000/uart@01c29000";
++		twi0 = "/soc@01c00000/twi@0x01c2ac00";
++		twi1 = "/soc@01c00000/twi@0x01c2b000";
++		twi2 = "/soc@01c00000/twi@0x01c2b400";
++		spi0 = "/soc@01c00000/spi@01c68000";
++		spi1 = "/soc@01c00000/spi@01c69000";
++		global_timer0 = "/soc@01c00000/timer@1c20c00";
++		cci0 = "/soc@01c00000/cci@0x01cb3000";
++		csi_res0 = "/soc@01c00000/csi_res@0x01cb0000";
++		vfe0 = "/soc@01c00000/vfe@0";
++		mmc0 = "/soc@01c00000/sdmmc@01c0f000";
++		mmc2 = "/soc@01c00000/sdmmc@01C11000";
++		nand0 = "/soc@01c00000/nand0@01c03000";
++		disp = "/soc@01c00000/disp@01000000";
++		lcd0 = "/soc@01c00000/lcd0@01c0c000";
++		hdmi = "/soc@01c00000/hdmi@01ee0000";
++		pwm = "/soc@01c00000/pwm@01c21400";
++		pwm0 = "/soc@01c00000/pwm0@01c21400";
++		s_pwm = "/soc@01c00000/s_pwm@1f03800";
++		spwm0 = "/soc@01c00000/spwm0@0x01f03800";
++		boot_disp = "/soc@01c00000/boot_disp";
++	};
++
++	chosen {
++		bootargs = "earlyprintk=sunxi-uart,0x01c28000 loglevel=8 initcall_debug=1 console=ttyS0 init=/init";
++		linux,initrd-start = <0x0 0x0>;
++		linux,initrd-end = <0x0 0x0>;
++	};
++
++	cpus {
++		#address-cells = <0x2>;
++		#size-cells = <0x0>;
++
++		cpu@0 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x0>;
++			enable-method = "psci";
++			cpufreq_tbl = <0x75300 0x927c0 0xafc80 0xc7380 0xdea80 0xea600 0xf6180 0x101d00 0x10d880 0x119400 0x124f80 0x148200>;
++			clock-latency = <0x1e8480>;
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		cpu@1 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x1>;
++			enable-method = "psci";
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		cpu@2 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x2>;
++			enable-method = "psci";
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		cpu@3 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x3>;
++			enable-method = "psci";
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		idle-states {
++			entry-method = "arm,psci";
++
++			cpu-sleep-0 {
++				compatible = "arm,idle-state";
++				arm,psci-suspend-param = <0x10000>;
++				entry-latency-us = <0x28>;
++				exit-latency-us = <0x64>;
++				min-residency-us = <0x96>;
++				linux,phandle = <0x90>;
++				phandle = <0x90>;
++			};
++
++			cluster-sleep-0 {
++				compatible = "arm,idle-state";
++				arm,psci-suspend-param = <0x1010000>;
++				entry-latency-us = <0x1f4>;
++				exit-latency-us = <0x3e8>;
++				min-residency-us = <0x9c4>;
++				linux,phandle = <0x91>;
++				phandle = <0x91>;
++			};
++
++			sys-sleep-0 {
++				compatible = "arm,idle-state";
++				arm,psci-suspend-param = <0x2010000>;
++				entry-latency-us = <0x3e8>;
++				exit-latency-us = <0x7d0>;
++				min-residency-us = <0x1194>;
++				linux,phandle = <0x92>;
++				phandle = <0x92>;
++			};
++		};
++	};
++
++	psci {
++		compatible = "arm,psci-0.2";
++		method = "smc";
++		psci_version = <0x84000000>;
++		cpu_suspend = <0xc4000001>;
++		cpu_off = <0x84000002>;
++		cpu_on = <0xc4000003>;
++		affinity_info = <0xc4000004>;
++		migrate = <0xc4000005>;
++		migrate_info_type = <0x84000006>;
++		migrate_info_up_cpu = <0xc4000007>;
++		system_off = <0x84000008>;
++		system_reset = <0x84000009>;
++	};
++
++	n_brom {
++		compatible = "allwinner,n-brom";
++		reg = <0x0 0x0 0x0 0xc000>;
++	};
++
++	s_brom {
++		compatible = "allwinner,s-brom";
++		reg = <0x0 0x0 0x0 0x10000>;
++	};
++
++	sram_a1 {
++		compatible = "allwinner,sram_a1";
++		reg = <0x0 0x10000 0x0 0x8000>;
++	};
++
++	sram_a2 {
++		compatible = "allwinner,sram_a2";
++		reg = <0x0 0x40000 0x0 0x14000>;
++	};
++
++	prcm {
++		compatible = "allwinner,prcm";
++		reg = <0x0 0x1f01400 0x0 0x400>;
++	};
++
++	cpuscfg {
++		compatible = "allwinner,cpuscfg";
++		reg = <0x0 0x1f01c00 0x0 0x400>;
++	};
++
++	ion {
++		compatible = "allwinner,sunxi-ion";
++
++		system_contig {
++			type = <0x1>;
++		};
++
++		cma {
++			type = <0x4>;
++		};
++
++		system {
++			type = <0x0>;
++		};
++	};
++
++	dram {
++		compatible = "allwinner,dram";
++		clocks = <0x93 0x94>;
++		clock-names = "pll_ddr0", "pll_ddr1";
++		dram_clk = <0x228>;
++		dram_type = <0x3>;
++		dram_zq = <0x3b3bbb>;
++		dram_odt_en = <0x1>;
++		dram_para1 = <0x10e410e4>;
++		dram_para2 = <0x1000>;
++		dram_mr0 = <0x1840>;
++		dram_mr1 = <0x40>;
++		dram_mr2 = <0x18>;
++		dram_mr3 = <0x2>;
++		dram_tpr0 = <0x4a2195>;
++		dram_tpr1 = <0x2424190>;
++		dram_tpr2 = <0x8b060>;
++		dram_tpr3 = <0x4b005dc>;
++		dram_tpr4 = <0x0>;
++		dram_tpr5 = <0x0>;
++		dram_tpr6 = <0x0>;
++		dram_tpr7 = <0x0>;
++		dram_tpr8 = <0x0>;
++		dram_tpr9 = <0x0>;
++		dram_tpr10 = <0x8808>;
++		dram_tpr11 = <0x20250000>;
++		dram_tpr12 = <0x0>;
++		dram_tpr13 = <0x4000800>;
++		device_type = "dram";
++	};
++
++	memory@40000000 {
++		device_type = "memory";
++		reg = <0x0 0x40000000 0x0 0x40000000>;
++	};
++
++	interrupt-controller@1c81000 {
++		compatible = "arm,cortex-a15-gic", "arm,cortex-a9-gic";
++		#interrupt-cells = <0x3>;
++		#address-cells = <0x0>;
++		device_type = "gic";
++		interrupt-controller;
++		reg = <0x0 0x1c81000 0x0 0x1000 0x0 0x1c82000 0x0 0x2000 0x0 0x1c84000 0x0 0x2000 0x0 0x1c86000 0x0 0x2000>;
++		interrupts = <0x1 0x9 0xf04>;
++		linux,phandle = <0x1>;
++		phandle = <0x1>;
++	};
++
++	sunxi-chipid@1c14200 {
++		compatible = "allwinner,sunxi-chipid";
++		device_type = "chipid";
++		reg = <0x0 0x1c14200 0x0 0x200>;
++	};
++
++	timer {
++		compatible = "arm,armv8-timer";
++		interrupts = <0x1 0xd 0xff01 0x1 0xe 0xff01 0x1 0xb 0xff01 0x1 0xa 0xff01>;
++		clock-frequency = <0x16e3600>;
++	};
++
++	pmu {
++		compatible = "arm,armv8-pmuv3";
++		interrupts = <0x0 0x78 0x4 0x0 0x79 0x4 0x0 0x7a 0x4 0x0 0x7b 0x4>;
++	};
++
++	dvfs_table {
++		compatible = "allwinner,dvfs_table";
++		max_freq = <0x44aa2000>;
++		min_freq = <0x1c9c3800>;
++		lv_count = <0x8>;
++		lv1_freq = <0x44aa2000>;
++		lv1_volt = <0x514>;
++		lv2_freq = <0x41cdb400>;
++		lv2_volt = <0x4ec>;
++		lv3_freq = <0x3ef14800>;
++		lv3_volt = <0x4d8>;
++		lv4_freq = <0x3c14dc00>;
++		lv4_volt = <0x4b0>;
++		lv5_freq = <0x39387000>;
++		lv5_volt = <0x488>;
++		lv6_freq = <0x365c0400>;
++		lv6_volt = <0x460>;
++		lv7_freq = <0x30a32c00>;
++		lv7_volt = <0x438>;
++		lv8_freq = <0x269fb200>;
++		lv8_volt = <0x410>;
++		device_type = "dvfs_table";
++	};
++
++	dramfreq {
++		compatible = "allwinner,sunxi-dramfreq";
++		reg = <0x0 0x1c62000 0x0 0x1000 0x0 0x1c63000 0x0 0x1000 0x0 0x1c20000 0x0 0x800>;
++		clocks = <0x93 0x94 0x95>;
++		status = "okay";
++	};
++
++	uboot {
++	};
++
++	gpu@0x01c40000 {
++		compatible = "arm,mali-400", "arm,mali-utgard";
++		reg = <0x0 0x1c40000 0x0 0x10000>;
++		interrupts = <0x0 0x61 0x4 0x0 0x62 0x4 0x0 0x63 0x4 0x0 0x64 0x4 0x0 0x66 0x4 0x0 0x67 0x4>;
++		interrupt-names = "IRQGP", "IRQGPMMU", "IRQPP0", "IRQPPMMU0", "IRQPP1", "IRQPPMMU1";
++		clocks = <0x96 0x97>;
++		device_type = "gpu_mali400_0";
++		normal_freq = <0x1c8>;
++		scene_ctrl_status = <0x0>;
++		temp_ctrl_status = <0x1>;
++	};
++
++	wlan {
++		compatible = "allwinner,sunxi-wlan";
++		wlan_io_regulator = "vcc-wifi-io";
++		wlan_busnum = <0x1>;
++		status = "okay";
++		device_type = "wlan";
++		clocks;
++		wlan_power;
++		wlan_regon = <0x79 0xb 0x2 0x1 0xffffffff 0xffffffff 0x0>;
++		wlan_hostwake = <0x79 0xb 0x3 0x6 0xffffffff 0xffffffff 0x0>;
++	};
++
++	bt {
++		compatible = "allwinner,sunxi-bt";
++		bt_io_regulator = "vcc-wifi-io";
++		status = "okay";
++		device_type = "bt";
++		clocks;
++		bt_power;
++		bt_rst_n = <0x79 0xb 0x4 0x1 0xffffffff 0xffffffff 0x0>;
++	};
++
++	btlpm {
++		compatible = "allwinner,sunxi-btlpm";
++		uart_index = <0x1>;
++		status = "okay";
++		device_type = "btlpm";
++		bt_wake = <0x79 0xb 0x6 0x1 0xffffffff 0xffffffff 0x1>;
++		bt_hostwake = <0x79 0xb 0x5 0x6 0xffffffff 0xffffffff 0x0>;
++	};
++
++	hall {
++		compatible = "allwinner,hall";
++		hall_pos = <0x0>;
++		status = "okay";
++		device_type = "hall";
++		hall_power = "hall-vcc-18";
++		hall_power_vol = <0x708>;
++		hall_gpio = <0x79 0xb 0xc 0x6 0xffffffff 0xffffffff 0x0>;
++	};
++};
+diff --git a/arch/arm64/boot/dts/sun50iw1p1-pine64-plus.dts b/arch/arm64/boot/dts/sun50iw1p1-pine64-plus.dts
+new file mode 100644
+index 00000000..0675b205
+--- /dev/null
++++ b/arch/arm64/boot/dts/sun50iw1p1-pine64-plus.dts
+@@ -0,0 +1,3433 @@
++/dts-v1/;
++
++/memreserve/	0x0000000045000000 0x0000000000200000;
++/memreserve/	0x0000000041010000 0x0000000000010000;
++/memreserve/	0x0000000041020000 0x0000000000000800;
++/memreserve/	0x0000000040100000 0x0000000000004000;
++/memreserve/	0x0000000040104000 0x0000000000001000;
++/memreserve/	0x0000000040105000 0x0000000000001000;
++/ {
++	model = "Pine64+";
++	compatible = "pine64,pine64-plus";
++	interrupt-parent = <0x1>;
++	#address-cells = <0x2>;
++	#size-cells = <0x2>;
++
++	leds {
++		compatible = "gpio-leds";
++		pinctrl-names = "default";
++		pinctrl-0 = <&status_led>;
++		status {
++			label = "system_status";
++			gpios = <0x79 0xb 7 0x1 0xffffffff 0xffffffff 0x0>; /* PL7 */
++			linux,default-trigger = "heartbeat";
++		};
++	};
++
++	clocks {
++		compatible = "allwinner,sunxi-clk-init";
++		device_type = "clocks";
++		#address-cells = <0x2>;
++		#size-cells = <0x2>;
++		ranges;
++		reg = <0x0 0x1c20000 0x0 0x320 0x0 0x1f01400 0x0 0xb0 0x0 0x1f00060 0x0 0x4>;
++
++		losc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-clock";
++			clock-frequency = <0x8000>;
++			clock-output-names = "losc";
++			linux,phandle = <0xc>;
++			phandle = <0xc>;
++		};
++
++		iosc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-clock";
++			clock-frequency = <0xf42400>;
++			clock-output-names = "iosc";
++			linux,phandle = <0xd>;
++			phandle = <0xd>;
++		};
++
++		hosc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-clock";
++			clock-frequency = <0x16e3600>;
++			clock-output-names = "hosc";
++			linux,phandle = <0x6>;
++			phandle = <0x6>;
++		};
++
++		pll_cpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_cpu";
++		};
++
++		pll_audio {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x1770000>;
++			clock-output-names = "pll_audio";
++			linux,phandle = <0x2>;
++			phandle = <0x2>;
++		};
++
++		pll_video0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "pll_video0";
++			linux,phandle = <0x3>;
++			phandle = <0x3>;
++		};
++
++		pll_ve {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_ve";
++			linux,phandle = <0x16>;
++			phandle = <0x16>;
++		};
++
++		pll_ddr0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_ddr0";
++			linux,phandle = <0x93>;
++			phandle = <0x93>;
++		};
++
++		pll_periph0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_periph0";
++			linux,phandle = <0x4>;
++			phandle = <0x4>;
++		};
++
++		pll_periph1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_periph1";
++			linux,phandle = <0x5>;
++			phandle = <0x5>;
++		};
++
++		pll_video1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "pll_video1";
++		};
++
++		pll_gpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_gpu";
++			linux,phandle = <0x96>;
++			phandle = <0x96>;
++		};
++
++		pll_mipi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_mipi";
++			linux,phandle = <0x8>;
++			phandle = <0x8>;
++		};
++
++		pll_hsic {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_hsic";
++			linux,phandle = <0x3a>;
++			phandle = <0x3a>;
++		};
++
++		pll_de {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "pll_de";
++			linux,phandle = <0x7>;
++			phandle = <0x7>;
++		};
++
++		pll_ddr1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_ddr1";
++			linux,phandle = <0x94>;
++			phandle = <0x94>;
++		};
++
++		pll_audiox8 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x2>;
++			clock-mult = <0x8>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_audiox8";
++		};
++
++		pll_audiox4 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x2>;
++			clock-mult = <0x8>;
++			clock-div = <0x2>;
++			clock-output-names = "pll_audiox4";
++			linux,phandle = <0x3c>;
++			phandle = <0x3c>;
++		};
++
++		pll_audiox2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x2>;
++			clock-mult = <0x8>;
++			clock-div = <0x4>;
++			clock-output-names = "pll_audiox2";
++		};
++
++		pll_video0x2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x3>;
++			clock-mult = <0x2>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_video0x2";
++		};
++
++		pll_periph0x2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x4>;
++			clock-mult = <0x2>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_periph0x2";
++			linux,phandle = <0x7b>;
++			phandle = <0x7b>;
++		};
++
++		pll_periph1x2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x5>;
++			clock-mult = <0x2>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_periph1x2";
++			linux,phandle = <0x5a>;
++			phandle = <0x5a>;
++		};
++
++		pll_periph0d2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x4>;
++			clock-mult = <0x1>;
++			clock-div = <0x2>;
++			clock-output-names = "pll_periph0d2";
++		};
++
++		hoscd2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x6>;
++			clock-mult = <0x1>;
++			clock-div = <0x2>;
++			clock-output-names = "hoscd2";
++		};
++
++		cpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "cpu";
++		};
++
++		cpuapb {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "cpuapb";
++		};
++
++		axi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "axi";
++		};
++
++		pll_periphahb0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "pll_periphahb0";
++		};
++
++		ahb1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ahb1";
++			linux,phandle = <0x95>;
++			phandle = <0x95>;
++		};
++
++		apb1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "apb1";
++		};
++
++		apb2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "apb2";
++			linux,phandle = <0x7e>;
++			phandle = <0x7e>;
++		};
++
++		ahb2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ahb2";
++		};
++
++		ths {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ths";
++			linux,phandle = <0x84>;
++			phandle = <0x84>;
++		};
++
++		nand {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "nand";
++			linux,phandle = <0x80>;
++			phandle = <0x80>;
++		};
++
++		sdmmc0_mod {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc0_mod";
++			linux,phandle = <0x60>;
++			phandle = <0x60>;
++		};
++
++		sdmmc0_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc0_bus";
++			linux,phandle = <0x61>;
++			phandle = <0x61>;
++		};
++
++		sdmmc0_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc0_rst";
++			linux,phandle = <0x62>;
++			phandle = <0x62>;
++		};
++
++		sdmmc1_mod {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc1_mod";
++			linux,phandle = <0x65>;
++			phandle = <0x65>;
++		};
++
++		sdmmc1_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc1_bus";
++			linux,phandle = <0x66>;
++			phandle = <0x66>;
++		};
++
++		sdmmc1_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc1_rst";
++			linux,phandle = <0x67>;
++			phandle = <0x67>;
++		};
++
++		sdmmc2_mod {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc2_mod";
++			linux,phandle = <0x5b>;
++			phandle = <0x5b>;
++		};
++
++		sdmmc2_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc2_bus";
++			linux,phandle = <0x5c>;
++			phandle = <0x5c>;
++		};
++
++		sdmmc2_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc2_rst";
++			linux,phandle = <0x5d>;
++			phandle = <0x5d>;
++		};
++
++		ts {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ts";
++		};
++
++		ce {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ce";
++			linux,phandle = <0x7a>;
++			phandle = <0x7a>;
++		};
++
++		spi0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "spi0";
++			linux,phandle = <0x52>;
++			phandle = <0x52>;
++		};
++
++		spi1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "spi1";
++			linux,phandle = <0x56>;
++			phandle = <0x56>;
++		};
++
++		i2s0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "i2s0";
++			linux,phandle = <0x42>;
++			phandle = <0x42>;
++		};
++
++		i2s1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "i2s1";
++			linux,phandle = <0x47>;
++			phandle = <0x47>;
++		};
++
++		i2s2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "i2s2";
++			linux,phandle = <0x48>;
++			phandle = <0x48>;
++		};
++
++		spdif {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "spdif";
++			linux,phandle = <0x49>;
++			phandle = <0x49>;
++		};
++
++		usbphy0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbphy0";
++			linux,phandle = <0x32>;
++			phandle = <0x32>;
++		};
++
++		usbphy1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbphy1";
++			linux,phandle = <0x36>;
++			phandle = <0x36>;
++		};
++
++		usbhsic {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbhsic";
++			linux,phandle = <0x38>;
++			phandle = <0x38>;
++		};
++
++		usbhsic12m {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbhsic12m";
++			linux,phandle = <0x39>;
++			phandle = <0x39>;
++		};
++
++		usbohci1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbohci1";
++			linux,phandle = <0x3b>;
++			phandle = <0x3b>;
++		};
++
++		usbohci0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbohci0";
++			linux,phandle = <0x35>;
++			phandle = <0x35>;
++		};
++
++		de {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x7>;
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "de";
++			linux,phandle = <0x6a>;
++			phandle = <0x6a>;
++		};
++
++		tcon0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x8>;
++			clock-output-names = "tcon0";
++			linux,phandle = <0x6b>;
++			phandle = <0x6b>;
++		};
++
++		tcon1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x3>;
++			clock-output-names = "tcon1";
++			linux,phandle = <0x6e>;
++			phandle = <0x6e>;
++		};
++
++		deinterlace {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "deinterlace";
++			linux,phandle = <0x7c>;
++			phandle = <0x7c>;
++		};
++
++		csi_s {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "csi_s";
++			linux,phandle = <0x73>;
++			phandle = <0x73>;
++		};
++
++		csi_m {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "csi_m";
++			linux,phandle = <0x74>;
++			phandle = <0x74>;
++		};
++
++		csi_misc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "csi_misc";
++			linux,phandle = <0x75>;
++			phandle = <0x75>;
++		};
++
++		ve {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ve";
++			linux,phandle = <0x17>;
++			phandle = <0x17>;
++		};
++
++		adda {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "adda";
++			linux,phandle = <0x41>;
++			phandle = <0x41>;
++		};
++
++		addax4 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "addax4";
++		};
++
++		avs {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "avs";
++		};
++
++		hdmi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x3>;
++			clock-output-names = "hdmi";
++			linux,phandle = <0x6f>;
++			phandle = <0x6f>;
++		};
++
++		hdmi_slow {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "hdmi_slow";
++			linux,phandle = <0x70>;
++			phandle = <0x70>;
++		};
++
++		mbus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "mbus";
++		};
++
++		mipidsi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "mipidsi";
++			linux,phandle = <0x6d>;
++			phandle = <0x6d>;
++		};
++
++		gpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "gpu";
++			linux,phandle = <0x97>;
++			phandle = <0x97>;
++		};
++
++		usbehci_16 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbohci_16";
++		};
++
++		usbehci1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbehci1";
++			linux,phandle = <0x37>;
++			phandle = <0x37>;
++		};
++
++		usbehci0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbehci0";
++			linux,phandle = <0x34>;
++			phandle = <0x34>;
++		};
++
++		usbotg {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbotg";
++			linux,phandle = <0x33>;
++			phandle = <0x33>;
++		};
++
++		gmac {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "gmac";
++			linux,phandle = <0x8f>;
++			phandle = <0x8f>;
++		};
++
++		sdram {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdram";
++		};
++
++		dma {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "dma";
++			linux,phandle = <0xb>;
++			phandle = <0xb>;
++		};
++
++		hwspinlock_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "hwspinlock_rst";
++			linux,phandle = <0xf>;
++			phandle = <0xf>;
++		};
++
++		hwspinlock_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "hwspinlock_bus";
++			linux,phandle = <0x10>;
++			phandle = <0x10>;
++		};
++
++		msgbox {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "msgbox";
++			linux,phandle = <0xe>;
++			phandle = <0xe>;
++		};
++
++		lvds {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "lvds";
++			linux,phandle = <0x6c>;
++			phandle = <0x6c>;
++		};
++
++		uart0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart0";
++			linux,phandle = <0x18>;
++			phandle = <0x18>;
++		};
++
++		uart1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart1";
++			linux,phandle = <0x1b>;
++			phandle = <0x1b>;
++		};
++
++		uart2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart2";
++			linux,phandle = <0x1e>;
++			phandle = <0x1e>;
++		};
++
++		uart3 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart3";
++			linux,phandle = <0x21>;
++			phandle = <0x21>;
++		};
++
++		uart4 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart4";
++			linux,phandle = <0x24>;
++			phandle = <0x24>;
++		};
++
++		scr {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "scr";
++			linux,phandle = <0x7d>;
++			phandle = <0x7d>;
++		};
++
++		twi0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi0";
++			linux,phandle = <0x27>;
++			phandle = <0x27>;
++		};
++
++		twi1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi1";
++			linux,phandle = <0x2a>;
++			phandle = <0x2a>;
++		};
++
++		twi2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi2";
++			linux,phandle = <0x2d>;
++			phandle = <0x2d>;
++		};
++
++		twi3 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi3";
++		};
++
++		pio {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "pio";
++			linux,phandle = <0xa>;
++			phandle = <0xa>;
++		};
++
++		cpurcir {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurcir";
++			linux,phandle = <0x12>;
++			phandle = <0x12>;
++		};
++
++		cpurpio {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurpio";
++			linux,phandle = <0x9>;
++			phandle = <0x9>;
++		};
++
++		cpurpll_peri0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurpll_peri0";
++		};
++
++		cpurcpus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurcpus";
++		};
++
++		cpurahbs {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurahbs";
++		};
++
++		cpurapbs {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurapbs";
++		};
++
++		losc_out {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "losc_out";
++			linux,phandle = <0x98>;
++			phandle = <0x98>;
++		};
++	};
++
++	soc@01c00000 {
++		compatible = "simple-bus";
++		#address-cells = <0x2>;
++		#size-cells = <0x2>;
++		ranges;
++		device_type = "soc";
++
++		pinctrl@01f02c00 {
++			compatible = "allwinner,sun50i-r-pinctrl";
++			reg = <0x0 0x1f02c00 0x0 0x400>;
++			interrupts = <0x0 0x2d 0x4>;
++			clocks = <0x9>;
++			device_type = "r_pio";
++			gpio-controller;
++			interrupt-controller;
++			#interrupt-cells = <0x2>;
++			#size-cells = <0x0>;
++			#gpio-cells = <0x6>;
++			linux,phandle = <0x79>;
++			phandle = <0x79>;
++
++			status_led: status_led@0 {
++				allwinner,pins = "PL7";
++				allwinner,function = "gpio_out";
++				allwinner,muxsel = <0x1>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_cir0@0 {
++				allwinner,pins = "PL11";
++				allwinner,function = "s_cir0";
++				allwinner,muxsel = <0x2>;
++				allwinner,drive = <0x2>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x11>;
++				phandle = <0x11>;
++			};
++
++			spwm0@0 {
++				linux,phandle = <0xaf>;
++				phandle = <0xaf>;
++				allwinner,pins = "PL10";
++				allwinner,function = "spwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spwm0@1 {
++				linux,phandle = <0xb0>;
++				phandle = <0xb0>;
++				allwinner,pins = "PL10";
++				allwinner,function = "spwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x7>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_uart0@0 {
++				linux,phandle = <0xb6>;
++				phandle = <0xb6>;
++				allwinner,pins = "PL2", "PL3";
++				allwinner,function = "s_uart0";
++				allwinner,pname = "s_uart0_tx", "s_uart0_rx";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_rsb0@0 {
++				linux,phandle = <0xb7>;
++				phandle = <0xb7>;
++				allwinner,pins = "PL0", "PL1";
++				allwinner,function = "s_rsb0";
++				allwinner,pname = "s_rsb0_sck", "s_rsb0_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_jtag0@0 {
++				linux,phandle = <0xb8>;
++				phandle = <0xb8>;
++				allwinner,pins = "PL4", "PL5", "PL6", "PL7";
++				allwinner,function = "s_jtag0";
++				allwinner,pname = "s_jtag0_tms", "s_jtag0_tck", "s_jtag0_tdo", "s_jtag0_tdi";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++		};
++
++		pinctrl@01c20800 {
++			compatible = "allwinner,sun50i-pinctrl";
++			reg = <0x0 0x1c20800 0x0 0x400>;
++			interrupts = <0x0 0xb 0x4 0x0 0x11 0x4 0x0 0x15 0x4>;
++			device_type = "pio";
++			clocks = <0xa>;
++			gpio-controller;
++			interrupt-controller;
++			#interrupt-cells = <0x2>;
++			#size-cells = <0x0>;
++			#gpio-cells = <0x6>;
++			linux,phandle = <0x30>;
++			phandle = <0x30>;
++
++			uart0@1 {
++				allwinner,pins = "PB8", "PB9";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x1a>;
++				phandle = <0x1a>;
++			};
++
++			uart1@1 {
++				allwinner,pins = "PG6", "PG7", "PG8", "PG9";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x1d>;
++				phandle = <0x1d>;
++			};
++
++			uart2@1 {
++				allwinner,pins = "PB0", "PB1", "PB2", "PB3";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x20>;
++				phandle = <0x20>;
++			};
++
++			uart3@1 {
++				allwinner,pins = "PH4", "PH5", "PH6", "PH7";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x23>;
++				phandle = <0x23>;
++			};
++
++			uart4@1 {
++				allwinner,pins = "PD2", "PD3", "PD4", "PD5";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x26>;
++				phandle = <0x26>;
++			};
++
++			twi0@1 {
++				allwinner,pins = "PH0", "PH1";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x29>;
++				phandle = <0x29>;
++			};
++
++			twi1@1 {
++				allwinner,pins = "PH2", "PH3";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x2c>;
++				phandle = <0x2c>;
++			};
++
++			twi2@1 {
++				allwinner,pins = "PE14", "PE15";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x2f>;
++				phandle = <0x2f>;
++			};
++
++			spi0@2 {
++				allwinner,pins = "PC3", "PC2", "PC0", "PC1";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x55>;
++				phandle = <0x55>;
++			};
++
++			spi1@2 {
++				allwinner,pins = "PD0", "PD1", "PD2", "PD3";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x59>;
++				phandle = <0x59>;
++			};
++
++			sdc0@1 {
++				allwinner,pins = "PF0", "PF1", "PF2", "PF3", "PF4", "PF5";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x64>;
++				phandle = <0x64>;
++			};
++
++			sdc1@1 {
++				allwinner,pins = "PG0", "PG1", "PG2", "PG3", "PG4", "PG5";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x69>;
++				phandle = <0x69>;
++			};
++
++			sdc2@1 {
++				allwinner,pins = "PC1", "PC5", "PC6", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x5f>;
++				phandle = <0x5f>;
++			};
++
++			daudio0@0 {
++				allwinner,pins = "PB6", "PB3", "PB4", "PB5", "PB7";
++				allwinner,function = "pcm0";
++				allwinner,muxsel = <0x3>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x43>;
++				phandle = <0x43>;
++			};
++
++			daudio0_sleep@0 {
++				allwinner,pins = "PB6", "PB3", "PB4", "PB5", "PB7";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x44>;
++				phandle = <0x44>;
++			};
++
++			daudio1@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "pcm1";
++				allwinner,muxsel = <0x3>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x45>;
++				phandle = <0x45>;
++			};
++
++			daudio1_sleep@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x46>;
++				phandle = <0x46>;
++			};
++
++			aif3@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "aif3";
++				allwinner,muxsel = <0x2>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x3e>;
++				phandle = <0x3e>;
++			};
++
++			aif2_sleep@0 {
++				allwinner,pins = "PB6", "PB4", "PB5", "PB7";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x3f>;
++				phandle = <0x3f>;
++			};
++
++			aif3_sleep@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x40>;
++				phandle = <0x40>;
++			};
++
++			spdif@0 {
++				allwinner,pins = "PH8";
++				allwinner,function = "spdif0";
++				allwinner,muxsel = <0x2>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x4a>;
++				phandle = <0x4a>;
++			};
++
++			spdif_sleep@0 {
++				allwinner,pins = "PH8";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x4b>;
++				phandle = <0x4b>;
++			};
++
++			csi0_sleep@0 {
++				allwinner,pins = "PE0", "PE2", "PE3", "PE4", "PE5", "PE6", "PE7", "PE8", "PE9", "PE10", "PE11", "PE12", "PE13";
++				allwinner,pname = "csi0_pck", "csi0_hsync", "csi0_vsync", "csi0_d0", "csi0_d1", "csi0_d2", "csi0_d3", "csi0_d4", "csi0_d5", "csi0_d6", "csi0_d7", "csi0_sck", "csi0_sda";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				allwinner,data = <0x0>;
++				linux,phandle = <0x77>;
++				phandle = <0x77>;
++			};
++
++			smartcard@0 {
++				allwinner,pins = "PB1", "PB4", "PB5", "PB6", "PB7";
++				allwinner,function = "sim0";
++				allwinner,muxsel = <0x5>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x7f>;
++				phandle = <0x7f>;
++			};
++
++			nand0@2 {
++				allwinner,pins = "PC0", "PC1", "PC2", "PC3", "PC4", "PC5", "PC6", "PC7", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16", "PC17", "PC18";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x83>;
++				phandle = <0x83>;
++			};
++
++			card0_boot_para@0 {
++				linux,phandle = <0x99>;
++				phandle = <0x99>;
++				allwinner,pins = "PF0", "PF1", "PF2", "PF3", "PF4", "PF5";
++				allwinner,function = "card0_boot_para";
++				allwinner,pname = "sdc_d1", "sdc_d0", "sdc_clk", "sdc_cmd", "sdc_d3", "sdc_d2";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			card2_boot_para@0 {
++				linux,phandle = <0x9a>;
++				phandle = <0x9a>;
++				allwinner,pins = "PC1", "PC5", "PC6", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "card2_boot_para";
++				allwinner,pname = "sdc_ds", "sdc_clk", "sdc_cmd", "sdc_d0", "sdc_d1", "sdc_d2", "sdc_d3", "sdc_d4", "sdc_d5", "sdc_d6", "sdc_d7", "sdc_emmc_rst";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi_para@0 {
++				linux,phandle = <0x9b>;
++				phandle = <0x9b>;
++				allwinner,pins = "PH0", "PH1";
++				allwinner,function = "twi_para";
++				allwinner,pname = "twi_scl", "twi_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart_para@0 {
++				linux,phandle = <0x9c>;
++				phandle = <0x9c>;
++				allwinner,pins = "PB8", "PB9";
++				allwinner,function = "uart_para";
++				allwinner,pname = "uart_debug_tx", "uart_debug_rx";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			jtag_para@0 {
++				linux,phandle = <0x9d>;
++				phandle = <0x9d>;
++				allwinner,pins = "PB0", "PB1", "PB2", "PB3";
++				allwinner,function = "jtag_para";
++				allwinner,pname = "jtag_ms", "jtag_ck", "jtag_do", "jtag_di";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			gmac0@0 {
++				linux,phandle = <0x9e>;
++				phandle = <0x9e>;
++				allwinner,pins = "PD18", "PD17", "PD16", "PD15", "PD20", "PD19", "PD11", "PD10", "PD9", "PD8", "PD13", "PD12", "PD21", "PD22", "PD23";
++				allwinner,function = "gmac0";
++				allwinner,pname = "gmac_txd0", "gmac_txd1", "gmac_txd2", "gmac_txd3", "gmac_txen", "gmac_gtxclk", "gmac_rxd0", "gmac_rxd1", "gmac_rxd2", "gmac_rxd3", "gmac_rxdv", "gmac_rxclk", "gmac_clkin", "gmac_mdc", "gmac_mdio";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi0@0 {
++				linux,phandle = <0x9f>;
++				phandle = <0x9f>;
++				allwinner,pins = "PH0", "PH1";
++				allwinner,function = "twi0";
++				allwinner,pname = "twi0_scl", "twi0_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi1@0 {
++				linux,phandle = <0xa0>;
++				phandle = <0xa0>;
++				allwinner,pins = "PH2", "PH3";
++				allwinner,function = "twi1";
++				allwinner,pname = "twi1_scl", "twi1_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi2@0 {
++				linux,phandle = <0xa1>;
++				phandle = <0xa1>;
++				allwinner,pins = "PE14", "PE15";
++				allwinner,function = "twi2";
++				allwinner,pname = "twi2_scl", "twi2_sda";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart0@0 {
++				linux,phandle = <0xa2>;
++				phandle = <0xa2>;
++				allwinner,pins = "PB8", "PB9";
++				allwinner,function = "uart0";
++				allwinner,pname = "uart0_tx", "uart0_rx";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart1@0 {
++				linux,phandle = <0xa3>;
++				phandle = <0xa3>;
++				allwinner,pins = "PG6", "PG7", "PG8", "PG9";
++				allwinner,function = "uart1";
++				allwinner,pname = "uart1_tx", "uart1_rx", "uart1_rts", "uart1_cts";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart2@0 {
++				linux,phandle = <0xa4>;
++				phandle = <0xa4>;
++				allwinner,pins = "PB0", "PB1", "PB2", "PB3";
++				allwinner,function = "uart2";
++				allwinner,pname = "uart2_tx", "uart2_rx", "uart2_rts", "uart2_cts";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart3@0 {
++				linux,phandle = <0xa5>;
++				phandle = <0xa5>;
++				allwinner,pins = "PD0", "PD1";
++				allwinner,function = "uart3";
++				allwinner,pname = "uart3_tx", "uart3_rx";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart4@0 {
++				linux,phandle = <0xa6>;
++				phandle = <0xa6>;
++				allwinner,pins = "PD2", "PD3", "PD4", "PD5";
++				allwinner,function = "uart4";
++				allwinner,pname = "uart4_tx", "uart4_rx", "uart4_rts", "uart4_cts";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi0@0 {
++				linux,phandle = <0xa7>;
++				phandle = <0xa7>;
++				allwinner,pins = "PC3";
++				allwinner,function = "spi0";
++				allwinner,pname = "spi0_cs0";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi0@1 {
++				linux,phandle = <0xa8>;
++				phandle = <0xa8>;
++				allwinner,pins = "PC2", "PC0", "PC1";
++				allwinner,function = "spi0";
++				allwinner,pname = "spi0_sclk", "spi0_mosi", "spi0_miso";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi1@0 {
++				linux,phandle = <0xa9>;
++				phandle = <0xa9>;
++				allwinner,pins = "PD0";
++				allwinner,function = "spi1";
++				allwinner,pname = "spi1_cs0";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi1@1 {
++				linux,phandle = <0xaa>;
++				phandle = <0xaa>;
++				allwinner,pins = "PD1", "PD2", "PD3";
++				allwinner,function = "spi1";
++				allwinner,pname = "spi1_sclk", "spi1_mosi", "spi1_miso";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			nand0@0 {
++				linux,phandle = <0xab>;
++				phandle = <0xab>;
++				allwinner,pins = "PC0", "PC1", "PC2", "PC5", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "nand0";
++				allwinner,pname = "nand0_we", "nand0_ale", "nand0_cle", "nand0_nre", "nand0_d0", "nand0_d1", "nand0_d2", "nand0_d3", "nand0_d4", "nand0_d5", "nand0_d6", "nand0_d7", "nand0_ndqs";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0x1>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			nand0@1 {
++				linux,phandle = <0xac>;
++				phandle = <0xac>;
++				allwinner,pins = "PC3", "PC4", "PC6", "PC7", "PC17", "PC18";
++				allwinner,function = "nand0";
++				allwinner,pname = "nand0_ce1", "nand0_ce0", "nand0_rb0", "nand0_rb1", "nand0_ce2", "nand0_ce3";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x1>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			pwm0@0 {
++				linux,phandle = <0xad>;
++				phandle = <0xad>;
++				allwinner,pins = "PD22";
++				allwinner,function = "pwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			pwm0@1 {
++				linux,phandle = <0xae>;
++				phandle = <0xae>;
++				allwinner,pins = "PD22";
++				allwinner,function = "pwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x7>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			csi0@0 {
++				linux,phandle = <0xb1>;
++				phandle = <0xb1>;
++				allwinner,pins = "PE0", "PE2", "PE3", "PE4", "PE5", "PE6", "PE7", "PE8", "PE9", "PE10", "PE11", "PE12", "PE13";
++				allwinner,function = "csi0";
++				allwinner,pname = "csi0_pck", "csi0_hsync", "csi0_vsync", "csi0_d0", "csi0_d1", "csi0_d2", "csi0_d3", "csi0_d4", "csi0_d5", "csi0_d6", "csi0_d7", "csi0_sck", "csi0_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			sdc0@0 {
++				linux,phandle = <0xb2>;
++				phandle = <0xb2>;
++				allwinner,pins = "PF0", "PF1", "PF2", "PF3", "PF4", "PF5";
++				allwinner,function = "sdc0";
++				allwinner,pname = "sdc0_d1", "sdc0_d0", "sdc0_clk", "sdc0_cmd", "sdc0_d3", "sdc0_d2";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			sdc1@0 {
++				linux,phandle = <0xb3>;
++				phandle = <0xb3>;
++				allwinner,pins = "PG0", "PG1", "PG2", "PG3", "PG4", "PG5";
++				allwinner,function = "sdc1";
++				allwinner,pname = "sdc1_clk", "sdc1_cmd", "sdc1_d0", "sdc1_d1", "sdc1_d2", "sdc1_d3";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			sdc2@0 {
++				linux,phandle = <0xb4>;
++				phandle = <0xb4>;
++				allwinner,pins = "PC1", "PC5", "PC6", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "sdc2";
++				allwinner,pname = "sdc2_ds", "sdc2_clk", "sdc2_cmd", "sdc2_d0", "sdc2_d1", "sdc2_d2", "sdc2_d3", "sdc2_d4", "sdc2_d5", "sdc2_d6", "sdc2_d7", "sdc2_emmc_rst";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			codec@0 {
++				linux,phandle = <0xb5>;
++				phandle = <0xb5>;
++				allwinner,pins = "PH7";
++				allwinner,function = "codec";
++				allwinner,pname = "gpio-spk";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			Vdevice@0 {
++				linux,phandle = <0xb9>;
++				phandle = <0xb9>;
++				allwinner,pins = "PB1", "PB2";
++				allwinner,function = "Vdevice";
++				allwinner,pname = "Vdevice_0", "Vdevice_1";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			w1_pin@0 {
++				linux,phandle = <0xba>;
++				phandle = <0xba>;
++				allwinner,pins = "PC8";
++				allwinner,function = "gpio_in";
++				allwinner,pname = "w1";
++				allwinner,muxsel = <0x0>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x0>;
++				allwinner,data = <0xffffffff>;
++			};
++		};
++
++		pinctrl@0 {
++			compatible = "allwinner,axp-pinctrl";
++			gpio-controller;
++			#size-cells = <0x0>;
++			#gpio-cells = <0x6>;
++			device_type = "axp_pio";
++			linux,phandle = <0x31>;
++			phandle = <0x31>;
++		};
++
++		dma-controller@01c02000 {
++			compatible = "allwinner,sun50i-dma";
++			reg = <0x0 0x1c02000 0x0 0x1000>;
++			interrupts = <0x0 0x32 0x4>;
++			clocks = <0xb>;
++			#dma-cells = <0x1>;
++		};
++
++		mbus-controller@01c62000 {
++			compatible = "allwinner,sun50i-mbus";
++			reg = <0x0 0x1c62000 0x0 0x110>;
++			#mbus-cells = <0x1>;
++		};
++
++		arisc {
++			compatible = "allwinner,sunxi-arisc";
++			#address-cells = <0x2>;
++			#size-cells = <0x2>;
++			clocks = <0xc 0xd 0x6 0x4>;
++			clock-names = "losc", "iosc", "hosc", "pll_periph0";
++			powchk_used = <0x0>;
++			power_reg = <0x2309621>;
++			system_power = <0x32>;
++		};
++
++		arisc_space {
++			compatible = "allwinner,arisc_space";
++			space1 = <0x40000 0x0 0x14000>;
++			space2 = <0x40100000 0x18000 0x4000>;
++			space3 = <0x40104000 0x0 0x1000>;
++			space4 = <0x40105000 0x0 0x1000>;
++		};
++
++		standby_space {
++			compatible = "allwinner,standby_space";
++			space1 = <0x41020000 0x0 0x800>;
++		};
++
++		msgbox@1c17000 {
++			compatible = "allwinner,msgbox";
++			clocks = <0xe>;
++			clock-names = "clk_msgbox";
++			reg = <0x0 0x1c17000 0x0 0x1000>;
++			interrupts = <0x0 0x31 0x1>;
++			status = "okay";
++		};
++
++		hwspinlock@1c18000 {
++			compatible = "allwinner,sunxi-hwspinlock";
++			clocks = <0xf 0x10>;
++			clock-names = "clk_hwspinlock_rst", "clk_hwspinlock_bus";
++			reg = <0x0 0x1c18000 0x0 0x1000>;
++			status = "okay";
++			num-locks = <0x8>;
++		};
++
++		s_cir@1f02000 {
++			compatible = "allwinner,s_cir";
++			reg = <0x0 0x1f02000 0x0 0x400>;
++			interrupts = <0x0 0x25 0x4>;
++			pinctrl-names = "default";
++			pinctrl-0 = <0x11>;
++			clocks = <0x6 0x12>;
++			supply = "vcc-pl";
++			ir_power_key_code = <0x4d>;
++			ir_addr_code = <0x4040>;
++			status = "okay";
++			device_type = "s_cir0";
++		};
++
++		s_uart@1f02800 {
++			compatible = "allwinner,s_uart";
++			reg = <0x0 0x1f02800 0x0 0x400>;
++			interrupts = <0x0 0x26 0x4>;
++			pinctrl-names = "default";
++			status = "okay";
++			device_type = "s_uart0";
++			pinctrl-0 = <0xb6>;
++		};
++
++		s_rsb@1f03400 {
++			compatible = "allwinner,s_rsb";
++			reg = <0x0 0x1f03400 0x0 0x400>;
++			interrupts = <0x0 0x27 0x4>;
++			pinctrl-names = "default";
++			status = "okay";
++			device_type = "s_rsb0";
++			pinctrl-0 = <0xb7>;
++		};
++
++		s_jtag0 {
++			compatible = "allwinner,s_jtag";
++			pinctrl-names = "default";
++			status = "disabled";
++			device_type = "s_jtag0";
++			pinctrl-0 = <0xb8>;
++		};
++
++		timer@1c20c00 {
++			compatible = "allwinner,sunxi-timer";
++			device_type = "timer";
++			reg = <0x0 0x1c20c00 0x0 0x90>;
++			interrupts = <0x0 0x12 0x1>;
++			clock-frequency = <0x16e3600>;
++			timer-prescale = <0x10>;
++		};
++
++		rtc@01f00000 {
++			compatible = "allwinner,sun50i-rtc";
++			device_type = "rtc";
++			reg = <0x0 0x1f00000 0x0 0x218>;
++			interrupts = <0x0 0x28 0x4>;
++			gpr_offset = <0x100>;
++			gpr_len = <0x4>;
++		};
++
++		ve@01c0e000 {
++			compatible = "allwinner,sunxi-cedar-ve";
++			reg = <0x0 0x1c0e000 0x0 0x1000 0x0 0x1c00000 0x0 0x10 0x0 0x1c20000 0x0 0x800>;
++			interrupts = <0x0 0x3a 0x4>;
++			clocks = <0x16 0x17>;
++		};
++
++		uart@01c28000 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart0";
++			reg = <0x0 0x1c28000 0x0 0x400>;
++			interrupts = <0x0 0x0 0x4>;
++			clocks = <0x18>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x1a>;
++			uart0_port = <0x0>;
++			uart0_type = <0x2>;
++			status = "okay";
++			pinctrl-0 = <0xa2>;
++		};
++
++		uart@01c28400 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart1";
++			reg = <0x0 0x1c28400 0x0 0x400>;
++			interrupts = <0x0 0x1 0x4>;
++			clocks = <0x1b>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x1d>;
++			uart1_port = <0x1>;
++			uart1_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa3>;
++		};
++
++		uart@01c28800 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart2";
++			reg = <0x0 0x1c28800 0x0 0x400>;
++			interrupts = <0x0 0x2 0x4>;
++			clocks = <0x1e>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x20>;
++			uart2_port = <0x2>;
++			uart2_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa4>;
++		};
++
++		uart@01c28c00 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart3";
++			reg = <0x0 0x1c28c00 0x0 0x400>;
++			interrupts = <0x0 0x3 0x4>;
++			clocks = <0x21>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x23>;
++			uart3_port = <0x3>;
++			uart3_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa5>;
++		};
++
++		uart@01c29000 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart4";
++			reg = <0x0 0x1c29000 0x0 0x400>;
++			interrupts = <0x0 0x4 0x4>;
++			clocks = <0x24>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x26>;
++			uart4_port = <0x4>;
++			uart4_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa6>;
++		};
++
++		twi@0x01c2ac00 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-twi";
++			device_type = "twi0";
++			reg = <0x0 0x1c2ac00 0x0 0x400>;
++			interrupts = <0x0 0x6 0x4>;
++			clocks = <0x27>;
++			clock-frequency = <0x61a80>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x29>;
++			status = "okay";
++			pinctrl-0 = <0x9f>;
++		};
++
++		twi@0x01c2b000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-twi";
++			device_type = "twi1";
++			reg = <0x0 0x1c2b000 0x0 0x400>;
++			interrupts = <0x0 0x7 0x4>;
++			clocks = <0x2a>;
++			clock-frequency = <0x30d40>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x2c>;
++			status = "okay";
++			pinctrl-0 = <0xa0>;
++		};
++
++		twi@0x01c2b400 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-twi";
++			device_type = "twi2";
++			reg = <0x0 0x1c2b400 0x0 0x400>;
++			interrupts = <0x0 0x8 0x4>;
++			clocks = <0x2d>;
++			clock-frequency = <0x30d40>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x2f>;
++			status = "disabled";
++			pinctrl-0 = <0xa1>;
++		};
++
++		usbc0@0 {
++			device_type = "usbc0";
++			compatible = "allwinner,sunxi-otg-manager";
++			usb_port_type = <0x1>;
++			usb_detect_type = <0x0>;
++			usb_host_init_state = <0x1>;
++			usb_regulator_io = "nocare";
++			usb_wakeup_suspend = <0x1>;
++			usb_luns = <0x3>;
++			usb_serial_unique = <0x1>;
++			usb_serial_number = "20080411";
++			rndis_wceis = <0x1>;
++			status = "okay";
++			usb_id_gpio;
++			usb_det_vbus_gpio;
++			usb_drv_vbus_gpio;
++		};
++
++		udc-controller@0x01c19000 {
++			compatible = "allwinner,sunxi-udc";
++			reg = <0x0 0x1c19000 0x0 0x1000 0x0 0x1c00000 0x0 0x100>;
++			interrupts = <0x0 0x47 0x4>;
++			clocks = <0x32 0x33>;
++			status = "okay";
++		};
++
++		ehci0-controller@0x01c1a000 {
++			compatible = "allwinner,sunxi-ehci0";
++			reg = <0x0 0x1c1a000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x48 0x4>;
++			clocks = <0x32 0x34>;
++			hci_ctrl_no = <0x0>;
++			status = "okay";
++		};
++
++		ohci0-controller@0x01c1a400 {
++			compatible = "allwinner,sunxi-ohci0";
++			reg = <0x0 0x1c1a000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x49 0x4>;
++			clocks = <0x32 0x35>;
++			hci_ctrl_no = <0x0>;
++			status = "okay";
++		};
++
++		usbc1@0 {
++			device_type = "usbc1";
++			usb_host_init_state = <0x1>;
++			usb_regulator_io = "nocare";
++			usb_wakeup_suspend = <0x1>;
++			usb_hsic_used = <0x0>;
++			usb_hsic_regulator_io = "vcc-hsic-12";
++			usb_hsic_ctrl = <0x0>;
++			usb_hsic_usb3503_flag = <0x0>;
++			status = "okay";
++			usb_port_type = <0x1>;
++			usb_detect_type = <0x0>;
++			usb_drv_vbus_gpio;
++			usb_hsic_rdy_gpio;
++			usb_hsic_hub_connect_gpio;
++			usb_hsic_int_n_gpio;
++			usb_hsic_reset_n_gpio;
++		};
++
++		ehci1-controller@0x01c1b000 {
++			compatible = "allwinner,sunxi-ehci1";
++			reg = <0x0 0x1c1b000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x4a 0x4>;
++			clocks = <0x36 0x37 0x38 0x39 0x3a>;
++			hci_ctrl_no = <0x1>;
++			status = "okay";
++		};
++
++		ohci1-controller@0x01c1b400 {
++			compatible = "allwinner,sunxi-ohci1";
++			reg = <0x0 0x1c1b000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x4b 0x4>;
++			clocks = <0x36 0x3b>;
++			hci_ctrl_no = <0x1>;
++			status = "okay";
++		};
++
++		codec@0x01c22c00 {
++			compatible = "allwinner,sunxi-internal-codec";
++			reg = <0x0 0x1c22c00 0x0 0x478 0x0 0x1f015c0 0x0 0x0>;
++			clocks = <0x3c>;
++			pinctrl-names = "aif2-default", "aif3-default", "aif2-sleep", "aif3-sleep";
++			pinctrl-1 = <0x3e>;
++			pinctrl-2 = <0x3f>;
++			pinctrl-3 = <0x40>;
++			gpio-spk = <0x30 0x7 0x7 0x1 0x1 0x1 0x1>;
++			headphonevol = <0x3b>;
++			spkervol = <0x1a>;
++			earpiecevol = <0x1e>;
++			maingain = <0x4>;
++			headsetmicgain = <0x4>;
++			adcagc_cfg = <0x0>;
++			adcdrc_cfg = <0x0>;
++			adchpf_cfg = <0x0>;
++			dacdrc_cfg = <0x0>;
++			dachpf_cfg = <0x0>;
++			aif1_lrlk_div = <0x40>;
++			aif2_lrlk_div = <0x40>;
++			aif2config = <0x0>;
++			aif3config = <0x0>;
++			pa_sleep_time = <0x15e>;
++			dac_digital_vol = <0xa0a0>;
++			status = "okay";
++			linux,phandle = <0x4d>;
++			phandle = <0x4d>;
++			device_type = "codec";
++			pinctrl-0 = <0xb5>;
++		};
++
++		i2s0-controller@0x01c22c00 {
++			compatible = "allwinner,sunxi-internal-i2s";
++			reg = <0x0 0x1c22c00 0x0 0x478>;
++			clocks = <0x2 0x41>;
++			status = "okay";
++			linux,phandle = <0x4c>;
++			phandle = <0x4c>;
++			device_type = "i2s";
++		};
++
++		daudio@0x01c22000 {
++			compatible = "allwinner,sunxi-daudio";
++			reg = <0x0 0x1c22000 0x0 0x58>;
++			clocks = <0x2 0x42>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x43>;
++			pinctrl-1 = <0x44>;
++			pcm_lrck_period = <0x20>;
++			pcm_lrckr_period = <0x1>;
++			slot_width_select = <0x20>;
++			pcm_lsb_first = <0x0>;
++			tx_data_mode = <0x0>;
++			rx_data_mode = <0x0>;
++			daudio_master = <0x4>;
++			audio_format = <0x1>;
++			signal_inversion = <0x1>;
++			frametype = <0x0>;
++			tdm_config = <0x1>;
++			tdm_num = <0x0>;
++			status = "disabled";
++			linux,phandle = <0x4e>;
++			phandle = <0x4e>;
++			device_type = "daudio0";
++		};
++
++		daudio@0x01c22400 {
++			compatible = "allwinner,sunxi-daudio";
++			reg = <0x0 0x1c22400 0x0 0x58>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x45>;
++			pinctrl-1 = <0x46>;
++			clocks = <0x2 0x47>;
++			pcm_lrck_period = <0x20>;
++			pcm_lrckr_period = <0x1>;
++			slot_width_select = <0x20>;
++			pcm_lsb_first = <0x0>;
++			tx_data_mode = <0x0>;
++			rx_data_mode = <0x0>;
++			daudio_master = <0x4>;
++			audio_format = <0x1>;
++			signal_inversion = <0x1>;
++			frametype = <0x0>;
++			tdm_config = <0x1>;
++			tdm_num = <0x1>;
++			status = "disabled";
++			linux,phandle = <0x4f>;
++			phandle = <0x4f>;
++			device_type = "daudio1";
++		};
++
++		daudio@0x01c22800 {
++			compatible = "allwinner,sunxi-tdmhdmi";
++			reg = <0x0 0x1c22800 0x0 0x58>;
++			clocks = <0x2 0x48>;
++			status = "okay";
++			linux,phandle = <0x50>;
++			phandle = <0x50>;
++			device_type = "daudio2";
++		};
++
++		spdif-controller@0x01c21000 {
++			compatible = "allwinner,sunxi-spdif";
++			reg = <0x0 0x1c21000 0x0 0x38>;
++			clocks = <0x2 0x49>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x4a>;
++			pinctrl-1 = <0x4b>;
++			status = "disabled";
++			linux,phandle = <0x51>;
++			phandle = <0x51>;
++			device_type = "spdif";
++		};
++
++		sound@0 {
++			compatible = "allwinner,sunxi-codec-machine";
++			interrupts = <0x0 0x1c 0x4>;
++			sunxi,i2s-controller = <0x4c>;
++			sunxi,audio-codec = <0x4d>;
++			aif2fmt = <0x3>;
++			aif3fmt = <0x3>;
++			aif2master = <0x1>;
++			hp_detect_case = <0x1>;
++			status = "okay";
++			device_type = "sndcodec";
++		};
++
++		sound@1 {
++			compatible = "allwinner,sunxi-daudio0-machine";
++			sunxi,daudio0-controller = <0x4e>;
++			status = "disabled";
++			device_type = "snddaudio0";
++		};
++
++		sound@2 {
++			compatible = "allwinner,sunxi-daudio1-machine";
++			sunxi,daudio1-controller = <0x4f>;
++			status = "disabled";
++			device_type = "snddaudio1";
++		};
++
++		sound@3 {
++			compatible = "allwinner,sunxi-hdmi-machine";
++			sunxi,hdmi-controller = <0x50>;
++			status = "okay";
++			device_type = "sndhdmi";
++		};
++
++		sound@4 {
++			compatible = "allwinner,sunxi-spdif-machine";
++			sunxi,spdif-controller = <0x51>;
++			status = "disabled";
++			device_type = "sndspdif";
++		};
++
++		spi@01c68000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-spi";
++			device_type = "spi0";
++			reg = <0x0 0x1c68000 0x0 0x1000>;
++			interrupts = <0x0 0x41 0x4>;
++			clocks = <0x4 0x52>;
++			clock-frequency = <0x5f5e100>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x55>;
++			spi0_cs_number = <0x1>;
++			spi0_cs_bitmap = <0x1>;
++			status = "disabled";
++			pinctrl-0 = <0xa7 0xa8>;
++
++			spidev@0 {
++				compatible = "spidev";
++				reg = <0x0>;
++				spi-max-frequency = <0x2faf080>;
++			};
++		};
++
++		spi@01c69000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-spi";
++			device_type = "spi1";
++			reg = <0x0 0x1c69000 0x0 0x1000>;
++			interrupts = <0x0 0x42 0x4>;
++			clocks = <0x4 0x56>;
++			clock-frequency = <0x5f5e100>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x59>;
++			spi1_cs_number = <0x1>;
++			spi1_cs_bitmap = <0x1>;
++			status = "disabled";
++			pinctrl-0 = <0xa9 0xaa>;
++		};
++
++		sdmmc@01C11000 {
++			compatible = "allwinner,sun50i-sdmmc2";
++			device_type = "sdc2";
++			reg = <0x0 0x1c11000 0x0 0x1000>;
++			interrupts = <0x0 0x3e 0x104>;
++			clocks = <0x6 0x5a 0x5b 0x5c 0x5d>;
++			clock-names = "osc24m", "pll_periph", "mmc", "ahb", "rst";
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x5f>;
++			bus-width = <0x8>;
++			max-frequency = <0x5f5e100>;
++			sdc_tm4_sm0_freq0 = <0x0>;
++			sdc_tm4_sm0_freq1 = <0x0>;
++			sdc_tm4_sm1_freq0 = <0x0>;
++			sdc_tm4_sm1_freq1 = <0x0>;
++			sdc_tm4_sm2_freq0 = <0x0>;
++			sdc_tm4_sm2_freq1 = <0x0>;
++			sdc_tm4_sm3_freq0 = <0x5000000>;
++			sdc_tm4_sm3_freq1 = <0x405>;
++			sdc_tm4_sm4_freq0 = <0x50000>;
++			sdc_tm4_sm4_freq1 = <0x408>;
++			status = "disabled";
++			non-removable;
++			pinctrl-0 = <0xb4>;
++			cd-gpios;
++			sunxi-power-save-mode;
++			sunxi-dis-signal-vol-sw;
++			mmc-ddr-1_8v;
++			mmc-hs200-1_8v;
++			mmc-hs400-1_8v;
++			vmmc = "vcc-emmc";
++			vqmmc = "vcc-lpddr";
++			vdmmc = "none";
++		};
++
++		sdmmc@01c0f000 {
++			compatible = "allwinner,sun50i-sdmmc0";
++			device_type = "sdc0";
++			reg = <0x0 0x1c0f000 0x0 0x1000>;
++			interrupts = <0x0 0x3c 0x104>;
++			clocks = <0x6 0x5a 0x60 0x61 0x62>;
++			clock-names = "osc24m", "pll_periph", "mmc", "ahb", "rst";
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x64>;
++			max-frequency = <0x2faf080>;
++			bus-width = <0x4>;
++			broken-cd;
++			status = "okay";
++			pinctrl-0 = <0xb2>;
++			cd-gpios = <0x30 0x5 0x6 0x0 0x1 0x2 0xffffffff>;
++			sunxi-power-save-mode;
++			vmmc = "none";
++			vqmmc = "none";
++			vdmmc = "vcc-sdc";
++		};
++
++		sdmmc@1C10000 {
++			compatible = "allwinner,sun50i-sdmmc1";
++			device_type = "sdc1";
++			reg = <0x0 0x1c10000 0x0 0x1000>;
++			interrupts = <0x0 0x3d 0x104>;
++			clocks = <0x6 0x5a 0x65 0x66 0x67>;
++			clock-names = "osc24m", "pll_periph", "mmc", "ahb", "rst";
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x69>;
++			max-frequency = <0x8f0d180>;
++			bus-width = <0x4>;
++			sunxi-dly-52M-ddr4 = <0x1 0x0 0x0 0x0 0x2>;
++			sunxi-dly-104M = <0x1 0x0 0x0 0x0 0x1>;
++			sunxi-dly-208M = <0x1 0x0 0x0 0x0 0x1>;
++			status = "okay";
++			pinctrl-0 = <0xb3>;
++			sd-uhs-sdr50;
++			sd-uhs-ddr50;
++			sd-uhs-sdr104;
++			cap-sdio-irq;
++			keep-power-in-suspend;
++			ignore-pm-notify;
++		};
++
++		disp@01000000 {
++			compatible = "allwinner,sun50i-disp";
++			reg = <0x0 0x1000000 0x0 0x300000 0x0 0x1c0c000 0x0 0x17fc 0x0 0x1ca0000 0x0 0x10fc>;
++			interrupts = <0x0 0x56 0x104 0x0 0x57 0x104 0x0 0x59 0x104>;
++			clocks = <0x6a 0x6b 0x6c 0x6d 0x6e>;
++			status = "okay";
++			device_type = "disp";
++			disp_init_enable = <0x1>;
++			disp_mode = <0x0>;
++			screen0_output_type = <0x3>;
++			screen0_output_mode = <0xa>;
++			screen1_output_type = <0x3>;
++			screen1_output_mode = <0xa>;
++			fb0_format = <0x0>;
++			fb0_width = <0x0>;
++			fb0_height = <0x0>;
++			fb1_format = <0x0>;
++			fb1_width = <0x0>;
++			fb1_height = <0x0>;
++		};
++
++		lcd0@01c0c000 {
++			compatible = "allwinner,sunxi-lcd0";
++			pinctrl-names = "active", "sleep";
++			status = "okay";
++			device_type = "lcd0";
++			lcd_used = <0x0>;
++			lcd_driver_name = "mb709_mipi";
++			lcd_backlight = <0x32>;
++			lcd_if = <0x4>;
++			lcd_x = <0x400>;
++			lcd_y = <0x258>;
++			lcd_width = <0x0>;
++			lcd_height = <0x0>;
++			lcd_dclk_freq = <0x37>;
++			lcd_pwm_used = <0x1>;
++			lcd_pwm_ch = <0x10>;
++			lcd_pwm_freq = <0xc350>;
++			lcd_pwm_pol = <0x1>;
++			lcd_pwm_max_limit = <0xfa>;
++			lcd_hbp = <0x78>;
++			lcd_ht = <0x604>;
++			lcd_hspw = <0x14>;
++			lcd_vbp = <0x17>;
++			lcd_vt = <0x27b>;
++			lcd_vspw = <0x2>;
++			lcd_dsi_if = <0x2>;
++			lcd_dsi_lane = <0x4>;
++			lcd_dsi_format = <0x0>;
++			lcd_dsi_eotp = <0x0>;
++			lcd_dsi_vc = <0x0>;
++			lcd_dsi_te = <0x0>;
++			lcd_frm = <0x0>;
++			lcd_gamma_en = <0x0>;
++			lcd_bright_curve_en = <0x0>;
++			lcd_cmap_en = <0x0>;
++			lcd_bl_en = <0x30 0x7 0xa 0x1 0x0 0xffffffff 0x1>;
++			lcd_bl_en_power = "none";
++			lcd_power = "vcc-mipi";
++			lcd_fix_power = "vcc-dsi-33";
++			lcd_gpio_0 = <0x30 0x3 0x18 0x1 0x0 0xffffffff 0x1>;
++		};
++
++		hdmi@01ee0000 {
++			compatible = "allwinner,sunxi-hdmi";
++			reg = <0x0 0x1ee0000 0x0 0x20000>;
++			clocks = <0x6f 0x70>;
++			device_type = "hdmi";
++			status = "okay";
++			hdmi_power = "vcc-hdmi-33";
++			hdmi_hdcp_enable = <0x0>;
++			hdmi_cts_compatibility = <0x0>;
++		};
++
++		tr@01000000 {
++			compatible = "allwinner,sun50i-tr";
++			reg = <0x0 0x1000000 0x0 0x200bc>;
++			interrupts = <0x0 0x60 0x104>;
++			clocks = <0x6a>;
++			status = "okay";
++		};
++
++		pwm@01c21400 {
++			compatible = "allwinner,sunxi-pwm";
++			reg = <0x0 0x1c21400 0x0 0x3c>;
++			pwm-number = <0x1>;
++			pwm-base = <0x0>;
++			pwms = <0x71>;
++		};
++
++		pwm0@01c21400 {
++			compatible = "allwinner,sunxi-pwm0";
++			pinctrl-names = "active", "sleep";
++			reg_base = <0x1c21400>;
++			reg_busy_offset = <0x0>;
++			reg_busy_shift = <0x1c>;
++			reg_enable_offset = <0x0>;
++			reg_enable_shift = <0x4>;
++			reg_clk_gating_offset = <0x0>;
++			reg_clk_gating_shift = <0x6>;
++			reg_bypass_offset = <0x0>;
++			reg_bypass_shift = <0x9>;
++			reg_pulse_start_offset = <0x0>;
++			reg_pulse_start_shift = <0x8>;
++			reg_mode_offset = <0x0>;
++			reg_mode_shift = <0x7>;
++			reg_polarity_offset = <0x0>;
++			reg_polarity_shift = <0x5>;
++			reg_period_offset = <0x4>;
++			reg_period_shift = <0x10>;
++			reg_period_width = <0x10>;
++			reg_active_offset = <0x4>;
++			reg_active_shift = <0x0>;
++			reg_active_width = <0x10>;
++			reg_prescal_offset = <0x0>;
++			reg_prescal_shift = <0x0>;
++			reg_prescal_width = <0x4>;
++			linux,phandle = <0x71>;
++			phandle = <0x71>;
++			device_type = "pwm0";
++			pwm_used = <0x0>;
++			pinctrl-0 = <0xad>;
++			pinctrl-1 = <0xae>;
++		};
++
++		s_pwm@1f03800 {
++			compatible = "allwinner,sunxi-s_pwm";
++			reg = <0x0 0x1f03800 0x0 0x3c>;
++			pwm-number = <0x1>;
++			pwm-base = <0x10>;
++			pwms = <0x72>;
++		};
++
++		spwm0@0x01f03800 {
++			compatible = "allwinner,sunxi-pwm16";
++			pinctrl-names = "active", "sleep";
++			reg_base = <0x1f03800>;
++			reg_busy_offset = <0x0>;
++			reg_busy_shift = <0x1c>;
++			reg_enable_offset = <0x0>;
++			reg_enable_shift = <0x4>;
++			reg_clk_gating_offset = <0x0>;
++			reg_clk_gating_shift = <0x6>;
++			reg_bypass_offset = <0x0>;
++			reg_bypass_shift = <0x9>;
++			reg_pulse_start_offset = <0x0>;
++			reg_pulse_start_shift = <0x8>;
++			reg_mode_offset = <0x0>;
++			reg_mode_shift = <0x7>;
++			reg_polarity_offset = <0x0>;
++			reg_polarity_shift = <0x5>;
++			reg_period_offset = <0x4>;
++			reg_period_shift = <0x10>;
++			reg_period_width = <0x10>;
++			reg_active_offset = <0x4>;
++			reg_active_shift = <0x0>;
++			reg_active_width = <0x10>;
++			reg_prescal_offset = <0x0>;
++			reg_prescal_shift = <0x0>;
++			reg_prescal_width = <0x4>;
++			linux,phandle = <0x72>;
++			phandle = <0x72>;
++			device_type = "spwm0";
++			s_pwm_used = <0x1>;
++			pinctrl-0 = <0xaf>;
++			pinctrl-1 = <0xb0>;
++		};
++
++		boot_disp {
++			compatible = "allwinner,boot_disp";
++			device_type = "boot_disp";
++			output_disp = <0x0>;
++			output_type = <0x3>;
++			output_mode = <0xa>;
++		};
++
++		cci@0x01cb3000 {
++			compatible = "allwinner,sunxi-csi_cci";
++			reg = <0x0 0x1cb3000 0x0 0x1000>;
++			interrupts = <0x0 0x55 0x4>;
++			status = "okay";
++		};
++
++		csi_res@0x01cb0000 {
++			compatible = "allwinner,sunxi-csi";
++			reg = <0x0 0x1cb0000 0x0 0x1000>;
++			status = "okay";
++		};
++
++		vfe@0 {
++			device_type = "csi0";
++			compatible = "allwinner,sunxi-vfe";
++			interrupts = <0x0 0x54 0x4>;
++			clocks = <0x73 0x74 0x75 0x4 0x6 0x5>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x77>;
++			csi0_sensor_list = <0x0>;
++			status = "disabled";
++			pinctrl-0 = <0xb1>;
++			csi0_mck = <0x30 0x4 0x1 0x0 0x0 0x1 0x0>;
++
++			dev@0 {
++				csi0_dev0_mname = "s5k4ec";
++				csi0_dev0_twi_addr = <0x5a>;
++				csi0_dev0_pos = "rear";
++				csi0_dev0_isp_used = <0x1>;
++				csi0_dev0_fmt = <0x0>;
++				csi0_dev0_stby_mode = <0x1>;
++				csi0_dev0_vflip = <0x0>;
++				csi0_dev0_hflip = <0x0>;
++				csi0_dev0_iovdd = "iovdd-csi";
++				csi0_dev0_iovdd_vol = <0x2ab980>;
++				csi0_dev0_avdd = "avdd-csi";
++				csi0_dev0_avdd_vol = <0x2ab980>;
++				csi0_dev0_dvdd = "dvdd-csi-18";
++				csi0_dev0_dvdd_vol = <0x16e360>;
++				csi0_dev0_flash_used = <0x0>;
++				csi0_dev0_flash_type = <0x2>;
++				csi0_dev0_flvdd = "vdd-csi-led";
++				csi0_dev0_flvdd_vol = <0x325aa0>;
++				csi0_dev0_act_used = <0x0>;
++				csi0_dev0_act_name = "ad5820_act";
++				csi0_dev0_act_slave = <0x18>;
++				status = "disabled";
++				device_type = "csi0_dev0";
++				csi0_dev0_afvdd;
++				csi0_dev0_afvdd_vol;
++				csi0_dev0_power_en;
++				csi0_dev0_reset = <0x30 0x4 0x10 0x0 0x0 0x1 0x0>;
++				csi0_dev0_pwdn = <0x30 0x4 0x11 0x0 0x0 0x1 0x0>;
++				csi0_dev0_flash_en;
++				csi0_dev0_flash_mode;
++				csi0_dev0_af_pwdn;
++			};
++		};
++
++		vdevice@0 {
++			compatible = "allwinner,sun50i-vdevice";
++			pinctrl-names = "default";
++			test-gpios = <0x79 0xb 0x0 0x1 0x2 0x3 0x4>;
++			status = "okay";
++			device_type = "Vdevice";
++			pinctrl-0 = <0xb9>;
++		};
++
++		onewire_device@0 {
++			compatible = "w1-gpio";
++			gpios = <0x30 0x2 0x8 0x0 0x0 0x0 0x0>;
++			pinctrl-names = "default";
++			pinctrl-0 = <0xba>;
++			status = "okay";
++		};
++
++		ce@1c15000 {
++			compatible = "allwinner,sunxi-ce";
++			reg = <0x0 0x1c15000 0x0 0x80 0x0 0x1c15800 0x0 0x80>;
++			interrupts = <0x0 0x5e 0xff01 0x0 0x50 0xff01>;
++			clock-frequency = <0x11e1a300 0xbebc200>;
++			clocks = <0x7a 0x7b>;
++		};
++
++		deinterlace@0x01e00000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sunxi-deinterlace";
++			reg = <0x0 0x1e00000 0x0 0x77c>;
++			interrupts = <0x0 0x5d 0x4>;
++			clocks = <0x7c 0x4>;
++			status = "okay";
++			device_type = "di";
++		};
++
++		smartcard@0x01c2c400 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sunxi-scr";
++			reg = <0x0 0x1c2c400 0x0 0x100>;
++			interrupts = <0x0 0x53 0x4>;
++			clocks = <0x7d 0x7e>;
++			clock-frequency = <0x16e3600>;
++			pinctrl-names = "default";
++			pinctrl-0 = <0x7f>;
++			status = "okay";
++			device_type = "smc";
++			smc_used;
++			smc_rst;
++			smc_vppen;
++			smc_vppp;
++			smc_det;
++			smc_vccen;
++			smc_sck;
++			smc_sda;
++		};
++
++		nmi@0x01f00c00 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sunxi-nmi";
++			reg = <0x0 0x1f00c00 0x0 0x50>;
++			nmi_irq_ctrl = <0xc>;
++			nmi_irq_en = <0x40>;
++			nmi_irq_status = <0x10>;
++			nmi_irq_mask = <0x50>;
++			status = "okay";
++		};
++
++		pmu0@0 {
++			compatible = "allwinner,pmu0";
++			device_type = "pmu0";
++			pmu_batdeten = <0x1>;
++			pmu_init_chgend_rate = <0x14>;
++			pmu_init_chg_enabled = <0x1>;
++			pmu_init_adc_freq = <0x320>;
++			pmu_init_adcts_freq = <0x320>;
++			pmu_init_chg_pretime = <0x46>;
++			pmu_init_chg_csttime = <0x2d0>;
++			pmu_batt_cap_correct = <0x1>;
++			pmu_chg_end_on_en = <0x0>;
++			pmu_pwroff_vol = <0xce4>;
++			pmu_pwron_vol = <0xa28>;
++			pmu_powkey_off_delay_time = <0x0>;
++			pmu_pwrok_time = <0x40>;
++			pmu_reset_shutdown_en = <0x1>;
++			pmu_restvol_adjust_time = <0x3c>;
++			pmu_ocv_cou_adjust_time = <0x3c>;
++			pmu_vbusen_func = <0x1>;
++			pmu_reset = <0x0>;
++			pmu_IRQ_wakeup = <0x1>;
++			pmu_hot_shutdowm = <0x1>;
++			pmu_inshort = <0x0>;
++			pmu_bat_shutdown_ltf = <0xc80>;
++			pmu_bat_shutdown_htf = <0xed>;
++			status = "okay";
++			pmu_id = <0x6>;
++			pmu_twi_addr = <0x34>;
++			pmu_twi_id = <0x1>;
++			pmu_irq_id = <0x40>;
++			pmu_chg_ic_temp = <0x0>;
++			pmu_battery_rdc = <0x58>;
++			pmu_battery_cap = <0x12c0>;
++			pmu_runtime_chgcur = <0x1c2>;
++			pmu_suspend_chgcur = <0x5dc>;
++			pmu_shutdown_chgcur = <0x5dc>;
++			pmu_init_chgvol = <0x1068>;
++			pmu_ac_vol = <0xfa0>;
++			pmu_ac_cur = <0xdac>;
++			pmu_usbpc_vol = <0x1130>;
++			pmu_usbpc_cur = <0x1f4>;
++			pmu_battery_warning_level1 = <0xf>;
++			pmu_battery_warning_level2 = <0x0>;
++			pmu_chgled_func = <0x1>;
++			pmu_chgled_type = <0x0>;
++			pmu_bat_para1 = <0x0>;
++			pmu_bat_para2 = <0x0>;
++			pmu_bat_para3 = <0x0>;
++			pmu_bat_para4 = <0x0>;
++			pmu_bat_para5 = <0x0>;
++			pmu_bat_para6 = <0x0>;
++			pmu_bat_para7 = <0x1>;
++			pmu_bat_para8 = <0x1>;
++			pmu_bat_para9 = <0x2>;
++			pmu_bat_para10 = <0x3>;
++			pmu_bat_para11 = <0x4>;
++			pmu_bat_para12 = <0xa>;
++			pmu_bat_para13 = <0x11>;
++			pmu_bat_para14 = <0x1a>;
++			pmu_bat_para15 = <0x29>;
++			pmu_bat_para16 = <0x2e>;
++			pmu_bat_para17 = <0x33>;
++			pmu_bat_para18 = <0x38>;
++			pmu_bat_para19 = <0x3b>;
++			pmu_bat_para20 = <0x41>;
++			pmu_bat_para21 = <0x45>;
++			pmu_bat_para22 = <0x4b>;
++			pmu_bat_para23 = <0x4f>;
++			pmu_bat_para24 = <0x53>;
++			pmu_bat_para25 = <0x59>;
++			pmu_bat_para26 = <0x5f>;
++			pmu_bat_para27 = <0x62>;
++			pmu_bat_para28 = <0x64>;
++			pmu_bat_para29 = <0x64>;
++			pmu_bat_para30 = <0x64>;
++			pmu_bat_para31 = <0x64>;
++			pmu_bat_para32 = <0x64>;
++			pmu_bat_temp_enable = <0x1>;
++			pmu_bat_charge_ltf = <0x8d5>;
++			pmu_bat_charge_htf = <0x184>;
++			pmu_bat_temp_para1 = <0x1d2a>;
++			pmu_bat_temp_para2 = <0x1180>;
++			pmu_bat_temp_para3 = <0xdbe>;
++			pmu_bat_temp_para4 = <0xae2>;
++			pmu_bat_temp_para5 = <0x8af>;
++			pmu_bat_temp_para6 = <0x6fc>;
++			pmu_bat_temp_para7 = <0x5a8>;
++			pmu_bat_temp_para8 = <0x3c9>;
++			pmu_bat_temp_para9 = <0x298>;
++			pmu_bat_temp_para10 = <0x1d2>;
++			pmu_bat_temp_para11 = <0x189>;
++			pmu_bat_temp_para12 = <0x14d>;
++			pmu_bat_temp_para13 = <0x11b>;
++			pmu_bat_temp_para14 = <0xf2>;
++			pmu_bat_temp_para15 = <0xb3>;
++			pmu_bat_temp_para16 = <0x86>;
++			pmu_powkey_off_time = <0x1770>;
++			pmu_powkey_off_func = <0x0>;
++			pmu_powkey_off_en = <0x1>;
++			pmu_powkey_long_time = <0x5dc>;
++			pmu_powkey_on_time = <0x3e8>;
++			power_start = <0x0>;
++		};
++
++		regu@0 {
++			compatible = "allwinner,pmu0_regu";
++			regulator_count = <0x17>;
++			status = "okay";
++			device_type = "pmu0_regu";
++			regulator1 = "axp81x_dcdc1 none vcc-nand vcc-emmc vcc-sdc vcc-usb-30 vcc-io vcc-pd";
++			regulator2 = "axp81x_dcdc2 none vdd-cpua";
++			regulator3 = "axp81x_dcdc3 none";
++			regulator4 = "axp81x_dcdc4 none";
++			regulator5 = "axp81x_dcdc5 none vcc-dram";
++			regulator6 = "axp81x_dcdc6 none vdd-sys";
++			regulator7 = "axp81x_dcdc7 none";
++			regulator8 = "axp81x_rtc none";
++			regulator9 = "axp81x_aldo1 none vdd-csi-led iovdd-csi vcc-pe";
++			regulator10 = "axp81x_aldo2 none vcc-pl";
++			regulator11 = "axp81x_aldo3 none vcc-avcc vcc-pll";
++			regulator12 = "axp81x_dldo1 none vcc-hdmi-33";
++			regulator13 = "axp81x_dldo2 none vcc-mipi";
++			regulator14 = "axp81x_dldo3 none avdd-csi";
++			regulator15 = "axp81x_dldo4 none vcc-deviceio";
++			regulator16 = "axp81x_eldo1 none vcc-cpvdd vcc-wifi-io vcc-pc vcc-pg";
++			regulator17 = "axp81x_eldo2 none vcc-lcd-0";
++			regulator18 = "axp81x_eldo3 none dvdd-csi-18";
++			regulator19 = "axp81x_fldo1 none vcc-hsic-12";
++			regulator20 = "axp81x_fldo2 none vdd-cpus";
++			regulator21 = "axp81x_gpio0ldo none vcc-ctp";
++			regulator22 = "axp81x_gpio1ldo none";
++			regulator23 = "axp81x_dc1sw none vcc-lvds vcc-dsi-33";
++		};
++
++		nand0@01c03000 {
++			compatible = "allwinner,sun50i-nand";
++			device_type = "nand0";
++			reg = <0x0 0x1c03000 0x0 0x1000>;
++			interrupts = <0x0 0x46 0x4>;
++			clocks = <0x4 0x80>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x83>;
++			nand0_regulator1 = "vcc-nand";
++			nand0_regulator2 = "none";
++			nand0_cache_level = <0x55aaaa55>;
++			nand0_flush_cache_num = <0x55aaaa55>;
++			nand0_capacity_level = <0x55aaaa55>;
++			nand0_id_number_ctl = <0x55aaaa55>;
++			nand0_print_level = <0x55aaaa55>;
++			nand0_p0 = <0x55aaaa55>;
++			nand0_p1 = <0x55aaaa55>;
++			nand0_p2 = <0x55aaaa55>;
++			nand0_p3 = <0x55aaaa55>;
++			status = "disabled";
++			nand0_support_2ch = <0x0>;
++			pinctrl-0 = <0xab 0xac>;
++		};
++
++		thermal_sensor {
++			compatible = "allwinner,thermal_sensor";
++			reg = <0x0 0x1c25000 0x0 0x400>;
++			interrupts = <0x0 0x1f 0x0>;
++			clocks = <0x6 0x84>;
++			sensor_num = <0x3>;
++			shut_temp = <0x78>;
++			status = "okay";
++
++			combine0 {
++				#thermal-sensor-cells = <0x1>;
++				combine_cnt = <0x3>;
++				combine_type = "max";
++				combine_chn = <0x0 0x1 0x2>;
++				linux,phandle = <0x85>;
++				phandle = <0x85>;
++			};
++		};
++
++		cpu_budget_cool {
++			compatible = "allwinner,budget_cooling";
++			#cooling-cells = <0x2>;
++			status = "okay";
++			state_cnt = <0x8>;
++			cluster_num = <0x1>;
++			/*  1152000   4 cores */
++			state0 = <0x119400 0x4>;
++			/*  1008000   4 cores */
++			state1 = <0xf6180 0x4>;
++			/*   912000   4 cores */
++			state2 = <0xdea80 0x4>;
++			/*   816000   4 cores */
++			state3 = <0xc7380 0x4>;
++			/*   720000   4 cores */
++			state4 = <0xafc80 0x4>;
++			/*   624000   3 cores */
++			state5 = <0x98580 0x3>;
++			/*   528000   2 cores */
++			state6 = <0x80e80 0x2>;
++			/*   480000    1 core */
++			state7 = <0x75300 0x1>;
++			linux,phandle = <0x87>;
++			phandle = <0x87>;
++		};
++
++		gpu_cooling {
++			compatible = "allwinner,gpu_cooling";
++			reg = <0x0 0x0 0x0 0x0>;
++			#cooling-cells = <0x2>;
++			status = "okay";
++			state_cnt = <0x3>;
++			state0 = <0x0>;
++			state1 = <0x168>;
++			state2 = <0x90>;
++			linux,phandle = <0x8c>;
++			phandle = <0x8c>;
++		};
++
++		thermal-zones {
++
++			soc_thermal {
++				polling-delay-passive = <0x1f4>;
++				polling-delay = <0x7d0>;
++				thermal-sensors = <0x85 0x0>;
++
++				trips {
++
++					t0 {
++						temperature = <0x50>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x86>;
++						phandle = <0x86>;
++					};
++
++					t1 {
++						temperature = <0x55>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x88>;
++						phandle = <0x88>;
++					};
++
++					t2 {
++						temperature = <0x5a>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x89>;
++						phandle = <0x89>;
++					};
++
++					t3 {
++						temperature = <0x5f>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x8a>;
++						phandle = <0x8a>;
++					};
++
++					t4 {
++						temperature = <0x55>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x8b>;
++						phandle = <0x8b>;
++					};
++
++					t5 {
++						temperature = <0x5a>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x8d>;
++						phandle = <0x8d>;
++					};
++
++					t6 {
++						temperature = <0x6c>;
++						type = "critical";
++						hysteresis = <0x0>;
++					};
++				};
++
++				cooling-maps {
++
++					bind0 {
++						contribution = <0x0>;
++						trip = <0x86>;
++						cooling-device = <0x87 0x1 0x1>;
++					};
++
++					bind1 {
++						contribution = <0x0>;
++						trip = <0x88>;
++						cooling-device = <0x87 0x2 0x2>;
++					};
++
++					bind2 {
++						contribution = <0x0>;
++						trip = <0x89>;
++						cooling-device = <0x87 0x3 0x6>;
++					};
++
++					bind3 {
++						contribution = <0x0>;
++						trip = <0x8a>;
++						cooling-device = <0x87 0x7 0x9>;
++					};
++
++					bind4 {
++						contribution = <0x0>;
++						trip = <0x8b>;
++						cooling-device = <0x8c 0x1 0x1>;
++					};
++
++					bind5 {
++						contribution = <0x0>;
++						trip = <0x8d>;
++						cooling-device = <0x8c 0x2 0x2>;
++					};
++				};
++			};
++		};
++
++		keyboard {
++			compatible = "allwinner,keyboard_2000mv";
++			reg = <0x0 0x1c21800 0x0 0x400>;
++			interrupts = <0x0 0x1e 0x0>;
++			status = "okay";
++			key_cnt = <0x5>;
++			key1 = <0xf0 0x73>;
++			key2 = <0x1f4 0x72>;
++			key3 = <0x2bc 0x8b>;
++			key4 = <0x37a 0x1c>;
++			key5 = <0x7d0 0x66>;
++		};
++
++		eth@01c30000 {
++			compatible = "allwinner,sunxi-gmac";
++			reg = <0x0 0x1c30000 0x0 0x10000 0x0 0x1c00000 0x0 0x30>;
++			pinctrl-names = "default";
++			interrupts = <0x0 0x52 0x4>;
++			interrupt-names = "gmacirq";
++			clocks = <0x8f>;
++			clock-names = "gmac";
++			phy-mode = "rgmii";
++			tx-delay = <0x3>;
++			rx-delay = <0x0>;
++			gmac_power1 = "axp81x_dc1sw:0";
++			status = "okay";
++			device_type = "gmac0";
++			pinctrl-0 = <0x9e>;
++			gmac_power2;
++			gmac_power3;
++		};
++
++		product {
++			device_type = "product";
++			version = "100";
++			machine = "evb";
++		};
++
++		platform {
++			device_type = "platform";
++			eraseflag = <0x1>;
++		};
++
++		target {
++			device_type = "target";
++			boot_clock = <0x3f0>;
++			storage_type = <0xffffffff>;
++			burn_key = <0x0>;
++		};
++
++		power_sply {
++			device_type = "power_sply";
++			dcdc1_vol = <0xf4f24>;
++			dcdc2_vol = <0xf468c>;
++			dcdc6_vol = <0xf468c>;
++			aldo1_vol = <0xaf0>;
++			aldo2_vol = <0xf4948>;
++			aldo3_vol = <0xf4df8>;
++			dldo1_vol = <0xce4>;
++			dldo2_vol = <0xce4>;
++			dldo3_vol = <0xaf0>;
++			dldo4_vol = <0xf4f24>;
++			eldo1_vol = <0xf4948>;
++			eldo2_vol = <0x708>;
++			eldo3_vol = <0x708>;
++			fldo1_vol = <0x4b0>;
++			fldo2_vol = <0xf468c>;
++			gpio0_vol = <0xc1c>;
++		};
++
++		card_boot {
++			device_type = "card_boot";
++			logical_start = <0xa000>;
++			sprite_gpio0;
++		};
++
++		pm_para {
++			device_type = "pm_para";
++			standby_mode = <0x1>;
++		};
++
++		card0_boot_para {
++			device_type = "card0_boot_para";
++			card_ctrl = <0x0>;
++			card_high_speed = <0x1>;
++			card_line = <0x4>;
++			pinctrl-0 = <0x99>;
++		};
++
++		card2_boot_para {
++			device_type = "card2_boot_para";
++			sdc_io_1v8 = <0x1>;
++			card_ctrl = <0x2>;
++			card_high_speed = <0x1>;
++			card_line = <0x8>;
++			pinctrl-0 = <0x9a>;
++			sdc_ex_dly_used = <0x2>;
++		};
++
++		twi_para {
++			device_type = "twi_para";
++			twi_port = <0x0>;
++			pinctrl-0 = <0x9b>;
++		};
++
++		uart_para {
++			device_type = "uart_para";
++			uart_debug_port = <0x0>;
++			pinctrl-0 = <0x9c>;
++		};
++
++		jtag_para {
++			device_type = "jtag_para";
++			jtag_enable = <0x1>;
++			pinctrl-0 = <0x9d>;
++		};
++
++		clock {
++			device_type = "clock";
++			pll4 = <0x12c>;
++			pll6 = <0x258>;
++			pll8 = <0x168>;
++			pll9 = <0x129>;
++			pll10 = <0x108>;
++		};
++
++		rtp_para {
++			device_type = "rtp_para";
++			rtp_used = <0x0>;
++			rtp_screen_size = <0x5>;
++			rtp_regidity_level = <0x5>;
++			rtp_press_threshold_enable = <0x0>;
++			rtp_press_threshold = <0x1f40>;
++			rtp_sensitive_level = <0xf>;
++			rtp_exchange_x_y_flag = <0x0>;
++		};
++
++		ctp {
++			device_type = "ctp";
++			compatible = "allwinner,sun50i-ctp-para";
++			status = "disabled";
++			ctp_name = "gt911_DB";
++			ctp_twi_id = <0x0>;
++			ctp_twi_addr = <0x40>;
++			ctp_screen_max_x = <0x400>;
++			ctp_screen_max_y = <0x258>;
++			ctp_revert_x_flag = <0x1>;
++			ctp_revert_y_flag = <0x1>;
++			ctp_exchange_x_y_flag = <0x0>;
++			ctp_int_port = <0x30 0x7 0x4 0x6 0xffffffff 0xffffffff 0xffffffff>;
++			ctp_wakeup = <0x30 0x7 0xb 0x1 0xffffffff 0xffffffff 0x1>;
++			ctp_power_ldo = "vcc-ctp";
++			ctp_power_ldo_vol = <0xce4>;
++			ctp_power_io;
++		};
++
++		ctp_list {
++			device_type = "ctp_list";
++			compatible = "allwinner,sun50i-ctp-list";
++			status = "okay";
++			gslX680new = <0x1>;
++			gt9xx_ts = <0x0>;
++			gt9xxf_ts = <0x1>;
++			gt9xxnew_ts = <0x0>;
++			gt82x = <0x1>;
++			zet622x = <0x1>;
++			aw5306_ts = <0x1>;
++		};
++
++		tkey_para {
++			device_type = "tkey_para";
++			tkey_used = <0x0>;
++			tkey_twi_id;
++			tkey_twi_addr;
++			tkey_int;
++		};
++
++		motor_para {
++			device_type = "motor_para";
++			motor_used = <0x0>;
++			motor_shake = <0x31 0xfffe 0x3 0x1 0xffffffff 0xffffffff 0x1>;
++		};
++
++		tvout_para {
++			device_type = "tvout_para";
++			tvout_used;
++			tvout_channel_num;
++			tv_en;
++		};
++
++		tvin_para {
++			device_type = "tvin_para";
++			tvin_used;
++			tvin_channel_num;
++		};
++
++		serial_feature {
++			device_type = "serial_feature";
++			sn_filename = "sn.txt";
++		};
++
++		gsensor {
++			device_type = "gsensor";
++			compatible = "allwinner,sun50i-gsensor-para";
++			status = "okay";
++			gsensor_twi_id = <0x1>;
++			gsensor_twi_addr = <0x1d>;
++			gsensor_vcc_io = "vcc-deviceio";
++			gsensor_vcc_io_val = <0xce4>;
++			gsensor_int1 = <0x30 0x7 0x5 0x6 0x1 0xffffffff 0xffffffff>;
++			gsensor_int2 = <0x30 0x7 0x6 0x6 0x1 0xffffffff 0xffffffff>;
++		};
++
++		gsensor_list {
++			device_type = "gsensor_list";
++			compatible = "allwinner,sun50i-gsensor-list-para";
++			gsensor_list__used = <0x1>;
++			lsm9ds0_acc_mag = <0x1>;
++			bma250 = <0x1>;
++			mma8452 = <0x1>;
++			mma7660 = <0x1>;
++			mma865x = <0x1>;
++			afa750 = <0x1>;
++			lis3de_acc = <0x1>;
++			lis3dh_acc = <0x1>;
++			kxtik = <0x1>;
++			dmard10 = <0x0>;
++			dmard06 = <0x1>;
++			mxc622x = <0x1>;
++			fxos8700 = <0x1>;
++			lsm303d = <0x0>;
++			sc7a30 = <0x1>;
++		};
++
++		3g_para {
++			device_type = "3g_para";
++			3g_used = <0x0>;
++			3g_usbc_num = <0x2>;
++			3g_uart_num = <0x0>;
++			bb_vbat = <0x79 0xb 0x3 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_host_wake = <0x79 0xc 0x0 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_on = <0x79 0xc 0x1 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_pwr_on = <0x79 0xc 0x3 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_wake = <0x79 0xc 0x4 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_rf_dis = <0x79 0xc 0x5 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_rst = <0x79 0xc 0x6 0x1 0xffffffff 0xffffffff 0x0>;
++			3g_int;
++		};
++
++		gyroscopesensor {
++			device_type = "gyroscopesensor";
++			compatible = "allwinner,sun50i-gyr_sensors-para";
++			status = "disabled";
++			gy_twi_id = <0x2>;
++			gy_twi_addr = <0x6a>;
++			gy_int1 = <0x30 0x0 0xa 0x6 0x1 0xffffffff 0xffffffff>;
++			gy_int2;
++		};
++
++		gy_list {
++			device_type = "gy_list";
++			compatible = "allwinner,sun50i-gyr_sensors-list-para";
++			status = "disabled";
++			lsm9ds0_gyr = <0x1>;
++			l3gd20_gyr = <0x0>;
++			bmg160_gyr = <0x1>;
++		};
++
++		lightsensor {
++			device_type = "lightsensor";
++			compatible = "allwinner,sun50i-lsensors-para";
++			status = "disabled";
++			ls_twi_id = <0x2>;
++			ls_twi_addr = <0x23>;
++			ls_int = <0x30 0x0 0xc 0x6 0x1 0xffffffff 0xffffffff>;
++		};
++
++		ls_list {
++			device_type = "ls_list";
++			compatible = "allwinner,sun50i-lsensors-list-para";
++			status = "disabled";
++			ltr_501als = <0x1>;
++			jsa1212 = <0x0>;
++			jsa1127 = <0x1>;
++			stk3x1x = <0x0>;
++		};
++
++		compasssensor {
++			device_type = "compasssensor";
++			compatible = "allwinner,sun50i-compass-para";
++			status = "disabled";
++			compass_twi_id = <0x2>;
++			compass_twi_addr = <0xd>;
++			compass_int = <0x30 0x0 0xb 0x6 0x1 0xffffffff 0xffffffff>;
++		};
++
++		compass_list {
++			device_type = "compass_list";
++			compatible = "allwinner,sun50i-compass-list-para";
++			status = "disabled";
++			lsm9ds0 = <0x1>;
++			lsm303d = <0x0>;
++		};
++
++		recovery_key {
++			device_type = "recovery_key";
++			key_max = <0xc>;
++			key_min = <0xa>;
++		};
++
++		fastboot_key {
++			device_type = "fastboot_key";
++			key_max = <0x6>;
++			key_min = <0x4>;
++		};
++	};
++
++	aliases {
++		serial0 = "/soc@01c00000/uart@01c28000";
++		serial1 = "/soc@01c00000/uart@01c28400";
++		serial2 = "/soc@01c00000/uart@01c28800";
++		serial3 = "/soc@01c00000/uart@01c28c00";
++		serial4 = "/soc@01c00000/uart@01c29000";
++		twi0 = "/soc@01c00000/twi@0x01c2ac00";
++		twi1 = "/soc@01c00000/twi@0x01c2b000";
++		twi2 = "/soc@01c00000/twi@0x01c2b400";
++		spi0 = "/soc@01c00000/spi@01c68000";
++		spi1 = "/soc@01c00000/spi@01c69000";
++		global_timer0 = "/soc@01c00000/timer@1c20c00";
++		cci0 = "/soc@01c00000/cci@0x01cb3000";
++		csi_res0 = "/soc@01c00000/csi_res@0x01cb0000";
++		vfe0 = "/soc@01c00000/vfe@0";
++		mmc0 = "/soc@01c00000/sdmmc@01c0f000";
++		mmc2 = "/soc@01c00000/sdmmc@01C11000";
++		nand0 = "/soc@01c00000/nand0@01c03000";
++		disp = "/soc@01c00000/disp@01000000";
++		lcd0 = "/soc@01c00000/lcd0@01c0c000";
++		hdmi = "/soc@01c00000/hdmi@01ee0000";
++		pwm = "/soc@01c00000/pwm@01c21400";
++		pwm0 = "/soc@01c00000/pwm0@01c21400";
++		s_pwm = "/soc@01c00000/s_pwm@1f03800";
++		spwm0 = "/soc@01c00000/spwm0@0x01f03800";
++		boot_disp = "/soc@01c00000/boot_disp";
++	};
++
++	chosen {
++		bootargs = "earlyprintk=sunxi-uart,0x01c28000 loglevel=8 initcall_debug=1 console=ttyS0 init=/init";
++		linux,initrd-start = <0x0 0x0>;
++		linux,initrd-end = <0x0 0x0>;
++	};
++
++	cpus {
++		#address-cells = <0x2>;
++		#size-cells = <0x0>;
++
++		cpu@0 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x0>;
++			enable-method = "psci";
++			cpufreq_tbl = <0x000639C0 0x00075300 0x0007b0c0 0x00080e80 0x0008ca00 0x000927c0 0x00098580 0x0009e340 0x000a4100 0x000afc80 0x000bb800 0x000c7380 0x000d2f00 0x000dea80 0x000ea600 0x000f6180 0x00101d00 0x0010d880 0x00119400 0x00124f80 0x00148200>;
++			clock-latency = <0x1e8480>;
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		cpu@1 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x1>;
++			enable-method = "psci";
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		cpu@2 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x2>;
++			enable-method = "psci";
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		cpu@3 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x3>;
++			enable-method = "psci";
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		idle-states {
++			entry-method = "arm,psci";
++
++			cpu-sleep-0 {
++				compatible = "arm,idle-state";
++				arm,psci-suspend-param = <0x10000>;
++				entry-latency-us = <0x28>;
++				exit-latency-us = <0x64>;
++				min-residency-us = <0x96>;
++				linux,phandle = <0x90>;
++				phandle = <0x90>;
++			};
++
++			cluster-sleep-0 {
++				compatible = "arm,idle-state";
++				arm,psci-suspend-param = <0x1010000>;
++				entry-latency-us = <0x1f4>;
++				exit-latency-us = <0x3e8>;
++				min-residency-us = <0x9c4>;
++				linux,phandle = <0x91>;
++				phandle = <0x91>;
++			};
++
++			sys-sleep-0 {
++				compatible = "arm,idle-state";
++				arm,psci-suspend-param = <0x2010000>;
++				entry-latency-us = <0x3e8>;
++				exit-latency-us = <0x7d0>;
++				min-residency-us = <0x1194>;
++				linux,phandle = <0x92>;
++				phandle = <0x92>;
++			};
++		};
++	};
++
++	psci {
++		compatible = "arm,psci-0.2";
++		method = "smc";
++		psci_version = <0x84000000>;
++		cpu_suspend = <0xc4000001>;
++		cpu_off = <0x84000002>;
++		cpu_on = <0xc4000003>;
++		affinity_info = <0xc4000004>;
++		migrate = <0xc4000005>;
++		migrate_info_type = <0x84000006>;
++		migrate_info_up_cpu = <0xc4000007>;
++		system_off = <0x84000008>;
++		system_reset = <0x84000009>;
++	};
++
++	n_brom {
++		compatible = "allwinner,n-brom";
++		reg = <0x0 0x0 0x0 0xc000>;
++	};
++
++	s_brom {
++		compatible = "allwinner,s-brom";
++		reg = <0x0 0x0 0x0 0x10000>;
++	};
++
++	sram_a1 {
++		compatible = "allwinner,sram_a1";
++		reg = <0x0 0x10000 0x0 0x8000>;
++	};
++
++	sram_a2 {
++		compatible = "allwinner,sram_a2";
++		reg = <0x0 0x40000 0x0 0x14000>;
++	};
++
++	prcm {
++		compatible = "allwinner,prcm";
++		reg = <0x0 0x1f01400 0x0 0x400>;
++	};
++
++	cpuscfg {
++		compatible = "allwinner,cpuscfg";
++		reg = <0x0 0x1f01c00 0x0 0x400>;
++	};
++
++	ion {
++		compatible = "allwinner,sunxi-ion";
++
++		system_contig {
++			type = <0x1>;
++		};
++
++		cma {
++			type = <0x4>;
++		};
++
++		system {
++			type = <0x0>;
++		};
++	};
++
++	dram {
++		compatible = "allwinner,dram";
++		clocks = <0x93 0x94>;
++		clock-names = "pll_ddr0", "pll_ddr1";
++		dram_clk = <0x2a0>;
++		dram_type = <0x3>;
++		dram_zq = <0x3b3bdd>;
++		dram_odt_en = <0x1>;
++		dram_para1 = <0x10e40400>;
++		dram_para2 = <0x4000000>;
++		dram_mr0 = <0x1c70>;
++		dram_mr1 = <0x40>;
++		dram_mr2 = <0x18>;
++		dram_mr3 = <0x0>;
++		dram_tpr0 = <0x48a192>;
++		dram_tpr1 = <0x1c2418d>;
++		dram_tpr2 = <0x76051>;
++		dram_tpr3 = <0x50005dc>;
++		dram_tpr4 = <0x0>;
++		dram_tpr5 = <0x0>;
++		dram_tpr6 = <0x0>;
++		dram_tpr7 = <0x2a066198>;
++		dram_tpr8 = <0x0>;
++		dram_tpr9 = <0x0>;
++		dram_tpr10 = <0x8808>;
++		dram_tpr11 = <0x40a60066>;
++		dram_tpr12 = <0x55550000>;
++		dram_tpr13 = <0x4000903>;
++		device_type = "dram";
++	};
++
++	memory@40000000 {
++		device_type = "memory";
++		reg = <0x0 0x41000000 0x0 0x3f000000>;
++	};
++
++	interrupt-controller@1c81000 {
++		compatible = "arm,cortex-a15-gic", "arm,cortex-a9-gic";
++		#interrupt-cells = <0x3>;
++		#address-cells = <0x0>;
++		device_type = "gic";
++		interrupt-controller;
++		reg = <0x0 0x1c81000 0x0 0x1000 0x0 0x1c82000 0x0 0x2000 0x0 0x1c84000 0x0 0x2000 0x0 0x1c86000 0x0 0x2000>;
++		interrupts = <0x1 0x9 0xf04>;
++		linux,phandle = <0x1>;
++		phandle = <0x1>;
++	};
++
++	sunxi-chipid@1c14200 {
++		compatible = "allwinner,sunxi-chipid";
++		device_type = "chipid";
++		reg = <0x0 0x1c14200 0x0 0x400>;
++	};
++
++	timer {
++		compatible = "arm,armv8-timer";
++		interrupts = <0x1 0xd 0xff01 0x1 0xe 0xff01 0x1 0xb 0xff01 0x1 0xa 0xff01>;
++		clock-frequency = <0x16e3600>;
++	};
++
++	pmu {
++		compatible = "arm,armv8-pmuv3";
++		interrupts = <0x0 0x78 0x4 0x0 0x79 0x4 0x0 0x7a 0x4 0x0 0x7b 0x4>;
++	};
++
++	dvfs_table {
++		compatible = "allwinner,dvfs_table";
++		max_freq = <0x44aa2000>;
++		min_freq = <0x1c9c3800>;
++		lv_count = <0x8>;
++		lv1_freq = <0x44aa2000>;
++		lv1_volt = <0x514>;
++		lv2_freq = <0x41cdb400>;
++		lv2_volt = <0x4ec>;
++		lv3_freq = <0x3ef14800>;
++		lv3_volt = <0x4d8>;
++		lv4_freq = <0x3c14dc00>;
++		lv4_volt = <0x4b0>;
++		lv5_freq = <0x39387000>;
++		lv5_volt = <0x488>;
++		lv6_freq = <0x365c0400>;
++		lv6_volt = <0x460>;
++		lv7_freq = <0x30a32c00>;
++		lv7_volt = <0x438>;
++		lv8_freq = <0x269fb200>;
++		lv8_volt = <0x410>;
++		device_type = "dvfs_table";
++	};
++
++	dramfreq {
++		compatible = "allwinner,sunxi-dramfreq";
++		reg = <0x0 0x1c62000 0x0 0x1000 0x0 0x1c63000 0x0 0x1000 0x0 0x1c20000 0x0 0x800>;
++		clocks = <0x93 0x94 0x95>;
++		status = "okay";
++	};
++
++	uboot {
++	};
++
++	gpu@0x01c40000 {
++		compatible = "arm,mali-400", "arm,mali-utgard";
++		reg = <0x0 0x1c40000 0x0 0x10000>;
++		interrupts = <0x0 0x61 0x4 0x0 0x62 0x4 0x0 0x63 0x4 0x0 0x64 0x4 0x0 0x66 0x4 0x0 0x67 0x4>;
++		interrupt-names = "IRQGP", "IRQGPMMU", "IRQPP0", "IRQPPMMU0", "IRQPP1", "IRQPPMMU1";
++		clocks = <0x96 0x97>;
++		device_type = "gpu_mali400_0";
++		normal_freq = <0x198>;
++		scene_ctrl_status = <0x0>;
++		temp_ctrl_status = <0x1>;
++	};
++
++	wlan {
++		compatible = "allwinner,sunxi-wlan";
++		wlan_io_regulator = "vcc-wifi-io";
++		wlan_busnum = <0x1>;
++		status = "okay";
++		device_type = "wlan";
++		clocks;
++		wlan_power;
++		wlan_regon = <0x79 0xb 0x2 0x1 0xffffffff 0xffffffff 0x0>;
++		wlan_hostwake = <0x79 0xb 0x3 0x6 0xffffffff 0xffffffff 0x0>;
++		efuse_map_path = "wifi_efuse_8189e_for_MB1019Q5.map";
++	};
++
++	bt {
++		compatible = "allwinner,sunxi-bt";
++		bt_io_regulator = "vcc-wifi-io";
++		status = "okay";
++		device_type = "bt";
++		clocks;
++		bt_power;
++		bt_rst_n = <0x79 0xb 0x4 0x1 0xffffffff 0xffffffff 0x0>;
++	};
++
++	btlpm {
++		compatible = "allwinner,sunxi-btlpm";
++		uart_index = <0x1>;
++		status = "okay";
++		device_type = "btlpm";
++		bt_wake = <0x79 0xb 0x6 0x1 0xffffffff 0xffffffff 0x1>;
++		bt_hostwake = <0x79 0xb 0x5 0x6 0xffffffff 0xffffffff 0x0>;
++	};
++};
+diff --git a/arch/arm64/boot/dts/sun50iw1p1-pine64.dts b/arch/arm64/boot/dts/sun50iw1p1-pine64.dts
+new file mode 100644
+index 00000000..1d9ba808
+--- /dev/null
++++ b/arch/arm64/boot/dts/sun50iw1p1-pine64.dts
+@@ -0,0 +1,3433 @@
++/dts-v1/;
++
++/memreserve/	0x0000000045000000 0x0000000000200000;
++/memreserve/	0x0000000041010000 0x0000000000010000;
++/memreserve/	0x0000000041020000 0x0000000000000800;
++/memreserve/	0x0000000040100000 0x0000000000004000;
++/memreserve/	0x0000000040104000 0x0000000000001000;
++/memreserve/	0x0000000040105000 0x0000000000001000;
++/ {
++	model = "Pine64";
++	compatible = "pine64,pine64";
++	interrupt-parent = <0x1>;
++	#address-cells = <0x2>;
++	#size-cells = <0x2>;
++
++	leds {
++		compatible = "gpio-leds";
++		pinctrl-names = "default";
++		pinctrl-0 = <&status_led>;
++		status {
++			label = "system_status";
++			gpios = <0x79 0xb 7 0x1 0xffffffff 0xffffffff 0x0>; /* PL7 */
++			linux,default-trigger = "heartbeat";
++		};
++	};
++
++	clocks {
++		compatible = "allwinner,sunxi-clk-init";
++		device_type = "clocks";
++		#address-cells = <0x2>;
++		#size-cells = <0x2>;
++		ranges;
++		reg = <0x0 0x1c20000 0x0 0x320 0x0 0x1f01400 0x0 0xb0 0x0 0x1f00060 0x0 0x4>;
++
++		losc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-clock";
++			clock-frequency = <0x8000>;
++			clock-output-names = "losc";
++			linux,phandle = <0xc>;
++			phandle = <0xc>;
++		};
++
++		iosc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-clock";
++			clock-frequency = <0xf42400>;
++			clock-output-names = "iosc";
++			linux,phandle = <0xd>;
++			phandle = <0xd>;
++		};
++
++		hosc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-clock";
++			clock-frequency = <0x16e3600>;
++			clock-output-names = "hosc";
++			linux,phandle = <0x6>;
++			phandle = <0x6>;
++		};
++
++		pll_cpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_cpu";
++		};
++
++		pll_audio {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x1770000>;
++			clock-output-names = "pll_audio";
++			linux,phandle = <0x2>;
++			phandle = <0x2>;
++		};
++
++		pll_video0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "pll_video0";
++			linux,phandle = <0x3>;
++			phandle = <0x3>;
++		};
++
++		pll_ve {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_ve";
++			linux,phandle = <0x16>;
++			phandle = <0x16>;
++		};
++
++		pll_ddr0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_ddr0";
++			linux,phandle = <0x93>;
++			phandle = <0x93>;
++		};
++
++		pll_periph0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_periph0";
++			linux,phandle = <0x4>;
++			phandle = <0x4>;
++		};
++
++		pll_periph1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_periph1";
++			linux,phandle = <0x5>;
++			phandle = <0x5>;
++		};
++
++		pll_video1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "pll_video1";
++		};
++
++		pll_gpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_gpu";
++			linux,phandle = <0x96>;
++			phandle = <0x96>;
++		};
++
++		pll_mipi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_mipi";
++			linux,phandle = <0x8>;
++			phandle = <0x8>;
++		};
++
++		pll_hsic {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_hsic";
++			linux,phandle = <0x3a>;
++			phandle = <0x3a>;
++		};
++
++		pll_de {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "pll_de";
++			linux,phandle = <0x7>;
++			phandle = <0x7>;
++		};
++
++		pll_ddr1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_ddr1";
++			linux,phandle = <0x94>;
++			phandle = <0x94>;
++		};
++
++		pll_audiox8 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x2>;
++			clock-mult = <0x8>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_audiox8";
++		};
++
++		pll_audiox4 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x2>;
++			clock-mult = <0x8>;
++			clock-div = <0x2>;
++			clock-output-names = "pll_audiox4";
++			linux,phandle = <0x3c>;
++			phandle = <0x3c>;
++		};
++
++		pll_audiox2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x2>;
++			clock-mult = <0x8>;
++			clock-div = <0x4>;
++			clock-output-names = "pll_audiox2";
++		};
++
++		pll_video0x2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x3>;
++			clock-mult = <0x2>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_video0x2";
++		};
++
++		pll_periph0x2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x4>;
++			clock-mult = <0x2>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_periph0x2";
++			linux,phandle = <0x7b>;
++			phandle = <0x7b>;
++		};
++
++		pll_periph1x2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x5>;
++			clock-mult = <0x2>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_periph1x2";
++			linux,phandle = <0x5a>;
++			phandle = <0x5a>;
++		};
++
++		pll_periph0d2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x4>;
++			clock-mult = <0x1>;
++			clock-div = <0x2>;
++			clock-output-names = "pll_periph0d2";
++		};
++
++		hoscd2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x6>;
++			clock-mult = <0x1>;
++			clock-div = <0x2>;
++			clock-output-names = "hoscd2";
++		};
++
++		cpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "cpu";
++		};
++
++		cpuapb {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "cpuapb";
++		};
++
++		axi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "axi";
++		};
++
++		pll_periphahb0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "pll_periphahb0";
++		};
++
++		ahb1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ahb1";
++			linux,phandle = <0x95>;
++			phandle = <0x95>;
++		};
++
++		apb1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "apb1";
++		};
++
++		apb2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "apb2";
++			linux,phandle = <0x7e>;
++			phandle = <0x7e>;
++		};
++
++		ahb2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ahb2";
++		};
++
++		ths {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ths";
++			linux,phandle = <0x84>;
++			phandle = <0x84>;
++		};
++
++		nand {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "nand";
++			linux,phandle = <0x80>;
++			phandle = <0x80>;
++		};
++
++		sdmmc0_mod {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc0_mod";
++			linux,phandle = <0x60>;
++			phandle = <0x60>;
++		};
++
++		sdmmc0_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc0_bus";
++			linux,phandle = <0x61>;
++			phandle = <0x61>;
++		};
++
++		sdmmc0_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc0_rst";
++			linux,phandle = <0x62>;
++			phandle = <0x62>;
++		};
++
++		sdmmc1_mod {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc1_mod";
++			linux,phandle = <0x65>;
++			phandle = <0x65>;
++		};
++
++		sdmmc1_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc1_bus";
++			linux,phandle = <0x66>;
++			phandle = <0x66>;
++		};
++
++		sdmmc1_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc1_rst";
++			linux,phandle = <0x67>;
++			phandle = <0x67>;
++		};
++
++		sdmmc2_mod {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc2_mod";
++			linux,phandle = <0x5b>;
++			phandle = <0x5b>;
++		};
++
++		sdmmc2_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc2_bus";
++			linux,phandle = <0x5c>;
++			phandle = <0x5c>;
++		};
++
++		sdmmc2_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc2_rst";
++			linux,phandle = <0x5d>;
++			phandle = <0x5d>;
++		};
++
++		ts {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ts";
++		};
++
++		ce {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ce";
++			linux,phandle = <0x7a>;
++			phandle = <0x7a>;
++		};
++
++		spi0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "spi0";
++			linux,phandle = <0x52>;
++			phandle = <0x52>;
++		};
++
++		spi1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "spi1";
++			linux,phandle = <0x56>;
++			phandle = <0x56>;
++		};
++
++		i2s0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "i2s0";
++			linux,phandle = <0x42>;
++			phandle = <0x42>;
++		};
++
++		i2s1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "i2s1";
++			linux,phandle = <0x47>;
++			phandle = <0x47>;
++		};
++
++		i2s2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "i2s2";
++			linux,phandle = <0x48>;
++			phandle = <0x48>;
++		};
++
++		spdif {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "spdif";
++			linux,phandle = <0x49>;
++			phandle = <0x49>;
++		};
++
++		usbphy0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbphy0";
++			linux,phandle = <0x32>;
++			phandle = <0x32>;
++		};
++
++		usbphy1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbphy1";
++			linux,phandle = <0x36>;
++			phandle = <0x36>;
++		};
++
++		usbhsic {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbhsic";
++			linux,phandle = <0x38>;
++			phandle = <0x38>;
++		};
++
++		usbhsic12m {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbhsic12m";
++			linux,phandle = <0x39>;
++			phandle = <0x39>;
++		};
++
++		usbohci1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbohci1";
++			linux,phandle = <0x3b>;
++			phandle = <0x3b>;
++		};
++
++		usbohci0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbohci0";
++			linux,phandle = <0x35>;
++			phandle = <0x35>;
++		};
++
++		de {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x7>;
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "de";
++			linux,phandle = <0x6a>;
++			phandle = <0x6a>;
++		};
++
++		tcon0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x8>;
++			clock-output-names = "tcon0";
++			linux,phandle = <0x6b>;
++			phandle = <0x6b>;
++		};
++
++		tcon1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x3>;
++			clock-output-names = "tcon1";
++			linux,phandle = <0x6e>;
++			phandle = <0x6e>;
++		};
++
++		deinterlace {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "deinterlace";
++			linux,phandle = <0x7c>;
++			phandle = <0x7c>;
++		};
++
++		csi_s {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "csi_s";
++			linux,phandle = <0x73>;
++			phandle = <0x73>;
++		};
++
++		csi_m {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "csi_m";
++			linux,phandle = <0x74>;
++			phandle = <0x74>;
++		};
++
++		csi_misc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "csi_misc";
++			linux,phandle = <0x75>;
++			phandle = <0x75>;
++		};
++
++		ve {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ve";
++			linux,phandle = <0x17>;
++			phandle = <0x17>;
++		};
++
++		adda {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "adda";
++			linux,phandle = <0x41>;
++			phandle = <0x41>;
++		};
++
++		addax4 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "addax4";
++		};
++
++		avs {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "avs";
++		};
++
++		hdmi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x3>;
++			clock-output-names = "hdmi";
++			linux,phandle = <0x6f>;
++			phandle = <0x6f>;
++		};
++
++		hdmi_slow {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "hdmi_slow";
++			linux,phandle = <0x70>;
++			phandle = <0x70>;
++		};
++
++		mbus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "mbus";
++		};
++
++		mipidsi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "mipidsi";
++			linux,phandle = <0x6d>;
++			phandle = <0x6d>;
++		};
++
++		gpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "gpu";
++			linux,phandle = <0x97>;
++			phandle = <0x97>;
++		};
++
++		usbehci_16 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbohci_16";
++		};
++
++		usbehci1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbehci1";
++			linux,phandle = <0x37>;
++			phandle = <0x37>;
++		};
++
++		usbehci0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbehci0";
++			linux,phandle = <0x34>;
++			phandle = <0x34>;
++		};
++
++		usbotg {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbotg";
++			linux,phandle = <0x33>;
++			phandle = <0x33>;
++		};
++
++		gmac {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "gmac";
++			linux,phandle = <0x8f>;
++			phandle = <0x8f>;
++		};
++
++		sdram {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdram";
++		};
++
++		dma {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "dma";
++			linux,phandle = <0xb>;
++			phandle = <0xb>;
++		};
++
++		hwspinlock_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "hwspinlock_rst";
++			linux,phandle = <0xf>;
++			phandle = <0xf>;
++		};
++
++		hwspinlock_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "hwspinlock_bus";
++			linux,phandle = <0x10>;
++			phandle = <0x10>;
++		};
++
++		msgbox {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "msgbox";
++			linux,phandle = <0xe>;
++			phandle = <0xe>;
++		};
++
++		lvds {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "lvds";
++			linux,phandle = <0x6c>;
++			phandle = <0x6c>;
++		};
++
++		uart0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart0";
++			linux,phandle = <0x18>;
++			phandle = <0x18>;
++		};
++
++		uart1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart1";
++			linux,phandle = <0x1b>;
++			phandle = <0x1b>;
++		};
++
++		uart2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart2";
++			linux,phandle = <0x1e>;
++			phandle = <0x1e>;
++		};
++
++		uart3 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart3";
++			linux,phandle = <0x21>;
++			phandle = <0x21>;
++		};
++
++		uart4 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart4";
++			linux,phandle = <0x24>;
++			phandle = <0x24>;
++		};
++
++		scr {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "scr";
++			linux,phandle = <0x7d>;
++			phandle = <0x7d>;
++		};
++
++		twi0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi0";
++			linux,phandle = <0x27>;
++			phandle = <0x27>;
++		};
++
++		twi1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi1";
++			linux,phandle = <0x2a>;
++			phandle = <0x2a>;
++		};
++
++		twi2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi2";
++			linux,phandle = <0x2d>;
++			phandle = <0x2d>;
++		};
++
++		twi3 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi3";
++		};
++
++		pio {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "pio";
++			linux,phandle = <0xa>;
++			phandle = <0xa>;
++		};
++
++		cpurcir {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurcir";
++			linux,phandle = <0x12>;
++			phandle = <0x12>;
++		};
++
++		cpurpio {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurpio";
++			linux,phandle = <0x9>;
++			phandle = <0x9>;
++		};
++
++		cpurpll_peri0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurpll_peri0";
++		};
++
++		cpurcpus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurcpus";
++		};
++
++		cpurahbs {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurahbs";
++		};
++
++		cpurapbs {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurapbs";
++		};
++
++		losc_out {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "losc_out";
++			linux,phandle = <0x98>;
++			phandle = <0x98>;
++		};
++	};
++
++	soc@01c00000 {
++		compatible = "simple-bus";
++		#address-cells = <0x2>;
++		#size-cells = <0x2>;
++		ranges;
++		device_type = "soc";
++
++		pinctrl@01f02c00 {
++			compatible = "allwinner,sun50i-r-pinctrl";
++			reg = <0x0 0x1f02c00 0x0 0x400>;
++			interrupts = <0x0 0x2d 0x4>;
++			clocks = <0x9>;
++			device_type = "r_pio";
++			gpio-controller;
++			interrupt-controller;
++			#interrupt-cells = <0x2>;
++			#size-cells = <0x0>;
++			#gpio-cells = <0x6>;
++			linux,phandle = <0x79>;
++			phandle = <0x79>;
++
++			status_led: status_led@0 {
++				allwinner,pins = "PL7";
++				allwinner,function = "gpio_out";
++				allwinner,muxsel = <0x1>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_cir0@0 {
++				allwinner,pins = "PL11";
++				allwinner,function = "s_cir0";
++				allwinner,muxsel = <0x2>;
++				allwinner,drive = <0x2>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x11>;
++				phandle = <0x11>;
++			};
++
++			spwm0@0 {
++				linux,phandle = <0xaf>;
++				phandle = <0xaf>;
++				allwinner,pins = "PL10";
++				allwinner,function = "spwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spwm0@1 {
++				linux,phandle = <0xb0>;
++				phandle = <0xb0>;
++				allwinner,pins = "PL10";
++				allwinner,function = "spwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x7>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_uart0@0 {
++				linux,phandle = <0xb6>;
++				phandle = <0xb6>;
++				allwinner,pins = "PL2", "PL3";
++				allwinner,function = "s_uart0";
++				allwinner,pname = "s_uart0_tx", "s_uart0_rx";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_rsb0@0 {
++				linux,phandle = <0xb7>;
++				phandle = <0xb7>;
++				allwinner,pins = "PL0", "PL1";
++				allwinner,function = "s_rsb0";
++				allwinner,pname = "s_rsb0_sck", "s_rsb0_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_jtag0@0 {
++				linux,phandle = <0xb8>;
++				phandle = <0xb8>;
++				allwinner,pins = "PL4", "PL5", "PL6", "PL7";
++				allwinner,function = "s_jtag0";
++				allwinner,pname = "s_jtag0_tms", "s_jtag0_tck", "s_jtag0_tdo", "s_jtag0_tdi";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++		};
++
++		pinctrl@01c20800 {
++			compatible = "allwinner,sun50i-pinctrl";
++			reg = <0x0 0x1c20800 0x0 0x400>;
++			interrupts = <0x0 0xb 0x4 0x0 0x11 0x4 0x0 0x15 0x4>;
++			device_type = "pio";
++			clocks = <0xa>;
++			gpio-controller;
++			interrupt-controller;
++			#interrupt-cells = <0x2>;
++			#size-cells = <0x0>;
++			#gpio-cells = <0x6>;
++			linux,phandle = <0x30>;
++			phandle = <0x30>;
++
++			uart0@1 {
++				allwinner,pins = "PB8", "PB9";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x1a>;
++				phandle = <0x1a>;
++			};
++
++			uart1@1 {
++				allwinner,pins = "PG6", "PG7", "PG8", "PG9";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x1d>;
++				phandle = <0x1d>;
++			};
++
++			uart2@1 {
++				allwinner,pins = "PB0", "PB1", "PB2", "PB3";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x20>;
++				phandle = <0x20>;
++			};
++
++			uart3@1 {
++				allwinner,pins = "PH4", "PH5", "PH6", "PH7";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x23>;
++				phandle = <0x23>;
++			};
++
++			uart4@1 {
++				allwinner,pins = "PD2", "PD3", "PD4", "PD5";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x26>;
++				phandle = <0x26>;
++			};
++
++			twi0@1 {
++				allwinner,pins = "PH0", "PH1";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x29>;
++				phandle = <0x29>;
++			};
++
++			twi1@1 {
++				allwinner,pins = "PH2", "PH3";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x2c>;
++				phandle = <0x2c>;
++			};
++
++			twi2@1 {
++				allwinner,pins = "PE14", "PE15";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x2f>;
++				phandle = <0x2f>;
++			};
++
++			spi0@2 {
++				allwinner,pins = "PC3", "PC2", "PC0", "PC1";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x55>;
++				phandle = <0x55>;
++			};
++
++			spi1@2 {
++				allwinner,pins = "PD0", "PD1", "PD2", "PD3";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x59>;
++				phandle = <0x59>;
++			};
++
++			sdc0@1 {
++				allwinner,pins = "PF0", "PF1", "PF2", "PF3", "PF4", "PF5";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x64>;
++				phandle = <0x64>;
++			};
++
++			sdc1@1 {
++				allwinner,pins = "PG0", "PG1", "PG2", "PG3", "PG4", "PG5";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x69>;
++				phandle = <0x69>;
++			};
++
++			sdc2@1 {
++				allwinner,pins = "PC1", "PC5", "PC6", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x5f>;
++				phandle = <0x5f>;
++			};
++
++			daudio0@0 {
++				allwinner,pins = "PB6", "PB3", "PB4", "PB5", "PB7";
++				allwinner,function = "pcm0";
++				allwinner,muxsel = <0x3>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x43>;
++				phandle = <0x43>;
++			};
++
++			daudio0_sleep@0 {
++				allwinner,pins = "PB6", "PB3", "PB4", "PB5", "PB7";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x44>;
++				phandle = <0x44>;
++			};
++
++			daudio1@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "pcm1";
++				allwinner,muxsel = <0x3>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x45>;
++				phandle = <0x45>;
++			};
++
++			daudio1_sleep@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x46>;
++				phandle = <0x46>;
++			};
++
++			aif3@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "aif3";
++				allwinner,muxsel = <0x2>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x3e>;
++				phandle = <0x3e>;
++			};
++
++			aif2_sleep@0 {
++				allwinner,pins = "PB6", "PB4", "PB5", "PB7";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x3f>;
++				phandle = <0x3f>;
++			};
++
++			aif3_sleep@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x40>;
++				phandle = <0x40>;
++			};
++
++			spdif@0 {
++				allwinner,pins = "PH8";
++				allwinner,function = "spdif0";
++				allwinner,muxsel = <0x2>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x4a>;
++				phandle = <0x4a>;
++			};
++
++			spdif_sleep@0 {
++				allwinner,pins = "PH8";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x4b>;
++				phandle = <0x4b>;
++			};
++
++			csi0_sleep@0 {
++				allwinner,pins = "PE0", "PE2", "PE3", "PE4", "PE5", "PE6", "PE7", "PE8", "PE9", "PE10", "PE11", "PE12", "PE13";
++				allwinner,pname = "csi0_pck", "csi0_hsync", "csi0_vsync", "csi0_d0", "csi0_d1", "csi0_d2", "csi0_d3", "csi0_d4", "csi0_d5", "csi0_d6", "csi0_d7", "csi0_sck", "csi0_sda";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				allwinner,data = <0x0>;
++				linux,phandle = <0x77>;
++				phandle = <0x77>;
++			};
++
++			smartcard@0 {
++				allwinner,pins = "PB1", "PB4", "PB5", "PB6", "PB7";
++				allwinner,function = "sim0";
++				allwinner,muxsel = <0x5>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x7f>;
++				phandle = <0x7f>;
++			};
++
++			nand0@2 {
++				allwinner,pins = "PC0", "PC1", "PC2", "PC3", "PC4", "PC5", "PC6", "PC7", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16", "PC17", "PC18";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x83>;
++				phandle = <0x83>;
++			};
++
++			card0_boot_para@0 {
++				linux,phandle = <0x99>;
++				phandle = <0x99>;
++				allwinner,pins = "PF0", "PF1", "PF2", "PF3", "PF4", "PF5";
++				allwinner,function = "card0_boot_para";
++				allwinner,pname = "sdc_d1", "sdc_d0", "sdc_clk", "sdc_cmd", "sdc_d3", "sdc_d2";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			card2_boot_para@0 {
++				linux,phandle = <0x9a>;
++				phandle = <0x9a>;
++				allwinner,pins = "PC1", "PC5", "PC6", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "card2_boot_para";
++				allwinner,pname = "sdc_ds", "sdc_clk", "sdc_cmd", "sdc_d0", "sdc_d1", "sdc_d2", "sdc_d3", "sdc_d4", "sdc_d5", "sdc_d6", "sdc_d7", "sdc_emmc_rst";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi_para@0 {
++				linux,phandle = <0x9b>;
++				phandle = <0x9b>;
++				allwinner,pins = "PH0", "PH1";
++				allwinner,function = "twi_para";
++				allwinner,pname = "twi_scl", "twi_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart_para@0 {
++				linux,phandle = <0x9c>;
++				phandle = <0x9c>;
++				allwinner,pins = "PB8", "PB9";
++				allwinner,function = "uart_para";
++				allwinner,pname = "uart_debug_tx", "uart_debug_rx";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			jtag_para@0 {
++				linux,phandle = <0x9d>;
++				phandle = <0x9d>;
++				allwinner,pins = "PB0", "PB1", "PB2", "PB3";
++				allwinner,function = "jtag_para";
++				allwinner,pname = "jtag_ms", "jtag_ck", "jtag_do", "jtag_di";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			gmac0@0 {
++				linux,phandle = <0x9e>;
++				phandle = <0x9e>;
++				allwinner,pins = "PD18", "PD17", "PD19", "PD20", "PD11", "PD10", "PD13", "PD22", "PD23";
++				allwinner,function = "gmac0";
++				allwinner,pname = "gmac_txd0", "gmac_txd1", "gmac_txclk", "gmac_txen", "gmac_rxd0", "gmac_rxd1", "gmac_rxdv", "gmac_mdc", "gmac_mdio";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi0@0 {
++				linux,phandle = <0x9f>;
++				phandle = <0x9f>;
++				allwinner,pins = "PH0", "PH1";
++				allwinner,function = "twi0";
++				allwinner,pname = "twi0_scl", "twi0_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi1@0 {
++				linux,phandle = <0xa0>;
++				phandle = <0xa0>;
++				allwinner,pins = "PH2", "PH3";
++				allwinner,function = "twi1";
++				allwinner,pname = "twi1_scl", "twi1_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi2@0 {
++				linux,phandle = <0xa1>;
++				phandle = <0xa1>;
++				allwinner,pins = "PE14", "PE15";
++				allwinner,function = "twi2";
++				allwinner,pname = "twi2_scl", "twi2_sda";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart0@0 {
++				linux,phandle = <0xa2>;
++				phandle = <0xa2>;
++				allwinner,pins = "PB8", "PB9";
++				allwinner,function = "uart0";
++				allwinner,pname = "uart0_tx", "uart0_rx";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart1@0 {
++				linux,phandle = <0xa3>;
++				phandle = <0xa3>;
++				allwinner,pins = "PG6", "PG7", "PG8", "PG9";
++				allwinner,function = "uart1";
++				allwinner,pname = "uart1_tx", "uart1_rx", "uart1_rts", "uart1_cts";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart2@0 {
++				linux,phandle = <0xa4>;
++				phandle = <0xa4>;
++				allwinner,pins = "PB0", "PB1", "PB2", "PB3";
++				allwinner,function = "uart2";
++				allwinner,pname = "uart2_tx", "uart2_rx", "uart2_rts", "uart2_cts";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart3@0 {
++				linux,phandle = <0xa5>;
++				phandle = <0xa5>;
++				allwinner,pins = "PD0", "PD1";
++				allwinner,function = "uart3";
++				allwinner,pname = "uart3_tx", "uart3_rx";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart4@0 {
++				linux,phandle = <0xa6>;
++				phandle = <0xa6>;
++				allwinner,pins = "PD2", "PD3", "PD4", "PD5";
++				allwinner,function = "uart4";
++				allwinner,pname = "uart4_tx", "uart4_rx", "uart4_rts", "uart4_cts";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi0@0 {
++				linux,phandle = <0xa7>;
++				phandle = <0xa7>;
++				allwinner,pins = "PC3";
++				allwinner,function = "spi0";
++				allwinner,pname = "spi0_cs0";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi0@1 {
++				linux,phandle = <0xa8>;
++				phandle = <0xa8>;
++				allwinner,pins = "PC2", "PC0", "PC1";
++				allwinner,function = "spi0";
++				allwinner,pname = "spi0_sclk", "spi0_mosi", "spi0_miso";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi1@0 {
++				linux,phandle = <0xa9>;
++				phandle = <0xa9>;
++				allwinner,pins = "PD0";
++				allwinner,function = "spi1";
++				allwinner,pname = "spi1_cs0";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi1@1 {
++				linux,phandle = <0xaa>;
++				phandle = <0xaa>;
++				allwinner,pins = "PD1", "PD2", "PD3";
++				allwinner,function = "spi1";
++				allwinner,pname = "spi1_sclk", "spi1_mosi", "spi1_miso";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			nand0@0 {
++				linux,phandle = <0xab>;
++				phandle = <0xab>;
++				allwinner,pins = "PC0", "PC1", "PC2", "PC5", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "nand0";
++				allwinner,pname = "nand0_we", "nand0_ale", "nand0_cle", "nand0_nre", "nand0_d0", "nand0_d1", "nand0_d2", "nand0_d3", "nand0_d4", "nand0_d5", "nand0_d6", "nand0_d7", "nand0_ndqs";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0x1>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			nand0@1 {
++				linux,phandle = <0xac>;
++				phandle = <0xac>;
++				allwinner,pins = "PC3", "PC4", "PC6", "PC7", "PC17", "PC18";
++				allwinner,function = "nand0";
++				allwinner,pname = "nand0_ce1", "nand0_ce0", "nand0_rb0", "nand0_rb1", "nand0_ce2", "nand0_ce3";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x1>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			pwm0@0 {
++				linux,phandle = <0xad>;
++				phandle = <0xad>;
++				allwinner,pins = "PD22";
++				allwinner,function = "pwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			pwm0@1 {
++				linux,phandle = <0xae>;
++				phandle = <0xae>;
++				allwinner,pins = "PD22";
++				allwinner,function = "pwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x7>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			csi0@0 {
++				linux,phandle = <0xb1>;
++				phandle = <0xb1>;
++				allwinner,pins = "PE0", "PE2", "PE3", "PE4", "PE5", "PE6", "PE7", "PE8", "PE9", "PE10", "PE11", "PE12", "PE13";
++				allwinner,function = "csi0";
++				allwinner,pname = "csi0_pck", "csi0_hsync", "csi0_vsync", "csi0_d0", "csi0_d1", "csi0_d2", "csi0_d3", "csi0_d4", "csi0_d5", "csi0_d6", "csi0_d7", "csi0_sck", "csi0_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			sdc0@0 {
++				linux,phandle = <0xb2>;
++				phandle = <0xb2>;
++				allwinner,pins = "PF0", "PF1", "PF2", "PF3", "PF4", "PF5";
++				allwinner,function = "sdc0";
++				allwinner,pname = "sdc0_d1", "sdc0_d0", "sdc0_clk", "sdc0_cmd", "sdc0_d3", "sdc0_d2";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			sdc1@0 {
++				linux,phandle = <0xb3>;
++				phandle = <0xb3>;
++				allwinner,pins = "PG0", "PG1", "PG2", "PG3", "PG4", "PG5";
++				allwinner,function = "sdc1";
++				allwinner,pname = "sdc1_clk", "sdc1_cmd", "sdc1_d0", "sdc1_d1", "sdc1_d2", "sdc1_d3";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			sdc2@0 {
++				linux,phandle = <0xb4>;
++				phandle = <0xb4>;
++				allwinner,pins = "PC1", "PC5", "PC6", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "sdc2";
++				allwinner,pname = "sdc2_ds", "sdc2_clk", "sdc2_cmd", "sdc2_d0", "sdc2_d1", "sdc2_d2", "sdc2_d3", "sdc2_d4", "sdc2_d5", "sdc2_d6", "sdc2_d7", "sdc2_emmc_rst";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			codec@0 {
++				linux,phandle = <0xb5>;
++				phandle = <0xb5>;
++				allwinner,pins = "PH7";
++				allwinner,function = "codec";
++				allwinner,pname = "gpio-spk";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			Vdevice@0 {
++				linux,phandle = <0xb9>;
++				phandle = <0xb9>;
++				allwinner,pins = "PB1", "PB2";
++				allwinner,function = "Vdevice";
++				allwinner,pname = "Vdevice_0", "Vdevice_1";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			w1_pin@0 {
++				linux,phandle = <0xba>;
++				phandle = <0xba>;
++				allwinner,pins = "PC8";
++				allwinner,function = "gpio_in";
++				allwinner,pname = "w1";
++				allwinner,muxsel = <0x0>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x0>;
++				allwinner,data = <0xffffffff>;
++			};
++		};
++
++		pinctrl@0 {
++			compatible = "allwinner,axp-pinctrl";
++			gpio-controller;
++			#size-cells = <0x0>;
++			#gpio-cells = <0x6>;
++			device_type = "axp_pio";
++			linux,phandle = <0x31>;
++			phandle = <0x31>;
++		};
++
++		dma-controller@01c02000 {
++			compatible = "allwinner,sun50i-dma";
++			reg = <0x0 0x1c02000 0x0 0x1000>;
++			interrupts = <0x0 0x32 0x4>;
++			clocks = <0xb>;
++			#dma-cells = <0x1>;
++		};
++
++		mbus-controller@01c62000 {
++			compatible = "allwinner,sun50i-mbus";
++			reg = <0x0 0x1c62000 0x0 0x110>;
++			#mbus-cells = <0x1>;
++		};
++
++		arisc {
++			compatible = "allwinner,sunxi-arisc";
++			#address-cells = <0x2>;
++			#size-cells = <0x2>;
++			clocks = <0xc 0xd 0x6 0x4>;
++			clock-names = "losc", "iosc", "hosc", "pll_periph0";
++			powchk_used = <0x0>;
++			power_reg = <0x2309621>;
++			system_power = <0x32>;
++		};
++
++		arisc_space {
++			compatible = "allwinner,arisc_space";
++			space1 = <0x40000 0x0 0x14000>;
++			space2 = <0x40100000 0x18000 0x4000>;
++			space3 = <0x40104000 0x0 0x1000>;
++			space4 = <0x40105000 0x0 0x1000>;
++		};
++
++		standby_space {
++			compatible = "allwinner,standby_space";
++			space1 = <0x41020000 0x0 0x800>;
++		};
++
++		msgbox@1c17000 {
++			compatible = "allwinner,msgbox";
++			clocks = <0xe>;
++			clock-names = "clk_msgbox";
++			reg = <0x0 0x1c17000 0x0 0x1000>;
++			interrupts = <0x0 0x31 0x1>;
++			status = "okay";
++		};
++
++		hwspinlock@1c18000 {
++			compatible = "allwinner,sunxi-hwspinlock";
++			clocks = <0xf 0x10>;
++			clock-names = "clk_hwspinlock_rst", "clk_hwspinlock_bus";
++			reg = <0x0 0x1c18000 0x0 0x1000>;
++			status = "okay";
++			num-locks = <0x8>;
++		};
++
++		s_cir@1f02000 {
++			compatible = "allwinner,s_cir";
++			reg = <0x0 0x1f02000 0x0 0x400>;
++			interrupts = <0x0 0x25 0x4>;
++			pinctrl-names = "default";
++			pinctrl-0 = <0x11>;
++			clocks = <0x6 0x12>;
++			supply = "vcc-pl";
++			ir_power_key_code = <0x4d>;
++			ir_addr_code = <0x4040>;
++			status = "okay";
++			device_type = "s_cir0";
++		};
++
++		s_uart@1f02800 {
++			compatible = "allwinner,s_uart";
++			reg = <0x0 0x1f02800 0x0 0x400>;
++			interrupts = <0x0 0x26 0x4>;
++			pinctrl-names = "default";
++			status = "okay";
++			device_type = "s_uart0";
++			pinctrl-0 = <0xb6>;
++		};
++
++		s_rsb@1f03400 {
++			compatible = "allwinner,s_rsb";
++			reg = <0x0 0x1f03400 0x0 0x400>;
++			interrupts = <0x0 0x27 0x4>;
++			pinctrl-names = "default";
++			status = "okay";
++			device_type = "s_rsb0";
++			pinctrl-0 = <0xb7>;
++		};
++
++		s_jtag0 {
++			compatible = "allwinner,s_jtag";
++			pinctrl-names = "default";
++			status = "disabled";
++			device_type = "s_jtag0";
++			pinctrl-0 = <0xb8>;
++		};
++
++		timer@1c20c00 {
++			compatible = "allwinner,sunxi-timer";
++			device_type = "timer";
++			reg = <0x0 0x1c20c00 0x0 0x90>;
++			interrupts = <0x0 0x12 0x1>;
++			clock-frequency = <0x16e3600>;
++			timer-prescale = <0x10>;
++		};
++
++		rtc@01f00000 {
++			compatible = "allwinner,sun50i-rtc";
++			device_type = "rtc";
++			reg = <0x0 0x1f00000 0x0 0x218>;
++			interrupts = <0x0 0x28 0x4>;
++			gpr_offset = <0x100>;
++			gpr_len = <0x4>;
++		};
++
++		ve@01c0e000 {
++			compatible = "allwinner,sunxi-cedar-ve";
++			reg = <0x0 0x1c0e000 0x0 0x1000 0x0 0x1c00000 0x0 0x10 0x0 0x1c20000 0x0 0x800>;
++			interrupts = <0x0 0x3a 0x4>;
++			clocks = <0x16 0x17>;
++		};
++
++		uart@01c28000 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart0";
++			reg = <0x0 0x1c28000 0x0 0x400>;
++			interrupts = <0x0 0x0 0x4>;
++			clocks = <0x18>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x1a>;
++			uart0_port = <0x0>;
++			uart0_type = <0x2>;
++			status = "okay";
++			pinctrl-0 = <0xa2>;
++		};
++
++		uart@01c28400 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart1";
++			reg = <0x0 0x1c28400 0x0 0x400>;
++			interrupts = <0x0 0x1 0x4>;
++			clocks = <0x1b>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x1d>;
++			uart1_port = <0x1>;
++			uart1_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa3>;
++		};
++
++		uart@01c28800 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart2";
++			reg = <0x0 0x1c28800 0x0 0x400>;
++			interrupts = <0x0 0x2 0x4>;
++			clocks = <0x1e>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x20>;
++			uart2_port = <0x2>;
++			uart2_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa4>;
++		};
++
++		uart@01c28c00 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart3";
++			reg = <0x0 0x1c28c00 0x0 0x400>;
++			interrupts = <0x0 0x3 0x4>;
++			clocks = <0x21>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x23>;
++			uart3_port = <0x3>;
++			uart3_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa5>;
++		};
++
++		uart@01c29000 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart4";
++			reg = <0x0 0x1c29000 0x0 0x400>;
++			interrupts = <0x0 0x4 0x4>;
++			clocks = <0x24>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x26>;
++			uart4_port = <0x4>;
++			uart4_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa6>;
++		};
++
++		twi@0x01c2ac00 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-twi";
++			device_type = "twi0";
++			reg = <0x0 0x1c2ac00 0x0 0x400>;
++			interrupts = <0x0 0x6 0x4>;
++			clocks = <0x27>;
++			clock-frequency = <0x61a80>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x29>;
++			status = "okay";
++			pinctrl-0 = <0x9f>;
++		};
++
++		twi@0x01c2b000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-twi";
++			device_type = "twi1";
++			reg = <0x0 0x1c2b000 0x0 0x400>;
++			interrupts = <0x0 0x7 0x4>;
++			clocks = <0x2a>;
++			clock-frequency = <0x30d40>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x2c>;
++			status = "okay";
++			pinctrl-0 = <0xa0>;
++		};
++
++		twi@0x01c2b400 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-twi";
++			device_type = "twi2";
++			reg = <0x0 0x1c2b400 0x0 0x400>;
++			interrupts = <0x0 0x8 0x4>;
++			clocks = <0x2d>;
++			clock-frequency = <0x30d40>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x2f>;
++			status = "disabled";
++			pinctrl-0 = <0xa1>;
++		};
++
++		usbc0@0 {
++			device_type = "usbc0";
++			compatible = "allwinner,sunxi-otg-manager";
++			usb_port_type = <0x1>;
++			usb_detect_type = <0x0>;
++			usb_host_init_state = <0x1>;
++			usb_regulator_io = "nocare";
++			usb_wakeup_suspend = <0x1>;
++			usb_luns = <0x3>;
++			usb_serial_unique = <0x1>;
++			usb_serial_number = "20080411";
++			rndis_wceis = <0x1>;
++			status = "okay";
++			usb_id_gpio;
++			usb_det_vbus_gpio;
++			usb_drv_vbus_gpio;
++		};
++
++		udc-controller@0x01c19000 {
++			compatible = "allwinner,sunxi-udc";
++			reg = <0x0 0x1c19000 0x0 0x1000 0x0 0x1c00000 0x0 0x100>;
++			interrupts = <0x0 0x47 0x4>;
++			clocks = <0x32 0x33>;
++			status = "okay";
++		};
++
++		ehci0-controller@0x01c1a000 {
++			compatible = "allwinner,sunxi-ehci0";
++			reg = <0x0 0x1c1a000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x48 0x4>;
++			clocks = <0x32 0x34>;
++			hci_ctrl_no = <0x0>;
++			status = "okay";
++		};
++
++		ohci0-controller@0x01c1a400 {
++			compatible = "allwinner,sunxi-ohci0";
++			reg = <0x0 0x1c1a000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x49 0x4>;
++			clocks = <0x32 0x35>;
++			hci_ctrl_no = <0x0>;
++			status = "okay";
++		};
++
++		usbc1@0 {
++			device_type = "usbc1";
++			usb_host_init_state = <0x1>;
++			usb_regulator_io = "nocare";
++			usb_wakeup_suspend = <0x1>;
++			usb_hsic_used = <0x0>;
++			usb_hsic_regulator_io = "vcc-hsic-12";
++			usb_hsic_ctrl = <0x0>;
++			usb_hsic_usb3503_flag = <0x0>;
++			status = "okay";
++			usb_port_type = <0x1>;
++			usb_detect_type = <0x0>;
++			usb_drv_vbus_gpio;
++			usb_hsic_rdy_gpio;
++			usb_hsic_hub_connect_gpio;
++			usb_hsic_int_n_gpio;
++			usb_hsic_reset_n_gpio;
++		};
++
++		ehci1-controller@0x01c1b000 {
++			compatible = "allwinner,sunxi-ehci1";
++			reg = <0x0 0x1c1b000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x4a 0x4>;
++			clocks = <0x36 0x37 0x38 0x39 0x3a>;
++			hci_ctrl_no = <0x1>;
++			status = "okay";
++		};
++
++		ohci1-controller@0x01c1b400 {
++			compatible = "allwinner,sunxi-ohci1";
++			reg = <0x0 0x1c1b000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x4b 0x4>;
++			clocks = <0x36 0x3b>;
++			hci_ctrl_no = <0x1>;
++			status = "okay";
++		};
++
++		codec@0x01c22c00 {
++			compatible = "allwinner,sunxi-internal-codec";
++			reg = <0x0 0x1c22c00 0x0 0x478 0x0 0x1f015c0 0x0 0x0>;
++			clocks = <0x3c>;
++			pinctrl-names = "aif2-default", "aif3-default", "aif2-sleep", "aif3-sleep";
++			pinctrl-1 = <0x3e>;
++			pinctrl-2 = <0x3f>;
++			pinctrl-3 = <0x40>;
++			gpio-spk = <0x30 0x7 0x7 0x1 0x1 0x1 0x1>;
++			headphonevol = <0x3b>;
++			spkervol = <0x1a>;
++			earpiecevol = <0x1e>;
++			maingain = <0x4>;
++			headsetmicgain = <0x4>;
++			adcagc_cfg = <0x0>;
++			adcdrc_cfg = <0x0>;
++			adchpf_cfg = <0x0>;
++			dacdrc_cfg = <0x0>;
++			dachpf_cfg = <0x0>;
++			aif1_lrlk_div = <0x40>;
++			aif2_lrlk_div = <0x40>;
++			aif2config = <0x0>;
++			aif3config = <0x0>;
++			pa_sleep_time = <0x15e>;
++			dac_digital_vol = <0xa0a0>;
++			status = "okay";
++			linux,phandle = <0x4d>;
++			phandle = <0x4d>;
++			device_type = "codec";
++			pinctrl-0 = <0xb5>;
++		};
++
++		i2s0-controller@0x01c22c00 {
++			compatible = "allwinner,sunxi-internal-i2s";
++			reg = <0x0 0x1c22c00 0x0 0x478>;
++			clocks = <0x2 0x41>;
++			status = "okay";
++			linux,phandle = <0x4c>;
++			phandle = <0x4c>;
++			device_type = "i2s";
++		};
++
++		daudio@0x01c22000 {
++			compatible = "allwinner,sunxi-daudio";
++			reg = <0x0 0x1c22000 0x0 0x58>;
++			clocks = <0x2 0x42>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x43>;
++			pinctrl-1 = <0x44>;
++			pcm_lrck_period = <0x20>;
++			pcm_lrckr_period = <0x1>;
++			slot_width_select = <0x20>;
++			pcm_lsb_first = <0x0>;
++			tx_data_mode = <0x0>;
++			rx_data_mode = <0x0>;
++			daudio_master = <0x4>;
++			audio_format = <0x1>;
++			signal_inversion = <0x1>;
++			frametype = <0x0>;
++			tdm_config = <0x1>;
++			tdm_num = <0x0>;
++			status = "disabled";
++			linux,phandle = <0x4e>;
++			phandle = <0x4e>;
++			device_type = "daudio0";
++		};
++
++		daudio@0x01c22400 {
++			compatible = "allwinner,sunxi-daudio";
++			reg = <0x0 0x1c22400 0x0 0x58>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x45>;
++			pinctrl-1 = <0x46>;
++			clocks = <0x2 0x47>;
++			pcm_lrck_period = <0x20>;
++			pcm_lrckr_period = <0x1>;
++			slot_width_select = <0x20>;
++			pcm_lsb_first = <0x0>;
++			tx_data_mode = <0x0>;
++			rx_data_mode = <0x0>;
++			daudio_master = <0x4>;
++			audio_format = <0x1>;
++			signal_inversion = <0x1>;
++			frametype = <0x0>;
++			tdm_config = <0x1>;
++			tdm_num = <0x1>;
++			status = "disabled";
++			linux,phandle = <0x4f>;
++			phandle = <0x4f>;
++			device_type = "daudio1";
++		};
++
++		daudio@0x01c22800 {
++			compatible = "allwinner,sunxi-tdmhdmi";
++			reg = <0x0 0x1c22800 0x0 0x58>;
++			clocks = <0x2 0x48>;
++			status = "okay";
++			linux,phandle = <0x50>;
++			phandle = <0x50>;
++			device_type = "daudio2";
++		};
++
++		spdif-controller@0x01c21000 {
++			compatible = "allwinner,sunxi-spdif";
++			reg = <0x0 0x1c21000 0x0 0x38>;
++			clocks = <0x2 0x49>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x4a>;
++			pinctrl-1 = <0x4b>;
++			status = "disabled";
++			linux,phandle = <0x51>;
++			phandle = <0x51>;
++			device_type = "spdif";
++		};
++
++		sound@0 {
++			compatible = "allwinner,sunxi-codec-machine";
++			interrupts = <0x0 0x1c 0x4>;
++			sunxi,i2s-controller = <0x4c>;
++			sunxi,audio-codec = <0x4d>;
++			aif2fmt = <0x3>;
++			aif3fmt = <0x3>;
++			aif2master = <0x1>;
++			hp_detect_case = <0x1>;
++			status = "okay";
++			device_type = "sndcodec";
++		};
++
++		sound@1 {
++			compatible = "allwinner,sunxi-daudio0-machine";
++			sunxi,daudio0-controller = <0x4e>;
++			status = "disabled";
++			device_type = "snddaudio0";
++		};
++
++		sound@2 {
++			compatible = "allwinner,sunxi-daudio1-machine";
++			sunxi,daudio1-controller = <0x4f>;
++			status = "disabled";
++			device_type = "snddaudio1";
++		};
++
++		sound@3 {
++			compatible = "allwinner,sunxi-hdmi-machine";
++			sunxi,hdmi-controller = <0x50>;
++			status = "okay";
++			device_type = "sndhdmi";
++		};
++
++		sound@4 {
++			compatible = "allwinner,sunxi-spdif-machine";
++			sunxi,spdif-controller = <0x51>;
++			status = "disabled";
++			device_type = "sndspdif";
++		};
++
++		spi@01c68000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-spi";
++			device_type = "spi0";
++			reg = <0x0 0x1c68000 0x0 0x1000>;
++			interrupts = <0x0 0x41 0x4>;
++			clocks = <0x4 0x52>;
++			clock-frequency = <0x5f5e100>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x55>;
++			spi0_cs_number = <0x1>;
++			spi0_cs_bitmap = <0x1>;
++			status = "disabled";
++			pinctrl-0 = <0xa7 0xa8>;
++
++			spidev@0 {
++				compatible = "spidev";
++				reg = <0x0>;
++				spi-max-frequency = <0x2faf080>;
++			};
++		};
++
++		spi@01c69000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-spi";
++			device_type = "spi1";
++			reg = <0x0 0x1c69000 0x0 0x1000>;
++			interrupts = <0x0 0x42 0x4>;
++			clocks = <0x4 0x56>;
++			clock-frequency = <0x5f5e100>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x59>;
++			spi1_cs_number = <0x1>;
++			spi1_cs_bitmap = <0x1>;
++			status = "disabled";
++			pinctrl-0 = <0xa9 0xaa>;
++		};
++
++		sdmmc@01C11000 {
++			compatible = "allwinner,sun50i-sdmmc2";
++			device_type = "sdc2";
++			reg = <0x0 0x1c11000 0x0 0x1000>;
++			interrupts = <0x0 0x3e 0x104>;
++			clocks = <0x6 0x5a 0x5b 0x5c 0x5d>;
++			clock-names = "osc24m", "pll_periph", "mmc", "ahb", "rst";
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x5f>;
++			bus-width = <0x8>;
++			max-frequency = <0x5f5e100>;
++			sdc_tm4_sm0_freq0 = <0x0>;
++			sdc_tm4_sm0_freq1 = <0x0>;
++			sdc_tm4_sm1_freq0 = <0x0>;
++			sdc_tm4_sm1_freq1 = <0x0>;
++			sdc_tm4_sm2_freq0 = <0x0>;
++			sdc_tm4_sm2_freq1 = <0x0>;
++			sdc_tm4_sm3_freq0 = <0x5000000>;
++			sdc_tm4_sm3_freq1 = <0x405>;
++			sdc_tm4_sm4_freq0 = <0x50000>;
++			sdc_tm4_sm4_freq1 = <0x408>;
++			status = "disabled";
++			non-removable;
++			pinctrl-0 = <0xb4>;
++			cd-gpios;
++			sunxi-power-save-mode;
++			sunxi-dis-signal-vol-sw;
++			mmc-ddr-1_8v;
++			mmc-hs200-1_8v;
++			mmc-hs400-1_8v;
++			vmmc = "vcc-emmc";
++			vqmmc = "vcc-lpddr";
++			vdmmc = "none";
++		};
++
++		sdmmc@01c0f000 {
++			compatible = "allwinner,sun50i-sdmmc0";
++			device_type = "sdc0";
++			reg = <0x0 0x1c0f000 0x0 0x1000>;
++			interrupts = <0x0 0x3c 0x104>;
++			clocks = <0x6 0x5a 0x60 0x61 0x62>;
++			clock-names = "osc24m", "pll_periph", "mmc", "ahb", "rst";
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x64>;
++			max-frequency = <0x2faf080>;
++			bus-width = <0x4>;
++			broken-cd;
++			status = "okay";
++			pinctrl-0 = <0xb2>;
++			cd-gpios = <0x30 0x5 0x6 0x0 0x1 0x2 0xffffffff>;
++			sunxi-power-save-mode;
++			vmmc = "none";
++			vqmmc = "none";
++			vdmmc = "vcc-sdc";
++		};
++
++		sdmmc@1C10000 {
++			compatible = "allwinner,sun50i-sdmmc1";
++			device_type = "sdc1";
++			reg = <0x0 0x1c10000 0x0 0x1000>;
++			interrupts = <0x0 0x3d 0x104>;
++			clocks = <0x6 0x5a 0x65 0x66 0x67>;
++			clock-names = "osc24m", "pll_periph", "mmc", "ahb", "rst";
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x69>;
++			max-frequency = <0x8f0d180>;
++			bus-width = <0x4>;
++			sunxi-dly-52M-ddr4 = <0x1 0x0 0x0 0x0 0x2>;
++			sunxi-dly-104M = <0x1 0x0 0x0 0x0 0x1>;
++			sunxi-dly-208M = <0x1 0x0 0x0 0x0 0x1>;
++			status = "okay";
++			pinctrl-0 = <0xb3>;
++			sd-uhs-sdr50;
++			sd-uhs-ddr50;
++			sd-uhs-sdr104;
++			cap-sdio-irq;
++			keep-power-in-suspend;
++			ignore-pm-notify;
++		};
++
++		disp@01000000 {
++			compatible = "allwinner,sun50i-disp";
++			reg = <0x0 0x1000000 0x0 0x300000 0x0 0x1c0c000 0x0 0x17fc 0x0 0x1ca0000 0x0 0x10fc>;
++			interrupts = <0x0 0x56 0x104 0x0 0x57 0x104 0x0 0x59 0x104>;
++			clocks = <0x6a 0x6b 0x6c 0x6d 0x6e>;
++			status = "okay";
++			device_type = "disp";
++			disp_init_enable = <0x1>;
++			disp_mode = <0x0>;
++			screen0_output_type = <0x3>;
++			screen0_output_mode = <0xa>;
++			screen1_output_type = <0x3>;
++			screen1_output_mode = <0xa>;
++			fb0_format = <0x0>;
++			fb0_width = <0x0>;
++			fb0_height = <0x0>;
++			fb1_format = <0x0>;
++			fb1_width = <0x0>;
++			fb1_height = <0x0>;
++		};
++
++		lcd0@01c0c000 {
++			compatible = "allwinner,sunxi-lcd0";
++			pinctrl-names = "active", "sleep";
++			status = "okay";
++			device_type = "lcd0";
++			lcd_used = <0x0>;
++			lcd_driver_name = "mb709_mipi";
++			lcd_backlight = <0x32>;
++			lcd_if = <0x4>;
++			lcd_x = <0x400>;
++			lcd_y = <0x258>;
++			lcd_width = <0x0>;
++			lcd_height = <0x0>;
++			lcd_dclk_freq = <0x37>;
++			lcd_pwm_used = <0x1>;
++			lcd_pwm_ch = <0x10>;
++			lcd_pwm_freq = <0xc350>;
++			lcd_pwm_pol = <0x1>;
++			lcd_pwm_max_limit = <0xfa>;
++			lcd_hbp = <0x78>;
++			lcd_ht = <0x604>;
++			lcd_hspw = <0x14>;
++			lcd_vbp = <0x17>;
++			lcd_vt = <0x27b>;
++			lcd_vspw = <0x2>;
++			lcd_dsi_if = <0x2>;
++			lcd_dsi_lane = <0x4>;
++			lcd_dsi_format = <0x0>;
++			lcd_dsi_eotp = <0x0>;
++			lcd_dsi_vc = <0x0>;
++			lcd_dsi_te = <0x0>;
++			lcd_frm = <0x0>;
++			lcd_gamma_en = <0x0>;
++			lcd_bright_curve_en = <0x0>;
++			lcd_cmap_en = <0x0>;
++			lcd_bl_en = <0x30 0x7 0xa 0x1 0x0 0xffffffff 0x1>;
++			lcd_bl_en_power = "none";
++			lcd_power = "vcc-mipi";
++			lcd_fix_power = "vcc-dsi-33";
++			lcd_gpio_0 = <0x30 0x3 0x18 0x1 0x0 0xffffffff 0x1>;
++		};
++
++		hdmi@01ee0000 {
++			compatible = "allwinner,sunxi-hdmi";
++			reg = <0x0 0x1ee0000 0x0 0x20000>;
++			clocks = <0x6f 0x70>;
++			device_type = "hdmi";
++			status = "okay";
++			hdmi_power = "vcc-hdmi-33";
++			hdmi_hdcp_enable = <0x0>;
++			hdmi_cts_compatibility = <0x0>;
++		};
++
++		tr@01000000 {
++			compatible = "allwinner,sun50i-tr";
++			reg = <0x0 0x1000000 0x0 0x200bc>;
++			interrupts = <0x0 0x60 0x104>;
++			clocks = <0x6a>;
++			status = "okay";
++		};
++
++		pwm@01c21400 {
++			compatible = "allwinner,sunxi-pwm";
++			reg = <0x0 0x1c21400 0x0 0x3c>;
++			pwm-number = <0x1>;
++			pwm-base = <0x0>;
++			pwms = <0x71>;
++		};
++
++		pwm0@01c21400 {
++			compatible = "allwinner,sunxi-pwm0";
++			pinctrl-names = "active", "sleep";
++			reg_base = <0x1c21400>;
++			reg_busy_offset = <0x0>;
++			reg_busy_shift = <0x1c>;
++			reg_enable_offset = <0x0>;
++			reg_enable_shift = <0x4>;
++			reg_clk_gating_offset = <0x0>;
++			reg_clk_gating_shift = <0x6>;
++			reg_bypass_offset = <0x0>;
++			reg_bypass_shift = <0x9>;
++			reg_pulse_start_offset = <0x0>;
++			reg_pulse_start_shift = <0x8>;
++			reg_mode_offset = <0x0>;
++			reg_mode_shift = <0x7>;
++			reg_polarity_offset = <0x0>;
++			reg_polarity_shift = <0x5>;
++			reg_period_offset = <0x4>;
++			reg_period_shift = <0x10>;
++			reg_period_width = <0x10>;
++			reg_active_offset = <0x4>;
++			reg_active_shift = <0x0>;
++			reg_active_width = <0x10>;
++			reg_prescal_offset = <0x0>;
++			reg_prescal_shift = <0x0>;
++			reg_prescal_width = <0x4>;
++			linux,phandle = <0x71>;
++			phandle = <0x71>;
++			device_type = "pwm0";
++			pwm_used = <0x0>;
++			pinctrl-0 = <0xad>;
++			pinctrl-1 = <0xae>;
++		};
++
++		s_pwm@1f03800 {
++			compatible = "allwinner,sunxi-s_pwm";
++			reg = <0x0 0x1f03800 0x0 0x3c>;
++			pwm-number = <0x1>;
++			pwm-base = <0x10>;
++			pwms = <0x72>;
++		};
++
++		spwm0@0x01f03800 {
++			compatible = "allwinner,sunxi-pwm16";
++			pinctrl-names = "active", "sleep";
++			reg_base = <0x1f03800>;
++			reg_busy_offset = <0x0>;
++			reg_busy_shift = <0x1c>;
++			reg_enable_offset = <0x0>;
++			reg_enable_shift = <0x4>;
++			reg_clk_gating_offset = <0x0>;
++			reg_clk_gating_shift = <0x6>;
++			reg_bypass_offset = <0x0>;
++			reg_bypass_shift = <0x9>;
++			reg_pulse_start_offset = <0x0>;
++			reg_pulse_start_shift = <0x8>;
++			reg_mode_offset = <0x0>;
++			reg_mode_shift = <0x7>;
++			reg_polarity_offset = <0x0>;
++			reg_polarity_shift = <0x5>;
++			reg_period_offset = <0x4>;
++			reg_period_shift = <0x10>;
++			reg_period_width = <0x10>;
++			reg_active_offset = <0x4>;
++			reg_active_shift = <0x0>;
++			reg_active_width = <0x10>;
++			reg_prescal_offset = <0x0>;
++			reg_prescal_shift = <0x0>;
++			reg_prescal_width = <0x4>;
++			linux,phandle = <0x72>;
++			phandle = <0x72>;
++			device_type = "spwm0";
++			s_pwm_used = <0x1>;
++			pinctrl-0 = <0xaf>;
++			pinctrl-1 = <0xb0>;
++		};
++
++		boot_disp {
++			compatible = "allwinner,boot_disp";
++			device_type = "boot_disp";
++			output_disp = <0x0>;
++			output_type = <0x3>;
++			output_mode = <0xa>;
++		};
++
++		cci@0x01cb3000 {
++			compatible = "allwinner,sunxi-csi_cci";
++			reg = <0x0 0x1cb3000 0x0 0x1000>;
++			interrupts = <0x0 0x55 0x4>;
++			status = "okay";
++		};
++
++		csi_res@0x01cb0000 {
++			compatible = "allwinner,sunxi-csi";
++			reg = <0x0 0x1cb0000 0x0 0x1000>;
++			status = "okay";
++		};
++
++		vfe@0 {
++			device_type = "csi0";
++			compatible = "allwinner,sunxi-vfe";
++			interrupts = <0x0 0x54 0x4>;
++			clocks = <0x73 0x74 0x75 0x4 0x6 0x5>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x77>;
++			csi0_sensor_list = <0x0>;
++			status = "disabled";
++			pinctrl-0 = <0xb1>;
++			csi0_mck = <0x30 0x4 0x1 0x0 0x0 0x1 0x0>;
++
++			dev@0 {
++				csi0_dev0_mname = "s5k4ec";
++				csi0_dev0_twi_addr = <0x5a>;
++				csi0_dev0_pos = "rear";
++				csi0_dev0_isp_used = <0x1>;
++				csi0_dev0_fmt = <0x0>;
++				csi0_dev0_stby_mode = <0x1>;
++				csi0_dev0_vflip = <0x0>;
++				csi0_dev0_hflip = <0x0>;
++				csi0_dev0_iovdd = "iovdd-csi";
++				csi0_dev0_iovdd_vol = <0x2ab980>;
++				csi0_dev0_avdd = "avdd-csi";
++				csi0_dev0_avdd_vol = <0x2ab980>;
++				csi0_dev0_dvdd = "dvdd-csi-18";
++				csi0_dev0_dvdd_vol = <0x16e360>;
++				csi0_dev0_flash_used = <0x0>;
++				csi0_dev0_flash_type = <0x2>;
++				csi0_dev0_flvdd = "vdd-csi-led";
++				csi0_dev0_flvdd_vol = <0x325aa0>;
++				csi0_dev0_act_used = <0x0>;
++				csi0_dev0_act_name = "ad5820_act";
++				csi0_dev0_act_slave = <0x18>;
++				status = "disabled";
++				device_type = "csi0_dev0";
++				csi0_dev0_afvdd;
++				csi0_dev0_afvdd_vol;
++				csi0_dev0_power_en;
++				csi0_dev0_reset = <0x30 0x4 0x10 0x0 0x0 0x1 0x0>;
++				csi0_dev0_pwdn = <0x30 0x4 0x11 0x0 0x0 0x1 0x0>;
++				csi0_dev0_flash_en;
++				csi0_dev0_flash_mode;
++				csi0_dev0_af_pwdn;
++			};
++		};
++
++		vdevice@0 {
++			compatible = "allwinner,sun50i-vdevice";
++			pinctrl-names = "default";
++			test-gpios = <0x79 0xb 0x0 0x1 0x2 0x3 0x4>;
++			status = "okay";
++			device_type = "Vdevice";
++			pinctrl-0 = <0xb9>;
++		};
++
++		onewire_device@0 {
++			compatible = "w1-gpio";
++			gpios = <0x30 0x2 0x8 0x0 0x0 0x0 0x0>;
++			pinctrl-names = "default";
++			pinctrl-0 = <0xba>;
++			status = "okay";
++		};
++
++		ce@1c15000 {
++			compatible = "allwinner,sunxi-ce";
++			reg = <0x0 0x1c15000 0x0 0x80 0x0 0x1c15800 0x0 0x80>;
++			interrupts = <0x0 0x5e 0xff01 0x0 0x50 0xff01>;
++			clock-frequency = <0x11e1a300 0xbebc200>;
++			clocks = <0x7a 0x7b>;
++		};
++
++		deinterlace@0x01e00000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sunxi-deinterlace";
++			reg = <0x0 0x1e00000 0x0 0x77c>;
++			interrupts = <0x0 0x5d 0x4>;
++			clocks = <0x7c 0x4>;
++			status = "okay";
++			device_type = "di";
++		};
++
++		smartcard@0x01c2c400 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sunxi-scr";
++			reg = <0x0 0x1c2c400 0x0 0x100>;
++			interrupts = <0x0 0x53 0x4>;
++			clocks = <0x7d 0x7e>;
++			clock-frequency = <0x16e3600>;
++			pinctrl-names = "default";
++			pinctrl-0 = <0x7f>;
++			status = "okay";
++			device_type = "smc";
++			smc_used;
++			smc_rst;
++			smc_vppen;
++			smc_vppp;
++			smc_det;
++			smc_vccen;
++			smc_sck;
++			smc_sda;
++		};
++
++		nmi@0x01f00c00 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sunxi-nmi";
++			reg = <0x0 0x1f00c00 0x0 0x50>;
++			nmi_irq_ctrl = <0xc>;
++			nmi_irq_en = <0x40>;
++			nmi_irq_status = <0x10>;
++			nmi_irq_mask = <0x50>;
++			status = "okay";
++		};
++
++		pmu0@0 {
++			compatible = "allwinner,pmu0";
++			device_type = "pmu0";
++			pmu_batdeten = <0x1>;
++			pmu_init_chgend_rate = <0x14>;
++			pmu_init_chg_enabled = <0x1>;
++			pmu_init_adc_freq = <0x320>;
++			pmu_init_adcts_freq = <0x320>;
++			pmu_init_chg_pretime = <0x46>;
++			pmu_init_chg_csttime = <0x2d0>;
++			pmu_batt_cap_correct = <0x1>;
++			pmu_chg_end_on_en = <0x0>;
++			pmu_pwroff_vol = <0xce4>;
++			pmu_pwron_vol = <0xa28>;
++			pmu_powkey_off_delay_time = <0x0>;
++			pmu_pwrok_time = <0x40>;
++			pmu_reset_shutdown_en = <0x1>;
++			pmu_restvol_adjust_time = <0x3c>;
++			pmu_ocv_cou_adjust_time = <0x3c>;
++			pmu_vbusen_func = <0x1>;
++			pmu_reset = <0x0>;
++			pmu_IRQ_wakeup = <0x1>;
++			pmu_hot_shutdowm = <0x1>;
++			pmu_inshort = <0x0>;
++			pmu_bat_shutdown_ltf = <0xc80>;
++			pmu_bat_shutdown_htf = <0xed>;
++			status = "okay";
++			pmu_id = <0x6>;
++			pmu_twi_addr = <0x34>;
++			pmu_twi_id = <0x1>;
++			pmu_irq_id = <0x40>;
++			pmu_chg_ic_temp = <0x0>;
++			pmu_battery_rdc = <0x58>;
++			pmu_battery_cap = <0x12c0>;
++			pmu_runtime_chgcur = <0x1c2>;
++			pmu_suspend_chgcur = <0x5dc>;
++			pmu_shutdown_chgcur = <0x5dc>;
++			pmu_init_chgvol = <0x1068>;
++			pmu_ac_vol = <0xfa0>;
++			pmu_ac_cur = <0xdac>;
++			pmu_usbpc_vol = <0x1130>;
++			pmu_usbpc_cur = <0x1f4>;
++			pmu_battery_warning_level1 = <0xf>;
++			pmu_battery_warning_level2 = <0x0>;
++			pmu_chgled_func = <0x1>;
++			pmu_chgled_type = <0x0>;
++			pmu_bat_para1 = <0x0>;
++			pmu_bat_para2 = <0x0>;
++			pmu_bat_para3 = <0x0>;
++			pmu_bat_para4 = <0x0>;
++			pmu_bat_para5 = <0x0>;
++			pmu_bat_para6 = <0x0>;
++			pmu_bat_para7 = <0x1>;
++			pmu_bat_para8 = <0x1>;
++			pmu_bat_para9 = <0x2>;
++			pmu_bat_para10 = <0x3>;
++			pmu_bat_para11 = <0x4>;
++			pmu_bat_para12 = <0xa>;
++			pmu_bat_para13 = <0x11>;
++			pmu_bat_para14 = <0x1a>;
++			pmu_bat_para15 = <0x29>;
++			pmu_bat_para16 = <0x2e>;
++			pmu_bat_para17 = <0x33>;
++			pmu_bat_para18 = <0x38>;
++			pmu_bat_para19 = <0x3b>;
++			pmu_bat_para20 = <0x41>;
++			pmu_bat_para21 = <0x45>;
++			pmu_bat_para22 = <0x4b>;
++			pmu_bat_para23 = <0x4f>;
++			pmu_bat_para24 = <0x53>;
++			pmu_bat_para25 = <0x59>;
++			pmu_bat_para26 = <0x5f>;
++			pmu_bat_para27 = <0x62>;
++			pmu_bat_para28 = <0x64>;
++			pmu_bat_para29 = <0x64>;
++			pmu_bat_para30 = <0x64>;
++			pmu_bat_para31 = <0x64>;
++			pmu_bat_para32 = <0x64>;
++			pmu_bat_temp_enable = <0x1>;
++			pmu_bat_charge_ltf = <0x8d5>;
++			pmu_bat_charge_htf = <0x184>;
++			pmu_bat_temp_para1 = <0x1d2a>;
++			pmu_bat_temp_para2 = <0x1180>;
++			pmu_bat_temp_para3 = <0xdbe>;
++			pmu_bat_temp_para4 = <0xae2>;
++			pmu_bat_temp_para5 = <0x8af>;
++			pmu_bat_temp_para6 = <0x6fc>;
++			pmu_bat_temp_para7 = <0x5a8>;
++			pmu_bat_temp_para8 = <0x3c9>;
++			pmu_bat_temp_para9 = <0x298>;
++			pmu_bat_temp_para10 = <0x1d2>;
++			pmu_bat_temp_para11 = <0x189>;
++			pmu_bat_temp_para12 = <0x14d>;
++			pmu_bat_temp_para13 = <0x11b>;
++			pmu_bat_temp_para14 = <0xf2>;
++			pmu_bat_temp_para15 = <0xb3>;
++			pmu_bat_temp_para16 = <0x86>;
++			pmu_powkey_off_time = <0x1770>;
++			pmu_powkey_off_func = <0x0>;
++			pmu_powkey_off_en = <0x1>;
++			pmu_powkey_long_time = <0x5dc>;
++			pmu_powkey_on_time = <0x3e8>;
++			power_start = <0x0>;
++		};
++
++		regu@0 {
++			compatible = "allwinner,pmu0_regu";
++			regulator_count = <0x17>;
++			status = "okay";
++			device_type = "pmu0_regu";
++			regulator1 = "axp81x_dcdc1 none vcc-nand vcc-emmc vcc-sdc vcc-usb-30 vcc-io vcc-pd";
++			regulator2 = "axp81x_dcdc2 none vdd-cpua";
++			regulator3 = "axp81x_dcdc3 none";
++			regulator4 = "axp81x_dcdc4 none";
++			regulator5 = "axp81x_dcdc5 none vcc-dram";
++			regulator6 = "axp81x_dcdc6 none vdd-sys";
++			regulator7 = "axp81x_dcdc7 none";
++			regulator8 = "axp81x_rtc none";
++			regulator9 = "axp81x_aldo1 none vdd-csi-led iovdd-csi vcc-pe";
++			regulator10 = "axp81x_aldo2 none vcc-pl";
++			regulator11 = "axp81x_aldo3 none vcc-avcc vcc-pll";
++			regulator12 = "axp81x_dldo1 none vcc-hdmi-33";
++			regulator13 = "axp81x_dldo2 none vcc-mipi";
++			regulator14 = "axp81x_dldo3 none avdd-csi";
++			regulator15 = "axp81x_dldo4 none vcc-deviceio";
++			regulator16 = "axp81x_eldo1 none vcc-cpvdd vcc-wifi-io vcc-pc vcc-pg";
++			regulator17 = "axp81x_eldo2 none vcc-lcd-0";
++			regulator18 = "axp81x_eldo3 none dvdd-csi-18";
++			regulator19 = "axp81x_fldo1 none vcc-hsic-12";
++			regulator20 = "axp81x_fldo2 none vdd-cpus";
++			regulator21 = "axp81x_gpio0ldo none vcc-ctp";
++			regulator22 = "axp81x_gpio1ldo none";
++			regulator23 = "axp81x_dc1sw none vcc-lvds vcc-dsi-33";
++		};
++
++		nand0@01c03000 {
++			compatible = "allwinner,sun50i-nand";
++			device_type = "nand0";
++			reg = <0x0 0x1c03000 0x0 0x1000>;
++			interrupts = <0x0 0x46 0x4>;
++			clocks = <0x4 0x80>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x83>;
++			nand0_regulator1 = "vcc-nand";
++			nand0_regulator2 = "none";
++			nand0_cache_level = <0x55aaaa55>;
++			nand0_flush_cache_num = <0x55aaaa55>;
++			nand0_capacity_level = <0x55aaaa55>;
++			nand0_id_number_ctl = <0x55aaaa55>;
++			nand0_print_level = <0x55aaaa55>;
++			nand0_p0 = <0x55aaaa55>;
++			nand0_p1 = <0x55aaaa55>;
++			nand0_p2 = <0x55aaaa55>;
++			nand0_p3 = <0x55aaaa55>;
++			status = "disabled";
++			nand0_support_2ch = <0x0>;
++			pinctrl-0 = <0xab 0xac>;
++		};
++
++		thermal_sensor {
++			compatible = "allwinner,thermal_sensor";
++			reg = <0x0 0x1c25000 0x0 0x400>;
++			interrupts = <0x0 0x1f 0x0>;
++			clocks = <0x6 0x84>;
++			sensor_num = <0x3>;
++			shut_temp = <0x78>;
++			status = "okay";
++
++			combine0 {
++				#thermal-sensor-cells = <0x1>;
++				combine_cnt = <0x3>;
++				combine_type = "max";
++				combine_chn = <0x0 0x1 0x2>;
++				linux,phandle = <0x85>;
++				phandle = <0x85>;
++			};
++		};
++
++		cpu_budget_cool {
++			compatible = "allwinner,budget_cooling";
++			#cooling-cells = <0x2>;
++			status = "okay";
++			state_cnt = <0x8>;
++			cluster_num = <0x1>;
++			/*  1152000   4 cores */
++			state0 = <0x119400 0x4>;
++			/*  1008000   4 cores */
++			state1 = <0xf6180 0x4>;
++			/*   912000   4 cores */
++			state2 = <0xdea80 0x4>;
++			/*   816000   4 cores */
++			state3 = <0xc7380 0x4>;
++			/*   720000   4 cores */
++			state4 = <0xafc80 0x4>;
++			/*   624000   3 cores */
++			state5 = <0x98580 0x3>;
++			/*   528000   2 cores */
++			state6 = <0x80e80 0x2>;
++			/*   480000    1 core */
++			state7 = <0x75300 0x1>;
++			linux,phandle = <0x87>;
++			phandle = <0x87>;
++		};
++
++		gpu_cooling {
++			compatible = "allwinner,gpu_cooling";
++			reg = <0x0 0x0 0x0 0x0>;
++			#cooling-cells = <0x2>;
++			status = "okay";
++			state_cnt = <0x3>;
++			state0 = <0x0>;
++			state1 = <0x168>;
++			state2 = <0x90>;
++			linux,phandle = <0x8c>;
++			phandle = <0x8c>;
++		};
++
++		thermal-zones {
++
++			soc_thermal {
++				polling-delay-passive = <0x1f4>;
++				polling-delay = <0x7d0>;
++				thermal-sensors = <0x85 0x0>;
++
++				trips {
++
++					t0 {
++						temperature = <0x50>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x86>;
++						phandle = <0x86>;
++					};
++
++					t1 {
++						temperature = <0x55>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x88>;
++						phandle = <0x88>;
++					};
++
++					t2 {
++						temperature = <0x5a>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x89>;
++						phandle = <0x89>;
++					};
++
++					t3 {
++						temperature = <0x5f>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x8a>;
++						phandle = <0x8a>;
++					};
++
++					t4 {
++						temperature = <0x55>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x8b>;
++						phandle = <0x8b>;
++					};
++
++					t5 {
++						temperature = <0x5a>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x8d>;
++						phandle = <0x8d>;
++					};
++
++					t6 {
++						temperature = <0x6c>;
++						type = "critical";
++						hysteresis = <0x0>;
++					};
++				};
++
++				cooling-maps {
++
++					bind0 {
++						contribution = <0x0>;
++						trip = <0x86>;
++						cooling-device = <0x87 0x1 0x1>;
++					};
++
++					bind1 {
++						contribution = <0x0>;
++						trip = <0x88>;
++						cooling-device = <0x87 0x2 0x2>;
++					};
++
++					bind2 {
++						contribution = <0x0>;
++						trip = <0x89>;
++						cooling-device = <0x87 0x3 0x6>;
++					};
++
++					bind3 {
++						contribution = <0x0>;
++						trip = <0x8a>;
++						cooling-device = <0x87 0x7 0x9>;
++					};
++
++					bind4 {
++						contribution = <0x0>;
++						trip = <0x8b>;
++						cooling-device = <0x8c 0x1 0x1>;
++					};
++
++					bind5 {
++						contribution = <0x0>;
++						trip = <0x8d>;
++						cooling-device = <0x8c 0x2 0x2>;
++					};
++				};
++			};
++		};
++
++		keyboard {
++			compatible = "allwinner,keyboard_2000mv";
++			reg = <0x0 0x1c21800 0x0 0x400>;
++			interrupts = <0x0 0x1e 0x0>;
++			status = "okay";
++			key_cnt = <0x5>;
++			key1 = <0xf0 0x73>;
++			key2 = <0x1f4 0x72>;
++			key3 = <0x2bc 0x8b>;
++			key4 = <0x37a 0x1c>;
++			key5 = <0x7d0 0x66>;
++		};
++
++		eth@01c30000 {
++			compatible = "allwinner,sunxi-gmac";
++			reg = <0x0 0x1c30000 0x0 0x10000 0x0 0x1c00000 0x0 0x30>;
++			pinctrl-names = "default";
++			interrupts = <0x0 0x52 0x4>;
++			interrupt-names = "gmacirq";
++			clocks = <0x8f>;
++			clock-names = "gmac";
++			phy-mode = "rmii";
++			tx-delay = <0x0>;
++			rx-delay = <0x0>;
++			gmac_power1 = "axp81x_dc1sw:0";
++			status = "okay";
++			device_type = "gmac0";
++			pinctrl-0 = <0x9e>;
++			gmac_power2;
++			gmac_power3;
++		};
++
++		product {
++			device_type = "product";
++			version = "100";
++			machine = "evb";
++		};
++
++		platform {
++			device_type = "platform";
++			eraseflag = <0x1>;
++		};
++
++		target {
++			device_type = "target";
++			boot_clock = <0x3f0>;
++			storage_type = <0xffffffff>;
++			burn_key = <0x0>;
++		};
++
++		power_sply {
++			device_type = "power_sply";
++			dcdc1_vol = <0xf4f24>;
++			dcdc2_vol = <0xf468c>;
++			dcdc6_vol = <0xf468c>;
++			aldo1_vol = <0xaf0>;
++			aldo2_vol = <0xf4948>;
++			aldo3_vol = <0xf4df8>;
++			dldo1_vol = <0xce4>;
++			dldo2_vol = <0xce4>;
++			dldo3_vol = <0xaf0>;
++			dldo4_vol = <0xf4f24>;
++			eldo1_vol = <0xf4948>;
++			eldo2_vol = <0x708>;
++			eldo3_vol = <0x708>;
++			fldo1_vol = <0x4b0>;
++			fldo2_vol = <0xf468c>;
++			gpio0_vol = <0xc1c>;
++		};
++
++		card_boot {
++			device_type = "card_boot";
++			logical_start = <0xa000>;
++			sprite_gpio0;
++		};
++
++		pm_para {
++			device_type = "pm_para";
++			standby_mode = <0x1>;
++		};
++
++		card0_boot_para {
++			device_type = "card0_boot_para";
++			card_ctrl = <0x0>;
++			card_high_speed = <0x1>;
++			card_line = <0x4>;
++			pinctrl-0 = <0x99>;
++		};
++
++		card2_boot_para {
++			device_type = "card2_boot_para";
++			sdc_io_1v8 = <0x1>;
++			card_ctrl = <0x2>;
++			card_high_speed = <0x1>;
++			card_line = <0x8>;
++			pinctrl-0 = <0x9a>;
++			sdc_ex_dly_used = <0x2>;
++		};
++
++		twi_para {
++			device_type = "twi_para";
++			twi_port = <0x0>;
++			pinctrl-0 = <0x9b>;
++		};
++
++		uart_para {
++			device_type = "uart_para";
++			uart_debug_port = <0x0>;
++			pinctrl-0 = <0x9c>;
++		};
++
++		jtag_para {
++			device_type = "jtag_para";
++			jtag_enable = <0x1>;
++			pinctrl-0 = <0x9d>;
++		};
++
++		clock {
++			device_type = "clock";
++			pll4 = <0x12c>;
++			pll6 = <0x258>;
++			pll8 = <0x168>;
++			pll9 = <0x129>;
++			pll10 = <0x108>;
++		};
++
++		rtp_para {
++			device_type = "rtp_para";
++			rtp_used = <0x0>;
++			rtp_screen_size = <0x5>;
++			rtp_regidity_level = <0x5>;
++			rtp_press_threshold_enable = <0x0>;
++			rtp_press_threshold = <0x1f40>;
++			rtp_sensitive_level = <0xf>;
++			rtp_exchange_x_y_flag = <0x0>;
++		};
++
++		ctp {
++			device_type = "ctp";
++			compatible = "allwinner,sun50i-ctp-para";
++			status = "disabled";
++			ctp_name = "gt911_DB";
++			ctp_twi_id = <0x0>;
++			ctp_twi_addr = <0x40>;
++			ctp_screen_max_x = <0x400>;
++			ctp_screen_max_y = <0x258>;
++			ctp_revert_x_flag = <0x1>;
++			ctp_revert_y_flag = <0x1>;
++			ctp_exchange_x_y_flag = <0x0>;
++			ctp_int_port = <0x30 0x7 0x4 0x6 0xffffffff 0xffffffff 0xffffffff>;
++			ctp_wakeup = <0x30 0x7 0xb 0x1 0xffffffff 0xffffffff 0x1>;
++			ctp_power_ldo = "vcc-ctp";
++			ctp_power_ldo_vol = <0xce4>;
++			ctp_power_io;
++		};
++
++		ctp_list {
++			device_type = "ctp_list";
++			compatible = "allwinner,sun50i-ctp-list";
++			status = "okay";
++			gslX680new = <0x1>;
++			gt9xx_ts = <0x0>;
++			gt9xxf_ts = <0x1>;
++			gt9xxnew_ts = <0x0>;
++			gt82x = <0x1>;
++			zet622x = <0x1>;
++			aw5306_ts = <0x1>;
++		};
++
++		tkey_para {
++			device_type = "tkey_para";
++			tkey_used = <0x0>;
++			tkey_twi_id;
++			tkey_twi_addr;
++			tkey_int;
++		};
++
++		motor_para {
++			device_type = "motor_para";
++			motor_used = <0x0>;
++			motor_shake = <0x31 0xfffe 0x3 0x1 0xffffffff 0xffffffff 0x1>;
++		};
++
++		tvout_para {
++			device_type = "tvout_para";
++			tvout_used;
++			tvout_channel_num;
++			tv_en;
++		};
++
++		tvin_para {
++			device_type = "tvin_para";
++			tvin_used;
++			tvin_channel_num;
++		};
++
++		serial_feature {
++			device_type = "serial_feature";
++			sn_filename = "sn.txt";
++		};
++
++		gsensor {
++			device_type = "gsensor";
++			compatible = "allwinner,sun50i-gsensor-para";
++			status = "okay";
++			gsensor_twi_id = <0x1>;
++			gsensor_twi_addr = <0x1d>;
++			gsensor_vcc_io = "vcc-deviceio";
++			gsensor_vcc_io_val = <0xce4>;
++			gsensor_int1 = <0x30 0x7 0x5 0x6 0x1 0xffffffff 0xffffffff>;
++			gsensor_int2 = <0x30 0x7 0x6 0x6 0x1 0xffffffff 0xffffffff>;
++		};
++
++		gsensor_list {
++			device_type = "gsensor_list";
++			compatible = "allwinner,sun50i-gsensor-list-para";
++			gsensor_list__used = <0x1>;
++			lsm9ds0_acc_mag = <0x1>;
++			bma250 = <0x1>;
++			mma8452 = <0x1>;
++			mma7660 = <0x1>;
++			mma865x = <0x1>;
++			afa750 = <0x1>;
++			lis3de_acc = <0x1>;
++			lis3dh_acc = <0x1>;
++			kxtik = <0x1>;
++			dmard10 = <0x0>;
++			dmard06 = <0x1>;
++			mxc622x = <0x1>;
++			fxos8700 = <0x1>;
++			lsm303d = <0x0>;
++			sc7a30 = <0x1>;
++		};
++
++		3g_para {
++			device_type = "3g_para";
++			3g_used = <0x0>;
++			3g_usbc_num = <0x2>;
++			3g_uart_num = <0x0>;
++			bb_vbat = <0x79 0xb 0x3 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_host_wake = <0x79 0xc 0x0 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_on = <0x79 0xc 0x1 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_pwr_on = <0x79 0xc 0x3 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_wake = <0x79 0xc 0x4 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_rf_dis = <0x79 0xc 0x5 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_rst = <0x79 0xc 0x6 0x1 0xffffffff 0xffffffff 0x0>;
++			3g_int;
++		};
++
++		gyroscopesensor {
++			device_type = "gyroscopesensor";
++			compatible = "allwinner,sun50i-gyr_sensors-para";
++			status = "disabled";
++			gy_twi_id = <0x2>;
++			gy_twi_addr = <0x6a>;
++			gy_int1 = <0x30 0x0 0xa 0x6 0x1 0xffffffff 0xffffffff>;
++			gy_int2;
++		};
++
++		gy_list {
++			device_type = "gy_list";
++			compatible = "allwinner,sun50i-gyr_sensors-list-para";
++			status = "disabled";
++			lsm9ds0_gyr = <0x1>;
++			l3gd20_gyr = <0x0>;
++			bmg160_gyr = <0x1>;
++		};
++
++		lightsensor {
++			device_type = "lightsensor";
++			compatible = "allwinner,sun50i-lsensors-para";
++			status = "disabled";
++			ls_twi_id = <0x2>;
++			ls_twi_addr = <0x23>;
++			ls_int = <0x30 0x0 0xc 0x6 0x1 0xffffffff 0xffffffff>;
++		};
++
++		ls_list {
++			device_type = "ls_list";
++			compatible = "allwinner,sun50i-lsensors-list-para";
++			status = "disabled";
++			ltr_501als = <0x1>;
++			jsa1212 = <0x0>;
++			jsa1127 = <0x1>;
++			stk3x1x = <0x0>;
++		};
++
++		compasssensor {
++			device_type = "compasssensor";
++			compatible = "allwinner,sun50i-compass-para";
++			status = "disabled";
++			compass_twi_id = <0x2>;
++			compass_twi_addr = <0xd>;
++			compass_int = <0x30 0x0 0xb 0x6 0x1 0xffffffff 0xffffffff>;
++		};
++
++		compass_list {
++			device_type = "compass_list";
++			compatible = "allwinner,sun50i-compass-list-para";
++			status = "disabled";
++			lsm9ds0 = <0x1>;
++			lsm303d = <0x0>;
++		};
++
++		recovery_key {
++			device_type = "recovery_key";
++			key_max = <0xc>;
++			key_min = <0xa>;
++		};
++
++		fastboot_key {
++			device_type = "fastboot_key";
++			key_max = <0x6>;
++			key_min = <0x4>;
++		};
++	};
++
++	aliases {
++		serial0 = "/soc@01c00000/uart@01c28000";
++		serial1 = "/soc@01c00000/uart@01c28400";
++		serial2 = "/soc@01c00000/uart@01c28800";
++		serial3 = "/soc@01c00000/uart@01c28c00";
++		serial4 = "/soc@01c00000/uart@01c29000";
++		twi0 = "/soc@01c00000/twi@0x01c2ac00";
++		twi1 = "/soc@01c00000/twi@0x01c2b000";
++		twi2 = "/soc@01c00000/twi@0x01c2b400";
++		spi0 = "/soc@01c00000/spi@01c68000";
++		spi1 = "/soc@01c00000/spi@01c69000";
++		global_timer0 = "/soc@01c00000/timer@1c20c00";
++		cci0 = "/soc@01c00000/cci@0x01cb3000";
++		csi_res0 = "/soc@01c00000/csi_res@0x01cb0000";
++		vfe0 = "/soc@01c00000/vfe@0";
++		mmc0 = "/soc@01c00000/sdmmc@01c0f000";
++		mmc2 = "/soc@01c00000/sdmmc@01C11000";
++		nand0 = "/soc@01c00000/nand0@01c03000";
++		disp = "/soc@01c00000/disp@01000000";
++		lcd0 = "/soc@01c00000/lcd0@01c0c000";
++		hdmi = "/soc@01c00000/hdmi@01ee0000";
++		pwm = "/soc@01c00000/pwm@01c21400";
++		pwm0 = "/soc@01c00000/pwm0@01c21400";
++		s_pwm = "/soc@01c00000/s_pwm@1f03800";
++		spwm0 = "/soc@01c00000/spwm0@0x01f03800";
++		boot_disp = "/soc@01c00000/boot_disp";
++	};
++
++	chosen {
++		bootargs = "earlyprintk=sunxi-uart,0x01c28000 loglevel=8 initcall_debug=1 console=ttyS0 init=/init";
++		linux,initrd-start = <0x0 0x0>;
++		linux,initrd-end = <0x0 0x0>;
++	};
++
++	cpus {
++		#address-cells = <0x2>;
++		#size-cells = <0x0>;
++
++		cpu@0 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x0>;
++			enable-method = "psci";
++			cpufreq_tbl = <0x000639C0 0x00075300 0x0007b0c0 0x00080e80 0x0008ca00 0x000927c0 0x00098580 0x0009e340 0x000a4100 0x000afc80 0x000bb800 0x000c7380 0x000d2f00 0x000dea80 0x000ea600 0x000f6180 0x00101d00 0x0010d880 0x00119400 0x00124f80 0x00148200>;
++			clock-latency = <0x1e8480>;
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		cpu@1 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x1>;
++			enable-method = "psci";
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		cpu@2 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x2>;
++			enable-method = "psci";
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		cpu@3 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x3>;
++			enable-method = "psci";
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		idle-states {
++			entry-method = "arm,psci";
++
++			cpu-sleep-0 {
++				compatible = "arm,idle-state";
++				arm,psci-suspend-param = <0x10000>;
++				entry-latency-us = <0x28>;
++				exit-latency-us = <0x64>;
++				min-residency-us = <0x96>;
++				linux,phandle = <0x90>;
++				phandle = <0x90>;
++			};
++
++			cluster-sleep-0 {
++				compatible = "arm,idle-state";
++				arm,psci-suspend-param = <0x1010000>;
++				entry-latency-us = <0x1f4>;
++				exit-latency-us = <0x3e8>;
++				min-residency-us = <0x9c4>;
++				linux,phandle = <0x91>;
++				phandle = <0x91>;
++			};
++
++			sys-sleep-0 {
++				compatible = "arm,idle-state";
++				arm,psci-suspend-param = <0x2010000>;
++				entry-latency-us = <0x3e8>;
++				exit-latency-us = <0x7d0>;
++				min-residency-us = <0x1194>;
++				linux,phandle = <0x92>;
++				phandle = <0x92>;
++			};
++		};
++	};
++
++	psci {
++		compatible = "arm,psci-0.2";
++		method = "smc";
++		psci_version = <0x84000000>;
++		cpu_suspend = <0xc4000001>;
++		cpu_off = <0x84000002>;
++		cpu_on = <0xc4000003>;
++		affinity_info = <0xc4000004>;
++		migrate = <0xc4000005>;
++		migrate_info_type = <0x84000006>;
++		migrate_info_up_cpu = <0xc4000007>;
++		system_off = <0x84000008>;
++		system_reset = <0x84000009>;
++	};
++
++	n_brom {
++		compatible = "allwinner,n-brom";
++		reg = <0x0 0x0 0x0 0xc000>;
++	};
++
++	s_brom {
++		compatible = "allwinner,s-brom";
++		reg = <0x0 0x0 0x0 0x10000>;
++	};
++
++	sram_a1 {
++		compatible = "allwinner,sram_a1";
++		reg = <0x0 0x10000 0x0 0x8000>;
++	};
++
++	sram_a2 {
++		compatible = "allwinner,sram_a2";
++		reg = <0x0 0x40000 0x0 0x14000>;
++	};
++
++	prcm {
++		compatible = "allwinner,prcm";
++		reg = <0x0 0x1f01400 0x0 0x400>;
++	};
++
++	cpuscfg {
++		compatible = "allwinner,cpuscfg";
++		reg = <0x0 0x1f01c00 0x0 0x400>;
++	};
++
++	ion {
++		compatible = "allwinner,sunxi-ion";
++
++		system_contig {
++			type = <0x1>;
++		};
++
++		cma {
++			type = <0x4>;
++		};
++
++		system {
++			type = <0x0>;
++		};
++	};
++
++	dram {
++		compatible = "allwinner,dram";
++		clocks = <0x93 0x94>;
++		clock-names = "pll_ddr0", "pll_ddr1";
++		dram_clk = <0x2a0>;
++		dram_type = <0x3>;
++		dram_zq = <0x3b3bdd>;
++		dram_odt_en = <0x1>;
++		dram_para1 = <0x10e40400>;
++		dram_para2 = <0x4000000>;
++		dram_mr0 = <0x1c70>;
++		dram_mr1 = <0x40>;
++		dram_mr2 = <0x18>;
++		dram_mr3 = <0x0>;
++		dram_tpr0 = <0x48a192>;
++		dram_tpr1 = <0x1c2418d>;
++		dram_tpr2 = <0x76051>;
++		dram_tpr3 = <0x50005dc>;
++		dram_tpr4 = <0x0>;
++		dram_tpr5 = <0x0>;
++		dram_tpr6 = <0x0>;
++		dram_tpr7 = <0x2a066198>;
++		dram_tpr8 = <0x0>;
++		dram_tpr9 = <0x0>;
++		dram_tpr10 = <0x8808>;
++		dram_tpr11 = <0x40a60066>;
++		dram_tpr12 = <0x55550000>;
++		dram_tpr13 = <0x4000903>;
++		device_type = "dram";
++	};
++
++	memory@40000000 {
++		device_type = "memory";
++		reg = <0x0 0x41000000 0x0 0x3f000000>;
++	};
++
++	interrupt-controller@1c81000 {
++		compatible = "arm,cortex-a15-gic", "arm,cortex-a9-gic";
++		#interrupt-cells = <0x3>;
++		#address-cells = <0x0>;
++		device_type = "gic";
++		interrupt-controller;
++		reg = <0x0 0x1c81000 0x0 0x1000 0x0 0x1c82000 0x0 0x2000 0x0 0x1c84000 0x0 0x2000 0x0 0x1c86000 0x0 0x2000>;
++		interrupts = <0x1 0x9 0xf04>;
++		linux,phandle = <0x1>;
++		phandle = <0x1>;
++	};
++
++	sunxi-chipid@1c14200 {
++		compatible = "allwinner,sunxi-chipid";
++		device_type = "chipid";
++		reg = <0x0 0x1c14200 0x0 0x400>;
++	};
++
++	timer {
++		compatible = "arm,armv8-timer";
++		interrupts = <0x1 0xd 0xff01 0x1 0xe 0xff01 0x1 0xb 0xff01 0x1 0xa 0xff01>;
++		clock-frequency = <0x16e3600>;
++	};
++
++	pmu {
++		compatible = "arm,armv8-pmuv3";
++		interrupts = <0x0 0x78 0x4 0x0 0x79 0x4 0x0 0x7a 0x4 0x0 0x7b 0x4>;
++	};
++
++	dvfs_table {
++		compatible = "allwinner,dvfs_table";
++		max_freq = <0x44aa2000>;
++		min_freq = <0x1c9c3800>;
++		lv_count = <0x8>;
++		lv1_freq = <0x44aa2000>;
++		lv1_volt = <0x514>;
++		lv2_freq = <0x41cdb400>;
++		lv2_volt = <0x4ec>;
++		lv3_freq = <0x3ef14800>;
++		lv3_volt = <0x4d8>;
++		lv4_freq = <0x3c14dc00>;
++		lv4_volt = <0x4b0>;
++		lv5_freq = <0x39387000>;
++		lv5_volt = <0x488>;
++		lv6_freq = <0x365c0400>;
++		lv6_volt = <0x460>;
++		lv7_freq = <0x30a32c00>;
++		lv7_volt = <0x438>;
++		lv8_freq = <0x269fb200>;
++		lv8_volt = <0x410>;
++		device_type = "dvfs_table";
++	};
++
++	dramfreq {
++		compatible = "allwinner,sunxi-dramfreq";
++		reg = <0x0 0x1c62000 0x0 0x1000 0x0 0x1c63000 0x0 0x1000 0x0 0x1c20000 0x0 0x800>;
++		clocks = <0x93 0x94 0x95>;
++		status = "okay";
++	};
++
++	uboot {
++	};
++
++	gpu@0x01c40000 {
++		compatible = "arm,mali-400", "arm,mali-utgard";
++		reg = <0x0 0x1c40000 0x0 0x10000>;
++		interrupts = <0x0 0x61 0x4 0x0 0x62 0x4 0x0 0x63 0x4 0x0 0x64 0x4 0x0 0x66 0x4 0x0 0x67 0x4>;
++		interrupt-names = "IRQGP", "IRQGPMMU", "IRQPP0", "IRQPPMMU0", "IRQPP1", "IRQPPMMU1";
++		clocks = <0x96 0x97>;
++		device_type = "gpu_mali400_0";
++		normal_freq = <0x198>;
++		scene_ctrl_status = <0x0>;
++		temp_ctrl_status = <0x1>;
++	};
++
++	wlan {
++		compatible = "allwinner,sunxi-wlan";
++		wlan_io_regulator = "vcc-wifi-io";
++		wlan_busnum = <0x1>;
++		status = "okay";
++		device_type = "wlan";
++		clocks;
++		wlan_power;
++		wlan_regon = <0x79 0xb 0x2 0x1 0xffffffff 0xffffffff 0x0>;
++		wlan_hostwake = <0x79 0xb 0x3 0x6 0xffffffff 0xffffffff 0x0>;
++		efuse_map_path = "wifi_efuse_8189e_for_MB1019Q5.map";
++	};
++
++	bt {
++		compatible = "allwinner,sunxi-bt";
++		bt_io_regulator = "vcc-wifi-io";
++		status = "okay";
++		device_type = "bt";
++		clocks;
++		bt_power;
++		bt_rst_n = <0x79 0xb 0x4 0x1 0xffffffff 0xffffffff 0x0>;
++	};
++
++	btlpm {
++		compatible = "allwinner,sunxi-btlpm";
++		uart_index = <0x1>;
++		status = "okay";
++		device_type = "btlpm";
++		bt_wake = <0x79 0xb 0x6 0x1 0xffffffff 0xffffffff 0x1>;
++		bt_hostwake = <0x79 0xb 0x5 0x6 0xffffffff 0xffffffff 0x0>;
++	};
++};
+diff --git a/arch/arm64/boot/dts/sun50iw1p1-pine64so.dts b/arch/arm64/boot/dts/sun50iw1p1-pine64so.dts
+new file mode 100644
+index 00000000..b9f3c546
+--- /dev/null
++++ b/arch/arm64/boot/dts/sun50iw1p1-pine64so.dts
+@@ -0,0 +1,3428 @@
++/dts-v1/;
++
++/memreserve/	0x0000000045000000 0x0000000000200000;
++/memreserve/	0x0000000041010000 0x0000000000010000;
++/memreserve/	0x0000000041020000 0x0000000000000800;
++/memreserve/	0x0000000040100000 0x0000000000004000;
++/memreserve/	0x0000000040104000 0x0000000000001000;
++/memreserve/	0x0000000040105000 0x0000000000001000;
++/ {
++	model = "SOPine";
++	compatible = "pine64,pine64-plus,sopine";
++	interrupt-parent = <0x1>;
++	#address-cells = <0x2>;
++	#size-cells = <0x2>;
++
++	leds {
++		compatible = "gpio-leds";
++		pinctrl-names = "default";
++		pinctrl-0 = <&status_led>;
++		status {
++			label = "system_status";
++			gpios = <0x79 0xb 7 0x1 0xffffffff 0xffffffff 0x0>; /* PL7 */
++			linux,default-trigger = "heartbeat";
++		};
++	};
++
++	clocks {
++		compatible = "allwinner,sunxi-clk-init";
++		device_type = "clocks";
++		#address-cells = <0x2>;
++		#size-cells = <0x2>;
++		ranges;
++		reg = <0x0 0x1c20000 0x0 0x320 0x0 0x1f01400 0x0 0xb0 0x0 0x1f00060 0x0 0x4>;
++
++		losc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-clock";
++			clock-frequency = <0x8000>;
++			clock-output-names = "losc";
++			linux,phandle = <0xc>;
++			phandle = <0xc>;
++		};
++
++		iosc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-clock";
++			clock-frequency = <0xf42400>;
++			clock-output-names = "iosc";
++			linux,phandle = <0xd>;
++			phandle = <0xd>;
++		};
++
++		hosc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-clock";
++			clock-frequency = <0x16e3600>;
++			clock-output-names = "hosc";
++			linux,phandle = <0x6>;
++			phandle = <0x6>;
++		};
++
++		pll_cpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_cpu";
++		};
++
++		pll_audio {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x1770000>;
++			clock-output-names = "pll_audio";
++			linux,phandle = <0x2>;
++			phandle = <0x2>;
++		};
++
++		pll_video0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "pll_video0";
++			linux,phandle = <0x3>;
++			phandle = <0x3>;
++		};
++
++		pll_ve {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_ve";
++			linux,phandle = <0x16>;
++			phandle = <0x16>;
++		};
++
++		pll_ddr0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_ddr0";
++			linux,phandle = <0x93>;
++			phandle = <0x93>;
++		};
++
++		pll_periph0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_periph0";
++			linux,phandle = <0x4>;
++			phandle = <0x4>;
++		};
++
++		pll_periph1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_periph1";
++			linux,phandle = <0x5>;
++			phandle = <0x5>;
++		};
++
++		pll_video1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "pll_video1";
++		};
++
++		pll_gpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_gpu";
++			linux,phandle = <0x96>;
++			phandle = <0x96>;
++		};
++
++		pll_mipi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_mipi";
++			linux,phandle = <0x8>;
++			phandle = <0x8>;
++		};
++
++		pll_hsic {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_hsic";
++			linux,phandle = <0x3a>;
++			phandle = <0x3a>;
++		};
++
++		pll_de {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "pll_de";
++			linux,phandle = <0x7>;
++			phandle = <0x7>;
++		};
++
++		pll_ddr1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-pll-clock";
++			lock-mode = "new";
++			clock-output-names = "pll_ddr1";
++			linux,phandle = <0x94>;
++			phandle = <0x94>;
++		};
++
++		pll_audiox8 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x2>;
++			clock-mult = <0x8>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_audiox8";
++		};
++
++		pll_audiox4 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x2>;
++			clock-mult = <0x8>;
++			clock-div = <0x2>;
++			clock-output-names = "pll_audiox4";
++			linux,phandle = <0x3c>;
++			phandle = <0x3c>;
++		};
++
++		pll_audiox2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x2>;
++			clock-mult = <0x8>;
++			clock-div = <0x4>;
++			clock-output-names = "pll_audiox2";
++		};
++
++		pll_video0x2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x3>;
++			clock-mult = <0x2>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_video0x2";
++		};
++
++		pll_periph0x2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x4>;
++			clock-mult = <0x2>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_periph0x2";
++			linux,phandle = <0x7b>;
++			phandle = <0x7b>;
++		};
++
++		pll_periph1x2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x5>;
++			clock-mult = <0x2>;
++			clock-div = <0x1>;
++			clock-output-names = "pll_periph1x2";
++			linux,phandle = <0x5a>;
++			phandle = <0x5a>;
++		};
++
++		pll_periph0d2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x4>;
++			clock-mult = <0x1>;
++			clock-div = <0x2>;
++			clock-output-names = "pll_periph0d2";
++		};
++
++		hoscd2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,fixed-factor-clock";
++			clocks = <0x6>;
++			clock-mult = <0x1>;
++			clock-div = <0x2>;
++			clock-output-names = "hoscd2";
++		};
++
++		cpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "cpu";
++		};
++
++		cpuapb {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "cpuapb";
++		};
++
++		axi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "axi";
++		};
++
++		pll_periphahb0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "pll_periphahb0";
++		};
++
++		ahb1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ahb1";
++			linux,phandle = <0x95>;
++			phandle = <0x95>;
++		};
++
++		apb1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "apb1";
++		};
++
++		apb2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "apb2";
++			linux,phandle = <0x7e>;
++			phandle = <0x7e>;
++		};
++
++		ahb2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ahb2";
++		};
++
++		ths {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ths";
++			linux,phandle = <0x84>;
++			phandle = <0x84>;
++		};
++
++		nand {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "nand";
++			linux,phandle = <0x80>;
++			phandle = <0x80>;
++		};
++
++		sdmmc0_mod {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc0_mod";
++			linux,phandle = <0x60>;
++			phandle = <0x60>;
++		};
++
++		sdmmc0_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc0_bus";
++			linux,phandle = <0x61>;
++			phandle = <0x61>;
++		};
++
++		sdmmc0_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc0_rst";
++			linux,phandle = <0x62>;
++			phandle = <0x62>;
++		};
++
++		sdmmc1_mod {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc1_mod";
++			linux,phandle = <0x65>;
++			phandle = <0x65>;
++		};
++
++		sdmmc1_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc1_bus";
++			linux,phandle = <0x66>;
++			phandle = <0x66>;
++		};
++
++		sdmmc1_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc1_rst";
++			linux,phandle = <0x67>;
++			phandle = <0x67>;
++		};
++
++		sdmmc2_mod {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc2_mod";
++			linux,phandle = <0x5b>;
++			phandle = <0x5b>;
++		};
++
++		sdmmc2_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc2_bus";
++			linux,phandle = <0x5c>;
++			phandle = <0x5c>;
++		};
++
++		sdmmc2_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdmmc2_rst";
++			linux,phandle = <0x5d>;
++			phandle = <0x5d>;
++		};
++
++		ts {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ts";
++		};
++
++		ce {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ce";
++			linux,phandle = <0x7a>;
++			phandle = <0x7a>;
++		};
++
++		spi0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "spi0";
++			linux,phandle = <0x52>;
++			phandle = <0x52>;
++		};
++
++		spi1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "spi1";
++			linux,phandle = <0x56>;
++			phandle = <0x56>;
++		};
++
++		i2s0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "i2s0";
++			linux,phandle = <0x42>;
++			phandle = <0x42>;
++		};
++
++		i2s1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "i2s1";
++			linux,phandle = <0x47>;
++			phandle = <0x47>;
++		};
++
++		i2s2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "i2s2";
++			linux,phandle = <0x48>;
++			phandle = <0x48>;
++		};
++
++		spdif {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "spdif";
++			linux,phandle = <0x49>;
++			phandle = <0x49>;
++		};
++
++		usbphy0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbphy0";
++			linux,phandle = <0x32>;
++			phandle = <0x32>;
++		};
++
++		usbphy1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbphy1";
++			linux,phandle = <0x36>;
++			phandle = <0x36>;
++		};
++
++		usbhsic {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbhsic";
++			linux,phandle = <0x38>;
++			phandle = <0x38>;
++		};
++
++		usbhsic12m {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbhsic12m";
++			linux,phandle = <0x39>;
++			phandle = <0x39>;
++		};
++
++		usbohci1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbohci1";
++			linux,phandle = <0x3b>;
++			phandle = <0x3b>;
++		};
++
++		usbohci0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbohci0";
++			linux,phandle = <0x35>;
++			phandle = <0x35>;
++		};
++
++		de {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x7>;
++			assigned-clock-rates = <0x11b3dc40>;
++			clock-output-names = "de";
++			linux,phandle = <0x6a>;
++			phandle = <0x6a>;
++		};
++
++		tcon0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x8>;
++			clock-output-names = "tcon0";
++			linux,phandle = <0x6b>;
++			phandle = <0x6b>;
++		};
++
++		tcon1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x3>;
++			clock-output-names = "tcon1";
++			linux,phandle = <0x6e>;
++			phandle = <0x6e>;
++		};
++
++		deinterlace {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "deinterlace";
++			linux,phandle = <0x7c>;
++			phandle = <0x7c>;
++		};
++
++		csi_s {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "csi_s";
++			linux,phandle = <0x73>;
++			phandle = <0x73>;
++		};
++
++		csi_m {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "csi_m";
++			linux,phandle = <0x74>;
++			phandle = <0x74>;
++		};
++
++		csi_misc {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "csi_misc";
++			linux,phandle = <0x75>;
++			phandle = <0x75>;
++		};
++
++		ve {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "ve";
++			linux,phandle = <0x17>;
++			phandle = <0x17>;
++		};
++
++		adda {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "adda";
++			linux,phandle = <0x41>;
++			phandle = <0x41>;
++		};
++
++		addax4 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "addax4";
++		};
++
++		avs {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "avs";
++		};
++
++		hdmi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			assigned-clock-parents = <0x3>;
++			clock-output-names = "hdmi";
++			linux,phandle = <0x6f>;
++			phandle = <0x6f>;
++		};
++
++		hdmi_slow {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "hdmi_slow";
++			linux,phandle = <0x70>;
++			phandle = <0x70>;
++		};
++
++		mbus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "mbus";
++		};
++
++		mipidsi {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "mipidsi";
++			linux,phandle = <0x6d>;
++			phandle = <0x6d>;
++		};
++
++		gpu {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "gpu";
++			linux,phandle = <0x97>;
++			phandle = <0x97>;
++		};
++
++		usbehci_16 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbohci_16";
++		};
++
++		usbehci1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbehci1";
++			linux,phandle = <0x37>;
++			phandle = <0x37>;
++		};
++
++		usbehci0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbehci0";
++			linux,phandle = <0x34>;
++			phandle = <0x34>;
++		};
++
++		usbotg {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "usbotg";
++			linux,phandle = <0x33>;
++			phandle = <0x33>;
++		};
++
++		gmac {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "gmac";
++			linux,phandle = <0x8f>;
++			phandle = <0x8f>;
++		};
++
++		sdram {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "sdram";
++		};
++
++		dma {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "dma";
++			linux,phandle = <0xb>;
++			phandle = <0xb>;
++		};
++
++		hwspinlock_rst {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "hwspinlock_rst";
++			linux,phandle = <0xf>;
++			phandle = <0xf>;
++		};
++
++		hwspinlock_bus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "hwspinlock_bus";
++			linux,phandle = <0x10>;
++			phandle = <0x10>;
++		};
++
++		msgbox {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "msgbox";
++			linux,phandle = <0xe>;
++			phandle = <0xe>;
++		};
++
++		lvds {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "lvds";
++			linux,phandle = <0x6c>;
++			phandle = <0x6c>;
++		};
++
++		uart0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart0";
++			linux,phandle = <0x18>;
++			phandle = <0x18>;
++		};
++
++		uart1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart1";
++			linux,phandle = <0x1b>;
++			phandle = <0x1b>;
++		};
++
++		uart2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart2";
++			linux,phandle = <0x1e>;
++			phandle = <0x1e>;
++		};
++
++		uart3 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart3";
++			linux,phandle = <0x21>;
++			phandle = <0x21>;
++		};
++
++		uart4 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "uart4";
++			linux,phandle = <0x24>;
++			phandle = <0x24>;
++		};
++
++		scr {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "scr";
++			linux,phandle = <0x7d>;
++			phandle = <0x7d>;
++		};
++
++		twi0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi0";
++			linux,phandle = <0x27>;
++			phandle = <0x27>;
++		};
++
++		twi1 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi1";
++			linux,phandle = <0x2a>;
++			phandle = <0x2a>;
++		};
++
++		twi2 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi2";
++			linux,phandle = <0x2d>;
++			phandle = <0x2d>;
++		};
++
++		twi3 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "twi3";
++		};
++
++		pio {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-clock";
++			clock-output-names = "pio";
++			linux,phandle = <0xa>;
++			phandle = <0xa>;
++		};
++
++		cpurcir {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurcir";
++			linux,phandle = <0x12>;
++			phandle = <0x12>;
++		};
++
++		cpurpio {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurpio";
++			linux,phandle = <0x9>;
++			phandle = <0x9>;
++		};
++
++		cpurpll_peri0 {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurpll_peri0";
++		};
++
++		cpurcpus {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurcpus";
++		};
++
++		cpurahbs {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurahbs";
++		};
++
++		cpurapbs {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "cpurapbs";
++		};
++
++		losc_out {
++			#clock-cells = <0x0>;
++			compatible = "allwinner,sunxi-periph-cpus-clock";
++			clock-output-names = "losc_out";
++			linux,phandle = <0x98>;
++			phandle = <0x98>;
++		};
++	};
++
++	soc@01c00000 {
++		compatible = "simple-bus";
++		#address-cells = <0x2>;
++		#size-cells = <0x2>;
++		ranges;
++		device_type = "soc";
++
++		pinctrl@01f02c00 {
++			compatible = "allwinner,sun50i-r-pinctrl";
++			reg = <0x0 0x1f02c00 0x0 0x400>;
++			interrupts = <0x0 0x2d 0x4>;
++			clocks = <0x9>;
++			device_type = "r_pio";
++			gpio-controller;
++			interrupt-controller;
++			#interrupt-cells = <0x2>;
++			#size-cells = <0x0>;
++			#gpio-cells = <0x6>;
++			linux,phandle = <0x79>;
++			phandle = <0x79>;
++
++			status_led: status_led@0 {
++				allwinner,pins = "PL7";
++				allwinner,function = "gpio_out";
++				allwinner,muxsel = <0x1>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_cir0@0 {
++				allwinner,pins = "PL11";
++				allwinner,function = "s_cir0";
++				allwinner,muxsel = <0x2>;
++				allwinner,drive = <0x2>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x11>;
++				phandle = <0x11>;
++			};
++
++			spwm0@0 {
++				linux,phandle = <0xaf>;
++				phandle = <0xaf>;
++				allwinner,pins = "PL10";
++				allwinner,function = "spwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spwm0@1 {
++				linux,phandle = <0xb0>;
++				phandle = <0xb0>;
++				allwinner,pins = "PL10";
++				allwinner,function = "spwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x7>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_uart0@0 {
++				linux,phandle = <0xb6>;
++				phandle = <0xb6>;
++				allwinner,pins = "PL2", "PL3";
++				allwinner,function = "s_uart0";
++				allwinner,pname = "s_uart0_tx", "s_uart0_rx";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_rsb0@0 {
++				linux,phandle = <0xb7>;
++				phandle = <0xb7>;
++				allwinner,pins = "PL0", "PL1";
++				allwinner,function = "s_rsb0";
++				allwinner,pname = "s_rsb0_sck", "s_rsb0_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			s_jtag0@0 {
++				linux,phandle = <0xb8>;
++				phandle = <0xb8>;
++				allwinner,pins = "PL4", "PL5", "PL6", "PL7";
++				allwinner,function = "s_jtag0";
++				allwinner,pname = "s_jtag0_tms", "s_jtag0_tck", "s_jtag0_tdo", "s_jtag0_tdi";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++		};
++
++		pinctrl@01c20800 {
++			compatible = "allwinner,sun50i-pinctrl";
++			reg = <0x0 0x1c20800 0x0 0x400>;
++			interrupts = <0x0 0xb 0x4 0x0 0x11 0x4 0x0 0x15 0x4>;
++			device_type = "pio";
++			clocks = <0xa>;
++			gpio-controller;
++			interrupt-controller;
++			#interrupt-cells = <0x2>;
++			#size-cells = <0x0>;
++			#gpio-cells = <0x6>;
++			linux,phandle = <0x30>;
++			phandle = <0x30>;
++
++			uart0@1 {
++				allwinner,pins = "PB8", "PB9";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x1a>;
++				phandle = <0x1a>;
++			};
++
++			uart1@1 {
++				allwinner,pins = "PG6", "PG7", "PG8", "PG9";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x1d>;
++				phandle = <0x1d>;
++			};
++
++			uart2@1 {
++				allwinner,pins = "PB0", "PB1", "PB2", "PB3";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x20>;
++				phandle = <0x20>;
++			};
++
++			uart3@1 {
++				allwinner,pins = "PH4", "PH5", "PH6", "PH7";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x23>;
++				phandle = <0x23>;
++			};
++
++			uart4@1 {
++				allwinner,pins = "PD2", "PD3", "PD4", "PD5";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x26>;
++				phandle = <0x26>;
++			};
++
++			twi0@1 {
++				allwinner,pins = "PH0", "PH1";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x29>;
++				phandle = <0x29>;
++			};
++
++			twi1@1 {
++				allwinner,pins = "PH2", "PH3";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x2c>;
++				phandle = <0x2c>;
++			};
++
++			twi2@1 {
++				allwinner,pins = "PE14", "PE15";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x2f>;
++				phandle = <0x2f>;
++			};
++
++			spi0@2 {
++				allwinner,pins = "PC3", "PC2", "PC0", "PC1";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x55>;
++				phandle = <0x55>;
++			};
++
++			spi1@2 {
++				allwinner,pins = "PD0", "PD1", "PD2", "PD3";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x59>;
++				phandle = <0x59>;
++			};
++
++			sdc0@1 {
++				allwinner,pins = "PF0", "PF1", "PF2", "PF3", "PF4", "PF5";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x64>;
++				phandle = <0x64>;
++			};
++
++			sdc1@1 {
++				allwinner,pins = "PG0", "PG1", "PG2", "PG3", "PG4", "PG5";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x69>;
++				phandle = <0x69>;
++			};
++
++			sdc2@1 {
++				allwinner,pins = "PC1", "PC5", "PC6", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x5f>;
++				phandle = <0x5f>;
++			};
++
++			daudio0@0 {
++				allwinner,pins = "PB6", "PB3", "PB4", "PB5", "PB7";
++				allwinner,function = "pcm0";
++				allwinner,muxsel = <0x3>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x43>;
++				phandle = <0x43>;
++			};
++
++			daudio0_sleep@0 {
++				allwinner,pins = "PB6", "PB3", "PB4", "PB5", "PB7";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x44>;
++				phandle = <0x44>;
++			};
++
++			daudio1@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "pcm1";
++				allwinner,muxsel = <0x3>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x45>;
++				phandle = <0x45>;
++			};
++
++			daudio1_sleep@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x46>;
++				phandle = <0x46>;
++			};
++
++			aif3@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "aif3";
++				allwinner,muxsel = <0x2>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x3e>;
++				phandle = <0x3e>;
++			};
++
++			aif2_sleep@0 {
++				allwinner,pins = "PB6", "PB4", "PB5", "PB7";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x3f>;
++				phandle = <0x3f>;
++			};
++
++			aif3_sleep@0 {
++				allwinner,pins = "PG10", "PG11", "PG12", "PG13";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x40>;
++				phandle = <0x40>;
++			};
++
++			spdif@0 {
++				allwinner,pins = "PH8";
++				allwinner,function = "spdif0";
++				allwinner,muxsel = <0x2>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x4a>;
++				phandle = <0x4a>;
++			};
++
++			spdif_sleep@0 {
++				allwinner,pins = "PH8";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x4b>;
++				phandle = <0x4b>;
++			};
++
++			csi0_sleep@0 {
++				allwinner,pins = "PE0", "PE2", "PE3", "PE4", "PE5", "PE6", "PE7", "PE8", "PE9", "PE10", "PE11", "PE12", "PE13";
++				allwinner,pname = "csi0_pck", "csi0_hsync", "csi0_vsync", "csi0_d0", "csi0_d1", "csi0_d2", "csi0_d3", "csi0_d4", "csi0_d5", "csi0_d6", "csi0_d7", "csi0_sck", "csi0_sda";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				allwinner,data = <0x0>;
++				linux,phandle = <0x77>;
++				phandle = <0x77>;
++			};
++
++			smartcard@0 {
++				allwinner,pins = "PB1", "PB4", "PB5", "PB6", "PB7";
++				allwinner,function = "sim0";
++				allwinner,muxsel = <0x5>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x1>;
++				linux,phandle = <0x7f>;
++				phandle = <0x7f>;
++			};
++
++			nand0@2 {
++				allwinner,pins = "PC0", "PC1", "PC2", "PC3", "PC4", "PC5", "PC6", "PC7", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16", "PC17", "PC18";
++				allwinner,function = "io_disabled";
++				allwinner,muxsel = <0x7>;
++				allwinner,drive = <0x1>;
++				allwinner,pull = <0x0>;
++				linux,phandle = <0x83>;
++				phandle = <0x83>;
++			};
++
++			card0_boot_para@0 {
++				linux,phandle = <0x99>;
++				phandle = <0x99>;
++				allwinner,pins = "PF0", "PF1", "PF2", "PF3", "PF4", "PF5";
++				allwinner,function = "card0_boot_para";
++				allwinner,pname = "sdc_d1", "sdc_d0", "sdc_clk", "sdc_cmd", "sdc_d3", "sdc_d2";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			card2_boot_para@0 {
++				linux,phandle = <0x9a>;
++				phandle = <0x9a>;
++				allwinner,pins = "PC1", "PC5", "PC6", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "card2_boot_para";
++				allwinner,pname = "sdc_ds", "sdc_clk", "sdc_cmd", "sdc_d0", "sdc_d1", "sdc_d2", "sdc_d3", "sdc_d4", "sdc_d5", "sdc_d6", "sdc_d7", "sdc_emmc_rst";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi_para@0 {
++				linux,phandle = <0x9b>;
++				phandle = <0x9b>;
++				allwinner,pins = "PH0", "PH1";
++				allwinner,function = "twi_para";
++				allwinner,pname = "twi_scl", "twi_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart_para@0 {
++				linux,phandle = <0x9c>;
++				phandle = <0x9c>;
++				allwinner,pins = "PB8", "PB9";
++				allwinner,function = "uart_para";
++				allwinner,pname = "uart_debug_tx", "uart_debug_rx";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			jtag_para@0 {
++				linux,phandle = <0x9d>;
++				phandle = <0x9d>;
++				allwinner,pins = "PB0", "PB1", "PB2", "PB3";
++				allwinner,function = "jtag_para";
++				allwinner,pname = "jtag_ms", "jtag_ck", "jtag_do", "jtag_di";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			gmac0@0 {
++				linux,phandle = <0x9e>;
++				phandle = <0x9e>;
++				allwinner,pins = "PD18", "PD17", "PD16", "PD15", "PD20", "PD19", "PD11", "PD10", "PD9", "PD8", "PD13", "PD12", "PD21", "PD22", "PD23";
++				allwinner,function = "gmac0";
++				allwinner,pname = "gmac_txd0", "gmac_txd1", "gmac_txd2", "gmac_txd3", "gmac_txen", "gmac_gtxclk", "gmac_rxd0", "gmac_rxd1", "gmac_rxd2", "gmac_rxd3", "gmac_rxdv", "gmac_rxclk", "gmac_clkin", "gmac_mdc", "gmac_mdio";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi0@0 {
++				linux,phandle = <0x9f>;
++				phandle = <0x9f>;
++				allwinner,pins = "PH0", "PH1";
++				allwinner,function = "twi0";
++				allwinner,pname = "twi0_scl", "twi0_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi1@0 {
++				linux,phandle = <0xa0>;
++				phandle = <0xa0>;
++				allwinner,pins = "PH2", "PH3";
++				allwinner,function = "twi1";
++				allwinner,pname = "twi1_scl", "twi1_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			twi2@0 {
++				linux,phandle = <0xa1>;
++				phandle = <0xa1>;
++				allwinner,pins = "PE14", "PE15";
++				allwinner,function = "twi2";
++				allwinner,pname = "twi2_scl", "twi2_sda";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart0@0 {
++				linux,phandle = <0xa2>;
++				phandle = <0xa2>;
++				allwinner,pins = "PB8", "PB9";
++				allwinner,function = "uart0";
++				allwinner,pname = "uart0_tx", "uart0_rx";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart1@0 {
++				linux,phandle = <0xa3>;
++				phandle = <0xa3>;
++				allwinner,pins = "PG6", "PG7", "PG8", "PG9";
++				allwinner,function = "uart1";
++				allwinner,pname = "uart1_tx", "uart1_rx", "uart1_rts", "uart1_cts";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart2@0 {
++				linux,phandle = <0xa4>;
++				phandle = <0xa4>;
++				allwinner,pins = "PB0", "PB1", "PB2", "PB3";
++				allwinner,function = "uart2";
++				allwinner,pname = "uart2_tx", "uart2_rx", "uart2_rts", "uart2_cts";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart3@0 {
++				linux,phandle = <0xa5>;
++				phandle = <0xa5>;
++				allwinner,pins = "PD0", "PD1";
++				allwinner,function = "uart3";
++				allwinner,pname = "uart3_tx", "uart3_rx";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			uart4@0 {
++				linux,phandle = <0xa6>;
++				phandle = <0xa6>;
++				allwinner,pins = "PD2", "PD3", "PD4", "PD5";
++				allwinner,function = "uart4";
++				allwinner,pname = "uart4_tx", "uart4_rx", "uart4_rts", "uart4_cts";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi0@0 {
++				linux,phandle = <0xa7>;
++				phandle = <0xa7>;
++				allwinner,pins = "PC3";
++				allwinner,function = "spi0";
++				allwinner,pname = "spi0_cs0";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi0@1 {
++				linux,phandle = <0xa8>;
++				phandle = <0xa8>;
++				allwinner,pins = "PC2", "PC0", "PC1";
++				allwinner,function = "spi0";
++				allwinner,pname = "spi0_sclk", "spi0_mosi", "spi0_miso";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi1@0 {
++				linux,phandle = <0xa9>;
++				phandle = <0xa9>;
++				allwinner,pins = "PD0";
++				allwinner,function = "spi1";
++				allwinner,pname = "spi1_cs0";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			spi1@1 {
++				linux,phandle = <0xaa>;
++				phandle = <0xaa>;
++				allwinner,pins = "PD1", "PD2", "PD3";
++				allwinner,function = "spi1";
++				allwinner,pname = "spi1_sclk", "spi1_mosi", "spi1_miso";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			nand0@0 {
++				linux,phandle = <0xab>;
++				phandle = <0xab>;
++				allwinner,pins = "PC0", "PC1", "PC2", "PC5", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "nand0";
++				allwinner,pname = "nand0_we", "nand0_ale", "nand0_cle", "nand0_nre", "nand0_d0", "nand0_d1", "nand0_d2", "nand0_d3", "nand0_d4", "nand0_d5", "nand0_d6", "nand0_d7", "nand0_ndqs";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0x1>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			nand0@1 {
++				linux,phandle = <0xac>;
++				phandle = <0xac>;
++				allwinner,pins = "PC3", "PC4", "PC6", "PC7", "PC17", "PC18";
++				allwinner,function = "nand0";
++				allwinner,pname = "nand0_ce1", "nand0_ce0", "nand0_rb0", "nand0_rb1", "nand0_ce2", "nand0_ce3";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x1>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			pwm0@0 {
++				linux,phandle = <0xad>;
++				phandle = <0xad>;
++				allwinner,pins = "PD22";
++				allwinner,function = "pwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			pwm0@1 {
++				linux,phandle = <0xae>;
++				phandle = <0xae>;
++				allwinner,pins = "PD22";
++				allwinner,function = "pwm0";
++				allwinner,pname = "pwm_positive";
++				allwinner,muxsel = <0x7>;
++				allwinner,pull = <0x0>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			csi0@0 {
++				linux,phandle = <0xb1>;
++				phandle = <0xb1>;
++				allwinner,pins = "PE0", "PE2", "PE3", "PE4", "PE5", "PE6", "PE7", "PE8", "PE9", "PE10", "PE11", "PE12", "PE13";
++				allwinner,function = "csi0";
++				allwinner,pname = "csi0_pck", "csi0_hsync", "csi0_vsync", "csi0_d0", "csi0_d1", "csi0_d2", "csi0_d3", "csi0_d4", "csi0_d5", "csi0_d6", "csi0_d7", "csi0_sck", "csi0_sda";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0xffffffff>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			sdc0@0 {
++				linux,phandle = <0xb2>;
++				phandle = <0xb2>;
++				allwinner,pins = "PF0", "PF1", "PF2", "PF3", "PF4", "PF5";
++				allwinner,function = "sdc0";
++				allwinner,pname = "sdc0_d1", "sdc0_d0", "sdc0_clk", "sdc0_cmd", "sdc0_d3", "sdc0_d2";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			sdc1@0 {
++				linux,phandle = <0xb3>;
++				phandle = <0xb3>;
++				allwinner,pins = "PG0", "PG1", "PG2", "PG3", "PG4", "PG5";
++				allwinner,function = "sdc1";
++				allwinner,pname = "sdc1_clk", "sdc1_cmd", "sdc1_d0", "sdc1_d1", "sdc1_d2", "sdc1_d3";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			sdc2@0 {
++				linux,phandle = <0xb4>;
++				phandle = <0xb4>;
++				allwinner,pins = "PC1", "PC5", "PC6", "PC8", "PC9", "PC10", "PC11", "PC12", "PC13", "PC14", "PC15", "PC16";
++				allwinner,function = "sdc2";
++				allwinner,pname = "sdc2_ds", "sdc2_clk", "sdc2_cmd", "sdc2_d0", "sdc2_d1", "sdc2_d2", "sdc2_d3", "sdc2_d4", "sdc2_d5", "sdc2_d6", "sdc2_d7", "sdc2_emmc_rst";
++				allwinner,muxsel = <0x3>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x3>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			codec@0 {
++				linux,phandle = <0xb5>;
++				phandle = <0xb5>;
++				allwinner,pins = "PH7";
++				allwinner,function = "codec";
++				allwinner,pname = "gpio-spk";
++				allwinner,muxsel = <0x2>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0xffffffff>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			Vdevice@0 {
++				linux,phandle = <0xb9>;
++				phandle = <0xb9>;
++				allwinner,pins = "PB1", "PB2";
++				allwinner,function = "Vdevice";
++				allwinner,pname = "Vdevice_0", "Vdevice_1";
++				allwinner,muxsel = <0x4>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x2>;
++				allwinner,data = <0xffffffff>;
++			};
++
++			w1_pin@0 {
++				linux,phandle = <0xba>;
++				phandle = <0xba>;
++				allwinner,pins = "PC8";
++				allwinner,function = "gpio_in";
++				allwinner,pname = "w1";
++				allwinner,muxsel = <0x0>;
++				allwinner,pull = <0x1>;
++				allwinner,drive = <0x0>;
++				allwinner,data = <0xffffffff>;
++			};
++		};
++
++		pinctrl@0 {
++			compatible = "allwinner,axp-pinctrl";
++			gpio-controller;
++			#size-cells = <0x0>;
++			#gpio-cells = <0x6>;
++			device_type = "axp_pio";
++			linux,phandle = <0x31>;
++			phandle = <0x31>;
++		};
++
++		dma-controller@01c02000 {
++			compatible = "allwinner,sun50i-dma";
++			reg = <0x0 0x1c02000 0x0 0x1000>;
++			interrupts = <0x0 0x32 0x4>;
++			clocks = <0xb>;
++			#dma-cells = <0x1>;
++		};
++
++		mbus-controller@01c62000 {
++			compatible = "allwinner,sun50i-mbus";
++			reg = <0x0 0x1c62000 0x0 0x110>;
++			#mbus-cells = <0x1>;
++		};
++
++		arisc {
++			compatible = "allwinner,sunxi-arisc";
++			#address-cells = <0x2>;
++			#size-cells = <0x2>;
++			clocks = <0xc 0xd 0x6 0x4>;
++			clock-names = "losc", "iosc", "hosc", "pll_periph0";
++			powchk_used = <0x0>;
++			power_reg = <0x2309621>;
++			system_power = <0x32>;
++		};
++
++		arisc_space {
++			compatible = "allwinner,arisc_space";
++			space1 = <0x40000 0x0 0x14000>;
++			space2 = <0x40100000 0x18000 0x4000>;
++			space3 = <0x40104000 0x0 0x1000>;
++			space4 = <0x40105000 0x0 0x1000>;
++		};
++
++		standby_space {
++			compatible = "allwinner,standby_space";
++			space1 = <0x41020000 0x0 0x800>;
++		};
++
++		msgbox@1c17000 {
++			compatible = "allwinner,msgbox";
++			clocks = <0xe>;
++			clock-names = "clk_msgbox";
++			reg = <0x0 0x1c17000 0x0 0x1000>;
++			interrupts = <0x0 0x31 0x1>;
++			status = "okay";
++		};
++
++		hwspinlock@1c18000 {
++			compatible = "allwinner,sunxi-hwspinlock";
++			clocks = <0xf 0x10>;
++			clock-names = "clk_hwspinlock_rst", "clk_hwspinlock_bus";
++			reg = <0x0 0x1c18000 0x0 0x1000>;
++			status = "okay";
++			num-locks = <0x8>;
++		};
++
++		s_cir@1f02000 {
++			compatible = "allwinner,s_cir";
++			reg = <0x0 0x1f02000 0x0 0x400>;
++			interrupts = <0x0 0x25 0x4>;
++			pinctrl-names = "default";
++			pinctrl-0 = <0x11>;
++			clocks = <0x6 0x12>;
++			supply = "vcc-pl";
++			ir_power_key_code = <0x4d>;
++			ir_addr_code = <0x4040>;
++			status = "okay";
++			device_type = "s_cir0";
++		};
++
++		s_uart@1f02800 {
++			compatible = "allwinner,s_uart";
++			reg = <0x0 0x1f02800 0x0 0x400>;
++			interrupts = <0x0 0x26 0x4>;
++			pinctrl-names = "default";
++			status = "okay";
++			device_type = "s_uart0";
++			pinctrl-0 = <0xb6>;
++		};
++
++		s_rsb@1f03400 {
++			compatible = "allwinner,s_rsb";
++			reg = <0x0 0x1f03400 0x0 0x400>;
++			interrupts = <0x0 0x27 0x4>;
++			pinctrl-names = "default";
++			status = "okay";
++			device_type = "s_rsb0";
++			pinctrl-0 = <0xb7>;
++		};
++
++		s_jtag0 {
++			compatible = "allwinner,s_jtag";
++			pinctrl-names = "default";
++			status = "disabled";
++			device_type = "s_jtag0";
++			pinctrl-0 = <0xb8>;
++		};
++
++		timer@1c20c00 {
++			compatible = "allwinner,sunxi-timer";
++			device_type = "timer";
++			reg = <0x0 0x1c20c00 0x0 0x90>;
++			interrupts = <0x0 0x12 0x1>;
++			clock-frequency = <0x16e3600>;
++			timer-prescale = <0x10>;
++		};
++
++		rtc@01f00000 {
++			compatible = "allwinner,sun50i-rtc";
++			device_type = "rtc";
++			reg = <0x0 0x1f00000 0x0 0x218>;
++			interrupts = <0x0 0x28 0x4>;
++			gpr_offset = <0x100>;
++			gpr_len = <0x4>;
++		};
++
++		ve@01c0e000 {
++			compatible = "allwinner,sunxi-cedar-ve";
++			reg = <0x0 0x1c0e000 0x0 0x1000 0x0 0x1c00000 0x0 0x10 0x0 0x1c20000 0x0 0x800>;
++			interrupts = <0x0 0x3a 0x4>;
++			clocks = <0x16 0x17>;
++		};
++
++		uart@01c28000 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart0";
++			reg = <0x0 0x1c28000 0x0 0x400>;
++			interrupts = <0x0 0x0 0x4>;
++			clocks = <0x18>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x1a>;
++			uart0_port = <0x0>;
++			uart0_type = <0x2>;
++			status = "okay";
++			pinctrl-0 = <0xa2>;
++		};
++
++		uart@01c28400 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart1";
++			reg = <0x0 0x1c28400 0x0 0x400>;
++			interrupts = <0x0 0x1 0x4>;
++			clocks = <0x1b>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x1d>;
++			uart1_port = <0x1>;
++			uart1_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa3>;
++		};
++
++		uart@01c28800 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart2";
++			reg = <0x0 0x1c28800 0x0 0x400>;
++			interrupts = <0x0 0x2 0x4>;
++			clocks = <0x1e>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x20>;
++			uart2_port = <0x2>;
++			uart2_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa4>;
++		};
++
++		uart@01c28c00 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart3";
++			reg = <0x0 0x1c28c00 0x0 0x400>;
++			interrupts = <0x0 0x3 0x4>;
++			clocks = <0x21>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x23>;
++			uart3_port = <0x3>;
++			uart3_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa5>;
++		};
++
++		uart@01c29000 {
++			compatible = "allwinner,sun50i-uart";
++			device_type = "uart4";
++			reg = <0x0 0x1c29000 0x0 0x400>;
++			interrupts = <0x0 0x4 0x4>;
++			clocks = <0x24>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x26>;
++			uart4_port = <0x4>;
++			uart4_type = <0x4>;
++			status = "okay";
++			pinctrl-0 = <0xa6>;
++		};
++
++		twi@0x01c2ac00 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-twi";
++			device_type = "twi0";
++			reg = <0x0 0x1c2ac00 0x0 0x400>;
++			interrupts = <0x0 0x6 0x4>;
++			clocks = <0x27>;
++			clock-frequency = <0x61a80>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x29>;
++			status = "okay";
++			pinctrl-0 = <0x9f>;
++		};
++
++		twi@0x01c2b000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-twi";
++			device_type = "twi1";
++			reg = <0x0 0x1c2b000 0x0 0x400>;
++			interrupts = <0x0 0x7 0x4>;
++			clocks = <0x2a>;
++			clock-frequency = <0x30d40>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x2c>;
++			status = "okay";
++			pinctrl-0 = <0xa0>;
++		};
++
++		twi@0x01c2b400 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-twi";
++			device_type = "twi2";
++			reg = <0x0 0x1c2b400 0x0 0x400>;
++			interrupts = <0x0 0x8 0x4>;
++			clocks = <0x2d>;
++			clock-frequency = <0x30d40>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x2f>;
++			status = "disabled";
++			pinctrl-0 = <0xa1>;
++		};
++
++		usbc0@0 {
++			device_type = "usbc0";
++			compatible = "allwinner,sunxi-otg-manager";
++			usb_port_type = <0x1>;
++			usb_detect_type = <0x0>;
++			usb_host_init_state = <0x1>;
++			usb_regulator_io = "nocare";
++			usb_wakeup_suspend = <0x1>;
++			usb_luns = <0x3>;
++			usb_serial_unique = <0x1>;
++			usb_serial_number = "20080411";
++			rndis_wceis = <0x1>;
++			status = "okay";
++			usb_id_gpio;
++			usb_det_vbus_gpio;
++			usb_drv_vbus_gpio;
++		};
++
++		udc-controller@0x01c19000 {
++			compatible = "allwinner,sunxi-udc";
++			reg = <0x0 0x1c19000 0x0 0x1000 0x0 0x1c00000 0x0 0x100>;
++			interrupts = <0x0 0x47 0x4>;
++			clocks = <0x32 0x33>;
++			status = "okay";
++		};
++
++		ehci0-controller@0x01c1a000 {
++			compatible = "allwinner,sunxi-ehci0";
++			reg = <0x0 0x1c1a000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x48 0x4>;
++			clocks = <0x32 0x34>;
++			hci_ctrl_no = <0x0>;
++			status = "okay";
++		};
++
++		ohci0-controller@0x01c1a400 {
++			compatible = "allwinner,sunxi-ohci0";
++			reg = <0x0 0x1c1a000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x49 0x4>;
++			clocks = <0x32 0x35>;
++			hci_ctrl_no = <0x0>;
++			status = "okay";
++		};
++
++		usbc1@0 {
++			device_type = "usbc1";
++			usb_host_init_state = <0x1>;
++			usb_regulator_io = "nocare";
++			usb_wakeup_suspend = <0x1>;
++			usb_hsic_used = <0x0>;
++			usb_hsic_regulator_io = "vcc-hsic-12";
++			usb_hsic_ctrl = <0x0>;
++			usb_hsic_usb3503_flag = <0x0>;
++			status = "okay";
++			usb_port_type = <0x1>;
++			usb_detect_type = <0x0>;
++			usb_drv_vbus_gpio;
++			usb_hsic_rdy_gpio;
++			usb_hsic_hub_connect_gpio;
++			usb_hsic_int_n_gpio;
++			usb_hsic_reset_n_gpio;
++		};
++
++		ehci1-controller@0x01c1b000 {
++			compatible = "allwinner,sunxi-ehci1";
++			reg = <0x0 0x1c1b000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x4a 0x4>;
++			clocks = <0x36 0x37 0x38 0x39 0x3a>;
++			hci_ctrl_no = <0x1>;
++			status = "okay";
++		};
++
++		ohci1-controller@0x01c1b400 {
++			compatible = "allwinner,sunxi-ohci1";
++			reg = <0x0 0x1c1b000 0x0 0xfff 0x0 0x1c00000 0x0 0x100 0x0 0x1c19000 0x0 0x1000>;
++			interrupts = <0x0 0x4b 0x4>;
++			clocks = <0x36 0x3b>;
++			hci_ctrl_no = <0x1>;
++			status = "okay";
++		};
++
++		codec@0x01c22c00 {
++			compatible = "allwinner,sunxi-internal-codec";
++			reg = <0x0 0x1c22c00 0x0 0x478 0x0 0x1f015c0 0x0 0x0>;
++			clocks = <0x3c>;
++			pinctrl-names = "aif2-default", "aif3-default", "aif2-sleep", "aif3-sleep";
++			pinctrl-1 = <0x3e>;
++			pinctrl-2 = <0x3f>;
++			pinctrl-3 = <0x40>;
++			gpio-spk = <0x30 0x7 0x7 0x1 0x1 0x1 0x1>;
++			headphonevol = <0x3b>;
++			spkervol = <0x1a>;
++			earpiecevol = <0x1e>;
++			maingain = <0x4>;
++			headsetmicgain = <0x4>;
++			adcagc_cfg = <0x0>;
++			adcdrc_cfg = <0x0>;
++			adchpf_cfg = <0x0>;
++			dacdrc_cfg = <0x0>;
++			dachpf_cfg = <0x0>;
++			aif1_lrlk_div = <0x40>;
++			aif2_lrlk_div = <0x40>;
++			aif2config = <0x0>;
++			aif3config = <0x0>;
++			pa_sleep_time = <0x15e>;
++			dac_digital_vol = <0xa0a0>;
++			status = "okay";
++			linux,phandle = <0x4d>;
++			phandle = <0x4d>;
++			device_type = "codec";
++			pinctrl-0 = <0xb5>;
++		};
++
++		i2s0-controller@0x01c22c00 {
++			compatible = "allwinner,sunxi-internal-i2s";
++			reg = <0x0 0x1c22c00 0x0 0x478>;
++			clocks = <0x2 0x41>;
++			status = "okay";
++			linux,phandle = <0x4c>;
++			phandle = <0x4c>;
++			device_type = "i2s";
++		};
++
++		daudio@0x01c22000 {
++			compatible = "allwinner,sunxi-daudio";
++			reg = <0x0 0x1c22000 0x0 0x58>;
++			clocks = <0x2 0x42>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x43>;
++			pinctrl-1 = <0x44>;
++			pcm_lrck_period = <0x20>;
++			pcm_lrckr_period = <0x1>;
++			slot_width_select = <0x20>;
++			pcm_lsb_first = <0x0>;
++			tx_data_mode = <0x0>;
++			rx_data_mode = <0x0>;
++			daudio_master = <0x4>;
++			audio_format = <0x1>;
++			signal_inversion = <0x1>;
++			frametype = <0x0>;
++			tdm_config = <0x1>;
++			tdm_num = <0x0>;
++			status = "disabled";
++			linux,phandle = <0x4e>;
++			phandle = <0x4e>;
++			device_type = "daudio0";
++		};
++
++		daudio@0x01c22400 {
++			compatible = "allwinner,sunxi-daudio";
++			reg = <0x0 0x1c22400 0x0 0x58>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x45>;
++			pinctrl-1 = <0x46>;
++			clocks = <0x2 0x47>;
++			pcm_lrck_period = <0x20>;
++			pcm_lrckr_period = <0x1>;
++			slot_width_select = <0x20>;
++			pcm_lsb_first = <0x0>;
++			tx_data_mode = <0x0>;
++			rx_data_mode = <0x0>;
++			daudio_master = <0x4>;
++			audio_format = <0x1>;
++			signal_inversion = <0x1>;
++			frametype = <0x0>;
++			tdm_config = <0x1>;
++			tdm_num = <0x1>;
++			status = "disabled";
++			linux,phandle = <0x4f>;
++			phandle = <0x4f>;
++			device_type = "daudio1";
++		};
++
++		daudio@0x01c22800 {
++			compatible = "allwinner,sunxi-tdmhdmi";
++			reg = <0x0 0x1c22800 0x0 0x58>;
++			clocks = <0x2 0x48>;
++			status = "okay";
++			linux,phandle = <0x50>;
++			phandle = <0x50>;
++			device_type = "daudio2";
++		};
++
++		spdif-controller@0x01c21000 {
++			compatible = "allwinner,sunxi-spdif";
++			reg = <0x0 0x1c21000 0x0 0x38>;
++			clocks = <0x2 0x49>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-0 = <0x4a>;
++			pinctrl-1 = <0x4b>;
++			status = "disabled";
++			linux,phandle = <0x51>;
++			phandle = <0x51>;
++			device_type = "spdif";
++		};
++
++		sound@0 {
++			compatible = "allwinner,sunxi-codec-machine";
++			interrupts = <0x0 0x1c 0x4>;
++			sunxi,i2s-controller = <0x4c>;
++			sunxi,audio-codec = <0x4d>;
++			aif2fmt = <0x3>;
++			aif3fmt = <0x3>;
++			aif2master = <0x1>;
++			hp_detect_case = <0x1>;
++			status = "okay";
++			device_type = "sndcodec";
++		};
++
++		sound@1 {
++			compatible = "allwinner,sunxi-daudio0-machine";
++			sunxi,daudio0-controller = <0x4e>;
++			status = "disabled";
++			device_type = "snddaudio0";
++		};
++
++		sound@2 {
++			compatible = "allwinner,sunxi-daudio1-machine";
++			sunxi,daudio1-controller = <0x4f>;
++			status = "disabled";
++			device_type = "snddaudio1";
++		};
++
++		sound@3 {
++			compatible = "allwinner,sunxi-hdmi-machine";
++			sunxi,hdmi-controller = <0x50>;
++			status = "okay";
++			device_type = "sndhdmi";
++		};
++
++		sound@4 {
++			compatible = "allwinner,sunxi-spdif-machine";
++			sunxi,spdif-controller = <0x51>;
++			status = "disabled";
++			device_type = "sndspdif";
++		};
++
++		spi@01c68000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-spi";
++			device_type = "spi0";
++			reg = <0x0 0x1c68000 0x0 0x1000>;
++			interrupts = <0x0 0x41 0x4>;
++			clocks = <0x4 0x52>;
++			clock-frequency = <0x5f5e100>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x55>;
++			spi0_cs_number = <0x1>;
++			spi0_cs_bitmap = <0x1>;
++			status = "disabled";
++			pinctrl-0 = <0xa7 0xa8>;
++		};
++
++		spi@01c69000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sun50i-spi";
++			device_type = "spi1";
++			reg = <0x0 0x1c69000 0x0 0x1000>;
++			interrupts = <0x0 0x42 0x4>;
++			clocks = <0x4 0x56>;
++			clock-frequency = <0x5f5e100>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x59>;
++			spi1_cs_number = <0x1>;
++			spi1_cs_bitmap = <0x1>;
++			status = "disabled";
++			pinctrl-0 = <0xa9 0xaa>;
++		};
++
++		sdmmc@01C11000 {
++			compatible = "allwinner,sun50i-sdmmc2";
++			device_type = "sdc2";
++			reg = <0x0 0x1c11000 0x0 0x1000>;
++			interrupts = <0x0 0x3e 0x104>;
++			clocks = <0x6 0x5a 0x5b 0x5c 0x5d>;
++			clock-names = "osc24m", "pll_periph", "mmc", "ahb", "rst";
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x5f>;
++			bus-width = <0x8>;
++			max-frequency = <0x5f5e100>;
++			sdc_tm4_sm0_freq0 = <0x0>;
++			sdc_tm4_sm0_freq1 = <0x0>;
++			sdc_tm4_sm1_freq0 = <0x0>;
++			sdc_tm4_sm1_freq1 = <0x0>;
++			sdc_tm4_sm2_freq0 = <0x0>;
++			sdc_tm4_sm2_freq1 = <0x0>;
++			sdc_tm4_sm3_freq0 = <0x5000000>;
++			sdc_tm4_sm3_freq1 = <0x405>;
++			sdc_tm4_sm4_freq0 = <0x50000>;
++			sdc_tm4_sm4_freq1 = <0x408>;
++			status = "disabled";
++			non-removable;
++			pinctrl-0 = <0xb4>;
++			cd-gpios;
++			sunxi-power-save-mode;
++			sunxi-dis-signal-vol-sw;
++			mmc-ddr-1_8v;
++			mmc-hs200-1_8v;
++			mmc-hs400-1_8v;
++			vmmc = "vcc-emmc";
++			vqmmc = "vcc-lpddr";
++			vdmmc = "none";
++		};
++
++		sdmmc@01c0f000 {
++			compatible = "allwinner,sun50i-sdmmc0";
++			device_type = "sdc0";
++			reg = <0x0 0x1c0f000 0x0 0x1000>;
++			interrupts = <0x0 0x3c 0x104>;
++			clocks = <0x6 0x5a 0x60 0x61 0x62>;
++			clock-names = "osc24m", "pll_periph", "mmc", "ahb", "rst";
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x64>;
++			max-frequency = <0x2faf080>;
++			bus-width = <0x4>;
++			broken-cd;
++			status = "okay";
++			non-removable = <0x1>;
++			pinctrl-0 = <0xb2>;
++			cd-gpios = <0x30 0x5 0x6 0x0 0x1 0x2 0x0>;
++			sunxi-power-save-mode;
++			vmmc = "none";
++			vqmmc = "none";
++			vdmmc = "vcc-sdc";
++		};
++
++		sdmmc@1C10000 {
++			compatible = "allwinner,sun50i-sdmmc1";
++			device_type = "sdc1";
++			reg = <0x0 0x1c10000 0x0 0x1000>;
++			interrupts = <0x0 0x3d 0x104>;
++			clocks = <0x6 0x5a 0x65 0x66 0x67>;
++			clock-names = "osc24m", "pll_periph", "mmc", "ahb", "rst";
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x69>;
++			max-frequency = <0x8f0d180>;
++			bus-width = <0x4>;
++			sunxi-dly-52M-ddr4 = <0x1 0x0 0x0 0x0 0x2>;
++			sunxi-dly-104M = <0x1 0x0 0x0 0x0 0x1>;
++			sunxi-dly-208M = <0x1 0x0 0x0 0x0 0x1>;
++			status = "okay";
++			pinctrl-0 = <0xb3>;
++			sd-uhs-sdr50;
++			sd-uhs-ddr50;
++			sd-uhs-sdr104;
++			cap-sdio-irq;
++			keep-power-in-suspend;
++			ignore-pm-notify;
++		};
++
++		disp@01000000 {
++			compatible = "allwinner,sun50i-disp";
++			reg = <0x0 0x1000000 0x0 0x300000 0x0 0x1c0c000 0x0 0x17fc 0x0 0x1ca0000 0x0 0x10fc>;
++			interrupts = <0x0 0x56 0x104 0x0 0x57 0x104 0x0 0x59 0x104>;
++			clocks = <0x6a 0x6b 0x6c 0x6d 0x6e>;
++			status = "okay";
++			device_type = "disp";
++			disp_init_enable = <0x1>;
++			disp_mode = <0x0>;
++			screen0_output_type = <0x3>;
++			screen0_output_mode = <0xa>;
++			screen1_output_type = <0x3>;
++			screen1_output_mode = <0xa>;
++			fb0_format = <0x0>;
++			fb0_width = <0x0>;
++			fb0_height = <0x0>;
++			fb1_format = <0x0>;
++			fb1_width = <0x0>;
++			fb1_height = <0x0>;
++		};
++
++		lcd0@01c0c000 {
++			compatible = "allwinner,sunxi-lcd0";
++			pinctrl-names = "active", "sleep";
++			status = "okay";
++			device_type = "lcd0";
++			lcd_used = <0x0>;
++			lcd_driver_name = "mb709_mipi";
++			lcd_backlight = <0x32>;
++			lcd_if = <0x4>;
++			lcd_x = <0x400>;
++			lcd_y = <0x258>;
++			lcd_width = <0x0>;
++			lcd_height = <0x0>;
++			lcd_dclk_freq = <0x37>;
++			lcd_pwm_used = <0x1>;
++			lcd_pwm_ch = <0x10>;
++			lcd_pwm_freq = <0xc350>;
++			lcd_pwm_pol = <0x1>;
++			lcd_pwm_max_limit = <0xfa>;
++			lcd_hbp = <0x78>;
++			lcd_ht = <0x604>;
++			lcd_hspw = <0x14>;
++			lcd_vbp = <0x17>;
++			lcd_vt = <0x27b>;
++			lcd_vspw = <0x2>;
++			lcd_dsi_if = <0x2>;
++			lcd_dsi_lane = <0x4>;
++			lcd_dsi_format = <0x0>;
++			lcd_dsi_eotp = <0x0>;
++			lcd_dsi_vc = <0x0>;
++			lcd_dsi_te = <0x0>;
++			lcd_frm = <0x0>;
++			lcd_gamma_en = <0x0>;
++			lcd_bright_curve_en = <0x0>;
++			lcd_cmap_en = <0x0>;
++			lcd_bl_en = <0x30 0x7 0xa 0x1 0x0 0xffffffff 0x1>;
++			lcd_bl_en_power = "none";
++			lcd_power = "vcc-mipi";
++			lcd_fix_power = "vcc-dsi-33";
++			lcd_gpio_0 = <0x30 0x3 0x18 0x1 0x0 0xffffffff 0x1>;
++		};
++
++		hdmi@01ee0000 {
++			compatible = "allwinner,sunxi-hdmi";
++			reg = <0x0 0x1ee0000 0x0 0x20000>;
++			clocks = <0x6f 0x70>;
++			device_type = "hdmi";
++			status = "okay";
++			hdmi_power = "vcc-hdmi-33";
++			hdmi_hdcp_enable = <0x0>;
++			hdmi_cts_compatibility = <0x0>;
++		};
++
++		tr@01000000 {
++			compatible = "allwinner,sun50i-tr";
++			reg = <0x0 0x1000000 0x0 0x200bc>;
++			interrupts = <0x0 0x60 0x104>;
++			clocks = <0x6a>;
++			status = "okay";
++		};
++
++		pwm@01c21400 {
++			compatible = "allwinner,sunxi-pwm";
++			reg = <0x0 0x1c21400 0x0 0x3c>;
++			pwm-number = <0x1>;
++			pwm-base = <0x0>;
++			pwms = <0x71>;
++		};
++
++		pwm0@01c21400 {
++			compatible = "allwinner,sunxi-pwm0";
++			pinctrl-names = "active", "sleep";
++			reg_base = <0x1c21400>;
++			reg_busy_offset = <0x0>;
++			reg_busy_shift = <0x1c>;
++			reg_enable_offset = <0x0>;
++			reg_enable_shift = <0x4>;
++			reg_clk_gating_offset = <0x0>;
++			reg_clk_gating_shift = <0x6>;
++			reg_bypass_offset = <0x0>;
++			reg_bypass_shift = <0x9>;
++			reg_pulse_start_offset = <0x0>;
++			reg_pulse_start_shift = <0x8>;
++			reg_mode_offset = <0x0>;
++			reg_mode_shift = <0x7>;
++			reg_polarity_offset = <0x0>;
++			reg_polarity_shift = <0x5>;
++			reg_period_offset = <0x4>;
++			reg_period_shift = <0x10>;
++			reg_period_width = <0x10>;
++			reg_active_offset = <0x4>;
++			reg_active_shift = <0x0>;
++			reg_active_width = <0x10>;
++			reg_prescal_offset = <0x0>;
++			reg_prescal_shift = <0x0>;
++			reg_prescal_width = <0x4>;
++			linux,phandle = <0x71>;
++			phandle = <0x71>;
++			device_type = "pwm0";
++			pwm_used = <0x0>;
++			pinctrl-0 = <0xad>;
++			pinctrl-1 = <0xae>;
++		};
++
++		s_pwm@1f03800 {
++			compatible = "allwinner,sunxi-s_pwm";
++			reg = <0x0 0x1f03800 0x0 0x3c>;
++			pwm-number = <0x1>;
++			pwm-base = <0x10>;
++			pwms = <0x72>;
++		};
++
++		spwm0@0x01f03800 {
++			compatible = "allwinner,sunxi-pwm16";
++			pinctrl-names = "active", "sleep";
++			reg_base = <0x1f03800>;
++			reg_busy_offset = <0x0>;
++			reg_busy_shift = <0x1c>;
++			reg_enable_offset = <0x0>;
++			reg_enable_shift = <0x4>;
++			reg_clk_gating_offset = <0x0>;
++			reg_clk_gating_shift = <0x6>;
++			reg_bypass_offset = <0x0>;
++			reg_bypass_shift = <0x9>;
++			reg_pulse_start_offset = <0x0>;
++			reg_pulse_start_shift = <0x8>;
++			reg_mode_offset = <0x0>;
++			reg_mode_shift = <0x7>;
++			reg_polarity_offset = <0x0>;
++			reg_polarity_shift = <0x5>;
++			reg_period_offset = <0x4>;
++			reg_period_shift = <0x10>;
++			reg_period_width = <0x10>;
++			reg_active_offset = <0x4>;
++			reg_active_shift = <0x0>;
++			reg_active_width = <0x10>;
++			reg_prescal_offset = <0x0>;
++			reg_prescal_shift = <0x0>;
++			reg_prescal_width = <0x4>;
++			linux,phandle = <0x72>;
++			phandle = <0x72>;
++			device_type = "spwm0";
++			s_pwm_used = <0x1>;
++			pinctrl-0 = <0xaf>;
++			pinctrl-1 = <0xb0>;
++		};
++
++		boot_disp {
++			compatible = "allwinner,boot_disp";
++			device_type = "boot_disp";
++			output_disp = <0x0>;
++			output_type = <0x3>;
++			output_mode = <0xa>;
++		};
++
++		cci@0x01cb3000 {
++			compatible = "allwinner,sunxi-csi_cci";
++			reg = <0x0 0x1cb3000 0x0 0x1000>;
++			interrupts = <0x0 0x55 0x4>;
++			status = "okay";
++		};
++
++		csi_res@0x01cb0000 {
++			compatible = "allwinner,sunxi-csi";
++			reg = <0x0 0x1cb0000 0x0 0x1000>;
++			status = "okay";
++		};
++
++		vfe@0 {
++			device_type = "csi0";
++			compatible = "allwinner,sunxi-vfe";
++			interrupts = <0x0 0x54 0x4>;
++			clocks = <0x73 0x74 0x75 0x4 0x6 0x5>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x77>;
++			csi0_sensor_list = <0x0>;
++			status = "disabled";
++			pinctrl-0 = <0xb1>;
++			csi0_mck = <0x30 0x4 0x1 0x0 0x0 0x1 0x0>;
++
++			dev@0 {
++				csi0_dev0_mname = "s5k4ec";
++				csi0_dev0_twi_addr = <0x5a>;
++				csi0_dev0_pos = "rear";
++				csi0_dev0_isp_used = <0x1>;
++				csi0_dev0_fmt = <0x0>;
++				csi0_dev0_stby_mode = <0x1>;
++				csi0_dev0_vflip = <0x0>;
++				csi0_dev0_hflip = <0x0>;
++				csi0_dev0_iovdd = "iovdd-csi";
++				csi0_dev0_iovdd_vol = <0x2ab980>;
++				csi0_dev0_avdd = "avdd-csi";
++				csi0_dev0_avdd_vol = <0x2ab980>;
++				csi0_dev0_dvdd = "dvdd-csi-18";
++				csi0_dev0_dvdd_vol = <0x16e360>;
++				csi0_dev0_flash_used = <0x0>;
++				csi0_dev0_flash_type = <0x2>;
++				csi0_dev0_flvdd = "vdd-csi-led";
++				csi0_dev0_flvdd_vol = <0x325aa0>;
++				csi0_dev0_act_used = <0x0>;
++				csi0_dev0_act_name = "ad5820_act";
++				csi0_dev0_act_slave = <0x18>;
++				status = "disabled";
++				device_type = "csi0_dev0";
++				csi0_dev0_afvdd;
++				csi0_dev0_afvdd_vol;
++				csi0_dev0_power_en;
++				csi0_dev0_reset = <0x30 0x4 0x10 0x0 0x0 0x1 0x0>;
++				csi0_dev0_pwdn = <0x30 0x4 0x11 0x0 0x0 0x1 0x0>;
++				csi0_dev0_flash_en;
++				csi0_dev0_flash_mode;
++				csi0_dev0_af_pwdn;
++			};
++		};
++
++		vdevice@0 {
++			compatible = "allwinner,sun50i-vdevice";
++			pinctrl-names = "default";
++			test-gpios = <0x79 0xb 0x0 0x1 0x2 0x3 0x4>;
++			status = "okay";
++			device_type = "Vdevice";
++			pinctrl-0 = <0xb9>;
++		};
++
++		onewire_device@0 {
++			compatible = "w1-gpio";
++			gpios = <0x30 0x2 0x8 0x0 0x0 0x0 0x0>;
++			pinctrl-names = "default";
++			pinctrl-0 = <0xba>;
++			status = "okay";
++		};
++
++		ce@1c15000 {
++			compatible = "allwinner,sunxi-ce";
++			reg = <0x0 0x1c15000 0x0 0x80 0x0 0x1c15800 0x0 0x80>;
++			interrupts = <0x0 0x5e 0xff01 0x0 0x50 0xff01>;
++			clock-frequency = <0x11e1a300 0xbebc200>;
++			clocks = <0x7a 0x7b>;
++		};
++
++		deinterlace@0x01e00000 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sunxi-deinterlace";
++			reg = <0x0 0x1e00000 0x0 0x77c>;
++			interrupts = <0x0 0x5d 0x4>;
++			clocks = <0x7c 0x4>;
++			status = "okay";
++			device_type = "di";
++		};
++
++		smartcard@0x01c2c400 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sunxi-scr";
++			reg = <0x0 0x1c2c400 0x0 0x100>;
++			interrupts = <0x0 0x53 0x4>;
++			clocks = <0x7d 0x7e>;
++			clock-frequency = <0x16e3600>;
++			pinctrl-names = "default";
++			pinctrl-0 = <0x7f>;
++			status = "okay";
++			device_type = "smc";
++			smc_used;
++			smc_rst;
++			smc_vppen;
++			smc_vppp;
++			smc_det;
++			smc_vccen;
++			smc_sck;
++			smc_sda;
++		};
++
++		nmi@0x01f00c00 {
++			#address-cells = <0x1>;
++			#size-cells = <0x0>;
++			compatible = "allwinner,sunxi-nmi";
++			reg = <0x0 0x1f00c00 0x0 0x50>;
++			nmi_irq_ctrl = <0xc>;
++			nmi_irq_en = <0x40>;
++			nmi_irq_status = <0x10>;
++			nmi_irq_mask = <0x50>;
++			status = "okay";
++		};
++
++		pmu0@0 {
++			compatible = "allwinner,pmu0";
++			device_type = "pmu0";
++			pmu_batdeten = <0x1>;
++			pmu_init_chgend_rate = <0x14>;
++			pmu_init_chg_enabled = <0x1>;
++			pmu_init_adc_freq = <0x320>;
++			pmu_init_adcts_freq = <0x320>;
++			pmu_init_chg_pretime = <0x46>;
++			pmu_init_chg_csttime = <0x2d0>;
++			pmu_batt_cap_correct = <0x1>;
++			pmu_chg_end_on_en = <0x0>;
++			pmu_pwroff_vol = <0xce4>;
++			pmu_pwron_vol = <0xa28>;
++			pmu_powkey_off_delay_time = <0x0>;
++			pmu_pwrok_time = <0x40>;
++			pmu_reset_shutdown_en = <0x1>;
++			pmu_restvol_adjust_time = <0x3c>;
++			pmu_ocv_cou_adjust_time = <0x3c>;
++			pmu_vbusen_func = <0x1>;
++			pmu_reset = <0x0>;
++			pmu_IRQ_wakeup = <0x1>;
++			pmu_hot_shutdowm = <0x1>;
++			pmu_inshort = <0x0>;
++			pmu_bat_shutdown_ltf = <0xc80>;
++			pmu_bat_shutdown_htf = <0xed>;
++			status = "okay";
++			pmu_id = <0x6>;
++			pmu_twi_addr = <0x34>;
++			pmu_twi_id = <0x1>;
++			pmu_irq_id = <0x40>;
++			pmu_chg_ic_temp = <0x0>;
++			pmu_battery_rdc = <0x58>;
++			pmu_battery_cap = <0x12c0>;
++			pmu_runtime_chgcur = <0x1c2>;
++			pmu_suspend_chgcur = <0x5dc>;
++			pmu_shutdown_chgcur = <0x5dc>;
++			pmu_init_chgvol = <0x1068>;
++			pmu_ac_vol = <0xfa0>;
++			pmu_ac_cur = <0xdac>;
++			pmu_usbpc_vol = <0x1130>;
++			pmu_usbpc_cur = <0x1f4>;
++			pmu_battery_warning_level1 = <0xf>;
++			pmu_battery_warning_level2 = <0x0>;
++			pmu_chgled_func = <0x1>;
++			pmu_chgled_type = <0x0>;
++			pmu_bat_para1 = <0x0>;
++			pmu_bat_para2 = <0x0>;
++			pmu_bat_para3 = <0x0>;
++			pmu_bat_para4 = <0x0>;
++			pmu_bat_para5 = <0x0>;
++			pmu_bat_para6 = <0x0>;
++			pmu_bat_para7 = <0x1>;
++			pmu_bat_para8 = <0x1>;
++			pmu_bat_para9 = <0x2>;
++			pmu_bat_para10 = <0x3>;
++			pmu_bat_para11 = <0x4>;
++			pmu_bat_para12 = <0xa>;
++			pmu_bat_para13 = <0x11>;
++			pmu_bat_para14 = <0x1a>;
++			pmu_bat_para15 = <0x29>;
++			pmu_bat_para16 = <0x2e>;
++			pmu_bat_para17 = <0x33>;
++			pmu_bat_para18 = <0x38>;
++			pmu_bat_para19 = <0x3b>;
++			pmu_bat_para20 = <0x41>;
++			pmu_bat_para21 = <0x45>;
++			pmu_bat_para22 = <0x4b>;
++			pmu_bat_para23 = <0x4f>;
++			pmu_bat_para24 = <0x53>;
++			pmu_bat_para25 = <0x59>;
++			pmu_bat_para26 = <0x5f>;
++			pmu_bat_para27 = <0x62>;
++			pmu_bat_para28 = <0x64>;
++			pmu_bat_para29 = <0x64>;
++			pmu_bat_para30 = <0x64>;
++			pmu_bat_para31 = <0x64>;
++			pmu_bat_para32 = <0x64>;
++			pmu_bat_temp_enable = <0x1>;
++			pmu_bat_charge_ltf = <0x8d5>;
++			pmu_bat_charge_htf = <0x184>;
++			pmu_bat_temp_para1 = <0x1d2a>;
++			pmu_bat_temp_para2 = <0x1180>;
++			pmu_bat_temp_para3 = <0xdbe>;
++			pmu_bat_temp_para4 = <0xae2>;
++			pmu_bat_temp_para5 = <0x8af>;
++			pmu_bat_temp_para6 = <0x6fc>;
++			pmu_bat_temp_para7 = <0x5a8>;
++			pmu_bat_temp_para8 = <0x3c9>;
++			pmu_bat_temp_para9 = <0x298>;
++			pmu_bat_temp_para10 = <0x1d2>;
++			pmu_bat_temp_para11 = <0x189>;
++			pmu_bat_temp_para12 = <0x14d>;
++			pmu_bat_temp_para13 = <0x11b>;
++			pmu_bat_temp_para14 = <0xf2>;
++			pmu_bat_temp_para15 = <0xb3>;
++			pmu_bat_temp_para16 = <0x86>;
++			pmu_powkey_off_time = <0x1770>;
++			pmu_powkey_off_func = <0x0>;
++			pmu_powkey_off_en = <0x1>;
++			pmu_powkey_long_time = <0x5dc>;
++			pmu_powkey_on_time = <0x3e8>;
++			power_start = <0x3>;
++		};
++
++		regu@0 {
++			compatible = "allwinner,pmu0_regu";
++			regulator_count = <0x17>;
++			status = "okay";
++			device_type = "pmu0_regu";
++			regulator1 = "axp81x_dcdc1 none vcc-nand vcc-emmc vcc-sdc vcc-usb-30 vcc-io vcc-pd";
++			regulator2 = "axp81x_dcdc2 none vdd-cpua";
++			regulator3 = "axp81x_dcdc3 none";
++			regulator4 = "axp81x_dcdc4 none";
++			regulator5 = "axp81x_dcdc5 none vcc-dram";
++			regulator6 = "axp81x_dcdc6 none vdd-sys";
++			regulator7 = "axp81x_dcdc7 none";
++			regulator8 = "axp81x_rtc none";
++			regulator9 = "axp81x_aldo1 none vdd-csi-led iovdd-csi vcc-pe";
++			regulator10 = "axp81x_aldo2 none vcc-pl";
++			regulator11 = "axp81x_aldo3 none vcc-avcc vcc-pll";
++			regulator12 = "axp81x_dldo1 none vcc-hdmi-33";
++			regulator13 = "axp81x_dldo2 none vcc-mipi";
++			regulator14 = "axp81x_dldo3 none avdd-csi";
++			regulator15 = "axp81x_dldo4 none vcc-deviceio";
++			regulator16 = "axp81x_eldo1 none vcc-cpvdd vcc-wifi-io vcc-pc vcc-pg";
++			regulator17 = "axp81x_eldo2 none vcc-lcd-0";
++			regulator18 = "axp81x_eldo3 none dvdd-csi-18";
++			regulator19 = "axp81x_fldo1 none vcc-hsic-12";
++			regulator20 = "axp81x_fldo2 none vdd-cpus";
++			regulator21 = "axp81x_gpio0ldo none vcc-ctp";
++			regulator22 = "axp81x_gpio1ldo none";
++			regulator23 = "axp81x_dc1sw none vcc-lvds vcc-dsi-33";
++		};
++
++		nand0@01c03000 {
++			compatible = "allwinner,sun50i-nand";
++			device_type = "nand0";
++			reg = <0x0 0x1c03000 0x0 0x1000>;
++			interrupts = <0x0 0x46 0x4>;
++			clocks = <0x4 0x80>;
++			pinctrl-names = "default", "sleep";
++			pinctrl-1 = <0x83>;
++			nand0_regulator1 = "vcc-nand";
++			nand0_regulator2 = "none";
++			nand0_cache_level = <0x55aaaa55>;
++			nand0_flush_cache_num = <0x55aaaa55>;
++			nand0_capacity_level = <0x55aaaa55>;
++			nand0_id_number_ctl = <0x55aaaa55>;
++			nand0_print_level = <0x55aaaa55>;
++			nand0_p0 = <0x55aaaa55>;
++			nand0_p1 = <0x55aaaa55>;
++			nand0_p2 = <0x55aaaa55>;
++			nand0_p3 = <0x55aaaa55>;
++			status = "disabled";
++			nand0_support_2ch = <0x0>;
++			pinctrl-0 = <0xab 0xac>;
++		};
++
++		thermal_sensor {
++			compatible = "allwinner,thermal_sensor";
++			reg = <0x0 0x1c25000 0x0 0x400>;
++			interrupts = <0x0 0x1f 0x0>;
++			clocks = <0x6 0x84>;
++			sensor_num = <0x3>;
++			shut_temp = <0x78>;
++			status = "okay";
++
++			combine0 {
++				#thermal-sensor-cells = <0x1>;
++				combine_cnt = <0x3>;
++				combine_type = "max";
++				combine_chn = <0x0 0x1 0x2>;
++				linux,phandle = <0x85>;
++				phandle = <0x85>;
++			};
++		};
++
++		cpu_budget_cool {
++			compatible = "allwinner,budget_cooling";
++			#cooling-cells = <0x2>;
++			status = "okay";
++			state_cnt = <0x8>;
++			cluster_num = <0x1>;
++			/*  1152000   4 cores */
++			state0 = <0x119400 0x4>;
++			/*  1008000   4 cores */
++			state1 = <0xf6180 0x4>;
++			/*   912000   4 cores */
++			state2 = <0xdea80 0x4>;
++			/*   816000   4 cores */
++			state3 = <0xc7380 0x4>;
++			/*   720000   4 cores */
++			state4 = <0xafc80 0x4>;
++			/*   624000   3 cores */
++			state5 = <0x98580 0x3>;
++			/*   528000   2 cores */
++			state6 = <0x80e80 0x2>;
++			/*   480000    1 core */
++			state7 = <0x75300 0x1>;
++			linux,phandle = <0x87>;
++			phandle = <0x87>;
++		};
++
++		gpu_cooling {
++			compatible = "allwinner,gpu_cooling";
++			reg = <0x0 0x0 0x0 0x0>;
++			#cooling-cells = <0x2>;
++			status = "okay";
++			state_cnt = <0x3>;
++			state0 = <0x0>;
++			state1 = <0x168>;
++			state2 = <0x90>;
++			linux,phandle = <0x8c>;
++			phandle = <0x8c>;
++		};
++
++		thermal-zones {
++
++			soc_thermal {
++				polling-delay-passive = <0x1f4>;
++				polling-delay = <0x7d0>;
++				thermal-sensors = <0x85 0x0>;
++
++				trips {
++
++					t0 {
++						temperature = <0x50>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x86>;
++						phandle = <0x86>;
++					};
++
++					t1 {
++						temperature = <0x55>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x88>;
++						phandle = <0x88>;
++					};
++
++					t2 {
++						temperature = <0x5a>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x89>;
++						phandle = <0x89>;
++					};
++
++					t3 {
++						temperature = <0x5f>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x8a>;
++						phandle = <0x8a>;
++					};
++
++					t4 {
++						temperature = <0x55>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x8b>;
++						phandle = <0x8b>;
++					};
++
++					t5 {
++						temperature = <0x5a>;
++						type = "passive";
++						hysteresis = <0x0>;
++						linux,phandle = <0x8d>;
++						phandle = <0x8d>;
++					};
++
++					t6 {
++						temperature = <0x6c>;
++						type = "critical";
++						hysteresis = <0x0>;
++					};
++				};
++
++				cooling-maps {
++
++					bind0 {
++						contribution = <0x0>;
++						trip = <0x86>;
++						cooling-device = <0x87 0x1 0x1>;
++					};
++
++					bind1 {
++						contribution = <0x0>;
++						trip = <0x88>;
++						cooling-device = <0x87 0x2 0x2>;
++					};
++
++					bind2 {
++						contribution = <0x0>;
++						trip = <0x89>;
++						cooling-device = <0x87 0x3 0x6>;
++					};
++
++					bind3 {
++						contribution = <0x0>;
++						trip = <0x8a>;
++						cooling-device = <0x87 0x7 0x9>;
++					};
++
++					bind4 {
++						contribution = <0x0>;
++						trip = <0x8b>;
++						cooling-device = <0x8c 0x1 0x1>;
++					};
++
++					bind5 {
++						contribution = <0x0>;
++						trip = <0x8d>;
++						cooling-device = <0x8c 0x2 0x2>;
++					};
++				};
++			};
++		};
++
++		keyboard {
++			compatible = "allwinner,keyboard_2000mv";
++			reg = <0x0 0x1c21800 0x0 0x400>;
++			interrupts = <0x0 0x1e 0x0>;
++			status = "okay";
++			key_cnt = <0x5>;
++			key1 = <0xf0 0x73>;
++			key2 = <0x1f4 0x72>;
++			key3 = <0x2bc 0x8b>;
++			key4 = <0x37a 0x1c>;
++			key5 = <0x7d0 0x66>;
++		};
++
++		eth@01c30000 {
++			compatible = "allwinner,sunxi-gmac";
++			reg = <0x0 0x1c30000 0x0 0x40000 0x0 0x1c00000 0x0 0x30>;
++			pinctrl-names = "default";
++			interrupts = <0x0 0x52 0x4>;
++			interrupt-names = "gmacirq";
++			clocks = <0x8f>;
++			clock-names = "gmac";
++			phy-mode = "rgmii";
++			tx-delay = <0x3>;
++			rx-delay = <0x0>;
++			gmac_power1 = "axp81x_dc1sw:0";
++			status = "okay";
++			device_type = "gmac0";
++			pinctrl-0 = <0x9e>;
++			gmac_power2;
++			gmac_power3;
++		};
++
++		product {
++			device_type = "product";
++			version = "100";
++			machine = "evb";
++		};
++
++		platform {
++			device_type = "platform";
++			eraseflag = <0x1>;
++		};
++
++		target {
++			device_type = "target";
++			boot_clock = <0x3f0>;
++			storage_type = <0xffffffff>;
++			burn_key = <0x0>;
++		};
++
++		power_sply {
++			device_type = "power_sply";
++			dcdc1_vol = <0xf4f24>;
++			dcdc2_vol = <0xf468c>;
++			dcdc6_vol = <0xf468c>;
++			aldo1_vol = <0xaf0>;
++			aldo2_vol = <0xf4948>;
++			aldo3_vol = <0xf4df8>;
++			dldo1_vol = <0xce4>;
++			dldo2_vol = <0xce4>;
++			dldo3_vol = <0xaf0>;
++			dldo4_vol = <0xf4f24>;
++			eldo1_vol = <0xf4948>;
++			eldo2_vol = <0x708>;
++			eldo3_vol = <0x708>;
++			fldo1_vol = <0x4b0>;
++			fldo2_vol = <0xf468c>;
++			gpio0_vol = <0xc1c>;
++		};
++
++		card_boot {
++			device_type = "card_boot";
++			logical_start = <0xa000>;
++			sprite_gpio0;
++		};
++
++		pm_para {
++			device_type = "pm_para";
++			standby_mode = <0x1>;
++		};
++
++		card0_boot_para {
++			device_type = "card0_boot_para";
++			card_ctrl = <0x0>;
++			card_high_speed = <0x1>;
++			card_line = <0x4>;
++			pinctrl-0 = <0x99>;
++		};
++
++		card2_boot_para {
++			device_type = "card2_boot_para";
++			sdc_io_1v8 = <0x1>;
++			card_ctrl = <0x2>;
++			card_high_speed = <0x1>;
++			card_line = <0x8>;
++			pinctrl-0 = <0x9a>;
++			sdc_ex_dly_used = <0x2>;
++		};
++
++		twi_para {
++			device_type = "twi_para";
++			twi_port = <0x0>;
++			pinctrl-0 = <0x9b>;
++		};
++
++		uart_para {
++			device_type = "uart_para";
++			uart_debug_port = <0x0>;
++			pinctrl-0 = <0x9c>;
++		};
++
++		jtag_para {
++			device_type = "jtag_para";
++			jtag_enable = <0x1>;
++			pinctrl-0 = <0x9d>;
++		};
++
++		clock {
++			device_type = "clock";
++			pll4 = <0x12c>;
++			pll6 = <0x258>;
++			pll8 = <0x168>;
++			pll9 = <0x129>;
++			pll10 = <0x108>;
++		};
++
++		rtp_para {
++			device_type = "rtp_para";
++			rtp_used = <0x0>;
++			rtp_screen_size = <0x5>;
++			rtp_regidity_level = <0x5>;
++			rtp_press_threshold_enable = <0x0>;
++			rtp_press_threshold = <0x1f40>;
++			rtp_sensitive_level = <0xf>;
++			rtp_exchange_x_y_flag = <0x0>;
++		};
++
++		ctp {
++			device_type = "ctp";
++			compatible = "allwinner,sun50i-ctp-para";
++			status = "disabled";
++			ctp_name = "gt911_DB";
++			ctp_twi_id = <0x0>;
++			ctp_twi_addr = <0x40>;
++			ctp_screen_max_x = <0x400>;
++			ctp_screen_max_y = <0x258>;
++			ctp_revert_x_flag = <0x1>;
++			ctp_revert_y_flag = <0x1>;
++			ctp_exchange_x_y_flag = <0x0>;
++			ctp_int_port = <0x30 0x7 0x4 0x6 0xffffffff 0xffffffff 0xffffffff>;
++			ctp_wakeup = <0x30 0x7 0xb 0x1 0xffffffff 0xffffffff 0x1>;
++			ctp_power_ldo = "vcc-ctp";
++			ctp_power_ldo_vol = <0xce4>;
++			ctp_power_io;
++		};
++
++		ctp_list {
++			device_type = "ctp_list";
++			compatible = "allwinner,sun50i-ctp-list";
++			status = "okay";
++			gslX680new = <0x1>;
++			gt9xx_ts = <0x0>;
++			gt9xxf_ts = <0x1>;
++			gt9xxnew_ts = <0x0>;
++			gt82x = <0x1>;
++			zet622x = <0x1>;
++			aw5306_ts = <0x1>;
++		};
++
++		tkey_para {
++			device_type = "tkey_para";
++			tkey_used = <0x0>;
++			tkey_twi_id;
++			tkey_twi_addr;
++			tkey_int;
++		};
++
++		motor_para {
++			device_type = "motor_para";
++			motor_used = <0x0>;
++			motor_shake = <0x31 0xfffe 0x3 0x1 0xffffffff 0xffffffff 0x1>;
++		};
++
++		tvout_para {
++			device_type = "tvout_para";
++			tvout_used;
++			tvout_channel_num;
++			tv_en;
++		};
++
++		tvin_para {
++			device_type = "tvin_para";
++			tvin_used;
++			tvin_channel_num;
++		};
++
++		serial_feature {
++			device_type = "serial_feature";
++			sn_filename = "sn.txt";
++		};
++
++		gsensor {
++			device_type = "gsensor";
++			compatible = "allwinner,sun50i-gsensor-para";
++			status = "disabled";
++			gsensor_twi_id = <0x1>;
++			gsensor_twi_addr = <0x1d>;
++			gsensor_vcc_io = "vcc-deviceio";
++			gsensor_vcc_io_val = <0xce4>;
++			gsensor_int1 = <0x30 0x7 0x5 0x6 0x1 0xffffffff 0xffffffff>;
++			gsensor_int2 = <0x30 0x7 0x6 0x6 0x1 0xffffffff 0xffffffff>;
++		};
++
++		gsensor_list {
++			device_type = "gsensor_list";
++			compatible = "allwinner,sun50i-gsensor-list-para";
++			gsensor_list__used = <0x1>;
++			lsm9ds0_acc_mag = <0x1>;
++			bma250 = <0x1>;
++			mma8452 = <0x1>;
++			mma7660 = <0x1>;
++			mma865x = <0x1>;
++			afa750 = <0x1>;
++			lis3de_acc = <0x1>;
++			lis3dh_acc = <0x1>;
++			kxtik = <0x1>;
++			dmard10 = <0x0>;
++			dmard06 = <0x1>;
++			mxc622x = <0x1>;
++			fxos8700 = <0x1>;
++			lsm303d = <0x0>;
++			sc7a30 = <0x1>;
++		};
++
++		3g_para {
++			device_type = "3g_para";
++			3g_used = <0x0>;
++			3g_usbc_num = <0x2>;
++			3g_uart_num = <0x0>;
++			bb_vbat = <0x79 0xb 0x3 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_host_wake = <0x79 0xc 0x0 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_on = <0x79 0xc 0x1 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_pwr_on = <0x79 0xc 0x3 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_wake = <0x79 0xc 0x4 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_rf_dis = <0x79 0xc 0x5 0x1 0xffffffff 0xffffffff 0x0>;
++			bb_rst = <0x79 0xc 0x6 0x1 0xffffffff 0xffffffff 0x0>;
++			3g_int;
++		};
++
++		gyroscopesensor {
++			device_type = "gyroscopesensor";
++			compatible = "allwinner,sun50i-gyr_sensors-para";
++			status = "disabled";
++			gy_twi_id = <0x2>;
++			gy_twi_addr = <0x6a>;
++			gy_int1 = <0x30 0x0 0xa 0x6 0x1 0xffffffff 0xffffffff>;
++			gy_int2;
++		};
++
++		gy_list {
++			device_type = "gy_list";
++			compatible = "allwinner,sun50i-gyr_sensors-list-para";
++			status = "disabled";
++			lsm9ds0_gyr = <0x1>;
++			l3gd20_gyr = <0x0>;
++			bmg160_gyr = <0x1>;
++		};
++
++		lightsensor {
++			device_type = "lightsensor";
++			compatible = "allwinner,sun50i-lsensors-para";
++			status = "disabled";
++			ls_twi_id = <0x2>;
++			ls_twi_addr = <0x23>;
++			ls_int = <0x30 0x0 0xc 0x6 0x1 0xffffffff 0xffffffff>;
++		};
++
++		ls_list {
++			device_type = "ls_list";
++			compatible = "allwinner,sun50i-lsensors-list-para";
++			status = "disabled";
++			ltr_501als = <0x1>;
++			jsa1212 = <0x0>;
++			jsa1127 = <0x1>;
++			stk3x1x = <0x0>;
++		};
++
++		compasssensor {
++			device_type = "compasssensor";
++			compatible = "allwinner,sun50i-compass-para";
++			status = "disabled";
++			compass_twi_id = <0x2>;
++			compass_twi_addr = <0xd>;
++			compass_int = <0x30 0x0 0xb 0x6 0x1 0xffffffff 0xffffffff>;
++		};
++
++		compass_list {
++			device_type = "compass_list";
++			compatible = "allwinner,sun50i-compass-list-para";
++			status = "disabled";
++			lsm9ds0 = <0x1>;
++			lsm303d = <0x0>;
++		};
++
++		recovery_key {
++			device_type = "recovery_key";
++			key_max = <0xc>;
++			key_min = <0xa>;
++		};
++
++		fastboot_key {
++			device_type = "fastboot_key";
++			key_max = <0x6>;
++			key_min = <0x4>;
++		};
++	};
++
++	aliases {
++		serial0 = "/soc@01c00000/uart@01c28000";
++		serial1 = "/soc@01c00000/uart@01c28400";
++		serial2 = "/soc@01c00000/uart@01c28800";
++		serial3 = "/soc@01c00000/uart@01c28c00";
++		serial4 = "/soc@01c00000/uart@01c29000";
++		twi0 = "/soc@01c00000/twi@0x01c2ac00";
++		twi1 = "/soc@01c00000/twi@0x01c2b000";
++		twi2 = "/soc@01c00000/twi@0x01c2b400";
++		spi0 = "/soc@01c00000/spi@01c68000";
++		spi1 = "/soc@01c00000/spi@01c69000";
++		global_timer0 = "/soc@01c00000/timer@1c20c00";
++		cci0 = "/soc@01c00000/cci@0x01cb3000";
++		csi_res0 = "/soc@01c00000/csi_res@0x01cb0000";
++		vfe0 = "/soc@01c00000/vfe@0";
++		mmc0 = "/soc@01c00000/sdmmc@01c0f000";
++		mmc2 = "/soc@01c00000/sdmmc@01C11000";
++		nand0 = "/soc@01c00000/nand0@01c03000";
++		disp = "/soc@01c00000/disp@01000000";
++		lcd0 = "/soc@01c00000/lcd0@01c0c000";
++		hdmi = "/soc@01c00000/hdmi@01ee0000";
++		pwm = "/soc@01c00000/pwm@01c21400";
++		pwm0 = "/soc@01c00000/pwm0@01c21400";
++		s_pwm = "/soc@01c00000/s_pwm@1f03800";
++		spwm0 = "/soc@01c00000/spwm0@0x01f03800";
++		boot_disp = "/soc@01c00000/boot_disp";
++	};
++
++	chosen {
++		bootargs = "earlyprintk=sunxi-uart,0x01c28000 loglevel=8 initcall_debug=1 console=ttyS0 init=/init";
++		linux,initrd-start = <0x0 0x0>;
++		linux,initrd-end = <0x0 0x0>;
++	};
++
++	cpus {
++		#address-cells = <0x2>;
++		#size-cells = <0x0>;
++
++		cpu@0 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x0>;
++			enable-method = "psci";
++			cpufreq_tbl = <0x000639C0 0x00075300 0x0007b0c0 0x00080e80 0x0008ca00 0x000927c0 0x00098580 0x0009e340 0x000a4100 0x000afc80 0x000bb800 0x000c7380 0x000d2f00 0x000dea80 0x000ea600 0x000f6180 0x00101d00 0x0010d880 0x00119400 0x00124f80 0x00148200>;
++			clock-latency = <0x1e8480>;
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		cpu@1 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x1>;
++			enable-method = "psci";
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		cpu@2 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x2>;
++			enable-method = "psci";
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		cpu@3 {
++			device_type = "cpu";
++			compatible = "arm,cortex-a53", "arm,armv8";
++			reg = <0x0 0x3>;
++			enable-method = "psci";
++			clock-frequency = <0x3c14dc00>;
++			cpu-idle-states = <0x90 0x91 0x92>;
++		};
++
++		idle-states {
++			entry-method = "arm,psci";
++
++			cpu-sleep-0 {
++				compatible = "arm,idle-state";
++				arm,psci-suspend-param = <0x10000>;
++				entry-latency-us = <0x28>;
++				exit-latency-us = <0x64>;
++				min-residency-us = <0x96>;
++				linux,phandle = <0x90>;
++				phandle = <0x90>;
++			};
++
++			cluster-sleep-0 {
++				compatible = "arm,idle-state";
++				arm,psci-suspend-param = <0x1010000>;
++				entry-latency-us = <0x1f4>;
++				exit-latency-us = <0x3e8>;
++				min-residency-us = <0x9c4>;
++				linux,phandle = <0x91>;
++				phandle = <0x91>;
++			};
++
++			sys-sleep-0 {
++				compatible = "arm,idle-state";
++				arm,psci-suspend-param = <0x2010000>;
++				entry-latency-us = <0x3e8>;
++				exit-latency-us = <0x7d0>;
++				min-residency-us = <0x1194>;
++				linux,phandle = <0x92>;
++				phandle = <0x92>;
++			};
++		};
++	};
++
++	psci {
++		compatible = "arm,psci-0.2";
++		method = "smc";
++		psci_version = <0x84000000>;
++		cpu_suspend = <0xc4000001>;
++		cpu_off = <0x84000002>;
++		cpu_on = <0xc4000003>;
++		affinity_info = <0xc4000004>;
++		migrate = <0xc4000005>;
++		migrate_info_type = <0x84000006>;
++		migrate_info_up_cpu = <0xc4000007>;
++		system_off = <0x84000008>;
++		system_reset = <0x84000009>;
++	};
++
++	n_brom {
++		compatible = "allwinner,n-brom";
++		reg = <0x0 0x0 0x0 0xc000>;
++	};
++
++	s_brom {
++		compatible = "allwinner,s-brom";
++		reg = <0x0 0x0 0x0 0x10000>;
++	};
++
++	sram_a1 {
++		compatible = "allwinner,sram_a1";
++		reg = <0x0 0x10000 0x0 0x8000>;
++	};
++
++	sram_a2 {
++		compatible = "allwinner,sram_a2";
++		reg = <0x0 0x40000 0x0 0x14000>;
++	};
++
++	prcm {
++		compatible = "allwinner,prcm";
++		reg = <0x0 0x1f01400 0x0 0x400>;
++	};
++
++	cpuscfg {
++		compatible = "allwinner,cpuscfg";
++		reg = <0x0 0x1f01c00 0x0 0x400>;
++	};
++
++	ion {
++		compatible = "allwinner,sunxi-ion";
++
++		system_contig {
++			type = <0x1>;
++		};
++
++		cma {
++			type = <0x4>;
++		};
++
++		system {
++			type = <0x0>;
++		};
++	};
++
++	dram {
++		compatible = "allwinner,dram";
++		clocks = <0x93 0x94>;
++		clock-names = "pll_ddr0", "pll_ddr1";
++		dram_clk = <0x228>;
++		dram_type = <0x7>;
++		dram_zq = <0x3b3bdd>;
++		dram_odt_en = <0x1>;
++		dram_para1 = <0x10e410e4>;
++		dram_para2 = <0x1000>;
++		dram_mr0 = <0x1840>;
++		dram_mr1 = <0x40>;
++		dram_mr2 = <0x18>;
++		dram_mr3 = <0x2>;
++		dram_tpr0 = <0x4a2195>;
++		dram_tpr1 = <0x2424190>;
++		dram_tpr2 = <0x8b060>;
++		dram_tpr3 = <0x50005dc>;
++		dram_tpr4 = <0x0>;
++		dram_tpr5 = <0x0>;
++		dram_tpr6 = <0x0>;
++		dram_tpr7 = <0x2a066198>;
++		dram_tpr8 = <0x0>;
++		dram_tpr9 = <0x0>;
++		dram_tpr10 = <0x8808>;
++		dram_tpr11 = <0x40a60066>;
++		dram_tpr12 = <0x55550000>;
++		dram_tpr13 = <0x4000900>;
++		device_type = "dram";
++	};
++
++	memory@40000000 {
++		device_type = "memory";
++		reg = <0x0 0x40000000 0x0 0x40000000>;
++	};
++
++	interrupt-controller@1c81000 {
++		compatible = "arm,cortex-a15-gic", "arm,cortex-a9-gic";
++		#interrupt-cells = <0x3>;
++		#address-cells = <0x0>;
++		device_type = "gic";
++		interrupt-controller;
++		reg = <0x0 0x1c81000 0x0 0x1000 0x0 0x1c82000 0x0 0x2000 0x0 0x1c84000 0x0 0x2000 0x0 0x1c86000 0x0 0x2000>;
++		interrupts = <0x1 0x9 0xf04>;
++		linux,phandle = <0x1>;
++		phandle = <0x1>;
++	};
++
++	sunxi-chipid@1c14200 {
++		compatible = "allwinner,sunxi-chipid";
++		device_type = "chipid";
++		reg = <0x0 0x1c14200 0x0 0x400>;
++	};
++
++	timer {
++		compatible = "arm,armv8-timer";
++		interrupts = <0x1 0xd 0xff01 0x1 0xe 0xff01 0x1 0xb 0xff01 0x1 0xa 0xff01>;
++		clock-frequency = <0x16e3600>;
++	};
++
++	pmu {
++		compatible = "arm,armv8-pmuv3";
++		interrupts = <0x0 0x78 0x4 0x0 0x79 0x4 0x0 0x7a 0x4 0x0 0x7b 0x4>;
++	};
++
++	dvfs_table {
++		compatible = "allwinner,dvfs_table";
++		max_freq = <0x44aa2000>;
++		min_freq = <0x1c9c3800>;
++		lv_count = <0x8>;
++		lv1_freq = <0x44aa2000>;
++		lv1_volt = <0x514>;
++		lv2_freq = <0x41cdb400>;
++		lv2_volt = <0x4ec>;
++		lv3_freq = <0x3ef14800>;
++		lv3_volt = <0x4d8>;
++		lv4_freq = <0x3c14dc00>;
++		lv4_volt = <0x4b0>;
++		lv5_freq = <0x39387000>;
++		lv5_volt = <0x488>;
++		lv6_freq = <0x365c0400>;
++		lv6_volt = <0x460>;
++		lv7_freq = <0x30a32c00>;
++		lv7_volt = <0x438>;
++		lv8_freq = <0x269fb200>;
++		lv8_volt = <0x410>;
++		device_type = "dvfs_table";
++	};
++
++	dramfreq {
++		compatible = "allwinner,sunxi-dramfreq";
++		reg = <0x0 0x1c62000 0x0 0x1000 0x0 0x1c63000 0x0 0x1000 0x0 0x1c20000 0x0 0x800>;
++		clocks = <0x93 0x94 0x95>;
++		status = "okay";
++	};
++
++	uboot {
++	};
++
++	gpu@0x01c40000 {
++		compatible = "arm,mali-400", "arm,mali-utgard";
++		reg = <0x0 0x1c40000 0x0 0x10000>;
++		interrupts = <0x0 0x61 0x4 0x0 0x62 0x4 0x0 0x63 0x4 0x0 0x64 0x4 0x0 0x66 0x4 0x0 0x67 0x4>;
++		interrupt-names = "IRQGP", "IRQGPMMU", "IRQPP0", "IRQPPMMU0", "IRQPP1", "IRQPPMMU1";
++		clocks = <0x96 0x97>;
++		device_type = "gpu_mali400_0";
++		normal_freq = <0x198>;
++		scene_ctrl_status = <0x0>;
++		temp_ctrl_status = <0x1>;
++	};
++
++	wlan {
++		compatible = "allwinner,sunxi-wlan";
++		wlan_io_regulator = "vcc-wifi-io";
++		wlan_busnum = <0x1>;
++		status = "okay";
++		device_type = "wlan";
++		clocks;
++		wlan_power;
++		wlan_regon = <0x79 0xb 0x2 0x1 0xffffffff 0xffffffff 0x0>;
++		wlan_hostwake = <0x79 0xb 0x3 0x6 0xffffffff 0xffffffff 0x0>;
++		efuse_map_path = "wifi_efuse_8189e_for_MB1019Q5.map";
++	};
++
++	bt {
++		compatible = "allwinner,sunxi-bt";
++		bt_io_regulator = "vcc-wifi-io";
++		status = "okay";
++		device_type = "bt";
++		clocks;
++		bt_power;
++		bt_rst_n = <0x79 0xb 0x4 0x1 0xffffffff 0xffffffff 0x0>;
++	};
++
++	btlpm {
++		compatible = "allwinner,sunxi-btlpm";
++		uart_index = <0x1>;
++		status = "okay";
++		device_type = "btlpm";
++		bt_wake = <0x79 0xb 0x6 0x1 0xffffffff 0xffffffff 0x1>;
++		bt_hostwake = <0x79 0xb 0x5 0x6 0xffffffff 0xffffffff 0x0>;
++	};
++};
diff --git a/device/linux-pine-a64lts/APKBUILD b/device/linux-pine-a64lts/APKBUILD
index 31653692f88bf6554c02fee9efe73839d2c4bd8b..913b342db9bdc13eccc668593be237eefba5d30d 100644
--- a/device/linux-pine-a64lts/APKBUILD
+++ b/device/linux-pine-a64lts/APKBUILD
@@ -23,6 +23,7 @@ source="
 	$pkgname-$_commit.tar.gz::https://github.com/longsleep/${_repository}/archive/${_commit}.tar.gz
 	$_config
 	compiler-gcc6.h
+	0001-add-pine64-DT-files.patch
 "
 builddir="$srcdir/${_repository}-${_commit}"
 
@@ -51,6 +52,9 @@ package() {
 		install -Dm644 "$_zimg" "$_target"
 		break
 	done
+	# TODO Replace with make dtbs_install
+	mkdir -p "$pkgdir/usr/share/dtb"
+	cp arch/arm64/boot/dts/sun50iw1p1-pine64so.dtb "$pkgdir/usr/share/dtb"
 	if ! [ -e "$_target" ]; then
 		error "Could not find zImage in $PWD!"
 		return 1
@@ -59,4 +63,5 @@ package() {
 
 sha512sums="0bfd1da6e873cd809ee94a75eccb394af8abf6f51d187c03e5fb29e249be953240cf3cf87f3e409d77f3600223bfabb7efeb3052fa3e4a0c40eb85b1ddc3dfaf  linux-pine-a64lts-5ea364f6dbe35934868010f07f6abbc0a2d76120.tar.gz
 c3e5ad971d14cf93ef8355f85d7f053ef22c91a6b944cad3d14e230d61ff60fc80c88e06ba39fc234e0ee95411abe6c1c2a739a20da2de362610e1833e48dec1  config-pine-a64lts.aarch64
-d80980e9474c82ba0ef1a6903b434d8bd1b092c40367ba543e72d2c119301c8b2d05265740e4104ca1ac5d15f6c4aa49e8776cb44264a9a28dc551e0d1850dcc  compiler-gcc6.h"
+d80980e9474c82ba0ef1a6903b434d8bd1b092c40367ba543e72d2c119301c8b2d05265740e4104ca1ac5d15f6c4aa49e8776cb44264a9a28dc551e0d1850dcc  compiler-gcc6.h
+bf69b9f514ab817c16e202dae5013d24e453eadf04cd9dc52494f5a1b00e1424d56fb1a98cd49f4ecf77e9255fecf07e87654e18ee0419fc6f62c65b7e1910be  0001-add-pine64-DT-files.patch"