| // SPDX-License-Identifier: (GPL-2.0+ OR MIT) |
| /* |
| * Copyright (c) 2019 Amlogic, Inc. All rights reserved. |
| */ |
| |
| /dts-v1/; |
| |
| #include "meson-sm1.dtsi" |
| #include "partition_mbox_normal.dtsi" |
| |
| / { |
| model = "Amlogic"; |
| amlogic-dt-id = "sm1_ac213_2g"; |
| model = "Amlogic Meson SM1 AC213"; |
| compatible = "amlogic, sm1"; |
| |
| aliases { |
| serial0 = &uart_AO; |
| serial1 = &uart_A; |
| serial2 = &uart_B; |
| serial3 = &uart_C; |
| serial4 = &uart_AO_B; |
| i2c0 = &i2c0; |
| i2c1 = &i2c1; |
| i2c2 = &i2c2; |
| i2c3 = &i2c3; |
| i2c4 = &i2c_AO; |
| spi0 = &spifc; |
| spi1 = &spicc0; |
| spi2 = &spicc1; |
| tsensor0 = &p_tsensor; |
| tsensor1 = &d_tsensor; |
| }; |
| chosen { |
| stdout-path = "serial0:115200n8"; |
| }; |
| memory@0 { |
| device_type = "memory"; |
| linux,usable-memory = <0x0 0x000000 0x0 0x80000000>; |
| }; |
| |
| reserved-memory { |
| #address-cells = <2>; |
| #size-cells = <2>; |
| ranges; |
| secmon_reserved:linux,secmon { |
| compatible = "shared-dma-pool"; |
| reusable; |
| size = <0x0 0x400000>; |
| alignment = <0x0 0x400000>; |
| alloc-ranges = <0x0 0x05000000 0x0 0x400000>; |
| }; |
| |
| ramoops@0x07400000 { |
| compatible = "ramoops"; |
| reg = <0x0 0x07400000 0x0 0x00100000>; |
| record-size = <0x20000>; |
| console-size = <0x20000>; |
| ftrace-size = <0x20000>; |
| pmsg-size = <0x0>; |
| }; |
| |
| logo_reserved:linux,meson-fb { |
| compatible = "shared-dma-pool"; |
| reusable; |
| size = <0x0 0x800000>; |
| alignment = <0x0 0x400000>; |
| alloc-ranges = <0x0 0x3f800000 0x0 0x800000>; |
| }; |
| |
| ion_cma_reserved:linux,ion-dev { |
| compatible = "shared-dma-pool"; |
| reusable; |
| size = <0x0 0x8000000>; |
| alignment = <0x0 0x400000>; |
| }; |
| /* POST PROCESS MANAGER */ |
| ppmgr_reserved:linux,ppmgr { |
| compatible = "shared-dma-pool"; |
| size = <0x0 0x0>; |
| }; |
| |
| codec_mm_cma:linux,codec_mm_cma { |
| compatible = "shared-dma-pool"; |
| reusable; |
| /* ion_codec_mm max can alloc size 80M*/ |
| size = <0x0 0x13400000>; |
| alignment = <0x0 0x400000>; |
| linux,contiguous-region; |
| }; |
| /* codec shared reserved */ |
| codec_mm_reserved:linux,codec_mm_reserved { |
| compatible = "amlogic, codec-mm-reserved"; |
| size = <0x0 0x0>; |
| alignment = <0x0 0x100000>; |
| //no-map; |
| }; |
| |
| picdec_cma_reserved:linux,picdec { |
| compatible = "shared-dma-pool"; |
| reusable; |
| size = <0x0>; |
| alignment = <0x0>; |
| linux,contiguous-region; |
| }; |
| }; |
| |
| codec_mm { |
| compatible = "amlogic, codec, mm"; |
| memory-region = <&codec_mm_cma &codec_mm_reserved>; |
| dev_name = "codec_mm"; |
| status = "okay"; |
| }; |
| |
| picdec { |
| compatible = "amlogic, picdec"; |
| memory-region = <&picdec_cma_reserved>; |
| dev_name = "picdec"; |
| status = "okay"; |
| }; |
| |
| main_12v: regulator-main_12v { |
| compatible = "regulator-fixed"; |
| regulator-name = "12V"; |
| regulator-min-microvolt = <12000000>; |
| regulator-max-microvolt = <12000000>; |
| regulator-always-on; |
| }; |
| |
| vcc_3v3: regulator-vcc_3v3 { |
| compatible = "regulator-fixed"; |
| regulator-name = "VCC_3V3"; |
| regulator-min-microvolt = <3300000>; |
| regulator-max-microvolt = <3300000>; |
| vin-supply = <&vddao_3v3>; |
| regulator-always-on; |
| }; |
| |
| vcc_5v: regulator-vcc_5v { |
| compatible = "regulator-fixed"; |
| regulator-name = "VCC5V"; |
| regulator-min-microvolt = <5000000>; |
| regulator-max-microvolt = <5000000>; |
| vin-supply = <&main_12v>; |
| regulator-always-on; |
| }; |
| |
| vddao_3v3: regulator-vddao_3v3 { |
| compatible = "regulator-fixed"; |
| regulator-name = "VDDAO_3V3"; |
| regulator-min-microvolt = <3300000>; |
| regulator-max-microvolt = <3300000>; |
| vin-supply = <&main_12v>; |
| regulator-always-on; |
| }; |
| |
| vddio_ao18: regulator-vddio_ao18 { |
| compatible = "regulator-fixed"; |
| regulator-name = "VDDIO_AO18"; |
| regulator-min-microvolt = <1800000>; |
| regulator-max-microvolt = <1800000>; |
| vin-supply = <&vddao_3v3>; |
| regulator-always-on; |
| }; |
| |
| vddio_boot: regulator-vddio_boot { |
| compatible = "regulator-fixed"; |
| regulator-name = "VDDIO_BOOT"; |
| regulator-min-microvolt = <1800000>; |
| regulator-max-microvolt = <1800000>; |
| vin-supply = <&vddao_3v3>; |
| regulator-always-on; |
| }; |
| |
| /*DCDC for MP8756GD*/ |
| cpu_opp_table0: cpu_opp_table0 { |
| compatible = "operating-points-v2"; |
| opp-shared; |
| |
| opp00 { |
| opp-hz = /bits/ 64 <100000000>; |
| opp-microvolt = <731000>; |
| }; |
| opp01 { |
| opp-hz = /bits/ 64 <250000000>; |
| opp-microvolt = <731000>; |
| }; |
| opp02 { |
| opp-hz = /bits/ 64 <500000000>; |
| opp-microvolt = <731000>; |
| }; |
| opp03 { |
| opp-hz = /bits/ 64 <667000000>; |
| opp-microvolt = <731000>; |
| }; |
| opp04 { |
| opp-hz = /bits/ 64 <1000000000>; |
| opp-microvolt = <731000>; |
| }; |
| opp05 { |
| opp-hz = /bits/ 64 <1200000000>; |
| opp-microvolt = <731000>; |
| }; |
| opp06 { |
| opp-hz = /bits/ 64 <1398000000>; |
| opp-microvolt = <761000>; |
| }; |
| opp07 { |
| opp-hz = /bits/ 64 <1512000000>; |
| opp-microvolt = <791000>; |
| }; |
| opp08 { |
| opp-hz = /bits/ 64 <1608000000>; |
| opp-microvolt = <831000>; |
| }; |
| opp09 { |
| opp-hz = /bits/ 64 <1704000000>; |
| opp-microvolt = <861000>; |
| }; |
| opp10 { |
| opp-hz = /bits/ 64 <1800000000>; |
| opp-microvolt = <981000>; |
| }; |
| }; |
| |
| cpufreq-meson { |
| compatible = "amlogic, cpufreq-meson"; |
| pinctrl-names = "default"; |
| pinctrl-0 = <&pwm_ao_d_pins3>; |
| status = "okay"; |
| }; |
| |
| videocapture_0 { |
| compatible = "amlogic, videocapture"; |
| dev_name = "videocapture"; |
| status = "okay"; |
| videocapture_id = <0>; |
| cma_mode = <1>; |
| }; |
| |
| videocapture_1 { |
| compatible = "amlogic, videocapture"; |
| dev_name = "videocapture"; |
| status = "okay"; |
| videocapture_id = <1>; |
| cma_mode = <1>; |
| }; |
| |
| dvb { |
| compatible = "amlogic, dvb"; |
| dev_name = "dvb"; |
| status = "ok"; |
| |
| dmx = <&demux>; |
| key_endia = <1>; |
| add_s2p2 = <1>; |
| add_ts_in = <1>; |
| add_asyncfifo = <1>; |
| /* |
| * ts0 = "serial"; |
| * ts0_control = <0x800>; |
| * ts0_invert = <0>; |
| * pinctrl-names = "s_ts0"; |
| * pinctrl-0 = <&dvb_s_ts0_pins>; |
| */ |
| }; |
| dvbfe { |
| compatible = "amlogic, dvbfe"; |
| dev_name = "dvbfe"; |
| dtv_demod0 = "Avl6762"; |
| dtv_demod0_i2c_adap = <&i2c3>; |
| dtv_demod0_i2c_addr = <0x14>; |
| dtv_demod0_reset_value = <0>; |
| dtv_demod0_reset_gpio = <&gpio GPIOZ_10 GPIO_ACTIVE_HIGH>; |
| dtv_demod0_ant_poweron_value = <0>; |
| dtv_demod0_ant_power_gpio = <&gpio GPIOH_5 GPIO_ACTIVE_HIGH>; |
| dtv_demod0_tuner_type = <52>; |
| fe0_dtv_demod = <0>; |
| fe0_ts = <0>; |
| fe0_dev = <0>; |
| }; |
| |
| gpioleds { |
| compatible = "gpio-leds"; |
| status = "okay"; |
| |
| sys_led { |
| label="sys_led"; |
| gpios=<&gpio_ao GPIOAO_11 GPIO_ACTIVE_HIGH>; |
| default-state ="on"; |
| }; |
| }; |
| |
| gpio_keypad{ |
| compatible = "amlogic, gpio_keypad"; |
| status = "okay"; |
| scan_period = <20>; |
| key_num = <1>; |
| key_name = "power"; |
| key_code = <116>; |
| key-gpios = <&gpio_ao GPIOAO_3 GPIO_ACTIVE_HIGH>; |
| detect_mode = <0>;/*0:polling mode, 1:irq mode*/ |
| }; |
| |
| adc_keypad { |
| compatible = "amlogic, adc_keypad"; |
| status = "okay"; |
| key_name = "vol-", "vol+", "enter"; |
| key_num = <3>; |
| io-channels = <&saradc 2>; |
| io-channel-names = "key-chan-2"; |
| key_chan = <2 2 2>; |
| key_code = <114 115 28>; |
| key_val = <143 266 389>; //val=voltage/1800mV*1023 |
| key_tolerance = <40 40 40>; |
| }; |
| |
| /* Audio Related start */ |
| pdm_codec:pdm_codec{ |
| #sound-dai-cells = <0>; |
| compatible = "amlogic, pdm_dummy_codec"; |
| status = "okay"; |
| }; |
| |
| dummy_codec:dummy_codec{ |
| #sound-dai-cells = <0>; |
| compatible = "amlogic, aml_dummy_codec"; |
| status = "okay"; |
| }; |
| |
| amlogic_codec:t9015{ |
| #sound-dai-cells = <0>; |
| compatible = "amlogic, aml_codec_T9015"; |
| reg = <0x0 0xFF632000 0x0 0x2000>; |
| is_auge_used = <1>; /* meson or auge chipset used */ |
| tocodec_inout = <1>; |
| tdmout_index = <1>; |
| ch0_sel = <0>; |
| ch1_sel = <1>; |
| |
| status = "okay"; |
| }; |
| |
| auge_sound { |
| compatible = "amlogic, g12a-sound-card"; |
| aml-audio-card,name = "AML-AUGESOUND"; |
| |
| /*avout mute gpio*/ |
| avout_mute-gpios = <&gpio_ao GPIOAO_2 GPIO_ACTIVE_HIGH>; |
| |
| aml-audio-card,dai-link@0 { |
| format = "dsp_a"; |
| mclk-fs = <512>; |
| //continuous-clock; |
| //bitclock-inversion; |
| //frame-inversion; |
| /* master mode */ |
| bitclock-master = <&tdma>; |
| frame-master = <&tdma>; |
| /* slave mode */ |
| /* |
| * bitclock-master = <&tdmacodec>; |
| * frame-master = <&tdmacodec>; |
| */ |
| suffix-name = "alsaPORT-pcm"; |
| tdmacpu: cpu { |
| sound-dai = <&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>; |
| }; |
| }; |
| |
| aml-audio-card,dai-link@1 { |
| format = "i2s";// "dsp_a"; |
| mclk-fs = <256>; |
| //continuous-clock; |
| //bitclock-inversion; |
| //frame-inversion; |
| /* master mode */ |
| bitclock-master = <&tdmb>; |
| frame-master = <&tdmb>; |
| /* slave mode */ |
| //bitclock-master = <&tdmbcodec>; |
| //frame-master = <&tdmbcodec>; |
| /* suffix-name, sync with android audio hal |
| * what's the dai link used for |
| */ |
| suffix-name = "alsaPORT-i2s"; |
| cpu { |
| sound-dai = <&tdmb>; |
| dai-tdm-slot-tx-mask = <1 1>; |
| dai-tdm-slot-rx-mask = <1 1>; |
| dai-tdm-slot-num = <2>; |
| /* |
| * 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 = <12288000>; |
| }; |
| tdmbcodec: codec { |
| sound-dai = <&amlogic_codec &ad82584f_62>; |
| }; |
| }; |
| |
| aml-audio-card,dai-link@2 { |
| format = "i2s"; |
| mclk-fs = <256>; |
| //continuous-clock; |
| //bitclock-inversion; |
| //frame-inversion; |
| /* master mode */ |
| bitclock-master = <&tdmc>; |
| frame-master = <&tdmc>; |
| /* slave mode */ |
| //bitclock-master = <&tdmccodec>; |
| //frame-master = <&tdmccodec>; |
| /* suffix-name, sync with android audio hal used for */ |
| //suffix-name = "alsaPORT-tdm"; |
| cpu { |
| sound-dai = <&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>; |
| }; |
| tdmccodec: codec { |
| sound-dai = <&dummy_codec>; |
| }; |
| }; |
| |
| aml-audio-card,dai-link@3 { |
| mclk-fs = <64>; |
| /* suffix-name, sync with android audio hal |
| * what's the dai link used for |
| */ |
| suffix-name = "alsaPORT-pdm"; |
| cpu { |
| sound-dai = <&pdm>; |
| }; |
| codec { |
| sound-dai = <&pdm_codec>; |
| }; |
| }; |
| |
| aml-audio-card,dai-link@4 { |
| mclk-fs = <128>; |
| /* suffix-name, sync with android audio hal used for */ |
| suffix-name = "alsaPORT-spdif"; |
| cpu { |
| sound-dai = <&spdifa>; |
| system-clock-frequency = <6144000>; |
| }; |
| codec { |
| sound-dai = <&dummy_codec>; |
| }; |
| }; |
| |
| /* spdif_b to hdmi, only playback */ |
| aml-audio-card,dai-link@5 { |
| mclk-fs = <128>; |
| continuous-clock; |
| /* suffix-name, sync with android audio hal |
| * what's the dai link used for |
| */ |
| suffix-name = "alsaPORT-spdifb"; |
| cpu { |
| sound-dai = <&spdifb>; |
| system-clock-frequency = <6144000>; |
| }; |
| codec { |
| sound-dai = <&dummy_codec>; |
| }; |
| }; |
| }; |
| /* Audio Related end */ |
| }; |
| |
| &pwm_AO_cd { |
| status = "okay"; |
| }; |
| |
| &uart_AO { |
| status = "okay"; |
| }; |
| |
| &dwc2_a { |
| status = "okay"; |
| /** 0: normal, 1: otg+dwc3 host only, 2: otg+dwc3 device only*/ |
| controller-type = <3>; |
| }; |
| |
| &usb0 { |
| status = "okay"; |
| }; |
| |
| &usb2_phy_v2 { |
| status = "okay"; |
| portnum = <2>; |
| }; |
| |
| &usb3_phy_v2 { |
| status = "okay"; |
| portnum = <1>; |
| otg = <1>; |
| gpio-vbus-power = "GPIOH_6"; |
| gpios = <&gpio GPIOH_6 GPIO_ACTIVE_HIGH>; |
| }; |
| |
| &pcie { |
| reset-gpio = <&gpio GPIOX_7 GPIO_ACTIVE_HIGH>; |
| status = "disabled"; |
| }; |
| |
| &i2c0 { |
| status = "disabled"; |
| }; |
| |
| &i2c1 { |
| status = "disabled"; |
| }; |
| |
| &i2c2 { |
| status = "disabled"; |
| }; |
| |
| &i2c3 { |
| status = "okay"; |
| pinctrl-names = "default"; |
| pinctrl-0 = <&i2c3_master_pins2>; |
| clock-frequency = <100000>; /* default 100k */ |
| |
| /* for ref board */ |
| ad82584f_62: ad82584f_62@62 { |
| compatible = "ESMT, ad82584f"; |
| #sound-dai-cells = <0>; |
| reg = <0x31>; |
| status = "okay"; |
| reset_pin = <&gpio GPIOA_5 0>; |
| no_mclk; |
| }; |
| }; |
| |
| &i2c_AO { |
| status = "disabled"; |
| }; |
| |
| &spifc { |
| status = "disabled"; |
| pinctrl-names = "default"; |
| pinctrl-0 = <&spifc_pins>; |
| spi-nand@0 { |
| compatible = "spi-nand"; |
| status = "disabled"; |
| reg = <0>; |
| spi-max-frequency = <16000000>; |
| }; |
| }; |
| |
| &spicc1 { |
| status = "disabled"; |
| pinctrl-names = "default"; |
| pinctrl-0 = <&spicc1_pins>; |
| cs-gpios = <&gpio GPIOH_6 0>; |
| }; |
| |
| /* Audio Related start */ |
| &audiobus { |
| tdma: tdm@0 { |
| compatible = "amlogic, sm1-snd-tdma"; |
| #sound-dai-cells = <0>; |
| dai-tdm-lane-slot-mask-in = <0 1>; |
| dai-tdm-oe-lane-slot-mask-out = <1 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>; |
| |
| status = "okay"; |
| }; |
| |
| tdmb: tdm@1 { |
| compatible = "amlogic, sm1-snd-tdmb"; |
| #sound-dai-cells = <0>; |
| dai-tdm-lane-slot-mask-in = <0 1 0 0>; |
| dai-tdm-lane-slot-mask-out = <1 0 0 0>; |
| dai-tdm-clk-sel = <1>; |
| clocks = <&clkaudio CLKID_AUDIO_MCLK_B |
| &clkc CLKID_MPLL1 |
| &clkc CLKID_MPLL0 |
| &clkaudio CLKID_AUDIO_SPDIFOUT_A>; |
| clock-names = "mclk", "clk_srcpll", |
| "samesource_srcpll", "samesource_clk"; |
| pinctrl-names = "tdm_pins"; |
| pinctrl-0 = <&tdmb_mclk &tdmout_b &tdmin_b>; |
| |
| mclk_pad = <0>; /* 0: mclk_0; 1: mclk_1 */ |
| |
| /* |
| * 0: tdmout_a; |
| * 1: tdmout_b; |
| * 2: tdmout_c; |
| * 3: spdifout; |
| * 4: spdifout_b; |
| */ |
| samesource_sel = <3>; |
| |
| status = "okay"; |
| }; |
| |
| tdmc: tdm@2 { |
| compatible = "amlogic, sm1-snd-tdmc"; |
| #sound-dai-cells = <0>; |
| dai-tdm-lane-slot-mask-in = <1 0 0 0>; |
| #dai-tdm-lane-slot-mask-out = <1 0 1 1>; |
| #dai-tdm-lane-oe-slot-mask-in = <0 0 0 0>; |
| #dai-tdm-lane-oe-slot-mask-out = <1 0 0 0>; |
| 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 &tdmin_c>; |
| mclk_pad = <0>; /* 0: mclk_0; 1: mclk_1 */ |
| status = "okay"; |
| }; |
| |
| tdmlb:tdm@3 { |
| compatible = "amlogic, sm1-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/SM1 |
| * 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"; |
| }; |
| |
| spdifa: spdif@0 { |
| compatible = "amlogic, sm1-snd-spdif-a"; |
| #sound-dai-cells = <0>; |
| clocks = <&clkc CLKID_MPLL0 |
| &clkc CLKID_FCLK_DIV4 |
| &clkaudio CLKID_AUDIO_GATE_SPDIFIN |
| &clkaudio CLKID_AUDIO_GATE_SPDIFOUT_A |
| &clkaudio CLKID_AUDIO_SPDIFIN |
| &clkaudio CLKID_AUDIO_SPDIFOUT_A>; |
| clock-names = "sysclk", "fixed_clk", "gate_spdifin", |
| "gate_spdifout", "clk_spdifin", "clk_spdifout"; |
| interrupts = |
| <GIC_SPI 151 IRQ_TYPE_EDGE_RISING>; |
| |
| interrupt-names = "irq_spdifin"; |
| pinctrl-names = "spdif_pins"; |
| pinctrl-0 = <&spdifout &spdifin>; |
| |
| status = "okay"; |
| }; |
| |
| spdifb: spdif@1 { |
| compatible = "amlogic, sm1-snd-spdif-b"; |
| #sound-dai-cells = <0>; |
| clocks = <&clkc CLKID_MPLL0 /*CLKID_HIFI_PLL*/ |
| &clkaudio CLKID_AUDIO_GATE_SPDIFOUT_B |
| &clkaudio CLKID_AUDIO_SPDIFOUT_B>; |
| clock-names = "sysclk", |
| "gate_spdifout", "clk_spdifout"; |
| |
| status = "okay"; |
| }; |
| |
| pdm: pdm { |
| compatible = "amlogic, sm1-snd-pdm"; |
| #sound-dai-cells = <0>; |
| |
| clocks = <&clkaudio CLKID_AUDIO_GATE_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>; |
| |
| /* mode 0~4, defalut:1 */ |
| filter_mode = <1>; |
| |
| status = "okay"; |
| }; |
| |
| earc:earc { |
| compatible = "amlogic, sm1-snd-earc"; |
| #sound-dai-cells = <0>; |
| |
| clocks = <&clkaudio CLKID_AUDIO_GATE_EARCRX |
| &clkaudio CLKID_EARCRX_CMDC |
| &clkaudio CLKID_EARCRX_DMAC |
| &clkc CLKID_FCLK_DIV5 |
| &clkc CLKID_FCLK_DIV3 |
| >; |
| clock-names = "rx_gate", |
| "rx_cmdc", |
| "rx_dmac", |
| "rx_cmdc_srcpll", |
| "rx_dmac_srcpll"; |
| |
| interrupts = < |
| GIC_SPI 88 IRQ_TYPE_EDGE_RISING |
| GIC_SPI 87 IRQ_TYPE_EDGE_RISING |
| >; |
| interrupt-names = "rx_cmdc", "rx_dmac"; |
| |
| status = "disabled"; |
| }; |
| |
| }; /* end of audiobus */ |
| /* Audio Related end */ |
| |
| &pinctrl_periphs { |
| /* Audio Related start */ |
| tdmout_a: tdmout_a { |
| mux { /* GPIOX_11, GPIOX_10, GPIOX_9 */ |
| groups = "tdm_a_sclk", |
| "tdm_a_fs", |
| "tdm_a_dout0"; |
| function = "tdm_a"; |
| }; |
| }; |
| |
| tdmin_a: tdmin_a { |
| mux { /* GPIOX_8 */ |
| groups = "tdm_a_din1"; |
| function = "tdm_a"; |
| }; |
| }; |
| |
| tdmb_mclk: tdmb_mclk { |
| mux { |
| groups = "mclk0_a"; |
| function = "mclk0"; |
| drive-strength = <2>; |
| }; |
| }; |
| tdmout_b: tdmout_b { |
| mux { /* GPIOA_1, GPIOA_2, GPIOA_3 */ |
| groups = "tdm_b_sclk", |
| "tdm_b_fs", |
| "tdm_b_dout0"; |
| function = "tdm_b"; |
| drive-strength = <2>; |
| }; |
| }; |
| |
| tdmin_b:tdmin_b { |
| mux { /* GPIOA_4 */ |
| groups = "tdm_b_din1"; |
| function = "tdm_b"; |
| drive-strength = <2>; |
| }; |
| }; |
| |
| tdmc_mclk: tdmc_mclk { |
| mux { /* GPIOA_11 */ |
| groups = "mclk1_a"; |
| function = "mclk1"; |
| }; |
| }; |
| |
| tdmout_c:tdmout_c { |
| mux { /* GPIOA_12, GPIOA_13 */ |
| groups = "tdm_c_sclk_a", |
| "tdm_c_fs_a"; |
| function = "tdm_c"; |
| }; |
| }; |
| |
| tdmin_c:tdmin_c { |
| mux { /* GPIOA_10 */ |
| groups = "tdm_c_din0_a"; |
| function = "tdm_c"; |
| }; |
| }; |
| |
| spdifin: spdifin { |
| mux {/* GPIOH_5 */ |
| groups = "spdif_in_h"; |
| function = "spdif_in"; |
| }; |
| }; |
| |
| pdmin: pdmin { |
| mux { /* GPIOA_5, GPIOA_6, GPIOA_8, GPIOA_9, GPIOA_7 */ |
| groups = "pdm_din0_a", |
| "pdm_din1_a", |
| "pdm_din2_a", |
| /*"pdm_din3_a",*/ |
| "pdm_dclk_a"; |
| function = "pdm"; |
| }; |
| }; |
| |
| spdifout: spdifout { |
| mux { /* GPIOH_4 */ |
| groups = "spdif_out_h"; |
| function = "spdif_out"; |
| }; |
| }; |
| /* Audio Related end */ |
| |
| }; /* end of pinctrl_periphs */ |
| |
| |
| /* emmc storage */ |
| &sd_emmc_c { |
| status = "okay"; |
| pinctrl-0 = <&emmc_pins>; |
| pinctrl-1 = <&emmc_clk_gate_pins>; |
| pinctrl-names = "default", "clk-gate"; |
| bus-width = <8>; |
| cap-sd-highspeed; |
| cap-mmc-highspeed; |
| cap-mmc-hw-reset; |
| max-frequency = <200000000>; |
| non-removable; |
| disable-wp; |
| card_type = <1>;/*emmc:1,sdcard:2,sdio:3*/ |
| //mmc-ddr-1_8v; |
| mmc-hs200-1_8v; |
| mmc-hs400-1_8v; |
| |
| vmmc-supply = <&vcc_3v3>; |
| vqmmc-supply = <&vddio_boot>; |
| }; |
| |
| /* SD card */ |
| &sd_emmc_b { |
| status = "okay"; |
| pinctrl-0 = <&sdcard_pins>; |
| pinctrl-1 = <&sdcard_clk_gate_pins>; |
| pinctrl-2 = <&sd_1bit_pins>; |
| pinctrl-3 = <&sd_to_ao_uart_clr_pins |
| &sdcard_clk_gate_pins &ao_to_sd_uart_pins>; |
| pinctrl-4 = <&sd_to_ao_uart_clr_pins |
| &sd_1bit_pins &ao_to_sd_uart_pins>; |
| pinctrl-5 = <&sdcard_pins &sd_to_ao_uart_pins>; |
| pinctrl-6 = <&sd_to_ao_uart_clr_pins |
| &ao_to_sd_uart_pins>; |
| pinctrl-7 = <&sdcard_pins &sd_to_ao_uart_pins>; |
| pinctrl-8 = <&sd_to_ao_uart_clr_pins |
| &ao_to_sd_uart_pins>; |
| pinctrl-names = "sd_default", |
| "clk-gate", |
| "sd_1bit_pins", |
| "sd_clk_cmd_uart_pins", |
| "sd_1bit_uart_pins", |
| "sd_to_ao_uart_pins", |
| "ao_to_sd_uart_pins", |
| "sd_to_ao_jtag_pins", |
| "ao_to_sd_jtag_pins"; |
| bus-width = <4>; |
| cap-sd-highspeed; |
| max-frequency = <200000000>; |
| disable-wp; |
| cd-gpios = <&gpio GPIOC_6 GPIO_ACTIVE_HIGH>; |
| dat1-gpios = <&gpio GPIOC_1 GPIO_ACTIVE_HIGH>; |
| dat3-gpios = <&gpio GPIOC_3 GPIO_ACTIVE_HIGH>; |
| cd-inverted; |
| card_type = <5>; |
| |
| vmmc-supply = <&vddao_3v3>; |
| vqmmc-supply = <&vddio_boot>; |
| }; |
| |
| /*sdio*/ |
| &sd_emmc_a { |
| status = "okay"; |
| pinctrl-0 = <&sdio_pins>; |
| pinctrl-1 = <&sdio_clk_gate_pins>; |
| pinctrl-names = "default", "clk-gate"; |
| bus-width = <4>; |
| cap-sd-highspeed; |
| sd-uhs-sdr12; |
| sd-uhs-sdr25; |
| sd-uhs-sdr50; |
| sd-uhs-sdr104; |
| non-removable; |
| max-frequency = <200000000>; |
| disable-wp; |
| cap-sdio-irq; |
| keep-power-in-suspend; |
| card_type = <3>; |
| |
| vmmc-supply = <&vddao_3v3>; |
| vqmmc-supply = <&vddio_boot>; |
| }; |
| |
| ðmac { |
| status = "okay"; |
| pinctrl-names = "internal_eth_pins"; |
| pinctrl-0 = <&internal_eth_pins>; |
| mc_val = <0x4be04>; |
| internal_phy=<1>; |
| }; |
| |
| &saradc { |
| status = "okay"; |
| vref-supply = <&vddio_ao18>; |
| }; |
| |
| &mtd_nand { |
| status = "disabled"; |
| partition = <&nand_partitions>; |
| 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>; |
| }; |
| logo{ |
| offset=<0x0 0x0>; |
| size=<0x0 0x200000>; |
| }; |
| recovery{ |
| offset=<0x0 0x0>; |
| size=<0x0 0x1000000>; |
| }; |
| boot{ |
| offset=<0x0 0x0>; |
| size=<0x0 0x4000000>; |
| }; |
| system{ |
| offset=<0x0 0x0>; |
| size=<0x0 0x11800000>;/*280M*/ /*<0x0 0x4000000>;//64M*/ |
| }; |
| data{ |
| offset=<0xffffffff 0xffffffff>; |
| size=<0x0 0x0>; |
| }; |
| }; |
| }; |
| |
| &cvbsout { |
| status = "disabled"; |
| /* performance: reg_address, reg_value */ |
| /* g12a */ |
| performance = <0x1bf0 0x9 |
| 0x1b56 0x333 |
| 0x1b12 0x8080 |
| 0x1b05 0xfd |
| 0x1c59 0xf850 |
| 0xffff 0x0>; /* ending flag */ |
| performance_sarft = <0x1bf0 0x9 |
| 0x1b56 0x333 |
| 0x1b12 0x0 |
| 0x1b05 0x9 |
| 0x1c59 0xfc48 |
| 0xffff 0x0>; /* ending flag */ |
| performance_revB_telecom = <0x1bf0 0x9 |
| 0x1b56 0x546 |
| 0x1b12 0x8080 |
| 0x1b05 0x9 |
| 0x1c59 0xf850 |
| 0xffff 0x0>; /* ending flag */ |
| }; |
| |
| &meson_fb { |
| status = "okay"; |
| display_size_default = <1920 1080 1920 2160 32>; |
| mem_size = <0x00800000 0x1980000 0x100000 0x100000 0x800000>; |
| logo_addr = "0x3f800000"; |
| mem_alloc = <0>; |
| pxp_mode = <0>; /** 0:normal mode 1:pxp mode */ |
| }; |
| |
| &aml_bt { |
| status = "okay"; |
| }; |
| |
| &aml_wifi { |
| status = "okay"; |
| }; |
| |
| &pwm_ef { |
| status = "okay"; |
| }; |
| |
| &uart_A { |
| status = "okay"; |
| }; |