1*4882a593Smuzhiyun// SPDX-License-Identifier: (GPL-2.0+ OR MIT) 2*4882a593Smuzhiyun/* 3*4882a593Smuzhiyun * Copyright (c) 2019 BayLibre, SAS 4*4882a593Smuzhiyun * Author: Neil Armstrong <narmstrong@baylibre.com> 5*4882a593Smuzhiyun * Copyright (c) 2019 Christian Hewitt <christianshewitt@gmail.com> 6*4882a593Smuzhiyun */ 7*4882a593Smuzhiyun 8*4882a593Smuzhiyun/dts-v1/; 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun#include "meson-g12b-w400.dtsi" 11*4882a593Smuzhiyun#include <dt-bindings/sound/meson-g12a-tohdmitx.h> 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun/ { 14*4882a593Smuzhiyun compatible = "azw,gtking", "amlogic,g12b"; 15*4882a593Smuzhiyun model = "Beelink GT-King"; 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun spdif_dit: audio-codec-1 { 18*4882a593Smuzhiyun #sound-dai-cells = <0>; 19*4882a593Smuzhiyun compatible = "linux,spdif-dit"; 20*4882a593Smuzhiyun status = "okay"; 21*4882a593Smuzhiyun sound-name-prefix = "DIT"; 22*4882a593Smuzhiyun }; 23*4882a593Smuzhiyun 24*4882a593Smuzhiyun sound { 25*4882a593Smuzhiyun compatible = "amlogic,axg-sound-card"; 26*4882a593Smuzhiyun model = "G12B-GTKING"; 27*4882a593Smuzhiyun audio-aux-devs = <&tdmout_b>; 28*4882a593Smuzhiyun audio-routing = "TDMOUT_B IN 0", "FRDDR_A OUT 1", 29*4882a593Smuzhiyun "TDMOUT_B IN 1", "FRDDR_B OUT 1", 30*4882a593Smuzhiyun "TDMOUT_B IN 2", "FRDDR_C OUT 1", 31*4882a593Smuzhiyun "TDM_B Playback", "TDMOUT_B OUT", 32*4882a593Smuzhiyun "SPDIFOUT IN 0", "FRDDR_A OUT 3", 33*4882a593Smuzhiyun "SPDIFOUT IN 1", "FRDDR_B OUT 3", 34*4882a593Smuzhiyun "SPDIFOUT IN 2", "FRDDR_C OUT 3"; 35*4882a593Smuzhiyun 36*4882a593Smuzhiyun assigned-clocks = <&clkc CLKID_MPLL2>, 37*4882a593Smuzhiyun <&clkc CLKID_MPLL0>, 38*4882a593Smuzhiyun <&clkc CLKID_MPLL1>; 39*4882a593Smuzhiyun assigned-clock-parents = <0>, <0>, <0>; 40*4882a593Smuzhiyun assigned-clock-rates = <294912000>, 41*4882a593Smuzhiyun <270950400>, 42*4882a593Smuzhiyun <393216000>; 43*4882a593Smuzhiyun status = "okay"; 44*4882a593Smuzhiyun 45*4882a593Smuzhiyun dai-link-0 { 46*4882a593Smuzhiyun sound-dai = <&frddr_a>; 47*4882a593Smuzhiyun }; 48*4882a593Smuzhiyun 49*4882a593Smuzhiyun dai-link-1 { 50*4882a593Smuzhiyun sound-dai = <&frddr_b>; 51*4882a593Smuzhiyun }; 52*4882a593Smuzhiyun 53*4882a593Smuzhiyun dai-link-2 { 54*4882a593Smuzhiyun sound-dai = <&frddr_c>; 55*4882a593Smuzhiyun }; 56*4882a593Smuzhiyun 57*4882a593Smuzhiyun /* 8ch hdmi interface */ 58*4882a593Smuzhiyun dai-link-3 { 59*4882a593Smuzhiyun sound-dai = <&tdmif_b>; 60*4882a593Smuzhiyun dai-format = "i2s"; 61*4882a593Smuzhiyun dai-tdm-slot-tx-mask-0 = <1 1>; 62*4882a593Smuzhiyun dai-tdm-slot-tx-mask-1 = <1 1>; 63*4882a593Smuzhiyun dai-tdm-slot-tx-mask-2 = <1 1>; 64*4882a593Smuzhiyun dai-tdm-slot-tx-mask-3 = <1 1>; 65*4882a593Smuzhiyun mclk-fs = <256>; 66*4882a593Smuzhiyun 67*4882a593Smuzhiyun codec { 68*4882a593Smuzhiyun sound-dai = <&tohdmitx TOHDMITX_I2S_IN_B>; 69*4882a593Smuzhiyun }; 70*4882a593Smuzhiyun }; 71*4882a593Smuzhiyun 72*4882a593Smuzhiyun /* spdif hdmi or toslink interface */ 73*4882a593Smuzhiyun dai-link-4 { 74*4882a593Smuzhiyun sound-dai = <&spdifout>; 75*4882a593Smuzhiyun 76*4882a593Smuzhiyun codec-0 { 77*4882a593Smuzhiyun sound-dai = <&spdif_dit>; 78*4882a593Smuzhiyun }; 79*4882a593Smuzhiyun 80*4882a593Smuzhiyun codec-1 { 81*4882a593Smuzhiyun sound-dai = <&tohdmitx TOHDMITX_SPDIF_IN_A>; 82*4882a593Smuzhiyun }; 83*4882a593Smuzhiyun }; 84*4882a593Smuzhiyun 85*4882a593Smuzhiyun /* spdif hdmi interface */ 86*4882a593Smuzhiyun dai-link-5 { 87*4882a593Smuzhiyun sound-dai = <&spdifout_b>; 88*4882a593Smuzhiyun 89*4882a593Smuzhiyun codec { 90*4882a593Smuzhiyun sound-dai = <&tohdmitx TOHDMITX_SPDIF_IN_B>; 91*4882a593Smuzhiyun }; 92*4882a593Smuzhiyun }; 93*4882a593Smuzhiyun 94*4882a593Smuzhiyun /* hdmi glue */ 95*4882a593Smuzhiyun dai-link-6 { 96*4882a593Smuzhiyun sound-dai = <&tohdmitx TOHDMITX_I2S_OUT>; 97*4882a593Smuzhiyun 98*4882a593Smuzhiyun codec { 99*4882a593Smuzhiyun sound-dai = <&hdmi_tx>; 100*4882a593Smuzhiyun }; 101*4882a593Smuzhiyun }; 102*4882a593Smuzhiyun }; 103*4882a593Smuzhiyun}; 104*4882a593Smuzhiyun 105*4882a593Smuzhiyun&arb { 106*4882a593Smuzhiyun status = "okay"; 107*4882a593Smuzhiyun}; 108*4882a593Smuzhiyun 109*4882a593Smuzhiyun&clkc_audio { 110*4882a593Smuzhiyun status = "okay"; 111*4882a593Smuzhiyun}; 112*4882a593Smuzhiyun 113*4882a593Smuzhiyun&frddr_a { 114*4882a593Smuzhiyun status = "okay"; 115*4882a593Smuzhiyun}; 116*4882a593Smuzhiyun 117*4882a593Smuzhiyun&frddr_b { 118*4882a593Smuzhiyun status = "okay"; 119*4882a593Smuzhiyun}; 120*4882a593Smuzhiyun 121*4882a593Smuzhiyun&frddr_c { 122*4882a593Smuzhiyun status = "okay"; 123*4882a593Smuzhiyun}; 124*4882a593Smuzhiyun 125*4882a593Smuzhiyun&spdifout { 126*4882a593Smuzhiyun pinctrl-0 = <&spdif_out_h_pins>; 127*4882a593Smuzhiyun pinctrl-names = "default"; 128*4882a593Smuzhiyun status = "okay"; 129*4882a593Smuzhiyun}; 130*4882a593Smuzhiyun 131*4882a593Smuzhiyun&spdifout_b { 132*4882a593Smuzhiyun status = "okay"; 133*4882a593Smuzhiyun}; 134*4882a593Smuzhiyun 135*4882a593Smuzhiyun&tdmif_b { 136*4882a593Smuzhiyun status = "okay"; 137*4882a593Smuzhiyun}; 138*4882a593Smuzhiyun 139*4882a593Smuzhiyun&tdmout_b { 140*4882a593Smuzhiyun status = "okay"; 141*4882a593Smuzhiyun}; 142*4882a593Smuzhiyun 143*4882a593Smuzhiyun&tohdmitx { 144*4882a593Smuzhiyun status = "okay"; 145*4882a593Smuzhiyun}; 146