dts: Add two dts files for S410 [3/3]
authorYeping Miao <yeping.miao@amlogic.com>
Fri, 7 Dec 2018 00:56:57 +0000 (08:56 +0800)
committerJianxin Pan <jianxin.pan@amlogic.com>
Wed, 26 Dec 2018 01:49:51 +0000 (17:49 -0800)
PD#SWPL-2887

Problem:
 adapt Soundbar solution to S410 platform

Solution:
 These two dts files are changed from S400.
 Change the audio related like following.
 hw:0,0 is for LINE in
 hw:0,1 is for HDMI i2s in
 hw:0,2 is for speaker out (4 i2s)

Verify:
 S410 A113D

Change-Id: I09fff371e511432f363e2ec8999b584af533ff9c
Signed-off-by: Yeping Miao <yeping.miao@amlogic.com>
MAINTAINERS
arch/arm64/boot/dts/amlogic/axg_s410.dts [new file with mode: 0644]
arch/arm64/boot/dts/amlogic/axg_s410_v03.dts [new file with mode: 0644]

index 7453264..a84caef 100644 (file)
@@ -14737,3 +14737,8 @@ M:      Evoke Zhang <evoke.zhang@amlogic.com>
 F:     arch/arm/boot/dts/amlogic/mesontl1_skt-panel.dtsi
 F:     arch/arm/boot/dts/amlogic/mesontl1_x301-panel.dtsi
 F:     arch/arm/boot/dts/amlogic/mesontl1_t309-panel.dtsi
+
+AMLOGIC MESONAXG RSR DTS
+M:     Yeping Miao <yeping.miao@amlogic.com>
+F:     arch/arm64/boot/dts/amlogic/axg_rsr.dts
+F:     arch/arm64/boot/dts/amlogic/axg_rsr_v03.dts
diff --git a/arch/arm64/boot/dts/amlogic/axg_s410.dts b/arch/arm64/boot/dts/amlogic/axg_s410.dts
new file mode 100644 (file)
index 0000000..e33be01
--- /dev/null
@@ -0,0 +1,1429 @@
+/*
+ * arch/arm64/boot/dts/amlogic/axg_s410.dts
+ *
+ * Copyright (C) 2017 Amlogic, Inc. All rights reserved.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.   See the GNU General Public License for
+ * more details.
+ *
+ */
+
+/dts-v1/;
+
+#include "mesonaxg.dtsi"
+//#include "mesonaxg_s400-panel.dtsi"
+/ {
+       model = "Amlogic";
+       amlogic-dt-id = "axg_s410_1g";
+       compatible = "amlogic, axg";
+       interrupt-parent = <&gic>;
+       #address-cells = <2>;
+       #size-cells = <2>;
+
+       aliases {
+               serial0 = &uart_AO;
+               serial1 = &uart_A;
+               serial2 = &uart_B;
+       };
+
+       memory@00000000 {
+               device_type = "memory";
+               linux,usable-memory = <0x0 0x000000 0x0 0x8000000>;
+       };
+
+       reserved-memory {
+               #address-cells = <2>;
+               #size-cells = <2>;
+               ranges;
+               /* global autoconfigured region for contiguous allocations */
+
+               secmon_reserved:linux,secmon {
+                       compatible = "shared-dma-pool";
+                       reusable;
+                       size = <0x0 0x400000>;
+                       alignment = <0x0 0x400000>;
+                       alloc-ranges = <0x0 0x05000000 0x0 0x400000>;
+               };
+
+               secos_reserved:linux,secos {
+                       status = "disable";
+                       compatible = "amlogic, aml_secos_memory";
+                       reg = <0x0 0x05300000 0x0 0x2000000>;
+                       no-map;
+               };
+               fb_reserved:linux,meson-fb {
+                       //compatible = "amlogic, fb-memory";
+                       //reg = <0x0 0x3e000000 0x0 0x1f00000>;
+                       compatible = "shared-dma-pool";
+                       reusable;
+                       size = <0x0 0x2000000>;
+                       alignment = <0x0 0x400000>;
+                       alloc-ranges = <0x0 0x3e000000 0x0 0x2000000>;
+               };
+       };
+       mtd_nand {
+               compatible = "amlogic, aml_mtd_nand";
+               dev_name = "mtdnand";
+               status = "okay";
+               reg = <0x0 0xFFE07800 0x0 0x200>;
+               interrupts = <  0 34 1 >;
+               pinctrl-names = "nand_rb_mod","nand_norb_mod", "nand_cs_only";
+               pinctrl-0 = <&all_nand_pins>;
+               pinctrl-1 = <&all_nand_pins>;
+               pinctrl-2 = <&nand_cs_pins>;
+               device_id = <0>;
+
+               /*fip/tpl configurations, must be same
+                * with uboot if bl_mode was set as 1
+                * bl_mode: 0 compact mode; 1 descrete mode
+                * if bl_mode was set as 1, fip configeration will work
+                */
+               bl_mode = <1>;
+               /*copy count of fip*/
+               fip_copies = <4>;
+               /*size of each fip copy */
+               fip_size = <0x200000>;
+               nand_clk_ctrl = <0xFFE07000>;
+               plat-names = "bootloader","nandnormal";
+               plat-num = <2>;
+               plat-part-0 = <&bootloader>;
+               plat-part-1 = <&nandnormal>;
+               bootloader: bootloader{
+                       enable_pad ="ce0";
+                       busy_pad = "rb0";
+                       timming_mode = "mode5";
+                       bch_mode = "bch8_1k";
+                       t_rea = <20>;
+                       t_rhoh = <15>;
+                       chip_num = <1>;
+                       part_num = <0>;
+                       rb_detect = <1>;
+               };
+               nandnormal: nandnormal{
+                       enable_pad ="ce0";
+                       busy_pad = "rb0";
+                       timming_mode = "mode5";
+                       bch_mode = "bch8_1k";
+                       plane_mode = "twoplane";
+                       t_rea = <20>;
+                       t_rhoh = <15>;
+                       chip_num = <2>;
+                       part_num = <3>;
+                       partition = <&nand_partitions>;
+                       rb_detect = <1>;
+               };
+               nand_partitions:nand_partition{
+                       /*
+                        * if bl_mode is 1, tpl size was generate by
+                        * fip_copies * fip_size which
+                        * will not skip bad when calculating
+                        * the partition size;
+                        *
+                        * if bl_mode is 0,
+                        * tpl partition must be comment out.
+                        */
+                       tpl{
+                               offset=<0x0 0x0>;
+                               size=<0x0 0x0>;
+                       };
+                       misc{
+                               offset=<0x0 0x0>;
+                               size=<0x0 0x200000>;
+                       };
+                       recovery{
+                               offset=<0x0 0x0>;
+                               size=<0x0 0x1000000>;
+                       };
+                       boot{
+                               offset=<0x0 0x0>;
+                               size=<0x0 0xF00000>;
+                       };
+                       system{
+                               offset=<0x0 0x0>;
+                               size=<0x0 0x3C00000>;
+                       };
+                       data{
+                               offset=<0xffffffff 0xffffffff>;
+                               size=<0x0 0x0>;
+                       };
+               };
+       };
+
+
+       ethmac: ethernet@0xff3f0000 {
+                       compatible = "amlogic, gxbb-eth-dwmac";
+                       reg = <0x0 0xff3f0000 0x0 0x10000
+                       0x0 0xff634540 0x0 0x8>;
+                       interrupts = <0 8 1>;
+                       pinctrl-names = "external_eth_pins";
+                       pinctrl-0 = <&external_eth_pins>;
+                       mc_val_internal_phy = <0x1800>;
+                       mc_val_external_phy = <0x1621>;
+                       interrupt-names = "macirq";
+                       clocks = <&clkc CLKID_ETH_CORE>;
+                       clock-names = "ethclk81";
+                       internal_phy=<0>;
+       };
+
+       aml_sensor0: aml-sensor@0 {
+               compatible = "amlogic, aml-thermal";
+               device_name = "thermal";
+               #thermal-sensor-cells = <1>;
+               cooling_devices {
+                       cpufreq_cool_cluster0 {
+                               min_state = <1000000>;
+                               dyn_coeff = <140>;
+                               cluster_id = <0>;
+                               node_name = "cpufreq_cool0";
+                               device_type = "cpufreq";
+                       };
+                       cpucore_cool_cluster0 {
+                               min_state = <1>;
+                               dyn_coeff = <0>;
+                               cluster_id = <0>;
+                               node_name = "cpucore_cool0";
+                               device_type = "cpucore";
+                       };
+               };
+               cpufreq_cool0:cpufreq_cool0 {
+                       #cooling-cells = <2>; /* min followed by max */
+               };
+               cpucore_cool0:cpucore_cool0 {
+                       #cooling-cells = <2>; /* min followed by max */
+               };
+       };
+       thermal-zones {
+               soc_thermal {
+                       polling-delay = <1000>;
+                       polling-delay-passive = <100>;
+                       sustainable-power = <1050>;
+
+                       thermal-sensors = <&aml_sensor0 3>;
+
+                       trips {
+                               switch_on: trip-point@0 {
+                                       temperature = <70000>;
+                                       hysteresis = <1000>;
+                                       type = "passive";
+                               };
+                               control: trip-point@1 {
+                                       temperature = <80000>;
+                                       hysteresis = <1000>;
+                                       type = "passive";
+                               };
+                               hot: trip-point@2 {
+                                       temperature = <85000>;
+                                       hysteresis = <5000>;
+                                       type = "hot";
+                               };
+                               critical: trip-point@3 {
+                                       temperature = <260000>;
+                                       hysteresis = <1000>;
+                                       type = "critical";
+                               };
+                       };
+
+                       cooling-maps {
+                               cpufreq_cooling_map {
+                                       trip = <&control>;
+                                       cooling-device = <&cpufreq_cool0 0 4>;
+                                       contribution = <1024>;
+                               };
+                               cpucore_cooling_map {
+                                       trip = <&control>;
+                                       cooling-device = <&cpucore_cool0 0 3>;
+                                       contribution = <1024>;
+                               };
+                       };
+               };
+       };
+
+       dwc3: dwc3@ff500000 {
+               compatible = "synopsys, dwc3";
+               status = "okay";
+               reg = <0x0 0xff500000 0x0 0x100000>;
+               interrupts = <0 30 4>;
+               usb-phy = <&usb2_phy>, <&usb3_phy>;
+               cpu-type = "gxl";
+               clock-src = "usb3.0";
+               clocks = <&clkc CLKID_USB_GENERAL>;
+               clock-names = "dwc_general";
+       };
+
+       usb2_phy: usb2phy@ffe09000 {
+               compatible = "amlogic, amlogic-new-usb2";
+               status = "okay";
+               portnum = <4>;
+               reg = <0x0 0xffe09000 0x0 0x80
+                                       0x0 0xffd01008 0x0 0x4>;
+       };
+
+       usb3_phy: usb3phy@ffe09080 {
+               compatible = "amlogic, amlogic-new-usb3";
+               status = "okay";
+               portnum = <0>;
+               reg = <0x0 0xffe09080 0x0 0x20>;
+               interrupts = <0 16 4>;
+               otg = <1>;
+               gpio-vbus-power = "GPIOAO_5";
+               gpios = <&gpio_ao GPIOAO_5 GPIO_ACTIVE_HIGH>;
+       };
+
+       dwc2_a {
+               compatible = "amlogic, dwc2";
+               device_name = "dwc2_a";
+               reg = <0x0 0xff400000 0x0 0x40000>;
+               status = "okay";
+               interrupts = <0 31 4>;
+               pl-periph-id = <0>; /** lm name */
+               clock-src = "usb0"; /** clock src */
+               port-id = <0>;  /** ref to mach/usb.h */
+               port-type = <2>; /** 0: otg, 1: host, 2: slave */
+               port-speed = <0>; /** 0: default, high, 1: full */
+               port-config = <0>; /** 0: default */
+               /*0:default,1:single,2:incr,3:incr4,4:incr8,5:incr16,6:disable*/
+               port-dma = <0>;
+               port-id-mode = <0>; /** 0: hardware, 1: sw_host, 2: sw_slave*/
+               usb-fifo = <728>;
+               cpu-type = "gxl";
+               /** 0: normal, 1: otg+dwc3 host only, 2: otg+dwc3 device only*/
+               controller-type = <3>;
+               phy-reg = <0xffe09000>;
+               phy-reg-size = <0xa0>;
+               clocks = <&clkc CLKID_USB_GENERAL
+                       &clkc CLKID_USB1_TO_DDR
+                       &clkc CLKID_USB1>;
+               clock-names = "usb_general",
+                       "usb1",
+                       "usb1_to_ddr";
+       };
+
+       pcie_A: pcieA@f9800000 {
+               compatible = "amlogic, amlogic-pcie", "snps,dw-pcie";
+               reg = <0x0 0xf9800000 0x0 0x400000
+                               0x0 0xff646000 0x0 0x2000
+                               0x0 0xf9f00000 0x0 0x100000
+                               0x0 PCIE_PHY_REG 0x0 PCIE_PHY_SIZE
+                               0x0 PCIE_RESET_REG 0x0 PCIE_RESET_SIZE>;
+               reg-names = "elbi", "cfg", "config", "phy", "reset";
+               reset-gpio = <&gpio GPIOX_19 GPIO_ACTIVE_HIGH>;
+               interrupts = <0 177 0>;
+               #interrupt-cells = <1>;
+               interrupt-map-mask = <0 0 0 0>;
+               interrupt-map = <0 0 0 0 &gic GIC_SPI 179 IRQ_TYPE_EDGE_RISING>;
+               bus-range = <0x0 0xff>;
+               #address-cells = <3>;
+               #size-cells = <2>;
+               device_type = "pci";
+               ranges = <0x82000000 0 0 0x0 0xf9c00000 0 0x00300000>;
+                       /* non-prefetchable memory */
+               num-lanes = <1>;
+               pcie-num = <1>;
+
+               clocks = <&clkc CLKID_USB_GENERAL
+               &clkc CLKID_PCIE_PLL
+               &clkc CLKID_MIPI_ENABLE_GATE
+               &clkc CLKID_MIPI_BANDGAP_GATE
+               &clkc CLKID_PCIE_A
+               &clkc CLKID_PCIE_CML_EN0>;
+               clock-names = "pcie_general",
+                               "pcie_refpll",
+                               "pcie_mipi_enable_gate",
+                               "pcie_mipi_bandgap_gate",
+                               "pcie",
+                               "port";
+               /*reset-gpio-type 0:Shared pad(no reset)1:OD pad2:Normal pad*/
+               gpio-type = <2>;
+               status = "disable";
+       };
+
+        pcie_B: pcieB@fa000000 {
+               compatible = "amlogic, amlogic-pcie", "snps,dw-pcie";
+               reg = <0x0 0xfa000000 0x0 0x400000
+                               0x0 0xff648000 0x0 0x2000
+                               0x0 0xfa400000 0x0 0x100000
+                               0x0 PCIE_PHY_REG 0x0 PCIE_PHY_SIZE
+                               0x0 PCIE_RESET_REG 0x0 PCIE_RESET_SIZE>;
+               reg-names = "elbi", "cfg", "config", "phy", "reset";
+               reset-gpio = <&gpio GPIOZ_10 GPIO_ACTIVE_HIGH>;
+               interrupts = <0 167 0>;
+               #interrupt-cells = <1>;
+               bus-range = <0x0 0xff>;
+               #address-cells = <3>;
+               #size-cells = <2>;
+               interrupt-map-mask = <0 0 0 0>;
+               interrupt-map = <0 0 0 0 &gic GIC_SPI 169 IRQ_TYPE_EDGE_RISING>;
+               device_type = "pci";
+               ranges = <0x81000000 0 0 0 0xfa500000 0x0 0x10000
+                       /* downstream I/O */
+                       0x82000000 0 0xfa510000 0x0 0xfa510000 0 0x002f0000>;
+                       /* non-prefetchable memory */
+               num-lanes = <1>;
+               pcie-num = <2>;
+
+               clocks = <&clkc CLKID_USB_GENERAL
+                               &clkc CLKID_PCIE_PLL
+                               &clkc CLKID_MIPI_ENABLE_GATE
+                               &clkc CLKID_MIPI_BANDGAP_GATE
+                               &clkc CLKID_PCIE_B
+                               &clkc CLKID_PCIE_CML_EN1>;
+               clock-names = "pcie_general",
+                               "pcie_refpll",
+                               "pcie_mipi_enable_gate",
+                               "pcie_mipi_bandgap_gate",
+                               "pcie",
+                               "port";
+               /*reset-gpio-type 0:Shared pad(no reset)1:OD pad2:Normal pad*/
+               gpio-type = <1>;
+               status = "disable";
+       };
+
+
+       uart_A: serial@ffd24000 {
+               compatible = "amlogic, meson-uart";
+               reg = <0x0 0xffd24000 0x0 0x18>;
+               interrupts = <0 26 1>;
+               status = "okay";
+               clocks = <&xtal
+                       &clkc CLKID_UART0>;
+               clock-names = "clk_uart",
+                       "clk_gate";
+               fifosize = < 128 >;
+               pinctrl-names = "default";
+               pinctrl-0 = <&a_uart_pins>;
+       };
+
+       uart_B: serial@ffd23000 {
+               compatible = "amlogic, meson-uart";
+               reg = <0x0 0xffd23000 0x0 0x18>;
+               interrupts = <0 75 1>;
+               status = "okay";
+               clocks = <&xtal
+                       &clkc CLKID_UART1>;
+               clock-names = "clk_uart",
+                       "clk_gate";
+               fifosize = < 64 >;
+               pinctrl-names = "default";
+               pinctrl-0 = <&b_uart_pins>;
+       };
+
+       meson-irblaster {
+               compatible = "amlogic, am_irblaster";
+               dev_name = "meson-irblaster";
+               status = "disable";
+               pinctrl-names = "default";
+               pinctrl-0 = <&irblaster_pins>;
+       };
+
+       vpu {
+               compatible = "amlogic, vpu-axg";
+               dev_name = "vpu";
+               status = "okay";
+               clocks = <&clkc CLKID_VAPB_MUX>,
+                       <&clkc CLKID_VPU_INTR>,
+                       <&clkc CLKID_VPU_P0_COMP>,
+                       <&clkc CLKID_VPU_P1_COMP>,
+                       <&clkc CLKID_VPU_MUX>;
+               clock-names = "vapb_clk",
+                       "vpu_intr_gate",
+                       "vpu_clk0",
+                       "vpu_clk1",
+                       "vpu_clk";
+               clk_level = <3>;
+               /* 0: 100.0M 1: 166.7M 2: 200.0M 3: 250.0M */
+       };
+
+       vout {
+               compatible = "amlogic, vout";
+               dev_name = "vout";
+               status = "disable";
+       };
+
+       /* Audio Related start */
+       /* Sound iomap */
+       aml_snd_iomap {
+               compatible = "amlogic, snd-iomap";
+               status = "okay";
+               #address-cells=<2>;
+               #size-cells=<2>;
+               ranges;
+               pdm_bus {
+                       reg = <0x0 0xFF632000 0x0 0x2000>;
+               };
+               audiobus_base {
+                       reg = <0x0 0xFF642000 0x0 0x2000>;
+               };
+               audiolocker_base {
+                       reg = <0x0 0xFF64A000 0x0 0x2000>;
+               };
+       };
+       pdm_codec:dummy{
+               #sound-dai-cells = <0>;
+               compatible = "amlogic, pdm_dummy_codec";
+               status = "okay";
+       };
+       dummy_codec:dummy{
+               #sound-dai-cells = <0>;
+               compatible = "amlogic, aml_dummy_codec";
+               status = "okay";
+       };
+
+       auge_sound {
+               compatible = "amlogic, axg-sound-card";
+               aml-audio-card,name = "AML-AUGESOUND";
+
+               aml-audio-card,loopback = <&aml_loopback>;
+
+               aml-audio-card,dai-link@0 {
+                       format = "i2s";
+                       mclk-fs = <256>;
+                       //continuous-clock;
+                       //bitclock-inversion;
+                       //frame-inversion;
+                       bitclock-master = <&aml_tdma>;
+                       frame-master = <&aml_tdma>;
+                       suffix-name = "alsaPORT-pcm";
+                       cpu{
+                               sound-dai = <&aml_tdma>;
+                               dai-tdm-slot-tx-mask = <1 1>;
+                               dai-tdm-slot-rx-mask = <1 1>;
+                               dai-tdm-slot-num = <2>;
+                               dai-tdm-slot-width = <32>;
+                               system-clock-frequency = <12288000>;
+                       };
+                       codec {
+                               sound-dai = <&dummy_codec &dummy_codec>;
+                       };
+               };
+
+               aml-audio-card,dai-link@1 {
+                       format = "i2s";
+                       mclk-fs = <256>;
+                       //continuous-clock;
+                       //bitclock-inversion;
+                       //frame-inversion;
+                       bitclock-master = <&tdmbcodec>;
+                       frame-master = <&tdmbcodec>;
+                       suffix-name = "alsaPORT-i2sCapture";
+                       cpu {
+                               sound-dai = <&aml_tdmb>;
+                               dai-tdm-slot-tx-mask = <1 1>;
+                               dai-tdm-slot-rx-mask = <1 1>;
+                               dai-tdm-slot-num = <2>;
+                               dai-tdm-slot-width = <32>;
+                               system-clock-frequency = <12288000>;
+                       };
+                       tdmbcodec:codec {
+                               /*
+                                * prefix-names = "3101_A", "3101_B",
+                                * "3101_C", "3101_D";
+                                * sound-dai = <&tlv320adc3101_32
+                                * &tlv320adc3101_30
+                                * &tlv320adc3101_34
+                                * &tlv320adc3101_36>;
+                                */
+                               sound-dai = <&dummy_codec>;
+                       };
+               };
+
+               aml-audio-card,dai-link@2 {
+                       format = "i2s";
+                       mclk-fs = <256>;
+                       //continuous-clock;
+                       //bitclock-inversion;
+                       //frame-inversion;
+                       //bitclock-master = <&aml_tdmc>;
+                       //frame-master = <&aml_tdmc>;
+                       suffix-name = "alsaPORT-i2sPlayback";
+                       cpu {
+                               sound-dai = <&aml_tdmc>;
+                               dai-tdm-slot-tx-mask = <1 1>;
+                               dai-tdm-slot-rx-mask = <1 1>;
+                               dai-tdm-slot-num = <2>;
+                               dai-tdm-slot-width = <32>;
+                               system-clock-frequency = <12288000>;
+                       };
+                       codec {
+                               prefix-names = "5707_A", "5707_B";
+                               sound-dai = <&tas5707_36 &tas5707_3a
+                                               &dummy_codec>;
+                       };
+               };
+
+               aml-audio-card,dai-link@3 {
+                       mclk-fs = <256>;
+                       cpu {
+                               sound-dai = <&aml_pdm>;
+                       };
+                       codec {
+                               /*
+                                * enable external loopback
+                                * and tlv320adc3101 as loopback
+                                */
+                               /*sound-dai = <&pdm_codec &tlv320adc3101_32>;*/
+                               /*
+                                * enable internal loopback
+                                * or disable loopback
+                                */
+                               sound-dai = <&pdm_codec>;
+                       };
+               };
+
+               aml-audio-card,dai-link@4 {
+                       mclk-fs = <128>;
+                       suffix-name = "alsaPORT-spdif";
+                       cpu {
+                               sound-dai = <&aml_spdif>;
+                               system-clock-frequency = <6144000>;
+                       };
+                       codec {
+                               sound-dai = <&dummy_codec>;
+                       };
+               };
+       };
+       audiolocker: locker {
+               compatible = "amlogic, audiolocker";
+               clocks = <&clkaudio CLKID_AUDIO_LOCKER_OUT
+                               &clkaudio CLKID_AUDIO_LOCKER_IN
+                               &clkaudio CLKID_AUDIO_MCLK_D
+                               &clkaudio CLKID_AUDIO_MCLK_E
+                               &clkc CLKID_MPLL1
+                               &clkc CLKID_MPLL2>;
+               clock-names = "lock_out", "lock_in", "out_src",
+                                       "in_src", "out_calc", "in_ref";
+               interrupts = <GIC_SPI 1 IRQ_TYPE_EDGE_RISING>;
+               interrupt-names = "irq";
+               frequency = <49000000>; /* pll */
+               dividor = <49>; /* locker's parent */
+               status = "okay";
+       };
+       /* Audio Related end */
+
+       bt-dev{
+               compatible = "amlogic, bt-dev";
+               dev_name = "bt-dev";
+               status = "disable";
+               gpio_reset = <&gpio GPIOX_21 GPIO_ACTIVE_HIGH>;
+       };
+
+       wifi{
+               compatible = "amlogic, aml_wifi";
+               dev_name = "aml_wifi";
+               status = "disable";
+               interrupt_pin = <&gpio GPIOX_6 GPIO_ACTIVE_HIGH>;
+               interrupts = <  0 67 4>;
+               irq_trigger_type = "GPIO_IRQ_LOW";
+               power_on_pin2 = <&gpio GPIOX_16 GPIO_ACTIVE_HIGH>;
+               power_on_pin = <&gpio GPIOX_7 GPIO_ACTIVE_HIGH>;
+               dhd_static_buf; //if use bcm wifi, config dhd_static_buf
+               pinctrl-names = "default";
+               pinctrl-0 = <&wifi_32k_pins>;
+               pwm_config = <&wifi_pwm_conf>;
+       };
+
+       wifi_pwm_conf:wifi_pwm_conf{
+               pwm_channel1_conf {
+                       pwms = <&pwm_ab MESON_PWM_0 30040 0>;
+                       duty-cycle = <15020>;
+                       times = <10>;
+               };
+               pwm_channel2_conf {
+                       pwms = <&pwm_ab MESON_PWM_2 30030 0>;
+                       duty-cycle = <15015>;
+                       times = <12>;
+               };
+       };
+
+       sd_emmc_c: emmc@ffe07000 {
+               status = "disabled";
+               compatible = "amlogic, meson-mmc-axg";
+               reg = <0x0 0xffe07000 0x0 0x2000>;
+               interrupts = <0 218 1>;
+               pinctrl-names = "emmc_clk_cmd_pins", "emmc_all_pins";
+               pinctrl-0 = <&emmc_clk_cmd_pins>;
+               pinctrl-1 = <&emmc_conf_pull_up &emmc_conf_pull_done>;
+               clocks = <&clkc CLKID_SD_EMMC_C>,
+                                <&clkc CLKID_SD_EMMC_C_P0_COMP>,
+                                <&clkc CLKID_FCLK_DIV2>,
+                                <&clkc CLKID_FCLK_DIV5>,
+                                <&xtal>;
+               clock-names = "core", "clkin0", "clkin1", "clkin2", "xtal";
+
+               bus-width = <8>;
+               cap-sd-highspeed;
+               cap-mmc-highspeed;
+               mmc-ddr-1_8v;
+               mmc-hs200-1_8v;
+
+               max-frequency = <200000000>;
+               non-removable;
+               disable-wp;
+               emmc {
+                       pinname = "emmc";
+                       ocr_avail = <0x200080>; /**VDD voltage 3.3 ~ 3.4 */
+                       caps = "MMC_CAP_8_BIT_DATA",
+                                "MMC_CAP_MMC_HIGHSPEED",
+                                "MMC_CAP_SD_HIGHSPEED",
+                                "MMC_CAP_NONREMOVABLE",
+                                "MMC_CAP_1_8V_DDR",
+                                "MMC_CAP_HW_RESET",
+                                "MMC_CAP_ERASE",
+                                "MMC_CAP_CMD23";
+                       caps2 = "MMC_CAP2_HS200", "MMC_CAP2_HS400";
+                       f_min = <400000>;
+                       f_max = <200000000>;
+                       max_req_size = <0x20000>; /**128KB*/
+                       gpio_dat3 = <&gpio BOOT_3 GPIO_ACTIVE_HIGH>;
+                       tx_delay = <8>;
+                       hw_reset = <&gpio BOOT_9 GPIO_ACTIVE_HIGH>;
+                       card_type = <1>;
+                       /* 1:mmc card(include eMMC),
+                        * 2:sd card(include tSD)
+                        */
+               };
+       };
+
+       sd_emmc_b:sdio@ffe05000 {
+               status = "okay";
+               compatible = "amlogic, meson-mmc-axg";
+               reg = <0x0 0xffe05000 0x0 0x2000>;
+               interrupts = <0 217 4>;
+               pinctrl-names = "sdio_clk_cmd_pins", "sdio_all_pins";
+               pinctrl-0 = <&sdio_clk_cmd_pins>;
+               pinctrl-1 = <&sdio_all_pins>;
+               clocks = <&clkc CLKID_SD_EMMC_B>,
+                                <&clkc CLKID_SD_EMMC_B_P0_COMP>,
+                                <&clkc CLKID_FCLK_DIV2>,
+                                <&clkc CLKID_FCLK_DIV5>,
+                                <&xtal>;
+               clock-names = "core", "clkin0", "clkin1", "clkin2", "xtal";
+
+               bus-width = <4>;
+               cap-sd-highspeed;
+               cap-mmc-highspeed;
+               max-frequency = <100000000>;
+               non-removable;
+               disable-wp;
+               sdio {
+                       pinname = "sdio";
+                       ocr_avail = <0x200080>; /**VDD voltage 3.3 ~ 3.4 */
+                       caps = "MMC_CAP_4_BIT_DATA",
+                                "MMC_CAP_MMC_HIGHSPEED",
+                                "MMC_CAP_SD_HIGHSPEED",
+                                "MMC_CAP_NONREMOVABLE",
+                                "MMC_CAP_UHS_SDR12",
+                                "MMC_CAP_UHS_SDR25",
+                                "MMC_CAP_UHS_SDR50",
+                                "MMC_CAP_UHS_SDR104",
+                                "MMC_PM_KEEP_POWER",
+                                "MMC_CAP_SDIO_IRQ";
+                       f_min = <400000>;
+                       f_max = <200000000>;
+                       max_req_size = <0x20000>; /**128KB*/
+                       card_type = <3>;
+                       /* 3:sdio device(ie:sdio-wifi),
+                        * 4:SD combo (IO+mem) card
+                        */
+               };
+       };
+
+       partitions: partitions{
+               parts = <11>;
+               part-0 = <&logo>;
+               part-1 = <&recovery>;
+               part-2 = <&rsv>;
+               part-3 = <&tee>;
+               part-4 = <&crypt>;
+               part-5 = <&misc>;
+               part-6 = <&instaboot>;
+               part-7 = <&boot>;
+               part-8 = <&system>;
+               part-9 = <&cache>;
+               part-10 = <&data>;
+
+               logo:logo{
+                       pname = "logo";
+                       size = <0x0 0x2000000>;
+                       mask = <1>;
+               };
+               recovery:recovery{
+                       pname = "recovery";
+                       size = <0x0 0x2000000>;
+                       mask = <1>;
+               };
+               rsv:rsv{
+                       pname = "rsv";
+                       size = <0x0 0x800000>;
+                       mask = <1>;
+               };
+               tee:tee{
+                       pname = "tee";
+                       size = <0x0 0x800000>;
+                       mask = <1>;
+               };
+               crypt:crypt{
+                       pname = "crypt";
+                       size = <0x0 0x2000000>;
+                       mask = <1>;
+               };
+               misc:misc{
+                       pname = "misc";
+                       size = <0x0 0x2000000>;
+                       mask = <1>;
+               };
+               instaboot:instaboot{
+                       pname = "instaboot";
+                       size = <0x0 0x400000>;
+                       mask = <1>;
+               };
+               boot:boot
+               {
+                       pname = "boot";
+                       size = <0x0 0x2000000>;
+                       mask = <1>;
+               };
+               system:system
+               {
+                       pname = "system";
+                       size = <0x0 0x80000000>;
+                       mask = <1>;
+               };
+               cache:cache
+               {
+                       pname = "cache";
+                       size = <0x0 0x20000000>;
+                       mask = <2>;
+               };
+               data:data
+               {
+                       pname = "data";
+                       size = <0xffffffff 0xffffffff>;
+                       mask = <4>;
+               };
+       };
+
+       meson-fb {
+               compatible = "amlogic, meson-fb";
+               memory-region = <&fb_reserved>;
+               dev_name = "meson-fb";
+               status = "disable";
+               interrupts = <0 3 1
+                       0 89 1>;
+               interrupt-names = "viu-vsync", "rdma";
+               mem_size = <0x00300000 0x1800000 0x00000000>;
+               /* uboot logo,fb0/fb1 memory size */
+               display_mode_default = "1080p60hz";
+               scale_mode = <0>;
+               /** 0:VPU free scale 1:OSD free scale 2:OSD super scale */
+               display_size_default = <768 1024 768 2048 32>;
+               /*768*1024*4*2 = 0x600000*/
+               mem_alloc = <1>;
+               logo_addr = "0x3e000000";
+               pxp_mode = <0>; /** 0:normal mode 1:pxp mode */
+       };
+
+       ge2d {
+               compatible = "amlogic, ge2d";
+               dev_name = "ge2d";
+               status = "disable";
+               interrupts = <0 150 1>;
+               interrupt-names = "ge2d";
+               clocks = <&clkc CLKID_VAPB_MUX>,
+                       <&clkc CLKID_GE2D_GATE>,
+                       <&clkc CLKID_G2D>;
+               clock-names = "clk_vapb_0",
+                       "clk_ge2d",
+                       "clk_ge2d_gate";
+               reg = <0x0 0xff940000 0x0 0x10000>;
+       };
+
+       adc_keypad {
+               compatible = "amlogic, adc_keypad";
+               status = "disable";
+               key_name = "power", "vol-", "vol+", "wifi", "<<", ">>";
+               key_num = <6>;
+               io-channels = <&saradc SARADC_CH0>;
+               io-channel-names = "key-chan-0";
+               key_chan = <SARADC_CH0 SARADC_CH0 SARADC_CH0
+                                       SARADC_CH0 SARADC_CH0 SARADC_CH0>;
+               key_code = <116 114 115 139 105 106>;
+               key_val = <0 143 266 389 512 635>; //val=voltage/1800mV*1023
+               key_tolerance = <40 40 40 40 40 40>;
+       };
+
+       unifykey{
+               compatible = "amlogic, unifykey";
+               status = "disable";
+
+               unifykey-num = <6>;
+               unifykey-index-0 = <&keysn_0>;
+               unifykey-index-1 = <&keysn_1>;
+               unifykey-index-2 = <&keysn_2>;
+               unifykey-index-3 = <&keysn_3>;
+               unifykey-index-4 = <&keysn_4>;
+               unifykey-index-5 = <&keysn_5>;
+
+               keysn_0: key_0{
+                       key-name = "usid";
+                       key-device = "normal";
+                       key-permit = "read","write","del";
+               };
+               keysn_1:key_1{
+                       key-name = "mac";
+                       key-device = "normal";
+                       key-permit = "read","write","del";
+               };
+               keysn_2:key_2{
+                       key-name = "secure_boot_set";
+                       key-device = "efuse";
+                       key-permit = "write";
+               };
+               keysn_3:key_3{
+                       key-name = "mac_bt";
+                       key-device = "normal";
+                       key-permit = "read","write","del";
+                       key-type        = "mac";
+               };
+               keysn_4:key_4{
+                       key-name = "mac_wifi";
+                       key-device = "normal";
+                       key-permit = "read","write","del";
+                       key-type = "mac";
+               };
+               keysn_5:key_5{
+                       key-name = "deviceid";
+                       key-device = "normal";
+                       key-permit = "read","write","del";
+               };
+       };//End unifykey
+
+}; /* end of / */
+&efuse {
+       status = "ok";
+};
+
+&pwm_ab {
+       status = "disable";
+};
+
+/* Audio Related start */
+/* for spk board */
+&i2c1 {
+       status = "okay";
+       pinctrl-names="default";
+       pinctrl-0=<&b_i2c_master>;
+
+       tlv320adc3101_32: tlv320adc3101_32@32 {
+               compatible = "ti,tlv320adc3101";
+               #sound-dai-cells = <0>;
+               reg = <0x19>;
+               differential_pair = <1>;
+               status = "okay";
+       };
+
+       tas5707_36: tas5707_36@36 {
+               compatible = "ti,tas5707";
+               #sound-dai-cells = <0>;
+               reg = <0x1b>;
+               status = "okay";
+               reset_pin = <&gpio_ao GPIOAO_4 0>;
+       };
+
+       tas5707_3a: tas5707_3a@3a {
+               compatible = "ti,tas5707";
+               #sound-dai-cells = <0>;
+               reg = <0x1d>;
+               status = "okay";
+       };
+};
+
+/* for mic board */
+&i2c_AO {
+       status = "okay";
+       pinctrl-names="default";
+       pinctrl-0=<&ao_i2c_master_pin2>;
+
+       aml_pca9557: aml_pca9557@0x1f {
+               compatible = "aml, ledring";
+               reg = <0x1f>;
+                       mode = <0>; /*0: 6-led 1: 4key+2led */
+                       key_num = <4>;
+                       led_dev_name = "aml_ledring";
+                       key_dev_name = "aml_pca_key";
+                       key_name = "mute", "pause", "vol+", "vol-";
+                       key_value = <200 201 202 203>;
+               status = "okay";
+       };
+
+       tlv320adc3101_30: tlv320adc3101_30@30 {
+               compatible = "ti,tlv320adc3101";
+               #sound-dai-cells = <0>;
+               reg = <0x18>;
+               status = "disable";
+       };
+       tlv320adc3101_34: tlv320adc3101_34@30 {
+               compatible = "ti,tlv320adc3101";
+               #sound-dai-cells = <0>;
+               reg = <0x1a>;
+               status = "disable";
+       };
+       tlv320adc3101_36: tlv320adc3101_36@30 {
+               compatible = "ti,tlv320adc3101";
+               #sound-dai-cells = <0>;
+               reg = <0x1b>;
+               status = "disable";
+       };
+       es7243_10: es7243_10@10 {
+               compatible = "MicArray_0";
+               #sound-dai-cells = <0>;
+               reg = <0x10>;
+               status = "disable";
+       };
+       es7243_12: es7243_12@12 {
+               compatible = "MicArray_1";
+               #sound-dai-cells = <0>;
+               reg = <0x12>;
+               status = "disable";
+       };
+       es7243_13: es7243_13@13 {
+               compatible = "MicArray_2";
+               #sound-dai-cells = <0>;
+               reg = <0x13>;
+               status = "disable";
+       };
+       is31fl3236a: is31f3236a@0x78 {
+               compatible = "issi,is31fl3236";
+               reg = <0x3c>;
+               status = "disable";
+               led1_r {
+                       label="LED1_R";
+                       reg_offset = <24>;
+               };
+               led1_g {
+                       label="LED1_G";
+                       reg_offset = <23>;
+               };
+               led1_b {
+                       label="LED1_B";
+                       reg_offset = <22>;
+               };
+               led2_r {
+                       label="LED2_R";
+                       reg_offset = <21>;
+               };
+               led2_g {
+                       label="LED2_G";
+                       reg_offset = <20>;
+               };
+               led2_b {
+                       label="LED2_B";
+                       reg_offset = <19>;
+               };
+               led3_r {
+                       label="LED3_R";
+                       reg_offset = <18>;
+               };
+               led3_g {
+                       label="LED3_G";
+                       reg_offset = <17>;
+               };
+               led3_b {
+                       label="LED3_B";
+                       reg_offset = <16>;
+               };
+               led4_r {
+                       label="LED4_R";
+                       reg_offset = <15>;
+               };
+               led4_g {
+                       label="LED4_G";
+                       reg_offset = <14>;
+               };
+               led4_b {
+                       label="LED4_B";
+                       reg_offset = <13>;
+               };
+               led5_r {
+                       label="LED5_R";
+                       reg_offset = <36>;
+               };
+               led5_g {
+                       label="LED5_G";
+                       reg_offset = <35>;
+               };
+               led5_b {
+                       label="LED5_B";
+                       reg_offset = <34>;
+               };
+               led6_r {
+                       label="LED6_R";
+                       reg_offset = <33>;
+               };
+               led6_g {
+                       label="LED6_G";
+                       reg_offset = <32>;
+               };
+               led6_b {
+                       label="LED6_B";
+                       reg_offset = <31>;
+               };
+               led7_r {
+                       label="LED7_R";
+                       reg_offset = <30>;
+               };
+               led7_g {
+                       label="LED7_G";
+                       reg_offset = <29>;
+               };
+               led7_b {
+                       label="LED7_B";
+                       reg_offset = <28>;
+               };
+               led8_r {
+                       label="LED8_R";
+                       reg_offset = <27>;
+               };
+               led8_g {
+                       label="LED8_G";
+                       reg_offset = <26>;
+               };
+               led8_b {
+                       label="LED8_B";
+                       reg_offset = <25>;
+               };
+       };
+};
+
+&audiobus {
+       aml_tdma: tdma {
+               compatible = "amlogic, axg-snd-tdma";
+               #sound-dai-cells = <0>;
+               dai-tdm-lane-slot-mask-in = <1 1>;
+               dai-tdm-lane-slot-mask-out = <0 0>;
+               dai-tdm-clk-sel = <0>;
+               clocks = <&clkaudio CLKID_AUDIO_MCLK_A
+                               &clkc CLKID_MPLL0>;
+               clock-names = "mclk", "clk_srcpll";
+               pinctrl-names = "tdm_pins";
+               pinctrl-0 = <&tdmout_a &tdmin_a>;
+       };
+
+       aml_tdmb: tdmb {
+               compatible = "amlogic, axg-snd-tdmb";
+               #sound-dai-cells = <0>;
+               dai-tdm-lane-slot-mask-in = <1 1 1 1>;
+               dai-tdm-lane-slot-mask-out = <0 0 0 0>;
+               dai-tdm-clk-sel = <1>;
+               clocks = <&clkaudio CLKID_AUDIO_MCLK_B
+                               &clkc CLKID_MPLL1>;
+               clock-names = "mclk", "clk_srcpll";
+               pinctrl-names = "tdm_pins";
+               pinctrl-0 = <&tdmin_b>;
+       };
+
+       aml_tdmc: tdmc {
+               compatible = "amlogic, axg-snd-tdmc";
+               #sound-dai-cells = <0>;
+               dai-tdm-lane-slot-mask-in = <0 0 0 0>;
+               dai-tdm-lane-slot-mask-out = <1 1 1 1>;
+               dai-tdm-clk-sel = <2>;
+               clocks = <&clkaudio CLKID_AUDIO_MCLK_C
+                               &clkc CLKID_MPLL2>;
+               clock-names = "mclk", "clk_srcpll";
+               pinctrl-names = "tdm_pins";
+               pinctrl-0 = <&tdmc_mclk &tdmout_c>;
+       };
+
+       aml_spdif: spdif {
+               compatible = "amlogic, axg-snd-spdif";
+               #sound-dai-cells = <0>;
+               clocks = <&clkc CLKID_MPLL0
+                               &clkc CLKID_FCLK_DIV4
+                               &clkaudio CLKID_AUDIO_SPDIFIN
+                               &clkaudio CLKID_AUDIO_SPDIFOUT
+                               &clkaudio CLKID_AUDIO_SPDIFIN_CTRL
+                               &clkaudio CLKID_AUDIO_SPDIFOUT_CTRL>;
+               clock-names = "sysclk", "fixed_clk", "gate_spdifin",
+                               "gate_spdifout", "clk_spdifin", "clk_spdifout";
+               interrupts =
+                               <GIC_SPI 87 IRQ_TYPE_EDGE_RISING>;
+
+               interrupt-names = "irq_spdifin";
+               pinctrl-names = "spdif_pins";
+               pinctrl-0 = <&spdifout &spdifin>;
+
+               /*
+                * whether do asrc for pcm.
+                * if raw data, asrc is disabled automatically
+                * 0: "Disable",
+                * 1: "Enable:32K",
+                * 2: "Enable:44K",
+                * 3: "Enable:48K",
+                * 4: "Enable:88K",
+                * 5: "Enable:96K",
+                * 6: "Enable:176K",
+                * 7: "Enable:192K",
+                */
+               auto_asrc = <3>;
+               status = "okay";
+       };
+       aml_pdm: pdm {
+               compatible = "amlogic, axg-snd-pdm";
+               #sound-dai-cells = <0>;
+               clocks = <&clkaudio CLKID_AUDIO_PDM
+                       &clkc CLKID_FCLK_DIV3
+                       &clkc CLKID_MPLL3
+                       &clkaudio CLKID_AUDIO_PDMIN0
+                       &clkaudio CLKID_AUDIO_PDMIN1>;
+               clock-names = "gate",
+                       "sysclk_srcpll",
+                       "dclk_srcpll",
+                       "pdm_dclk",
+                       "pdm_sysclk";
+               pinctrl-names = "pdm_pins";
+               pinctrl-0 = <&pdmin>;
+               filter_mode = <1>; /* mode 0~4, defalut:1 */
+               status = "okay";
+       };
+
+       aml_loopback: loopback {
+               compatible = "amlogic, snd-loopback";
+
+               /*
+                * external loopback clock config
+                * enable clk while pdm record data
+                */
+               /*clocks = <&clkc CLKID_MPLL1>;*/
+               /*clock-names = "datalb_mpll";*/
+
+               /*
+                * 0: out rate = in data rate;
+                * 1: out rate = loopback data rate;
+                */
+               lb_mode = <0>;
+
+               /* datain src
+                * 0: tdmin_a;
+                * 1: tdmin_b;
+                * 2: tdmin_c;
+                * 3: spdifin;
+                * 4: pdmin;
+                */
+               datain_src = <4>;
+               datain_chnum = <8>;
+               datain_chmask = <0x7f>;
+
+               /* tdmin_lb src
+                * 0: tdmoutA
+                * 1: tdmoutB
+                * 2: tdmoutC
+                * 3: PAD_tdminA
+                * 4: PAD_tdminB
+                * 5: PAD_tdminC
+                */
+
+               /*if tdmin_lb >= 3, use external loopback*/
+               datalb_src = <2>;
+               datalb_chnum = <2>;
+               /*config which data pin as loopback*/
+               /*datalb-lane-mask-in = <0 0 0 1>;*/
+               datalb_chmask = <0x1>;
+
+
+               status = "okay";
+       };
+
+       audioresample: resample {
+               compatible = "amlogic, axg-resample";
+               clocks = <&clkc CLKID_MPLL3
+                               &clkaudio CLKID_AUDIO_MCLK_F
+                               &clkaudio CLKID_AUDIO_RESAMPLE_CTRL>;
+               clock-names = "resample_pll", "resample_src", "resample_clk";
+               /*same with toddr_src
+                *      TDMIN_A,
+                *      TDMIN_B,
+                *      TDMIN_C,
+                *      SPDIFIN,
+                *      PDMIN,
+                *      NONE,
+                *      TDMIN_LB,
+                *      LOOPBACK,
+                */
+               resample_module = <3>;
+               status = "okay";
+       };
+       aml_pwrdet: pwrdet {
+               compatible = "amlogic, axg-power-detect";
+
+               interrupts = <GIC_SPI 91 IRQ_TYPE_EDGE_RISING>;
+               interrupt-names = "pwrdet_irq";
+
+               /* pwrdet source sel
+                * 7: loopback;
+                * 6: tdmin_lb;
+                * 5: reserved;
+                * 4: pdmin;
+                * 3: spdifin;
+                * 2: tdmin_c;
+                * 1: tdmin_b;
+                * 0: tdmin_a;
+                */
+               pwrdet_src = <4>;
+
+               hi_th = <0x70000>;
+               lo_th = <0x16000>;
+
+               status = "disabled";
+       };
+}; /* end of audiobus */
+
+&pinctrl_periphs {
+       tdmout_a: tdmout_a {
+               mux {
+                       groups = "tdma_sclk",
+                               "tdma_fs";
+                       function = "tdma_out";
+               };
+       };
+
+       tdmout_a_data: tdmout_a_data {
+               mux {
+                       groups = "tdma_dout1_x15";
+                       function = "tdma_out";
+               };
+       };
+
+       tdmin_a: tdmin_a {
+               mux {
+                       groups = "tdma_din0";
+                       function = "tdma_in";
+               };
+       };
+
+       tdmb_mclk: tdmb_mclk {
+               mux {
+                       groups = "mclk_b";
+                       function = "mclk_b";
+               };
+       };
+
+       tdmout_b: tdmout_b {
+               mux {
+                       groups = "tdmb_sclk",
+                               "tdmb_fs";
+                       function = "tdmb_out";
+               };
+       };
+       // tdmin and tdmout are the same pins. can't use at same time
+       tdmin_b:tdmin_b {
+               mux {
+                       groups =
+                               "tdmb_slv_sclk",
+                               "tdmb_slv_fs",
+                               "tdmb_din0",
+                               "tdmb_din1",
+                               "tdmb_din2_a12",
+                               "tdmb_din3_a13";
+                       function = "tdmb_in";
+               };
+       };
+
+       tdmc_mclk: tdmc_mclk {
+               mux {
+                       groups = "mclk_a";
+                       function = "mclk_a";
+               };
+       };
+
+       tdmout_c:tdmout_c {
+               mux {
+                       groups = "tdmc_sclk",
+                               "tdmc_fs",
+                               "tdmc_dout0",
+                               "tdmc_dout1",
+                               "tdmc_dout2_a6",
+                               "tdmc_dout3_a7";
+                       function = "tdmc_out";
+               };
+       };
+
+
+       tdmin_c:tdmin_c {
+               mux {
+                       groups = "tdmc_din1";
+                       function = "tdmc_in";
+               };
+       };
+
+       spdifout: spidfout {
+               mux {
+                       groups = "spdif_out_a20";
+                       function = "spdif_out";
+               };
+       };
+
+       spdifin: spidfin {
+               mux {
+                       groups = "spdif_in_a19";
+                       function = "spdif_in";
+               };
+       };
+
+       pdmin: pdmin {
+               mux {
+                       groups = "pdm_dclk_a14",
+                               "pdm_din0",
+                               "pdm_din1",
+                               "pdm_din2",
+                               "pdm_din3";
+                       function = "pdm";
+               };
+       };
+
+       bl_pwm_on_pins: bl_pwm_on_pin {
+               mux {
+                       groups = "pwm_b_z";
+                       function = "pwm_b";
+               };
+       };
+}; /* end of pinctrl_periphs */
+/* Audio Related End */
+
+&aobus{
+       uart_AO: serial@3000 {
+               compatible = "amlogic, meson-uart";
+               reg = <0x0 0x3000 0x0 0x18>;
+               interrupts = <0 193 1>;
+               status = "okay";
+               clocks = <&xtal>;
+               clock-names = "clk_uart";
+               xtal_tick_en = <1>;
+               fifosize = < 64 >;
+               pinctrl-names = "default";
+               pinctrl-0 = <&ao_uart_pins>;
+               support-sysrq = <0>;    /* 0 not support , 1 support */
+       };
+
+       uart_AO_B: serial@4000 {
+               compatible = "amlogic, meson-uart";
+               reg = <0x0 0x4000 0x0 0x18>;
+               interrupts = <0 197 1>;
+               status = "disable";
+               clocks = <&xtal>;
+               clock-names = "clk_uart";
+               fifosize = < 64 >;
+               pinctrl-names = "default";
+               pinctrl-0 = <&ao_b_uart_pins>;
+       };
+};
+
+&audio_data{
+       status = "okay";
+};
diff --git a/arch/arm64/boot/dts/amlogic/axg_s410_v03.dts b/arch/arm64/boot/dts/amlogic/axg_s410_v03.dts
new file mode 100644 (file)
index 0000000..933bf73
--- /dev/null
@@ -0,0 +1,1344 @@
+/*
+ * arch/arm64/boot/dts/amlogic/axg_s410_v03.dts
+ *
+ * Copyright (C) 2017 Amlogic, Inc. All rights reserved.
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE.   See the GNU General Public License for
+ * more details.
+ *
+ */
+
+/dts-v1/;
+
+#include "mesonaxg.dtsi"
+//#include "mesonaxg_s400-panel.dtsi"
+/ {
+       model = "Amlogic";
+       amlogic-dt-id = "axg_s410_v03";
+       compatible = "amlogic, axg";
+       interrupt-parent = <&gic>;
+       #address-cells = <2>;
+       #size-cells = <2>;
+
+       aliases {
+               serial0 = &uart_AO;
+               serial1 = &uart_A;
+       };
+
+       memory@00000000 {
+               device_type = "memory";
+               linux,usable-memory = <0x0 0x000000 0x0 0x40000000>;
+       };
+
+       reserved-memory {
+               #address-cells = <2>;
+               #size-cells = <2>;
+               ranges;
+               /* global autoconfigured region for contiguous allocations */
+               secmon_reserved:linux,secmon {
+                       compatible = "shared-dma-pool";
+                       reusable;
+                       size = <0x0 0x400000>;
+                       alignment = <0x0 0x400000>;
+                       alloc-ranges = <0x0 0x05000000 0x0 0x400000>;
+               };
+
+               secos_reserved:linux,secos {
+                       status = "disable";
+                       compatible = "amlogic, aml_secos_memory";
+                       reg = <0x0 0x05300000 0x0 0x2000000>;
+                       no-map;
+               };
+               fb_reserved:linux,meson-fb {
+                       //compatible = "amlogic, fb-memory";
+                       //reg = <0x0 0x3e000000 0x0 0x1f00000>;
+                       compatible = "shared-dma-pool";
+                       reusable;
+                       size = <0x0 0x2000000>;
+                       alignment = <0x0 0x400000>;
+                       alloc-ranges = <0x0 0x3e000000 0x0 0x2000000>;
+               };
+       };
+       mtd_nand {
+               compatible = "amlogic, aml_mtd_nand";
+               dev_name = "mtdnand";
+               status = "okay";
+               reg = <0x0 0xFFE07800 0x0 0x200>;
+               interrupts = <  0 34 1 >;
+               pinctrl-names = "nand_rb_mod","nand_norb_mod", "nand_cs_only";
+               pinctrl-0 = <&all_nand_pins>;
+               pinctrl-1 = <&all_nand_pins>;
+               pinctrl-2 = <&nand_cs_pins>;
+               device_id = <0>;
+
+               /*fip/tpl configurations, must be same
+                * with uboot if bl_mode was set as 1
+                * bl_mode: 0 compact mode; 1 descrete mode
+                * if bl_mode was set as 1, fip configeration will work
+                */
+               bl_mode = <1>;
+               /*copy count of fip*/
+               fip_copies = <4>;
+               /*size of each fip copy */
+               fip_size = <0x200000>;
+               nand_clk_ctrl = <0xFFE07000>;
+               plat-names = "bootloader","nandnormal";
+               plat-num = <2>;
+               plat-part-0 = <&bootloader>;
+               plat-part-1 = <&nandnormal>;
+               bootloader: bootloader{
+                       enable_pad ="ce0";
+                       busy_pad = "rb0";
+                       timming_mode = "mode5";
+                       bch_mode = "bch8_1k";
+                       t_rea = <20>;
+                       t_rhoh = <15>;
+                       chip_num = <1>;
+                       part_num = <0>;
+                       rb_detect = <1>;
+               };
+               nandnormal: nandnormal{
+                       enable_pad ="ce0";
+                       busy_pad = "rb0";
+                       timming_mode = "mode5";
+                       bch_mode = "bch8_1k";
+                       plane_mode = "twoplane";
+                       t_rea = <20>;
+                       t_rhoh = <15>;
+                       chip_num = <2>;
+                       part_num = <3>;
+                       partition = <&nand_partitions>;
+                       rb_detect = <1>;
+               };
+               nand_partitions:nand_partition{
+                       /*
+                        * if bl_mode is 1, tpl size was generate by
+                        * fip_copies * fip_size which
+                        * will not skip bad when calculating
+                        * the partition size;
+                        *
+                        * if bl_mode is 0,
+                        * tpl partition must be comment out.
+                        */
+                       tpl{
+                               offset=<0x0 0x0>;
+                               size=<0x0 0x0>;
+                       };
+                       misc{
+                               offset=<0x0 0x0>;
+                               size=<0x0 0x200000>;
+                       };
+                       logo{
+                               offset=<0x0 0x0>;
+                               size=<0x0 0x200000>;
+                       };
+                       recovery{
+                               offset=<0x0 0x0>;
+                               size=<0x0 0x1000000>;
+                       };
+                       boot{
+                               offset=<0x0 0x0>;
+                               size=<0x0 0xF00000>;
+                       };
+                       system{
+                               offset=<0x0 0x0>;
+                               size=<0x0 0x11800000>;
+                       };
+                       data{
+                               offset=<0xffffffff 0xffffffff>;
+                               size=<0x0 0x0>;
+                       };
+               };
+       };
+
+
+       ethmac: ethernet@0xff3f0000 {
+                       compatible = "amlogic, gxbb-eth-dwmac";
+                       reg = <0x0 0xff3f0000 0x0 0x10000
+                       0x0 0xff634540 0x0 0x8>;
+                       interrupts = <0 8 1>;
+                       pinctrl-names = "external_eth_pins";
+                       pinctrl-0 = <&external_eth_pins>;
+                       mc_val_internal_phy = <0x1800>;
+                       mc_val_external_phy = <0x1621>;
+                       interrupt-names = "macirq";
+                       clocks = <&clkc CLKID_ETH_CORE>;
+                       clock-names = "ethclk81";
+                       internal_phy=<0>;
+       };
+
+       aml_sensor0: aml-sensor@0 {
+               compatible = "amlogic, aml-thermal";
+               device_name = "thermal";
+               #thermal-sensor-cells = <1>;
+               cooling_devices {
+                       cpufreq_cool_cluster0 {
+                               min_state = <1000000>;
+                               dyn_coeff = <140>;
+                               cluster_id = <0>;
+                               node_name = "cpufreq_cool0";
+                               device_type = "cpufreq";
+                       };
+                       cpucore_cool_cluster0 {
+                               min_state = <1>;
+                               dyn_coeff = <0>;
+                               cluster_id = <0>;
+                               node_name = "cpucore_cool0";
+                               device_type = "cpucore";
+                       };
+               };
+               cpufreq_cool0:cpufreq_cool0 {
+                       #cooling-cells = <2>; /* min followed by max */
+               };
+               cpucore_cool0:cpucore_cool0 {
+                       #cooling-cells = <2>; /* min followed by max */
+               };
+       };
+       thermal-zones {
+               soc_thermal {
+                       polling-delay = <1000>;
+                       polling-delay-passive = <100>;
+                       sustainable-power = <1050>;
+
+                       thermal-sensors = <&aml_sensor0 3>;
+
+                       trips {
+                               switch_on: trip-point@0 {
+                                       temperature = <70000>;
+                                       hysteresis = <1000>;
+                                       type = "passive";
+                               };
+                               control: trip-point@1 {
+                                       temperature = <80000>;
+                                       hysteresis = <1000>;
+                                       type = "passive";
+                               };
+                               hot: trip-point@2 {
+                                       temperature = <85000>;
+                                       hysteresis = <5000>;
+                                       type = "hot";
+                               };
+                               critical: trip-point@3 {
+                                       temperature = <260000>;
+                                       hysteresis = <1000>;
+                                       type = "critical";
+                               };
+                       };
+
+                       cooling-maps {
+                               cpufreq_cooling_map {
+                                       trip = <&control>;
+                                       cooling-device = <&cpufreq_cool0 0 4>;
+                                       contribution = <1024>;
+                               };
+                               cpucore_cooling_map {
+                                       trip = <&control>;
+                                       cooling-device = <&cpucore_cool0 0 3>;
+                                       contribution = <1024>;
+                               };
+                       };
+               };
+       };
+
+       dwc3: dwc3@ff500000 {
+               compatible = "synopsys, dwc3";
+               status = "okay";
+               reg = <0x0 0xff500000 0x0 0x100000>;
+               interrupts = <0 30 4>;
+               usb-phy = <&usb2_phy>, <&usb3_phy>;
+               cpu-type = "gxl";
+               clock-src = "usb3.0";
+               clocks = <&clkc CLKID_USB_GENERAL>;
+               clock-names = "dwc_general";
+       };
+
+       usb2_phy: usb2phy@ffe09000 {
+               compatible = "amlogic, amlogic-new-usb2";
+               status = "okay";
+               portnum = <4>;
+               reg = <0x0 0xffe09000 0x0 0x80
+                                       0x0 0xffd01008 0x0 0x4>;
+       };
+
+       usb3_phy: usb3phy@ffe09080 {
+               compatible = "amlogic, amlogic-new-usb3";
+               status = "okay";
+               portnum = <0>;
+               reg = <0x0 0xffe09080 0x0 0x20>;
+               interrupts = <0 16 4>;
+               otg = <1>;
+               gpio-vbus-power = "GPIOAO_5";
+               gpios = <&gpio_ao GPIOAO_5 GPIO_ACTIVE_HIGH>;
+       };
+
+       dwc2_a {
+               compatible = "amlogic, dwc2";
+               device_name = "dwc2_a";
+               reg = <0x0 0xff400000 0x0 0x40000>;
+               status = "okay";
+               interrupts = <0 31 4>;
+               pl-periph-id = <0>; /** lm name */
+               clock-src = "usb0"; /** clock src */
+               port-id = <0>; /** ref to mach/usb.h */
+               port-type = <2>; /** 0: otg, 1: host, 2: slave */
+               port-speed = <0>; /** 0: default, high, 1: full */
+               port-config = <0>; /** 0: default */
+               /*0:default,1:single,2:incr,3:incr4,4:incr8,5:incr16,6:disable*/
+               port-dma = <0>;
+               port-id-mode = <0>; /** 0: hardware, 1: sw_host, 2: sw_slave*/
+               usb-fifo = <728>;
+               cpu-type = "gxl";
+               /** 0: normal, 1: otg+dwc3 host only, 2: otg+dwc3 device only*/
+               controller-type = <3>;
+               phy-reg = <0xffe09000>;
+               phy-reg-size = <0xa0>;
+               clocks = <&clkc CLKID_USB_GENERAL
+                       &clkc CLKID_USB1_TO_DDR
+                       &clkc CLKID_USB1>;
+               clock-names = "usb_general",
+                       "usb1",
+                       "usb1_to_ddr";
+       };
+
+       pcie_A: pcieA@f9800000 {
+               compatible = "amlogic, amlogic-pcie", "snps,dw-pcie";
+               reg = <0x0 0xf9800000 0x0 0x400000
+                               0x0 0xff646000 0x0 0x2000
+                               0x0 0xf9f00000 0x0 0x100000
+                               0x0 PCIE_PHY_REG 0x0 PCIE_PHY_SIZE
+                               0x0 PCIE_RESET_REG 0x0 PCIE_RESET_SIZE>;
+               reg-names = "elbi", "cfg", "config", "phy", "reset";
+               reset-gpio = <&gpio GPIOX_19 GPIO_ACTIVE_HIGH>;
+               interrupts = <0 177 0>;
+               #interrupt-cells = <1>;
+               bus-range = <0x0 0xff>;
+               #address-cells = <3>;
+               #size-cells = <2>;
+               interrupt-map-mask = <0 0 0 0>;
+               interrupt-map = <0 0 0 0 &gic GIC_SPI 179 IRQ_TYPE_EDGE_RISING>;
+               device_type = "pci";
+               ranges = <0x82000000 0 0 0x0 0xf9c00000 0 0x00300000>;
+                       /* non-prefetchable memory */
+               num-lanes = <1>;
+               pcie-num = <1>;
+
+               clocks = <&clkc CLKID_USB_GENERAL
+               &clkc CLKID_PCIE_PLL
+               &clkc CLKID_MIPI_ENABLE_GATE
+               &clkc CLKID_MIPI_BANDGAP_GATE
+               &clkc CLKID_PCIE_A
+               &clkc CLKID_PCIE_CML_EN0>;
+               clock-names = "pcie_general",
+                               "pcie_refpll",
+                               "pcie_mipi_enable_gate",
+                               "pcie_mipi_bandgap_gate",
+                               "pcie",
+                               "port";
+               /*reset-gpio-type 0:Shared pad(no reset)1:OD pad2:Normal pad*/
+               gpio-type = <2>;
+               status = "disable";
+       };
+
+        pcie_B: pcieB@fa000000 {
+               compatible = "amlogic, amlogic-pcie", "snps,dw-pcie";
+               reg = <0x0 0xfa000000 0x0 0x400000
+                               0x0 0xff648000 0x0 0x2000
+                               0x0 0xfa400000 0x0 0x100000
+                               0x0 PCIE_PHY_REG 0x0 PCIE_PHY_SIZE
+                               0x0 PCIE_RESET_REG 0x0 PCIE_RESET_SIZE>;
+               reg-names = "elbi", "cfg", "config", "phy", "reset";
+               reset-gpio = <&gpio GPIOZ_10 GPIO_ACTIVE_HIGH>;
+               interrupts = <0 167 0>;
+               #interrupt-cells = <1>;
+               bus-range = <0x0 0xff>;
+               #address-cells = <3>;
+               #size-cells = <2>;
+               interrupt-map-mask = <0 0 0 0>;
+               interrupt-map = <0 0 0 0 &gic GIC_SPI 169 IRQ_TYPE_EDGE_RISING>;
+               device_type = "pci";
+               ranges = <0x81000000 0 0 0 0xfa500000 0x0 0x10000
+                       /* downstream I/O */
+                       0x82000000 0 0xfa510000 0x0 0xfa510000 0 0x002f0000>;
+                       /* non-prefetchable memory */
+               num-lanes = <1>;
+               pcie-num = <2>;
+
+               clocks = <&clkc CLKID_USB_GENERAL
+                               &clkc CLKID_PCIE_PLL
+                               &clkc CLKID_MIPI_ENABLE_GATE
+                               &clkc CLKID_MIPI_BANDGAP_GATE
+                               &clkc CLKID_PCIE_B
+                               &clkc CLKID_PCIE_CML_EN1>;
+               clock-names = "pcie_general",
+                               "pcie_refpll",
+                               "pcie_mipi_enable_gate",
+                               "pcie_mipi_bandgap_gate",
+                               "pcie",
+                               "port";
+               /*reset-gpio-type 0:Shared pad(no reset)1:OD pad2:Normal pad*/
+               gpio-type = <1>;
+               status = "disable";
+       };
+
+
+       uart_A: serial@ffd24000 {
+               compatible = "amlogic, meson-uart";
+               reg = <0x0 0xffd24000 0x0 0x18>;
+               interrupts = <0 26 1>;
+               status = "okay";
+               clocks = <&xtal
+                       &clkc CLKID_UART0>;
+               clock-names = "clk_uart",
+                       "clk_gate";
+               fifosize = < 128 >;
+               pinctrl-names = "default";
+               pinctrl-0 = <&a_uart_pins>;
+       };
+
+       uart_B: serial@ffd23000 {
+               compatible = "amlogic, meson-uart";
+               reg = <0x0 0xffd23000 0x0 0x18>;
+               interrupts = <0 75 1>;
+               status = "disable";
+               clocks = <&xtal
+                       &clkc CLKID_UART1>;
+               clock-names = "clk_uart",
+                       "clk_gate";
+               fifosize = < 64 >;
+               pinctrl-names = "default";
+               pinctrl-0 = <&b_uart_pins>;
+       };
+
+       vpu {
+               compatible = "amlogic, vpu-axg";
+               dev_name = "vpu";
+               status = "okay";
+               clocks = <&clkc CLKID_VAPB_MUX>,
+                       <&clkc CLKID_VPU_INTR>,
+                       <&clkc CLKID_VPU_P0_COMP>,
+                       <&clkc CLKID_VPU_P1_COMP>,
+                       <&clkc CLKID_VPU_MUX>;
+               clock-names = "vapb_clk",
+                       "vpu_intr_gate",
+                       "vpu_clk0",
+                       "vpu_clk1",
+                       "vpu_clk";
+               clk_level = <3>;
+               /* 0: 100.0M 1: 166.7M 2: 200.0M 3: 250.0M */
+       };
+
+       vout {
+               compatible = "amlogic, vout";
+               dev_name = "vout";
+               status = "okay";
+       };
+
+       /* Sound iomap */
+       aml_snd_iomap {
+               compatible = "amlogic, snd-iomap";
+               status = "okay";
+               #address-cells=<2>;
+               #size-cells=<2>;
+               ranges;
+               pdm_bus {
+                       reg = <0x0 0xFF632000 0x0 0x2000>;
+               };
+               audiobus_base {
+                       reg = <0x0 0xFF642000 0x0 0x2000>;
+               };
+       };
+       pdm_codec:dummy{
+               #sound-dai-cells = <0>;
+               compatible = "amlogic, pdm_dummy_codec";
+               status = "okay";
+       };
+       dummy_codec:dummy{
+               #sound-dai-cells = <0>;
+               compatible = "amlogic, aml_dummy_codec";
+               status = "okay";
+       };
+
+       auge_sound {
+               compatible = "amlogic, axg-sound-card";
+               aml-audio-card,name = "AML-AUGESOUND";
+
+               aml-audio-card,loopback = <&aml_loopback>;
+
+               aml-audio-card,hp-det-gpio = <&gpio GPIOZ_7 GPIO_ACTIVE_LOW>;
+
+               aml-audio-card,dai-link@0 {
+                       format = "dsp_a";
+                       mclk-fs = <512>;
+                       //continuous-clock;
+                       //bitclock-inversion;
+                       //frame-inversion;
+                       //bitclock-master = <&tdmacodec>;
+                       //frame-master = <&tdmacodec>;
+                       tdmacpu: cpu {
+                               sound-dai = <&aml_tdma>;
+                               dai-tdm-slot-tx-mask =
+                                                       <1 1 1 1 1 1 1 1>;
+                               dai-tdm-slot-rx-mask =
+                                                       <1 1 1 1 1 1 1 1>;
+                               dai-tdm-slot-num = <8>;
+                               dai-tdm-slot-width = <32>;
+                               system-clock-frequency = <24576000>;
+                       };
+                       tdmacodec: codec {
+                               sound-dai = <&dummy_codec &dummy_codec>;
+                       };
+               };
+
+               aml-audio-card,dai-link@1 {
+                       format = "i2s";
+                       mclk-fs = <256>;
+                       //continuous-clock;
+                       //bitclock-inversion;
+                       //frame-inversion;
+                       bitclock-master = <&aml_tdmb>;
+                       frame-master = <&aml_tdmb>;
+                       cpu {
+                               sound-dai = <&aml_tdmb>;
+                               dai-tdm-slot-tx-mask = <1 1>;
+                               dai-tdm-slot-rx-mask = <1 1>;
+                               dai-tdm-slot-num = <2>;
+                               dai-tdm-slot-width = <32>;
+                               system-clock-frequency = <12288000>;
+                       };
+                       codec {
+                               /*
+                                * prefix-names = "3101_A", "3101_B",
+                                * "3101_C", "3101_D";
+                                * sound-dai = <&tlv320adc3101_32
+                                * &tlv320adc3101_30
+                                * &tlv320adc3101_34
+                                * &tlv320adc3101_36>;
+                                */
+                               sound-dai = <&tlv320adc3101_32 &dummy_codec>;
+                       };
+               };
+
+               aml-audio-card,dai-link@2 {
+                       format = "i2s";
+                       mclk-fs = <256>;
+                       //continuous-clock;
+                       //bitclock-inversion;
+                       //frame-inversion;
+                       //bitclock-master = <&aml_tdmc>;
+                       //frame-master = <&aml_tdmc>;
+                       cpu {
+                               sound-dai = <&aml_tdmc>;
+                               dai-tdm-slot-tx-mask = <1 1>;
+                               dai-tdm-slot-rx-mask = <1 1>;
+                               dai-tdm-slot-num = <2>;
+                               dai-tdm-slot-width = <32>;
+                               system-clock-frequency = <12288000>;
+                       };
+                       codec {
+                               prefix-names = "5707_A", "5707_B";
+                               sound-dai = <&tas5707_36 &tas5707_3a
+                                               &dummy_codec>;
+                       };
+               };
+
+               aml-audio-card,dai-link@3 {
+                       mclk-fs = <256>;
+                       cpu {
+                               sound-dai = <&aml_pdm>;
+                       };
+                       codec {
+                               /*
+                                *enable external loopback
+                                *and tlv320adc3101 as loopback
+                                */
+                               /*sound-dai = <&pdm_codec &tlv320adc3101_32>;*/
+                               /*
+                                * enable internal loopback
+                                * or disable loopback
+                                */
+                               sound-dai = <&pdm_codec>;
+                       };
+               };
+
+               aml-audio-card,dai-link@4 {
+                       mclk-fs = <128>;
+                       cpu {
+                               sound-dai = <&aml_spdif>;
+                               system-clock-frequency = <6144000>;
+                       };
+                       codec {
+                               sound-dai = <&dummy_codec>;
+                       };
+               };
+       };
+
+       bt-dev{
+               compatible = "amlogic, bt-dev";
+               dev_name = "bt-dev";
+               status = "disable";
+               gpio_reset = <&gpio     GPIOX_21 GPIO_ACTIVE_HIGH>;
+       };
+
+       wifi{
+               compatible = "amlogic, aml_wifi";
+               dev_name = "aml_wifi";
+               status = "disable";
+               interrupt_pin = <&gpio GPIOX_6 GPIO_ACTIVE_HIGH>;
+               interrupts = <  0 67 4>;
+               irq_trigger_type = "GPIO_IRQ_LOW";
+               power_on_pin2 = <&gpio GPIOX_16 GPIO_ACTIVE_HIGH>;
+               power_on_pin = <&gpio GPIOX_7   GPIO_ACTIVE_HIGH>;
+               dhd_static_buf; //if use bcm wifi, config dhd_static_buf
+               pinctrl-names = "default";
+               pinctrl-0 = <&wifi_32k_pins>;
+               pwm_config = <&wifi_pwm_conf>;
+       };
+
+       wifi_pwm_conf:wifi_pwm_conf{
+               pwm_channel1_conf {
+                       pwms = <&pwm_ab MESON_PWM_0 30040 0>;
+                       duty-cycle = <15020>;
+                       times = <10>;
+               };
+               pwm_channel2_conf {
+                       pwms = <&pwm_ab MESON_PWM_2 30030 0>;
+                       duty-cycle = <15015>;
+                       times = <12>;
+               };
+       };
+
+       sd_emmc_c: emmc@ffe07000 {
+               status = "disabled";
+               compatible = "amlogic, meson-mmc-axg";
+               reg = <0x0 0xffe07000 0x0 0x2000>;
+               interrupts = <0 218 1>;
+               pinctrl-names = "emmc_clk_cmd_pins", "emmc_all_pins";
+               pinctrl-0 = <&emmc_clk_cmd_pins>;
+               pinctrl-1 = <&emmc_conf_pull_up &emmc_conf_pull_done>;
+               clocks = <&clkc CLKID_SD_EMMC_C>,
+                                <&clkc CLKID_SD_EMMC_C_P0_COMP>,
+                                <&clkc CLKID_FCLK_DIV2>,
+                                <&clkc CLKID_FCLK_DIV5>,
+                                <&xtal>;
+               clock-names = "core", "clkin0", "clkin1", "clkin2", "xtal";
+
+               bus-width = <8>;
+               cap-sd-highspeed;
+               cap-mmc-highspeed;
+               mmc-ddr-1_8v;
+               mmc-hs200-1_8v;
+
+               max-frequency = <200000000>;
+               non-removable;
+               disable-wp;
+               emmc {
+                       pinname = "emmc";
+                       ocr_avail = <0x200080>; /**VDD voltage 3.3 ~ 3.4 */
+                       caps = "MMC_CAP_8_BIT_DATA",
+                                "MMC_CAP_MMC_HIGHSPEED",
+                                "MMC_CAP_SD_HIGHSPEED",
+                                "MMC_CAP_NONREMOVABLE",
+                                "MMC_CAP_1_8V_DDR",
+                                "MMC_CAP_HW_RESET",
+                                "MMC_CAP_ERASE",
+                                "MMC_CAP_CMD23";
+                       caps2 = "MMC_CAP2_HS200", "MMC_CAP2_HS400";
+                       f_min = <400000>;
+                       f_max = <200000000>;
+                       max_req_size = <0x20000>; /**128KB*/
+                       gpio_dat3 = <&gpio BOOT_3 GPIO_ACTIVE_HIGH>;
+                       tx_delay = <8>;
+                       hw_reset = <&gpio BOOT_9 GPIO_ACTIVE_HIGH>;
+                       card_type = <1>;
+                       /* 1:mmc card(include eMMC),
+                        * 2:sd card(include tSD)
+                        */
+               };
+       };
+
+       sd_emmc_b:sdio@ffe05000 {
+               status = "okay";
+               compatible = "amlogic, meson-mmc-axg";
+               reg = <0x0 0xffe05000 0x0 0x2000>;
+               interrupts = <0 217 4>;
+               pinctrl-names = "sdio_clk_cmd_pins", "sdio_all_pins";
+               pinctrl-0 = <&sdio_clk_cmd_pins>;
+               pinctrl-1 = <&sdio_all_pins>;
+               clocks = <&clkc CLKID_SD_EMMC_B>,
+                                <&clkc CLKID_SD_EMMC_B_P0_COMP>,
+                                <&clkc CLKID_FCLK_DIV2>,
+                                <&clkc CLKID_FCLK_DIV5>,
+                                <&xtal>;
+               clock-names = "core", "clkin0", "clkin1", "clkin2", "xtal";
+
+               bus-width = <4>;
+               cap-sd-highspeed;
+               cap-mmc-highspeed;
+               max-frequency = <100000000>;
+               non-removable;
+               disable-wp;
+               sdio {
+                       pinname = "sdio";
+                       ocr_avail = <0x200080>; /**VDD voltage 3.3 ~ 3.4 */
+                       caps = "MMC_CAP_4_BIT_DATA",
+                                "MMC_CAP_MMC_HIGHSPEED",
+                                "MMC_CAP_SD_HIGHSPEED",
+                                "MMC_CAP_NONREMOVABLE",
+                                "MMC_CAP_UHS_SDR12",
+                                "MMC_CAP_UHS_SDR25",
+                                "MMC_CAP_UHS_SDR50",
+                                "MMC_CAP_UHS_SDR104",
+                                "MMC_PM_KEEP_POWER",
+                                "MMC_CAP_SDIO_IRQ";
+                       f_min = <400000>;
+                       f_max = <200000000>;
+                       max_req_size = <0x20000>; /**128KB*/
+                       card_type = <3>;
+                       /* 3:sdio device(ie:sdio-wifi),
+                        * 4:SD combo (IO+mem) card
+                        */
+               };
+       };
+
+       partitions: partitions{
+               parts = <11>;
+               part-0 = <&logo>;
+               part-1 = <&recovery>;
+               part-2 = <&rsv>;
+               part-3 = <&tee>;
+               part-4 = <&crypt>;
+               part-5 = <&misc>;
+               part-6 = <&instaboot>;
+               part-7 = <&boot>;
+               part-8 = <&system>;
+               part-9 = <&cache>;
+               part-10 = <&data>;
+
+               logo:logo{
+                       pname = "logo";
+                       size = <0x0 0x2000000>;
+                       mask = <1>;
+               };
+               recovery:recovery{
+                       pname = "recovery";
+                       size = <0x0 0x2000000>;
+                       mask = <1>;
+               };
+               rsv:rsv{
+                       pname = "rsv";
+                       size = <0x0 0x800000>;
+                       mask = <1>;
+               };
+               tee:tee{
+                       pname = "tee";
+                       size = <0x0 0x800000>;
+                       mask = <1>;
+               };
+               crypt:crypt{
+                       pname = "crypt";
+                       size = <0x0 0x2000000>;
+                       mask = <1>;
+               };
+               misc:misc{
+                       pname = "misc";
+                       size = <0x0 0x2000000>;
+                       mask = <1>;
+               };
+               instaboot:instaboot{
+                       pname = "instaboot";
+                       size = <0x0 0x400000>;
+                       mask = <1>;
+               };
+               boot:boot
+               {
+                       pname = "boot";
+                       size = <0x0 0x2000000>;
+                       mask = <1>;
+               };
+               system:system
+               {
+                       pname = "system";
+                       size = <0x0 0x80000000>;
+                       mask = <1>;
+               };
+               cache:cache
+               {
+                       pname = "cache";
+                       size = <0x0 0x20000000>;
+                       mask = <2>;
+               };
+               data:data
+               {
+                       pname = "data";
+                       size = <0xffffffff 0xffffffff>;
+                       mask = <4>;
+               };
+       };
+
+       meson-fb {
+               compatible = "amlogic, meson-axg";
+               memory-region = <&fb_reserved>;
+               dev_name = "meson-fb";
+               status = "okay";
+               interrupts = <0 3 1
+                       0 89 1>;
+               interrupt-names = "viu-vsync", "rdma";
+               mem_size = <0x00300000 0x1800000 0x00000000>;
+               /* uboot logo,fb0/fb1 memory size */
+               display_mode_default = "1080p60hz";
+               scale_mode = <0>;
+               /** 0:VPU free scale 1:OSD free scale 2:OSD super scale */
+               display_size_default = <768 1024 768 2048 32>;
+               /*768*1024*4*2 = 0x600000*/
+               mem_alloc = <1>;
+               logo_addr = "0x3e000000";
+               pxp_mode = <0>; /** 0:normal mode 1:pxp mode */
+       };
+
+       ge2d {
+               compatible = "amlogic, ge2d-axg";
+               dev_name = "ge2d";
+               status = "okay";
+               interrupts = <0 150 1>;
+               interrupt-names = "ge2d";
+               clocks = <&clkc CLKID_VAPB_MUX>,
+                       <&clkc CLKID_G2D>,
+                       <&clkc CLKID_GE2D_GATE>;
+               clock-names = "clk_vapb_0",
+                       "clk_ge2d",
+                       "clk_ge2d_gate";
+               reg = <0x0 0xff940000 0x0 0x10000>;
+       };
+
+       adc_keypad {
+               compatible = "amlogic, adc_keypad";
+               status = "disable";
+               key_name = "power", "vol-", "vol+", "wifi", "<<", ">>";
+               key_num = <6>;
+               io-channels = <&saradc SARADC_CH0>;
+               io-channel-names = "key-chan-0";
+               key_chan = <SARADC_CH0 SARADC_CH0 SARADC_CH0
+                                       SARADC_CH0 SARADC_CH0 SARADC_CH0>;
+               key_code = <116 114 115 139 105 106>;
+               key_val = <0 143 266 389 512 635>; //val=voltage/1800mV*1023
+               key_tolerance = <40 40 40 40 40 40>;
+       };
+
+       unifykey{
+               compatible = "amlogic, unifykey";
+               status = "disable";
+
+               unifykey-num = <6>;
+               unifykey-index-0 = <&keysn_0>;
+               unifykey-index-1 = <&keysn_1>;
+               unifykey-index-2 = <&keysn_2>;
+               unifykey-index-3 = <&keysn_3>;
+               unifykey-index-4 = <&keysn_4>;
+               unifykey-index-5 = <&keysn_5>;
+
+               keysn_0: key_0{
+                       key-name = "usid";
+                       key-device = "normal";
+                       key-permit = "read","write","del";
+               };
+               keysn_1:key_1{
+                       key-name = "mac";
+                       key-device = "normal";
+                       key-permit = "read","write","del";
+               };
+               keysn_2:key_2{
+                       key-name = "secure_boot_set";
+                       key-device = "efuse";
+                       key-permit = "write";
+               };
+               keysn_3:key_3{
+                       key-name = "mac_bt";
+                       key-device = "normal";
+                       key-permit = "read","write","del";
+                       key-type        = "mac";
+               };
+               keysn_4:key_4{
+                       key-name = "mac_wifi";
+                       key-device = "normal";
+                       key-permit = "read","write","del";
+                       key-type = "mac";
+               };
+               keysn_5:key_5{
+                       key-name = "deviceid";
+                       key-device = "normal";
+                       key-permit = "read","write","del";
+               };
+       };//End unifykey
+
+}; /* end of / */
+&efuse {
+       status = "ok";
+};
+
+&pwm_ab {
+       status = "okay";
+};
+/* Audio Related start */
+/* for spk board */
+&i2c1 {
+       status = "okay";
+       pinctrl-names="default";
+       pinctrl-0=<&b_i2c_master>;
+
+       tlv320adc3101_32: tlv320adc3101_32@32 {
+               compatible = "ti,tlv320adc3101";
+               #sound-dai-cells = <0>;
+               reg = <0x19>;
+               differential_pair = <1>;
+               status = "okay";
+       };
+
+       tas5707_36: tas5707_36@36 {
+               compatible = "ti,tas5707";
+               #sound-dai-cells = <0>;
+               reg = <0x1b>;
+               status = "okay";
+               reset_pin = <&gpio_ao GPIOAO_4 0>;
+       };
+
+       tas5707_3a: tas5707_3a@3a {
+               compatible = "ti,tas5707";
+               #sound-dai-cells = <0>;
+               reg = <0x1d>;
+               status = "okay";
+       };
+};
+
+/* for mic board */
+&i2c_AO {
+       status = "okay";
+       pinctrl-names="default";
+       pinctrl-0=<&ao_i2c_master_pin2>;
+
+       aml_pca9557: aml_pca9557@0x1f {
+               compatible = "aml, ledring";
+               reg = <0x1f>;
+                       mode = <0>; /*0: 6-led 1: 4key+2led */
+                       key_num = <4>;
+                       led_dev_name = "aml_ledring";
+                       key_dev_name = "aml_pca_key";
+                       key_name = "mute", "pause", "vol+", "vol-";
+                       key_value = <200 201 202 203>;
+               status = "okay";
+       };
+
+       tlv320adc3101_30: tlv320adc3101_30@30 {
+               compatible = "ti,tlv320adc3101";
+               #sound-dai-cells = <0>;
+               reg = <0x18>;
+               status = "disable";
+       };
+       tlv320adc3101_34: tlv320adc3101_34@30 {
+               compatible = "ti,tlv320adc3101";
+               #sound-dai-cells = <0>;
+               reg = <0x1a>;
+               status = "disable";
+       };
+       tlv320adc3101_36: tlv320adc3101_36@30 {
+               compatible = "ti,tlv320adc3101";
+               #sound-dai-cells = <0>;
+               reg = <0x1b>;
+               status = "disable";
+       };
+
+       es7243_10: es7243_10@10 {
+               compatible = "MicArray_0";
+               #sound-dai-cells = <0>;
+               reg = <0x10>;
+               status = "disable";
+       };
+       es7243_12: es7243_12@12 {
+               compatible = "MicArray_1";
+               #sound-dai-cells = <0>;
+               reg = <0x12>;
+               status = "disable";
+       };
+       es7243_13: es7243_13@13 {
+               compatible = "MicArray_2";
+               #sound-dai-cells = <0>;
+               reg = <0x13>;
+               status = "disable";
+       };
+       is31fl3236a: is31f3236a@0x78 {
+               compatible = "issi,is31fl3236";
+               reg = <0x3c>;
+               status = "disable";
+               led1_r {
+                       label="LED1_R";
+                       reg_offset = <24>;
+               };
+               led1_g {
+                       label="LED1_G";
+                       reg_offset = <23>;
+               };
+               led1_b {
+                       label="LED1_B";
+                       reg_offset = <22>;
+               };
+               led2_r {
+                       label="LED2_R";
+                       reg_offset = <21>;
+               };
+               led2_g {
+                       label="LED2_G";
+                       reg_offset = <20>;
+               };
+               led2_b {
+                       label="LED2_B";
+                       reg_offset = <19>;
+               };
+               led3_r {
+                       label="LED3_R";
+                       reg_offset = <18>;
+               };
+               led3_g {
+                       label="LED3_G";
+                       reg_offset = <17>;
+               };
+               led3_b {
+                       label="LED3_B";
+                       reg_offset = <16>;
+               };
+               led4_r {
+                       label="LED4_R";
+                       reg_offset = <15>;
+               };
+               led4_g {
+                       label="LED4_G";
+                       reg_offset = <14>;
+               };
+               led4_b {
+                       label="LED4_B";
+                       reg_offset = <13>;
+               };
+               led5_r {
+                       label="LED5_R";
+                       reg_offset = <36>;
+               };
+               led5_g {
+                       label="LED5_G";
+                       reg_offset = <35>;
+               };
+               led5_b {
+                       label="LED5_B";
+                       reg_offset = <34>;
+               };
+               led6_r {
+                       label="LED6_R";
+                       reg_offset = <33>;
+               };
+               led6_g {
+                       label="LED6_G";
+                       reg_offset = <32>;
+               };
+               led6_b {
+                       label="LED6_B";
+                       reg_offset = <31>;
+               };
+               led7_r {
+                       label="LED7_R";
+                       reg_offset = <30>;
+               };
+               led7_g {
+                       label="LED7_G";
+                       reg_offset = <29>;
+               };
+               led7_b {
+                       label="LED7_B";
+                       reg_offset = <28>;
+               };
+               led8_r {
+                       label="LED8_R";
+                       reg_offset = <27>;
+               };
+               led8_g {
+                       label="LED8_G";
+                       reg_offset = <26>;
+               };
+               led8_b {
+                       label="LED8_B";
+                       reg_offset = <25>;
+               };
+       };
+};
+
+&audiobus {
+       aml_tdma: tdma {
+               compatible = "amlogic, axg-snd-tdma";
+               #sound-dai-cells = <0>;
+               dai-tdm-lane-slot-mask-in = <1 0>;
+               dai-tdm-lane-slot-mask-out = <0 1>;
+               dai-tdm-clk-sel = <0>;
+               clocks = <&clkaudio CLKID_AUDIO_MCLK_A
+                               &clkc CLKID_MPLL0>;
+               clock-names = "mclk", "clk_srcpll";
+               pinctrl-names = "tdm_pins";
+               pinctrl-0 = <&tdmout_a &tdmin_a &tdmout_a_data>;
+       };
+
+       aml_tdmb: tdmb {
+               compatible = "amlogic, axg-snd-tdmb";
+               #sound-dai-cells = <0>;
+               /*dai-tdm-lane-slot-mask-in = <1 1 1 1>;*/
+               dai-tdm-lane-slot-mask-in = <0 0 0 1>;
+               dai-tdm-clk-sel = <1>;
+               clocks = <&clkaudio CLKID_AUDIO_MCLK_B
+                               &clkc CLKID_MPLL1>;
+               clock-names = "mclk", "clk_srcpll";
+               pinctrl-names = "tdm_pins";
+               pinctrl-0 = <&tdmb_mclk &tdmout_b &tdmin_b>;
+       };
+
+       aml_tdmc: tdmc {
+               compatible = "amlogic, axg-snd-tdmc";
+               #sound-dai-cells = <0>;
+               dai-tdm-lane-slot-mask-in = <0 1 0 0>;
+               dai-tdm-lane-slot-mask-out = <0 0 1 1>;
+               dai-tdm-clk-sel = <2>;
+               clocks = <&clkaudio CLKID_AUDIO_MCLK_C
+                               &clkc CLKID_MPLL2>;
+               clock-names = "mclk", "clk_srcpll";
+               pinctrl-names = "tdm_pins";
+               pinctrl-0 = <&tdmc_mclk &tdmout_c>;
+       };
+
+       aml_spdif: spdif {
+               compatible = "amlogic, axg-snd-spdif";
+               #sound-dai-cells = <0>;
+               clocks = <&clkc CLKID_MPLL0
+                               &clkc CLKID_FCLK_DIV4
+                               &clkaudio CLKID_AUDIO_SPDIFIN
+                               &clkaudio CLKID_AUDIO_SPDIFOUT
+                               &clkaudio CLKID_AUDIO_SPDIFIN_CTRL
+                               &clkaudio CLKID_AUDIO_SPDIFOUT_CTRL>;
+               clock-names = "sysclk", "fixed_clk", "gate_spdifin",
+                               "gate_spdifout", "clk_spdifin", "clk_spdifout";
+               interrupts =
+                               <GIC_SPI 87 IRQ_TYPE_EDGE_RISING>;
+
+               interrupt-names = "irq_spdifin";
+               pinctrl-names = "spdif_pins";
+               pinctrl-0 = <&spdifout &spdifin>;
+               status = "okay";
+       };
+       aml_pdm: pdm {
+               compatible = "amlogic, axg-snd-pdm";
+               #sound-dai-cells = <0>;
+               clocks = <&clkaudio CLKID_AUDIO_PDM
+                       &clkc CLKID_FCLK_DIV3
+                       &clkc CLKID_MPLL3
+                       &clkaudio CLKID_AUDIO_PDMIN0
+                       &clkaudio CLKID_AUDIO_PDMIN1>;
+               clock-names = "gate",
+                       "sysclk_srcpll",
+                       "dclk_srcpll",
+                       "pdm_dclk",
+                       "pdm_sysclk";
+               pinctrl-names = "pdm_pins";
+               pinctrl-0 = <&pdmin>;
+               filter_mode = <1>; /* mode 0~4, defalut:1 */
+               status = "okay";
+       };
+
+       aml_loopback: loopback {
+               compatible = "amlogic, snd-loopback";
+
+               /*
+                * external loopback clock config
+                * enable clk while pdm record data
+                */
+               /*clocks = <&clkc CLKID_MPLL1>;*/
+               /*clock-names = "datalb_mpll";*/
+
+               /*
+                * 0: out rate = in data rate;
+                * 1: out rate = loopback data rate;
+                */
+
+               lb_mode = <0>;
+
+               /* datain src
+                * 0: tdmin_a;
+                * 1: tdmin_b;
+                * 2: tdmin_c;
+                * 3: spdifin;
+                * 4: pdmin;
+                */
+               datain_src = <4>;
+               datain_chnum = <8>;
+               datain_chmask = <0x7f>;
+
+               /* tdmin_lb src
+                * 0: tdmoutA
+                * 1: tdmoutB
+                * 2: tdmoutC
+                * 3: PAD_tdminA
+                * 4: PAD_tdminB
+                * 5: PAD_tdminC
+                */
+
+               /*if tdmin_lb >= 3, use external loopback*/
+               datalb_src = <2>;
+               datalb_chnum = <2>;
+               /*config which data pin as loopback*/
+               /*datalb-lane-mask-in = <0 0 0 1>;*/
+               datalb_chmask = <0x1>;
+
+               status = "okay";
+       };
+}; /* end of audiobus */
+
+&pinctrl_periphs {
+       tdmout_a: tdmout_a {
+               mux {
+                       groups = "tdma_sclk",
+                               "tdma_fs";
+                       function = "tdma_out";
+               };
+       };
+
+       tdmout_a_data: tdmout_a_data {
+               mux {
+                       groups = "tdma_dout1_x15";
+                       function = "tdma_out";
+               };
+       };
+
+       tdmin_a: tdmin_a {
+               mux {
+                       groups = "tdma_din0";
+                       function = "tdma_in";
+               };
+       };
+
+       tdmb_mclk: tdmb_mclk {
+               mux {
+                       groups = "mclk_b";
+                       function = "mclk_b";
+               };
+       };
+
+       tdmout_b: tdmout_b {
+               mux {
+                       groups = "tdmb_sclk",
+                               "tdmb_fs";
+                       function = "tdmb_out";
+               };
+       };
+       // tdmin and tdmout are the same pins. can't use at same time
+       tdmin_b:tdmin_b {
+               mux {
+                       groups = "tdmb_din0",
+                               "tdmb_din1",
+                               "tdmb_din2_a12",
+                               "tdmb_din3_a13";
+                       function = "tdmb_in";
+               };
+       };
+
+       tdmc_mclk: tdmc_mclk {
+               mux {
+                       groups = "mclk_a";
+                       function = "mclk_a";
+               };
+       };
+
+       tdmout_c:tdmout_c {
+               mux {
+                       groups = "tdmc_sclk",
+                               "tdmc_fs",
+                               "tdmc_dout0",
+                               "tdmc_dout2_a6",
+                               "tdmc_dout3_a7";
+                       function = "tdmc_out";
+               };
+       };
+
+
+       tdmin_c:tdmin_c {
+               mux {
+                       groups = "tdmc_din1";
+                       function = "tdmc_in";
+               };
+       };
+
+       spdifout: spidfout {
+               mux {
+                       groups = "spdif_out_a20";
+                       function = "spdif_out";
+               };
+       };
+
+       spdifin: spidfin {
+               mux {
+                       groups = "spdif_in_a19";
+                       function = "spdif_in";
+               };
+       };
+
+       pdmin: pdmin {
+               mux {
+                       groups = "pdm_dclk_a14",
+                               "pdm_din0",
+                               "pdm_din1",
+                               "pdm_din2",
+                               "pdm_din3";
+                       function = "pdm";
+               };
+       };
+
+       bl_pwm_on_pins: bl_pwm_on_pin {
+               mux {
+                       groups = "pwm_b_z";
+                       function = "pwm_b";
+               };
+       };
+       bl_pwm_off_pins:bl_pwm_off_pin {
+               mux {
+                       pins = "GPIOZ_4";
+                       function = "gpio_periphs";
+                       output-high;
+               };
+       };
+}; /* end of pinctrl_periphs */
+/* Audio Related End */
+
+&aobus{
+       uart_AO: serial@3000 {
+               compatible = "amlogic, meson-uart";
+               reg = <0x0 0x3000 0x0 0x18>;
+               interrupts = <0 193 1>;
+               status = "okay";
+               clocks = <&xtal>;
+               clock-names = "clk_uart";
+               xtal_tick_en = <1>;
+               fifosize = < 64 >;
+               pinctrl-names = "default";
+               pinctrl-0 = <&ao_uart_pins>;
+               support-sysrq = <0>;    /* 0 not support , 1 support */
+       };
+
+       uart_AO_B: serial@4000 {
+               compatible = "amlogic, meson-uart";
+               reg = <0x0 0x4000 0x0 0x18>;
+               interrupts = <0 197 1>;
+               status = "disable";
+               clocks = <&xtal>;
+               clock-names = "clk_uart";
+               fifosize = < 64 >;
+               pinctrl-names = "default";
+               pinctrl-0 = <&ao_b_uart_pins>;
+       };
+};