162306a36Sopenharmony_ci// SPDX-License-Identifier: (GPL-2.0+ OR MIT) 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright (c) 2019 BayLibre, SAS 462306a36Sopenharmony_ci * Author: Neil Armstrong <narmstrong@baylibre.com> 562306a36Sopenharmony_ci * Copyright (c) 2019 Christian Hewitt <christianshewitt@gmail.com> 662306a36Sopenharmony_ci */ 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci/dts-v1/; 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#include "meson-g12b-w400.dtsi" 1162306a36Sopenharmony_ci#include <dt-bindings/sound/meson-g12a-tohdmitx.h> 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci/ { 1462306a36Sopenharmony_ci compatible = "ugoos,am6", "amlogic,s922x", "amlogic,g12b"; 1562306a36Sopenharmony_ci model = "Ugoos AM6"; 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci spdif_dit: audio-codec-1 { 1862306a36Sopenharmony_ci #sound-dai-cells = <0>; 1962306a36Sopenharmony_ci compatible = "linux,spdif-dit"; 2062306a36Sopenharmony_ci status = "okay"; 2162306a36Sopenharmony_ci sound-name-prefix = "DIT"; 2262306a36Sopenharmony_ci }; 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_ci sound { 2562306a36Sopenharmony_ci compatible = "amlogic,axg-sound-card"; 2662306a36Sopenharmony_ci model = "UGOOS-AM6"; 2762306a36Sopenharmony_ci audio-aux-devs = <&tdmout_b>; 2862306a36Sopenharmony_ci audio-routing = "TDMOUT_B IN 0", "FRDDR_A OUT 1", 2962306a36Sopenharmony_ci "TDMOUT_B IN 1", "FRDDR_B OUT 1", 3062306a36Sopenharmony_ci "TDMOUT_B IN 2", "FRDDR_C OUT 1", 3162306a36Sopenharmony_ci "TDM_B Playback", "TDMOUT_B OUT", 3262306a36Sopenharmony_ci "SPDIFOUT IN 0", "FRDDR_A OUT 3", 3362306a36Sopenharmony_ci "SPDIFOUT IN 1", "FRDDR_B OUT 3", 3462306a36Sopenharmony_ci "SPDIFOUT IN 2", "FRDDR_C OUT 3"; 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ci assigned-clocks = <&clkc CLKID_MPLL2>, 3762306a36Sopenharmony_ci <&clkc CLKID_MPLL0>, 3862306a36Sopenharmony_ci <&clkc CLKID_MPLL1>; 3962306a36Sopenharmony_ci assigned-clock-parents = <0>, <0>, <0>; 4062306a36Sopenharmony_ci assigned-clock-rates = <294912000>, 4162306a36Sopenharmony_ci <270950400>, 4262306a36Sopenharmony_ci <393216000>; 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ci dai-link-0 { 4562306a36Sopenharmony_ci sound-dai = <&frddr_a>; 4662306a36Sopenharmony_ci }; 4762306a36Sopenharmony_ci 4862306a36Sopenharmony_ci dai-link-1 { 4962306a36Sopenharmony_ci sound-dai = <&frddr_b>; 5062306a36Sopenharmony_ci }; 5162306a36Sopenharmony_ci 5262306a36Sopenharmony_ci dai-link-2 { 5362306a36Sopenharmony_ci sound-dai = <&frddr_c>; 5462306a36Sopenharmony_ci }; 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci /* 8ch hdmi interface */ 5762306a36Sopenharmony_ci dai-link-3 { 5862306a36Sopenharmony_ci sound-dai = <&tdmif_b>; 5962306a36Sopenharmony_ci dai-format = "i2s"; 6062306a36Sopenharmony_ci dai-tdm-slot-tx-mask-0 = <1 1>; 6162306a36Sopenharmony_ci dai-tdm-slot-tx-mask-1 = <1 1>; 6262306a36Sopenharmony_ci dai-tdm-slot-tx-mask-2 = <1 1>; 6362306a36Sopenharmony_ci dai-tdm-slot-tx-mask-3 = <1 1>; 6462306a36Sopenharmony_ci mclk-fs = <256>; 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_ci codec { 6762306a36Sopenharmony_ci sound-dai = <&tohdmitx TOHDMITX_I2S_IN_B>; 6862306a36Sopenharmony_ci }; 6962306a36Sopenharmony_ci }; 7062306a36Sopenharmony_ci 7162306a36Sopenharmony_ci /* spdif hdmi or toslink interface */ 7262306a36Sopenharmony_ci dai-link-4 { 7362306a36Sopenharmony_ci sound-dai = <&spdifout>; 7462306a36Sopenharmony_ci 7562306a36Sopenharmony_ci codec-0 { 7662306a36Sopenharmony_ci sound-dai = <&spdif_dit>; 7762306a36Sopenharmony_ci }; 7862306a36Sopenharmony_ci 7962306a36Sopenharmony_ci codec-1 { 8062306a36Sopenharmony_ci sound-dai = <&tohdmitx TOHDMITX_SPDIF_IN_A>; 8162306a36Sopenharmony_ci }; 8262306a36Sopenharmony_ci }; 8362306a36Sopenharmony_ci 8462306a36Sopenharmony_ci /* spdif hdmi interface */ 8562306a36Sopenharmony_ci dai-link-5 { 8662306a36Sopenharmony_ci sound-dai = <&spdifout_b>; 8762306a36Sopenharmony_ci 8862306a36Sopenharmony_ci codec { 8962306a36Sopenharmony_ci sound-dai = <&tohdmitx TOHDMITX_SPDIF_IN_B>; 9062306a36Sopenharmony_ci }; 9162306a36Sopenharmony_ci }; 9262306a36Sopenharmony_ci 9362306a36Sopenharmony_ci /* hdmi glue */ 9462306a36Sopenharmony_ci dai-link-6 { 9562306a36Sopenharmony_ci sound-dai = <&tohdmitx TOHDMITX_I2S_OUT>; 9662306a36Sopenharmony_ci 9762306a36Sopenharmony_ci codec { 9862306a36Sopenharmony_ci sound-dai = <&hdmi_tx>; 9962306a36Sopenharmony_ci }; 10062306a36Sopenharmony_ci }; 10162306a36Sopenharmony_ci }; 10262306a36Sopenharmony_ci}; 10362306a36Sopenharmony_ci 10462306a36Sopenharmony_ci&arb { 10562306a36Sopenharmony_ci status = "okay"; 10662306a36Sopenharmony_ci}; 10762306a36Sopenharmony_ci 10862306a36Sopenharmony_ci&clkc_audio { 10962306a36Sopenharmony_ci status = "okay"; 11062306a36Sopenharmony_ci}; 11162306a36Sopenharmony_ci 11262306a36Sopenharmony_ci&frddr_a { 11362306a36Sopenharmony_ci status = "okay"; 11462306a36Sopenharmony_ci}; 11562306a36Sopenharmony_ci 11662306a36Sopenharmony_ci&frddr_b { 11762306a36Sopenharmony_ci status = "okay"; 11862306a36Sopenharmony_ci}; 11962306a36Sopenharmony_ci 12062306a36Sopenharmony_ci&frddr_c { 12162306a36Sopenharmony_ci status = "okay"; 12262306a36Sopenharmony_ci}; 12362306a36Sopenharmony_ci 12462306a36Sopenharmony_ci&ir { 12562306a36Sopenharmony_ci linux,rc-map-name = "rc-khadas"; 12662306a36Sopenharmony_ci}; 12762306a36Sopenharmony_ci 12862306a36Sopenharmony_ci&spdifout { 12962306a36Sopenharmony_ci pinctrl-0 = <&spdif_out_h_pins>; 13062306a36Sopenharmony_ci pinctrl-names = "default"; 13162306a36Sopenharmony_ci status = "okay"; 13262306a36Sopenharmony_ci}; 13362306a36Sopenharmony_ci 13462306a36Sopenharmony_ci&spdifout_b { 13562306a36Sopenharmony_ci status = "okay"; 13662306a36Sopenharmony_ci}; 13762306a36Sopenharmony_ci 13862306a36Sopenharmony_ci&tdmif_b { 13962306a36Sopenharmony_ci status = "okay"; 14062306a36Sopenharmony_ci}; 14162306a36Sopenharmony_ci 14262306a36Sopenharmony_ci&tdmout_b { 14362306a36Sopenharmony_ci status = "okay"; 14462306a36Sopenharmony_ci}; 14562306a36Sopenharmony_ci 14662306a36Sopenharmony_ci&tohdmitx { 14762306a36Sopenharmony_ci status = "okay"; 14862306a36Sopenharmony_ci}; 14962306a36Sopenharmony_ci 15062306a36Sopenharmony_ci&uart_A { 15162306a36Sopenharmony_ci status = "okay"; 15262306a36Sopenharmony_ci pinctrl-0 = <&uart_a_pins>, <&uart_a_cts_rts_pins>; 15362306a36Sopenharmony_ci pinctrl-names = "default"; 15462306a36Sopenharmony_ci uart-has-rtscts; 15562306a36Sopenharmony_ci 15662306a36Sopenharmony_ci bluetooth { 15762306a36Sopenharmony_ci compatible = "brcm,bcm43438-bt"; 15862306a36Sopenharmony_ci shutdown-gpios = <&gpio GPIOX_17 GPIO_ACTIVE_HIGH>; 15962306a36Sopenharmony_ci max-speed = <2000000>; 16062306a36Sopenharmony_ci clocks = <&wifi32k>; 16162306a36Sopenharmony_ci clock-names = "lpo"; 16262306a36Sopenharmony_ci }; 16362306a36Sopenharmony_ci}; 16462306a36Sopenharmony_ci 16562306a36Sopenharmony_ci&uart_AO { 16662306a36Sopenharmony_ci status = "okay"; 16762306a36Sopenharmony_ci pinctrl-0 = <&uart_ao_a_pins>; 16862306a36Sopenharmony_ci pinctrl-names = "default"; 16962306a36Sopenharmony_ci}; 17062306a36Sopenharmony_ci 17162306a36Sopenharmony_ci&usb { 17262306a36Sopenharmony_ci status = "okay"; 17362306a36Sopenharmony_ci dr_mode = "host"; 17462306a36Sopenharmony_ci vbus-supply = <&usb_pwr_en>; 17562306a36Sopenharmony_ci}; 17662306a36Sopenharmony_ci 17762306a36Sopenharmony_ci&usb2_phy0 { 17862306a36Sopenharmony_ci phy-supply = <&usb1_pow>; 17962306a36Sopenharmony_ci}; 18062306a36Sopenharmony_ci 18162306a36Sopenharmony_ci&usb2_phy1 { 18262306a36Sopenharmony_ci phy-supply = <&usb1_pow>; 18362306a36Sopenharmony_ci}; 184