10b928e4eSChristian Hewitt// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
20b928e4eSChristian Hewitt/*
30b928e4eSChristian Hewitt * Copyright (c) 2019 BayLibre, SAS
40b928e4eSChristian Hewitt * Author: Neil Armstrong <narmstrong@baylibre.com>
50b928e4eSChristian Hewitt * Copyright (c) 2019 Christian Hewitt <christianshewitt@gmail.com>
60b928e4eSChristian Hewitt */
70b928e4eSChristian Hewitt
80b928e4eSChristian Hewitt/dts-v1/;
90b928e4eSChristian Hewitt
100b928e4eSChristian Hewitt#include "meson-g12b-w400.dtsi"
110b928e4eSChristian Hewitt#include <dt-bindings/sound/meson-g12a-tohdmitx.h>
120b928e4eSChristian Hewitt
130b928e4eSChristian Hewitt/ {
140b928e4eSChristian Hewitt	compatible = "azw,gtking", "amlogic,g12b";
150b928e4eSChristian Hewitt	model = "Beelink GT-King Pro";
160b928e4eSChristian Hewitt
170b928e4eSChristian Hewitt	gpio-keys-polled {
180b928e4eSChristian Hewitt		compatible = "gpio-keys-polled";
190b928e4eSChristian Hewitt		#address-cells = <1>;
200b928e4eSChristian Hewitt		#size-cells = <0>;
210b928e4eSChristian Hewitt		poll-interval = <100>;
220b928e4eSChristian Hewitt
230b928e4eSChristian Hewitt		power-button {
240b928e4eSChristian Hewitt			label = "power";
250b928e4eSChristian Hewitt			linux,code = <KEY_POWER>;
260b928e4eSChristian Hewitt			gpios = <&gpio_ao GPIOAO_3 GPIO_ACTIVE_HIGH>;
270b928e4eSChristian Hewitt		};
280b928e4eSChristian Hewitt	};
290b928e4eSChristian Hewitt
300b928e4eSChristian Hewitt	leds {
310b928e4eSChristian Hewitt		compatible = "gpio-leds";
320b928e4eSChristian Hewitt
330b928e4eSChristian Hewitt		white {
340b928e4eSChristian Hewitt			label = "power:white";
350b928e4eSChristian Hewitt			gpios = <&gpio_ao GPIOAO_11 GPIO_ACTIVE_HIGH>;
360b928e4eSChristian Hewitt			default-state = "on";
370b928e4eSChristian Hewitt		};
380b928e4eSChristian Hewitt	};
390b928e4eSChristian Hewitt
400b928e4eSChristian Hewitt	sound {
410b928e4eSChristian Hewitt		compatible = "amlogic,axg-sound-card";
420b928e4eSChristian Hewitt		model = "G12B-GTKING-PRO";
430b928e4eSChristian Hewitt		audio-aux-devs = <&tdmout_b>;
440b928e4eSChristian Hewitt		audio-routing = "TDMOUT_B IN 0", "FRDDR_A OUT 1",
450b928e4eSChristian Hewitt				"TDMOUT_B IN 1", "FRDDR_B OUT 1",
460b928e4eSChristian Hewitt				"TDMOUT_B IN 2", "FRDDR_C OUT 1",
470b928e4eSChristian Hewitt				"TDM_B Playback", "TDMOUT_B OUT";
480b928e4eSChristian Hewitt
490b928e4eSChristian Hewitt		assigned-clocks = <&clkc CLKID_MPLL2>,
500b928e4eSChristian Hewitt				  <&clkc CLKID_MPLL0>,
510b928e4eSChristian Hewitt				  <&clkc CLKID_MPLL1>;
520b928e4eSChristian Hewitt		assigned-clock-parents = <0>, <0>, <0>;
530b928e4eSChristian Hewitt		assigned-clock-rates = <294912000>,
540b928e4eSChristian Hewitt				       <270950400>,
550b928e4eSChristian Hewitt				       <393216000>;
560b928e4eSChristian Hewitt		status = "okay";
570b928e4eSChristian Hewitt
580b928e4eSChristian Hewitt		dai-link-0 {
590b928e4eSChristian Hewitt			sound-dai = <&frddr_a>;
600b928e4eSChristian Hewitt		};
610b928e4eSChristian Hewitt
620b928e4eSChristian Hewitt		dai-link-1 {
630b928e4eSChristian Hewitt			sound-dai = <&frddr_b>;
640b928e4eSChristian Hewitt		};
650b928e4eSChristian Hewitt
660b928e4eSChristian Hewitt		dai-link-2 {
670b928e4eSChristian Hewitt			sound-dai = <&frddr_c>;
680b928e4eSChristian Hewitt		};
690b928e4eSChristian Hewitt
700b928e4eSChristian Hewitt		/* 8ch hdmi interface */
710b928e4eSChristian Hewitt		dai-link-3 {
720b928e4eSChristian Hewitt			sound-dai = <&tdmif_b>;
730b928e4eSChristian Hewitt			dai-format = "i2s";
740b928e4eSChristian Hewitt			dai-tdm-slot-tx-mask-0 = <1 1>;
750b928e4eSChristian Hewitt			dai-tdm-slot-tx-mask-1 = <1 1>;
760b928e4eSChristian Hewitt			dai-tdm-slot-tx-mask-2 = <1 1>;
770b928e4eSChristian Hewitt			dai-tdm-slot-tx-mask-3 = <1 1>;
780b928e4eSChristian Hewitt			mclk-fs = <256>;
790b928e4eSChristian Hewitt
800b928e4eSChristian Hewitt			codec {
810b928e4eSChristian Hewitt				sound-dai = <&tohdmitx TOHDMITX_I2S_IN_B>;
820b928e4eSChristian Hewitt			};
830b928e4eSChristian Hewitt		};
840b928e4eSChristian Hewitt
850b928e4eSChristian Hewitt		dai-link-4 {
860b928e4eSChristian Hewitt			sound-dai = <&tohdmitx TOHDMITX_I2S_OUT>;
870b928e4eSChristian Hewitt
880b928e4eSChristian Hewitt			codec {
890b928e4eSChristian Hewitt				sound-dai = <&hdmi_tx>;
900b928e4eSChristian Hewitt			};
910b928e4eSChristian Hewitt		};
920b928e4eSChristian Hewitt	};
930b928e4eSChristian Hewitt};
940b928e4eSChristian Hewitt
950b928e4eSChristian Hewitt&arb {
960b928e4eSChristian Hewitt	status = "okay";
970b928e4eSChristian Hewitt};
980b928e4eSChristian Hewitt
990b928e4eSChristian Hewitt&clkc_audio {
1000b928e4eSChristian Hewitt	status = "okay";
1010b928e4eSChristian Hewitt};
1020b928e4eSChristian Hewitt
1030b928e4eSChristian Hewitt&frddr_a {
1040b928e4eSChristian Hewitt	status = "okay";
1050b928e4eSChristian Hewitt};
1060b928e4eSChristian Hewitt
1070b928e4eSChristian Hewitt&frddr_b {
1080b928e4eSChristian Hewitt	status = "okay";
1090b928e4eSChristian Hewitt};
1100b928e4eSChristian Hewitt
1110b928e4eSChristian Hewitt&frddr_c {
1120b928e4eSChristian Hewitt	status = "okay";
1130b928e4eSChristian Hewitt};
1140b928e4eSChristian Hewitt
1150b928e4eSChristian Hewitt&tdmif_b {
1160b928e4eSChristian Hewitt	status = "okay";
1170b928e4eSChristian Hewitt};
1180b928e4eSChristian Hewitt
1190b928e4eSChristian Hewitt&tdmout_b {
1200b928e4eSChristian Hewitt	status = "okay";
1210b928e4eSChristian Hewitt};
1220b928e4eSChristian Hewitt
1230b928e4eSChristian Hewitt&tohdmitx {
1240b928e4eSChristian Hewitt	status = "okay";
1250b928e4eSChristian Hewitt};
126