| /* |
| * arch/arm64/boot/dts/amlogic/axg_s400_v03gva_sbr.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_s400_v03gva_sbr"; |
| 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 */ |
| ramoops@0x07400000 { |
| compatible = "ramoops"; |
| reg = <0x0 0x07400000 0x0 0x00100000>; |
| record-size = <0x20000>; |
| console-size = <0x40000>; |
| ftrace-size = <0x80000>; |
| pmsg-size = <0x20000>; |
| }; |
| |
| 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 = "disabled"; |
| 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>; |
| }; |
| }; |
| |
| cma_shrinker { |
| compatible = "amlogic, cma-shrinker"; |
| status = "okay"; |
| adj = <0 100 200 250 900 950>; |
| free = <7680 24288 28528 32600 32768 36624>; |
| }; |
| |
| 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>; |
| clocks = <&clkc CLKID_SD_EMMC_C>, |
| <&clkc CLKID_FCLK_DIV2>; |
| clock-names = "gate", "fdiv2pll"; |
| bl_mode = <1>; |
| fip_copies = <4>; |
| 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{ |
| tpl{ |
| offset=<0x0 0x0>; |
| size=<0x0 0x0>; |
| }; |
| recovery{ |
| offset=<0x0 0x0>; |
| size=<0x0 0x1000000>; |
| }; |
| boot{ |
| offset=<0x0 0x0>; |
| size=<0x0 0x1000000>; |
| }; |
| system{ |
| offset=<0x0 0x0>; |
| size=<0x0 0x11800000>; |
| }; |
| factory{ |
| offset=<0x0 0x0>; |
| size=<0x0 0x1000000>; |
| }; |
| data{ |
| offset=<0xffffffff 0xffffffff>; |
| size=<0x0 0x0>; |
| }; |
| }; |
| }; |
| |
| |
| ethmac: ethernet@0xff3f0000 { |
| compatible = "amlogic, gxbb-eth-dwmac"; |
| reg = <0x0 0xff3f0000 0x0 0x10000 |
| 0x0 0xff634540 0x0 0x8 |
| 0x0 0xff634558 0x0 0xc |
| 0x0 0xffd01008 0x0 0x4>; |
| 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 = "disabled"; |
| }; |
| |
| 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 = "disabled"; |
| }; |
| |
| |
| 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 = "disabled"; |
| 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,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>; |
| dai-tdm-slot-rx-mask = |
| <1>; |
| dai-tdm-slot-num = <1>; |
| dai-tdm-slot-width = <32>; |
| system-clock-frequency = <512000>; |
| }; |
| 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; |
| |
| /*A113D tdmb slave for HDMI*/ |
| bitclock-master = <&tdmbcodec>; |
| frame-master = <&tdmbcodec>; |
| |
| /*A113D tdmb master for LineIn*/ |
| /* |
| * bitclock-master = <&aml_tdmb>; |
| * frame-master = <&aml_tdmb>; |
| */ |
| |
| 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>; |
| 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>; |
| */ |
| prefix-names = "tas5782m_pu1", "tas5782m_pu2", |
| "tas5782m_pu3", "tas5782m_pu4", "tas5782m_pu5", |
| "tas5782m_pu6"; |
| sound-dai = <&tas5782m_pu1 &tas5782m_pu2 |
| &tas5782m_pu3 &tas5782m_pu4 &tas5782m_pu5 |
| &tas5782m_pu6>; |
| }; |
| }; |
| |
| aml-audio-card,dai-link@3 { |
| mclk-fs = <256>; |
| cpu { |
| sound-dai = <&aml_pdm>; |
| }; |
| codec { |
| 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>; |
| }; |
| }; |
| |
| aml-audio-card,dai-link@5 { |
| mclk-fs = <256>; |
| continuous-clock; |
| suffix-name = "alsaPORT-loopback"; |
| cpu { |
| sound-dai = <&loopback>; |
| system-clock-frequency = <12288000>; |
| }; |
| codec { |
| sound-dai = <&dummy_codec>; |
| }; |
| }; |
| }; |
| |
| bt-dev{ |
| compatible = "amlogic, bt-dev"; |
| dev_name = "bt-dev"; |
| status = "okay"; |
| gpio_reset = <&gpio GPIOX_21 GPIO_ACTIVE_HIGH>; |
| }; |
| |
| wifi{ |
| compatible = "amlogic, aml_wifi"; |
| dev_name = "aml_wifi"; |
| status = "okay"; |
| 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 30541 0>; |
| duty-cycle = <15270>; |
| times = <10>; |
| }; |
| pwm_channel2_conf { |
| pwms = <&pwm_ab MESON_PWM_2 30500 0>; |
| duty-cycle = <15250>; |
| 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 = <4>; |
| 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 = "disabled"; |
| 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 = "disabled"; |
| 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 = "okay"; |
| 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 = "okay"; |
| |
| 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>; |
| unifykey-index-6 = <&keysn_6>; |
| |
| 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"; |
| }; |
| keysn_6:key_6{ |
| key-name = "gva_certs"; |
| key-device = "normal"; |
| key-permit = "read","write","del"; |
| }; |
| };//End unifykey |
| audio_data: audio_data { |
| compatible = "amlogic, audio_data"; |
| query_licence_cmd = <0x82000050>; |
| status = "okay"; |
| }; |
| }; /* 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"; |
| }; |
| |
| /*****************************************************************/ |
| tas5782m_pu1: tas5782m_pu1@48 { |
| compatible = "ti, tas5782m"; |
| #sound-dai-cells = <0>; |
| reg = <0x48>; |
| reset_pin = <&gpio_ao GPIOAO_4 GPIO_ACTIVE_LOW>; |
| status = "okay"; |
| codec_name = "tas5782m"; |
| work_mode = <0>; /*0: i2s 1:tdm*/ |
| chip_offset = <1>; /*chip_N [1,2....]*/ |
| }; |
| |
| tas5782m_pu2: tas5782m_pu2@49 { |
| compatible = "ti, tas5782m"; |
| #sound-dai-cells = <0>; |
| reg = <0x49>; |
| status = "okay"; |
| codec_name = "tas5782m"; |
| work_mode = <0>; /*0: i2s 1:tdm*/ |
| chip_offset = <2>; /*chip_N [1,2....]*/ |
| }; |
| |
| tas5782m_pu3: tas5782m_pu3@4a { |
| compatible = "ti, tas5782m"; |
| #sound-dai-cells = <0>; |
| reg = <0x4a>; |
| status = "okay"; |
| codec_name = "tas5782m"; |
| work_mode = <0>; /*0: i2s 1:tdm*/ |
| chip_offset = <3>; /*chip_N [1,2....]*/ |
| }; |
| |
| tas5782m_pu4: tas5782m_pu4@4b { |
| compatible = "ti, tas5782m"; |
| #sound-dai-cells = <0>; |
| reg = <0x4b>; |
| status = "okay"; |
| codec_name = "tas5782m"; |
| work_mode = <0>; /*0: i2s 1:tdm*/ |
| chip_offset = <4>; /*chip_N [1,2....]*/ |
| }; |
| /*****************************************************************/ |
| tas5707_36: tas5707_36@36 { |
| compatible = "ti, tas5707"; |
| #sound-dai-cells = <0>; |
| reg = <0x1b>; |
| status = "disabled"; |
| reset_pin = <&gpio_ao GPIOAO_4 0>; |
| }; |
| |
| tas5707_3a: tas5707_3a@3a { |
| compatible = "ti,tas5707"; |
| #sound-dai-cells = <0>; |
| reg = <0x1d>; |
| status = "disabled"; |
| }; |
| }; |
| |
| /* for mic board */ |
| &i2c_AO { |
| status = "okay"; |
| pinctrl-names="default"; |
| pinctrl-0=<&ao_i2c_master_pin2>; |
| |
| /*****************************************************************/ |
| mcu6350: mcu6350@40 { |
| reg = <0x40>; |
| status = "okay"; |
| }; |
| |
| /*****************************************************************/ |
| tas5782m_pu5: tas5782m_pu5@48 { |
| compatible = "ti, tas5782m"; |
| #sound-dai-cells = <0>; |
| reg = <0x48>; |
| status = "okay"; |
| codec_name = "tas5782m"; |
| work_mode = <0>; /*0: i2s 1:tdm*/ |
| chip_offset = <5>; /*chip_N [1,2....]*/ |
| }; |
| |
| tas5782m_pu6: tas5782m_pu6@49 { |
| compatible = "ti, tas5782m"; |
| #sound-dai-cells = <0>; |
| reg = <0x49>; |
| status = "okay"; |
| codec_name = "tas5782m"; |
| work_mode = <0>; /*0: i2s 1:tdm*/ |
| chip_offset = <6>; /*chip_N [1,2....]*/ |
| }; |
| /*****************************************************************/ |
| aml_pca9557: aml_pca9557@0x1f { |
| compatible = "amlogic,pca9557_keypad"; |
| reg = <0x1f>; |
| key_num = <4>; |
| key_name = "fdr", "hotword", "pause", "mute"; |
| key_value = <106 105 139 116>; |
| key_index_mask = <0x4 0x8 0x10 0x20>; |
| key_input_mask = <0x3C>; |
| 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"; |
| }; |
| |
| cy8c4014_08: cy8c4014_08@08 { |
| compatible = "cy8c4014"; |
| #sound-dai-cells = <0>; |
| reg = <0x8>; |
| status = "okay"; |
| }; |
| |
| is31fl3236a: is31f3236a@0x78 { |
| compatible = "issi,is31fl3236,gva"; |
| reg = <0x3c>; |
| status = "okay"; |
| led1_b { |
| label="LED1_B"; |
| reg_offset = <1>; |
| }; |
| led1_g { |
| label="LED1_G"; |
| reg_offset = <2>; |
| }; |
| led1_r { |
| label="LED1_R"; |
| reg_offset = <3>; |
| }; |
| led2_b { |
| label="LED2_B"; |
| reg_offset = <4>; |
| }; |
| led2_g { |
| label="LED2_G"; |
| reg_offset = <5>; |
| }; |
| led2_r { |
| label="LED2_R"; |
| reg_offset = <6>; |
| }; |
| led3_b { |
| label="LED3_B"; |
| reg_offset = <7>; |
| }; |
| led3_g { |
| label="LED3_G"; |
| reg_offset = <8>; |
| }; |
| led3_r { |
| label="LED3_R"; |
| reg_offset = <9>; |
| }; |
| led4_b { |
| label="LED4_B"; |
| reg_offset = <10>; |
| }; |
| led4_g { |
| label="LED4_G"; |
| reg_offset = <11>; |
| }; |
| led4_r { |
| label="LED4_R"; |
| reg_offset = <12>; |
| }; |
| }; |
| }; |
| |
| &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-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"; |
| |
| /*A113D tdmb slave for HDMI*/ |
| pinctrl-0 = <&tdmb_mclk &tdmin_b_slv &tdmin_b>; |
| |
| /*A113D tdmb master for LineIn*/ |
| /* |
| * 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 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>; |
| }; |
| |
| tdmlb:tdm@3 { |
| compatible = "amlogic, axg-snd-tdmlb"; |
| #sound-dai-cells = <0>; |
| |
| dai-tdm-lane-lb-slot-mask-in = <1 0 0 0>; |
| dai-tdm-clk-sel = <1>; |
| |
| clocks = <&clkaudio CLKID_AUDIO_MCLK_B |
| &clkc CLKID_MPLL1>; |
| clock-names = "mclk", "clk_srcpll"; |
| |
| /* |
| * select tdmin_lb src; |
| * AXG |
| * 0: TDMOUTA |
| * 1: TDMOUTB |
| * 2: TDMOUTC |
| * 3: PAD_TDMINA |
| * 4: PAD_TDMINB |
| * 5: PAD_TDMINC |
| * |
| * G12A/G12B |
| * 0: TDMOUTA |
| * 1: TDMOUTB |
| * 2: TDMOUTC |
| * 3: PAD_TDMINA_DIN* |
| * 4: PAD_TDMINB_DIN* |
| * 5: PAD_TDMINC_DIN* |
| * 6: PAD_TDMINA_D*, oe pin |
| * 7: PAD_TDMINB_D*, oe pin |
| * |
| * TL1 |
| * 0: TDMOUTA |
| * 1: TDMOUTB |
| * 2: TDMOUTC |
| * 3: PAD_TDMINA_DIN* |
| * 4: PAD_TDMINB_DIN* |
| * 5: PAD_TDMINC_DIN* |
| * 6: PAD_TDMINA_D* |
| * 7: PAD_TDMINB_D* |
| * 8: PAD_TDMINC_D* |
| * 9: HDMIRX_I2S |
| * 10: ACODEC_ADC |
| */ |
| lb-src-sel = <1>; |
| |
| status = "disabled"; |
| }; |
| |
| 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 = <0>; |
| 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"; |
| }; |
| |
| loopback:loopback@0 { |
| compatible = "amlogic, axg-loopback"; |
| #sound-dai-cells = <0>; |
| |
| clocks = <&clkaudio CLKID_AUDIO_PDM |
| &clkc CLKID_FCLK_DIV3 |
| &clkc CLKID_MPLL3 |
| &clkaudio CLKID_AUDIO_PDMIN0 |
| &clkaudio CLKID_AUDIO_PDMIN1 |
| &clkc CLKID_MPLL0 |
| &clkaudio CLKID_AUDIO_MCLK_A>; |
| clock-names = "pdm_gate", |
| "pdm_sysclk_srcpll", |
| "pdm_dclk_srcpll", |
| "pdm_dclk", |
| "pdm_sysclk", |
| "tdminlb_mpll", |
| "tdminlb_mclk"; |
| |
| /* datain src |
| * 0: tdmin_a; |
| * 1: tdmin_b; |
| * 2: tdmin_c; |
| * 3: spdifin; |
| * 4: pdmin; |
| */ |
| datain_src = <4>; |
| datain_chnum = <6>; |
| datain_chmask = <0x3f>; |
| /* config which data pin for loopback */ |
| datain-lane-mask-in = <1 1 1 0>; |
| |
| /* calc mclk for datalb */ |
| mclk-fs = <256>; |
| |
| /* tdmin_lb src |
| * 0: tdmoutA |
| * 1: tdmoutB |
| * 2: tdmoutC |
| * 3: PAD_TDMINA_DIN*, refer to core pinmux |
| * 4: PAD_TDMINB_DIN*, refer to core pinmux |
| * 5: PAD_TDMINC_DIN*, refer to core pinmux |
| * 6: PAD_TDMINA_D*, oe, refer to core pinmux |
| * 7: PAD_TDMINB_D*, oe, refer to core pinmux |
| */ |
| /* if tdmin_lb >= 3, use external loopback */ |
| datalb_src = <2>; |
| datalb_chnum = <2>; |
| datalb_chmask = <0x3>; |
| /* config which data pin as loopback */ |
| datalb-lane-mask-in = <1 0 0 0>; |
| |
| 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"; |
| }; |
| }; /* 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_b_slv: tdmin_b_slv{ |
| mux { |
| groups = "tdmb_slv_sclk", "tdmb_slv_fs"; |
| function = "tdmb_in"; |
| }; |
| }; |
| |
| // 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_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"; |
| }; |
| }; |
| 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>; |
| }; |
| }; |
| |
| &audio_data{ |
| status = "okay"; |
| }; |
| |
| &custom_maps{ |
| mapnum = <4>; |
| map0 = <&map_0>; |
| map1 = <&map_1>; |
| map2 = <&map_2>; |
| map3 = <&map_3>; |
| map_0: map_0{ |
| mapname = "amlogic-remote-1"; |
| customcode = <0xfb04>; |
| release_delay = <80>; |
| size = <50>; /*keymap size*/ |
| keymap = <REMOTE_KEY(0x47, KEY_0) |
| REMOTE_KEY(0x13, KEY_1) |
| REMOTE_KEY(0x10, KEY_2) |
| REMOTE_KEY(0x11, KEY_3) |
| REMOTE_KEY(0x0F, KEY_4) |
| REMOTE_KEY(0x0C, KEY_5) |
| REMOTE_KEY(0x0D, KEY_6) |
| REMOTE_KEY(0x0B, KEY_7) |
| REMOTE_KEY(0x08, KEY_8) |
| REMOTE_KEY(0x09, KEY_9) |
| REMOTE_KEY(0x5C, KEY_RIGHTCTRL) |
| REMOTE_KEY(0x51, KEY_F3) |
| REMOTE_KEY(0x50, KEY_F4) |
| REMOTE_KEY(0x40, KEY_F5) |
| REMOTE_KEY(0x4d, KEY_F6) |
| REMOTE_KEY(0x43, KEY_F7) |
| REMOTE_KEY(0x17, KEY_F8) |
| REMOTE_KEY(0x00, KEY_F9) |
| REMOTE_KEY(0x01, KEY_F10) |
| REMOTE_KEY(0x16, KEY_F11) |
| REMOTE_KEY(0x49, KEY_BACKSPACE) |
| REMOTE_KEY(0x06, KEY_PROPS) |
| REMOTE_KEY(0x14, KEY_UNDO) |
| REMOTE_KEY(0x44, KEY_UP) |
| REMOTE_KEY(0x1D, KEY_DOWN) |
| REMOTE_KEY(0x1C, KEY_LEFT) |
| REMOTE_KEY(0x48, KEY_RIGHT) |
| REMOTE_KEY(0x53, KEY_LEFTMETA) |
| REMOTE_KEY(0x45, KEY_PAGEUP) |
| REMOTE_KEY(0x19, KEY_PAGEDOWN) |
| REMOTE_KEY(0x52, KEY_PAUSE) |
| REMOTE_KEY(0x05, KEY_HANGEUL) |
| REMOTE_KEY(0x59, KEY_HANJA) |
| REMOTE_KEY(0x1b, KEY_SCALE) |
| REMOTE_KEY(0x04, KEY_KPCOMMA) |
| REMOTE_KEY(0x1A, KEY_POWER) |
| REMOTE_KEY(0x0A, KEY_TAB) |
| REMOTE_KEY(0x0e, KEY_MUTE) |
| REMOTE_KEY(0x1F, KEY_HOME) |
| REMOTE_KEY(0x1e, KEY_FRONT) |
| REMOTE_KEY(0x07, KEY_COPY) |
| REMOTE_KEY(0x12, KEY_OPEN) |
| REMOTE_KEY(0x54, KEY_PASTE) |
| REMOTE_KEY(0x02, KEY_FIND) |
| REMOTE_KEY(0x4f, KEY_A) |
| REMOTE_KEY(0x42, KEY_B) |
| REMOTE_KEY(0x5d, KEY_C) |
| REMOTE_KEY(0x4c, KEY_D) |
| REMOTE_KEY(0x58, KEY_CUT) |
| REMOTE_KEY(0x55, KEY_CALC)>; |
| }; |
| map_1: map_1{ |
| mapname = "amlogic-remote-2"; |
| customcode = <0xfe01>; |
| release_delay = <80>; |
| size = <53>; |
| keymap = <REMOTE_KEY(0x01, KEY_1) |
| REMOTE_KEY(0x02, KEY_2) |
| REMOTE_KEY(0x03, KEY_3) |
| REMOTE_KEY(0x04, KEY_4) |
| REMOTE_KEY(0x05, KEY_5) |
| REMOTE_KEY(0x06, KEY_6) |
| REMOTE_KEY(0x07, KEY_7) |
| REMOTE_KEY(0x08, KEY_8) |
| REMOTE_KEY(0x09, KEY_9) |
| REMOTE_KEY(0x0a, KEY_0) |
| REMOTE_KEY(0x1F, KEY_FN_F1) |
| REMOTE_KEY(0x15, KEY_MENU) |
| REMOTE_KEY(0x16, KEY_TAB) |
| REMOTE_KEY(0x0c, KEY_CHANNELUP) |
| REMOTE_KEY(0x0d, KEY_CHANNELDOWN) |
| REMOTE_KEY(0x0e, KEY_VOLUMEUP) |
| REMOTE_KEY(0x0f, KEY_VOLUMEDOWN) |
| REMOTE_KEY(0x11, KEY_HOME) |
| REMOTE_KEY(0x1c, KEY_RIGHT) |
| REMOTE_KEY(0x1b, KEY_LEFT) |
| REMOTE_KEY(0x19, KEY_UP) |
| REMOTE_KEY(0x1a, KEY_DOWN) |
| REMOTE_KEY(0x1d, KEY_ENTER) |
| REMOTE_KEY(0x17, KEY_MUTE) |
| REMOTE_KEY(0x49, KEY_FINANCE) |
| REMOTE_KEY(0x43, KEY_BACK) |
| REMOTE_KEY(0x12, KEY_FN_F4) |
| REMOTE_KEY(0x14, KEY_FN_F5) |
| REMOTE_KEY(0x18, KEY_FN_F6) |
| REMOTE_KEY(0x59, KEY_INFO) |
| REMOTE_KEY(0x5a, KEY_STOPCD) |
| REMOTE_KEY(0x10, KEY_POWER) |
| REMOTE_KEY(0x42, KEY_PREVIOUSSONG) |
| REMOTE_KEY(0x44, KEY_NEXTSONG) |
| REMOTE_KEY(0x1e, KEY_REWIND) |
| REMOTE_KEY(0x4b, KEY_FASTFORWARD) |
| REMOTE_KEY(0x58, KEY_PLAYPAUSE) |
| REMOTE_KEY(0x46, KEY_PROPS) |
| REMOTE_KEY(0x40, KEY_UNDO) |
| REMOTE_KEY(0x38, KEY_SCROLLLOCK) |
| REMOTE_KEY(0x57, KEY_FN) |
| REMOTE_KEY(0x5b, KEY_FN_ESC) |
| REMOTE_KEY(0x54, KEY_RED) |
| REMOTE_KEY(0x4c, KEY_GREEN) |
| REMOTE_KEY(0x4e, KEY_YELLOW) |
| REMOTE_KEY(0x55, KEY_BLUE) |
| REMOTE_KEY(0x53, KEY_BLUETOOTH) |
| REMOTE_KEY(0x52, KEY_WLAN) |
| REMOTE_KEY(0x39, KEY_CAMERA) |
| REMOTE_KEY(0x41, KEY_SOUND) |
| REMOTE_KEY(0x0b, KEY_QUESTION) |
| REMOTE_KEY(0x00, KEY_CHAT) |
| REMOTE_KEY(0x13, KEY_SEARCH)>; |
| }; |
| map_2: map_2{ |
| mapname = "amlogic-remote-3"; |
| customcode = <0xbd02>; |
| release_delay = <80>; |
| size = <17>; |
| keymap = <REMOTE_KEY(0xca,103) |
| REMOTE_KEY(0xd2,108) |
| REMOTE_KEY(0x99,105) |
| REMOTE_KEY(0xc1,106) |
| REMOTE_KEY(0xce,97) |
| REMOTE_KEY(0x45,116) |
| REMOTE_KEY(0xc5,133) |
| REMOTE_KEY(0x80,113) |
| REMOTE_KEY(0xd0,15) |
| REMOTE_KEY(0xd6,125) |
| REMOTE_KEY(0x95,102) |
| REMOTE_KEY(0xdd,104) |
| REMOTE_KEY(0x8c,109) |
| REMOTE_KEY(0x89,131) |
| REMOTE_KEY(0x9c,130) |
| REMOTE_KEY(0x9a,120) |
| REMOTE_KEY(0xcd,121)>; |
| }; |
| map_3: map_3{ |
| mapname = "amlogic-remote-3"; |
| customcode = <0xa4e8>; /* Reference Remote Control */ |
| release_delay = <80>; |
| size = <45>; |
| keymap = < |
| REMOTE_KEY(0xc7, 200) /* power */ |
| REMOTE_KEY(0x93, 201) /* eject-->input source */ |
| REMOTE_KEY(0xb2, 202) /* usb */ |
| REMOTE_KEY(0xb8, 203) /* coaxial */ |
| REMOTE_KEY(0xb7, 204) /* aux */ |
| REMOTE_KEY(0x8a, 205) /* scan-->hdmi arc */ |
| REMOTE_KEY(0x96, 206) /* dimmer */ |
| REMOTE_KEY(0x90, 207) /* hdmi1 */ |
| REMOTE_KEY(0xa8, 208) /* hdmi2 */ |
| REMOTE_KEY(0x85, 209) /* mute */ |
| REMOTE_KEY(0x80, 210) /* vol+ */ |
| REMOTE_KEY(0x81, 211) /* vol- */ |
| REMOTE_KEY(0x61, 212) /* DAP */ |
| REMOTE_KEY(0x62, 213) /* BM */ |
| REMOTE_KEY(0x63, 214) /* DRC */ |
| REMOTE_KEY(0x64, 215) /* POST */ |
| REMOTE_KEY(0x65, 216) /* UPMIX */ |
| REMOTE_KEY(0x66, 217) /* VIRT */ |
| REMOTE_KEY(0x67, 218) /* LEGACY */ |
| REMOTE_KEY(0x68, 219) /* HFILT */ |
| REMOTE_KEY(0x69, 220) /* Loundness */ |
| REMOTE_KEY(0x60, 221) /* Audio_info */ |
| REMOTE_KEY(0xb1, 222) /* CD */ |
| REMOTE_KEY(0xb4, 223) /* CD */ |
| REMOTE_KEY(0xb9, 224) /* CD */ |
| REMOTE_KEY(0xab, 225) /* CD */ |
| REMOTE_KEY(0x91, 226) /* CD */ |
| REMOTE_KEY(0x92, 227) /* CD */ |
| REMOTE_KEY(0x89, 228) /* CD */ |
| REMOTE_KEY(0x88, 229) /* CD */ |
| REMOTE_KEY(0xa5, 230) /* CD */ |
| REMOTE_KEY(0x84, 231) /* CD */ |
| REMOTE_KEY(0x72, 232) /* CD */ |
| REMOTE_KEY(0x73, 233) /* CD */ |
| REMOTE_KEY(0x9a, 234) /* CD */ |
| REMOTE_KEY(0x9b, 235) /* CD */ |
| REMOTE_KEY(0xa0, 236) /* CD */ |
| REMOTE_KEY(0x71, 237) /* CD */ |
| REMOTE_KEY(0x74, 238) /* CD */ |
| REMOTE_KEY(0x75, 239) /* CD */ |
| REMOTE_KEY(0x7e, 240) /* CD */ |
| REMOTE_KEY(0x7f, 241) /* CD */ |
| REMOTE_KEY(0x7a, 242) /* CD */ |
| REMOTE_KEY(0xa7, 243) /* CD */ |
| REMOTE_KEY(0xa9, 244) /* CD */ |
| >; |
| }; |
| }; |