18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * soc-apci-intel-tgl-match.c - tables and support for ICL ACPI enumeration.
48c2ecf20Sopenharmony_ci *
58c2ecf20Sopenharmony_ci * Copyright (c) 2019, Intel Corporation.
68c2ecf20Sopenharmony_ci *
78c2ecf20Sopenharmony_ci */
88c2ecf20Sopenharmony_ci
98c2ecf20Sopenharmony_ci#include <sound/soc-acpi.h>
108c2ecf20Sopenharmony_ci#include <sound/soc-acpi-intel-match.h>
118c2ecf20Sopenharmony_ci
128c2ecf20Sopenharmony_cistatic struct snd_soc_acpi_codecs tgl_codecs = {
138c2ecf20Sopenharmony_ci	.num_codecs = 1,
148c2ecf20Sopenharmony_ci	.codecs = {"MX98357A"}
158c2ecf20Sopenharmony_ci};
168c2ecf20Sopenharmony_ci
178c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_endpoint single_endpoint = {
188c2ecf20Sopenharmony_ci	.num = 0,
198c2ecf20Sopenharmony_ci	.aggregated = 0,
208c2ecf20Sopenharmony_ci	.group_position = 0,
218c2ecf20Sopenharmony_ci	.group_id = 0,
228c2ecf20Sopenharmony_ci};
238c2ecf20Sopenharmony_ci
248c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_endpoint spk_l_endpoint = {
258c2ecf20Sopenharmony_ci	.num = 0,
268c2ecf20Sopenharmony_ci	.aggregated = 1,
278c2ecf20Sopenharmony_ci	.group_position = 0,
288c2ecf20Sopenharmony_ci	.group_id = 1,
298c2ecf20Sopenharmony_ci};
308c2ecf20Sopenharmony_ci
318c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_endpoint spk_r_endpoint = {
328c2ecf20Sopenharmony_ci	.num = 0,
338c2ecf20Sopenharmony_ci	.aggregated = 1,
348c2ecf20Sopenharmony_ci	.group_position = 1,
358c2ecf20Sopenharmony_ci	.group_id = 1,
368c2ecf20Sopenharmony_ci};
378c2ecf20Sopenharmony_ci
388c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt711_0_adr[] = {
398c2ecf20Sopenharmony_ci	{
408c2ecf20Sopenharmony_ci		.adr = 0x000020025D071100,
418c2ecf20Sopenharmony_ci		.num_endpoints = 1,
428c2ecf20Sopenharmony_ci		.endpoints = &single_endpoint,
438c2ecf20Sopenharmony_ci		.name_prefix = "rt711"
448c2ecf20Sopenharmony_ci	}
458c2ecf20Sopenharmony_ci};
468c2ecf20Sopenharmony_ci
478c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt711_1_adr[] = {
488c2ecf20Sopenharmony_ci	{
498c2ecf20Sopenharmony_ci		.adr = 0x000120025D071100,
508c2ecf20Sopenharmony_ci		.num_endpoints = 1,
518c2ecf20Sopenharmony_ci		.endpoints = &single_endpoint,
528c2ecf20Sopenharmony_ci		.name_prefix = "rt711"
538c2ecf20Sopenharmony_ci	}
548c2ecf20Sopenharmony_ci};
558c2ecf20Sopenharmony_ci
568c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1308_1_dual_adr[] = {
578c2ecf20Sopenharmony_ci	{
588c2ecf20Sopenharmony_ci		.adr = 0x000120025D130800,
598c2ecf20Sopenharmony_ci		.num_endpoints = 1,
608c2ecf20Sopenharmony_ci		.endpoints = &spk_l_endpoint,
618c2ecf20Sopenharmony_ci		.name_prefix = "rt1308-1"
628c2ecf20Sopenharmony_ci	},
638c2ecf20Sopenharmony_ci	{
648c2ecf20Sopenharmony_ci		.adr = 0x000122025D130800,
658c2ecf20Sopenharmony_ci		.num_endpoints = 1,
668c2ecf20Sopenharmony_ci		.endpoints = &spk_r_endpoint,
678c2ecf20Sopenharmony_ci		.name_prefix = "rt1308-2"
688c2ecf20Sopenharmony_ci	}
698c2ecf20Sopenharmony_ci};
708c2ecf20Sopenharmony_ci
718c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1308_1_single_adr[] = {
728c2ecf20Sopenharmony_ci	{
738c2ecf20Sopenharmony_ci		.adr = 0x000120025D130800,
748c2ecf20Sopenharmony_ci		.num_endpoints = 1,
758c2ecf20Sopenharmony_ci		.endpoints = &single_endpoint,
768c2ecf20Sopenharmony_ci		.name_prefix = "rt1308-1"
778c2ecf20Sopenharmony_ci	}
788c2ecf20Sopenharmony_ci};
798c2ecf20Sopenharmony_ci
808c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1308_2_single_adr[] = {
818c2ecf20Sopenharmony_ci	{
828c2ecf20Sopenharmony_ci		.adr = 0x000220025D130800,
838c2ecf20Sopenharmony_ci		.num_endpoints = 1,
848c2ecf20Sopenharmony_ci		.endpoints = &single_endpoint,
858c2ecf20Sopenharmony_ci		.name_prefix = "rt1308-1"
868c2ecf20Sopenharmony_ci	}
878c2ecf20Sopenharmony_ci};
888c2ecf20Sopenharmony_ci
898c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1308_1_group1_adr[] = {
908c2ecf20Sopenharmony_ci	{
918c2ecf20Sopenharmony_ci		.adr = 0x000120025D130800,
928c2ecf20Sopenharmony_ci		.num_endpoints = 1,
938c2ecf20Sopenharmony_ci		.endpoints = &spk_l_endpoint,
948c2ecf20Sopenharmony_ci		.name_prefix = "rt1308-1"
958c2ecf20Sopenharmony_ci	}
968c2ecf20Sopenharmony_ci};
978c2ecf20Sopenharmony_ci
988c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1308_2_group1_adr[] = {
998c2ecf20Sopenharmony_ci	{
1008c2ecf20Sopenharmony_ci		.adr = 0x000220025D130800,
1018c2ecf20Sopenharmony_ci		.num_endpoints = 1,
1028c2ecf20Sopenharmony_ci		.endpoints = &spk_r_endpoint,
1038c2ecf20Sopenharmony_ci		.name_prefix = "rt1308-2"
1048c2ecf20Sopenharmony_ci	}
1058c2ecf20Sopenharmony_ci};
1068c2ecf20Sopenharmony_ci
1078c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt715_0_adr[] = {
1088c2ecf20Sopenharmony_ci	{
1098c2ecf20Sopenharmony_ci		.adr = 0x000021025D071500,
1108c2ecf20Sopenharmony_ci		.num_endpoints = 1,
1118c2ecf20Sopenharmony_ci		.endpoints = &single_endpoint,
1128c2ecf20Sopenharmony_ci		.name_prefix = "rt715"
1138c2ecf20Sopenharmony_ci	}
1148c2ecf20Sopenharmony_ci};
1158c2ecf20Sopenharmony_ci
1168c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt715_3_adr[] = {
1178c2ecf20Sopenharmony_ci	{
1188c2ecf20Sopenharmony_ci		.adr = 0x000320025D071500,
1198c2ecf20Sopenharmony_ci		.num_endpoints = 1,
1208c2ecf20Sopenharmony_ci		.endpoints = &single_endpoint,
1218c2ecf20Sopenharmony_ci		.name_prefix = "rt715"
1228c2ecf20Sopenharmony_ci	}
1238c2ecf20Sopenharmony_ci};
1248c2ecf20Sopenharmony_ci
1258c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device mx8373_1_adr[] = {
1268c2ecf20Sopenharmony_ci	{
1278c2ecf20Sopenharmony_ci		.adr = 0x000123019F837300,
1288c2ecf20Sopenharmony_ci		.num_endpoints = 1,
1298c2ecf20Sopenharmony_ci		.endpoints = &spk_r_endpoint,
1308c2ecf20Sopenharmony_ci		.name_prefix = "Right"
1318c2ecf20Sopenharmony_ci	},
1328c2ecf20Sopenharmony_ci	{
1338c2ecf20Sopenharmony_ci		.adr = 0x000127019F837300,
1348c2ecf20Sopenharmony_ci		.num_endpoints = 1,
1358c2ecf20Sopenharmony_ci		.endpoints = &spk_l_endpoint,
1368c2ecf20Sopenharmony_ci		.name_prefix = "Left"
1378c2ecf20Sopenharmony_ci	}
1388c2ecf20Sopenharmony_ci};
1398c2ecf20Sopenharmony_ci
1408c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt5682_0_adr[] = {
1418c2ecf20Sopenharmony_ci	{
1428c2ecf20Sopenharmony_ci		.adr = 0x000021025D568200,
1438c2ecf20Sopenharmony_ci		.num_endpoints = 1,
1448c2ecf20Sopenharmony_ci		.endpoints = &single_endpoint,
1458c2ecf20Sopenharmony_ci		.name_prefix = "rt5682"
1468c2ecf20Sopenharmony_ci	}
1478c2ecf20Sopenharmony_ci};
1488c2ecf20Sopenharmony_ci
1498c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt711_sdca_0_adr[] = {
1508c2ecf20Sopenharmony_ci	{
1518c2ecf20Sopenharmony_ci		.adr = 0x000030025D071101,
1528c2ecf20Sopenharmony_ci		.num_endpoints = 1,
1538c2ecf20Sopenharmony_ci		.endpoints = &single_endpoint,
1548c2ecf20Sopenharmony_ci		.name_prefix = "rt711"
1558c2ecf20Sopenharmony_ci	}
1568c2ecf20Sopenharmony_ci};
1578c2ecf20Sopenharmony_ci
1588c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1316_1_group1_adr[] = {
1598c2ecf20Sopenharmony_ci	{
1608c2ecf20Sopenharmony_ci		.adr = 0x000131025D131601, /* unique ID is set for some reason */
1618c2ecf20Sopenharmony_ci		.num_endpoints = 1,
1628c2ecf20Sopenharmony_ci		.endpoints = &spk_l_endpoint,
1638c2ecf20Sopenharmony_ci		.name_prefix = "rt1316-1"
1648c2ecf20Sopenharmony_ci	}
1658c2ecf20Sopenharmony_ci};
1668c2ecf20Sopenharmony_ci
1678c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1316_2_group1_adr[] = {
1688c2ecf20Sopenharmony_ci	{
1698c2ecf20Sopenharmony_ci		.adr = 0x000230025D131601,
1708c2ecf20Sopenharmony_ci		.num_endpoints = 1,
1718c2ecf20Sopenharmony_ci		.endpoints = &spk_r_endpoint,
1728c2ecf20Sopenharmony_ci		.name_prefix = "rt1316-2"
1738c2ecf20Sopenharmony_ci	}
1748c2ecf20Sopenharmony_ci};
1758c2ecf20Sopenharmony_ci
1768c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt714_3_adr[] = {
1778c2ecf20Sopenharmony_ci	{
1788c2ecf20Sopenharmony_ci		.adr = 0x000330025D071401,
1798c2ecf20Sopenharmony_ci		.num_endpoints = 1,
1808c2ecf20Sopenharmony_ci		.endpoints = &single_endpoint,
1818c2ecf20Sopenharmony_ci		.name_prefix = "rt714"
1828c2ecf20Sopenharmony_ci	}
1838c2ecf20Sopenharmony_ci};
1848c2ecf20Sopenharmony_ci
1858c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr tgl_i2s_rt1308[] = {
1868c2ecf20Sopenharmony_ci	{
1878c2ecf20Sopenharmony_ci		.mask = BIT(0),
1888c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt711_0_adr),
1898c2ecf20Sopenharmony_ci		.adr_d = rt711_0_adr,
1908c2ecf20Sopenharmony_ci	},
1918c2ecf20Sopenharmony_ci	{}
1928c2ecf20Sopenharmony_ci};
1938c2ecf20Sopenharmony_ci
1948c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr tgl_rvp[] = {
1958c2ecf20Sopenharmony_ci	{
1968c2ecf20Sopenharmony_ci		.mask = BIT(0),
1978c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt711_0_adr),
1988c2ecf20Sopenharmony_ci		.adr_d = rt711_0_adr,
1998c2ecf20Sopenharmony_ci	},
2008c2ecf20Sopenharmony_ci	{
2018c2ecf20Sopenharmony_ci		.mask = BIT(1),
2028c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt1308_1_dual_adr),
2038c2ecf20Sopenharmony_ci		.adr_d = rt1308_1_dual_adr,
2048c2ecf20Sopenharmony_ci	},
2058c2ecf20Sopenharmony_ci	{}
2068c2ecf20Sopenharmony_ci};
2078c2ecf20Sopenharmony_ci
2088c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr tgl_chromebook_base[] = {
2098c2ecf20Sopenharmony_ci	{
2108c2ecf20Sopenharmony_ci		.mask = BIT(0),
2118c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt5682_0_adr),
2128c2ecf20Sopenharmony_ci		.adr_d = rt5682_0_adr,
2138c2ecf20Sopenharmony_ci	},
2148c2ecf20Sopenharmony_ci	{
2158c2ecf20Sopenharmony_ci		.mask = BIT(1),
2168c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(mx8373_1_adr),
2178c2ecf20Sopenharmony_ci		.adr_d = mx8373_1_adr,
2188c2ecf20Sopenharmony_ci	},
2198c2ecf20Sopenharmony_ci	{}
2208c2ecf20Sopenharmony_ci};
2218c2ecf20Sopenharmony_ci
2228c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr tgl_3_in_1_default[] = {
2238c2ecf20Sopenharmony_ci	{
2248c2ecf20Sopenharmony_ci		.mask = BIT(0),
2258c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt711_0_adr),
2268c2ecf20Sopenharmony_ci		.adr_d = rt711_0_adr,
2278c2ecf20Sopenharmony_ci	},
2288c2ecf20Sopenharmony_ci	{
2298c2ecf20Sopenharmony_ci		.mask = BIT(1),
2308c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt1308_1_group1_adr),
2318c2ecf20Sopenharmony_ci		.adr_d = rt1308_1_group1_adr,
2328c2ecf20Sopenharmony_ci	},
2338c2ecf20Sopenharmony_ci	{
2348c2ecf20Sopenharmony_ci		.mask = BIT(2),
2358c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt1308_2_group1_adr),
2368c2ecf20Sopenharmony_ci		.adr_d = rt1308_2_group1_adr,
2378c2ecf20Sopenharmony_ci	},
2388c2ecf20Sopenharmony_ci	{
2398c2ecf20Sopenharmony_ci		.mask = BIT(3),
2408c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt715_3_adr),
2418c2ecf20Sopenharmony_ci		.adr_d = rt715_3_adr,
2428c2ecf20Sopenharmony_ci	},
2438c2ecf20Sopenharmony_ci	{}
2448c2ecf20Sopenharmony_ci};
2458c2ecf20Sopenharmony_ci
2468c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr tgl_3_in_1_mono_amp[] = {
2478c2ecf20Sopenharmony_ci	{
2488c2ecf20Sopenharmony_ci		.mask = BIT(0),
2498c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt711_0_adr),
2508c2ecf20Sopenharmony_ci		.adr_d = rt711_0_adr,
2518c2ecf20Sopenharmony_ci	},
2528c2ecf20Sopenharmony_ci	{
2538c2ecf20Sopenharmony_ci		.mask = BIT(1),
2548c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt1308_1_single_adr),
2558c2ecf20Sopenharmony_ci		.adr_d = rt1308_1_single_adr,
2568c2ecf20Sopenharmony_ci	},
2578c2ecf20Sopenharmony_ci	{
2588c2ecf20Sopenharmony_ci		.mask = BIT(3),
2598c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt715_3_adr),
2608c2ecf20Sopenharmony_ci		.adr_d = rt715_3_adr,
2618c2ecf20Sopenharmony_ci	},
2628c2ecf20Sopenharmony_ci	{}
2638c2ecf20Sopenharmony_ci};
2648c2ecf20Sopenharmony_ci
2658c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr tgl_sdw_rt711_link1_rt1308_link2_rt715_link0[] = {
2668c2ecf20Sopenharmony_ci	{
2678c2ecf20Sopenharmony_ci		.mask = BIT(1),
2688c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt711_1_adr),
2698c2ecf20Sopenharmony_ci		.adr_d = rt711_1_adr,
2708c2ecf20Sopenharmony_ci	},
2718c2ecf20Sopenharmony_ci	{
2728c2ecf20Sopenharmony_ci		.mask = BIT(2),
2738c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt1308_2_single_adr),
2748c2ecf20Sopenharmony_ci		.adr_d = rt1308_2_single_adr,
2758c2ecf20Sopenharmony_ci	},
2768c2ecf20Sopenharmony_ci	{
2778c2ecf20Sopenharmony_ci		.mask = BIT(0),
2788c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt715_0_adr),
2798c2ecf20Sopenharmony_ci		.adr_d = rt715_0_adr,
2808c2ecf20Sopenharmony_ci	},
2818c2ecf20Sopenharmony_ci	{}
2828c2ecf20Sopenharmony_ci};
2838c2ecf20Sopenharmony_ci
2848c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr tgl_3_in_1_sdca[] = {
2858c2ecf20Sopenharmony_ci	{
2868c2ecf20Sopenharmony_ci		.mask = BIT(0),
2878c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt711_sdca_0_adr),
2888c2ecf20Sopenharmony_ci		.adr_d = rt711_sdca_0_adr,
2898c2ecf20Sopenharmony_ci	},
2908c2ecf20Sopenharmony_ci	{
2918c2ecf20Sopenharmony_ci		.mask = BIT(1),
2928c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt1316_1_group1_adr),
2938c2ecf20Sopenharmony_ci		.adr_d = rt1316_1_group1_adr,
2948c2ecf20Sopenharmony_ci	},
2958c2ecf20Sopenharmony_ci	{
2968c2ecf20Sopenharmony_ci		.mask = BIT(2),
2978c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt1316_2_group1_adr),
2988c2ecf20Sopenharmony_ci		.adr_d = rt1316_2_group1_adr,
2998c2ecf20Sopenharmony_ci	},
3008c2ecf20Sopenharmony_ci	{
3018c2ecf20Sopenharmony_ci		.mask = BIT(3),
3028c2ecf20Sopenharmony_ci		.num_adr = ARRAY_SIZE(rt714_3_adr),
3038c2ecf20Sopenharmony_ci		.adr_d = rt714_3_adr,
3048c2ecf20Sopenharmony_ci	},
3058c2ecf20Sopenharmony_ci	{}
3068c2ecf20Sopenharmony_ci};
3078c2ecf20Sopenharmony_ci
3088c2ecf20Sopenharmony_cistatic struct snd_soc_acpi_codecs tgl_max98373_amp = {
3098c2ecf20Sopenharmony_ci	.num_codecs = 1,
3108c2ecf20Sopenharmony_ci	.codecs = {"MX98373"}
3118c2ecf20Sopenharmony_ci};
3128c2ecf20Sopenharmony_ci
3138c2ecf20Sopenharmony_cistruct snd_soc_acpi_mach snd_soc_acpi_intel_tgl_machines[] = {
3148c2ecf20Sopenharmony_ci	{
3158c2ecf20Sopenharmony_ci		.id = "10EC1308",
3168c2ecf20Sopenharmony_ci		.drv_name = "sof_sdw",
3178c2ecf20Sopenharmony_ci		.link_mask = 0x1, /* RT711 on SoundWire link0 */
3188c2ecf20Sopenharmony_ci		.links = tgl_i2s_rt1308,
3198c2ecf20Sopenharmony_ci		.sof_fw_filename = "sof-tgl.ri",
3208c2ecf20Sopenharmony_ci		.sof_tplg_filename = "sof-tgl-rt711-i2s-rt1308.tplg",
3218c2ecf20Sopenharmony_ci	},
3228c2ecf20Sopenharmony_ci	{
3238c2ecf20Sopenharmony_ci		.id = "10EC5682",
3248c2ecf20Sopenharmony_ci		.drv_name = "tgl_max98357a_rt5682",
3258c2ecf20Sopenharmony_ci		.machine_quirk = snd_soc_acpi_codec_list,
3268c2ecf20Sopenharmony_ci		.quirk_data = &tgl_codecs,
3278c2ecf20Sopenharmony_ci		.sof_fw_filename = "sof-tgl.ri",
3288c2ecf20Sopenharmony_ci		.sof_tplg_filename = "sof-tgl-max98357a-rt5682.tplg",
3298c2ecf20Sopenharmony_ci	},
3308c2ecf20Sopenharmony_ci	{
3318c2ecf20Sopenharmony_ci		.id = "10EC5682",
3328c2ecf20Sopenharmony_ci		.drv_name = "tgl_max98373_rt5682",
3338c2ecf20Sopenharmony_ci		.machine_quirk = snd_soc_acpi_codec_list,
3348c2ecf20Sopenharmony_ci		.quirk_data = &tgl_max98373_amp,
3358c2ecf20Sopenharmony_ci		.sof_fw_filename = "sof-tgl.ri",
3368c2ecf20Sopenharmony_ci		.sof_tplg_filename = "sof-tgl-max98373-rt5682.tplg",
3378c2ecf20Sopenharmony_ci	},
3388c2ecf20Sopenharmony_ci	{},
3398c2ecf20Sopenharmony_ci};
3408c2ecf20Sopenharmony_ciEXPORT_SYMBOL_GPL(snd_soc_acpi_intel_tgl_machines);
3418c2ecf20Sopenharmony_ci
3428c2ecf20Sopenharmony_ci/* this table is used when there is no I2S codec present */
3438c2ecf20Sopenharmony_cistruct snd_soc_acpi_mach snd_soc_acpi_intel_tgl_sdw_machines[] = {
3448c2ecf20Sopenharmony_ci	{
3458c2ecf20Sopenharmony_ci		.link_mask = 0x7,
3468c2ecf20Sopenharmony_ci		.links = tgl_sdw_rt711_link1_rt1308_link2_rt715_link0,
3478c2ecf20Sopenharmony_ci		.drv_name = "sof_sdw",
3488c2ecf20Sopenharmony_ci		.sof_fw_filename = "sof-tgl.ri",
3498c2ecf20Sopenharmony_ci		.sof_tplg_filename = "sof-tgl-rt715-rt711-rt1308-mono.tplg",
3508c2ecf20Sopenharmony_ci	},
3518c2ecf20Sopenharmony_ci	{
3528c2ecf20Sopenharmony_ci		.link_mask = 0xF, /* 4 active links required */
3538c2ecf20Sopenharmony_ci		.links = tgl_3_in_1_default,
3548c2ecf20Sopenharmony_ci		.drv_name = "sof_sdw",
3558c2ecf20Sopenharmony_ci		.sof_fw_filename = "sof-tgl.ri",
3568c2ecf20Sopenharmony_ci		.sof_tplg_filename = "sof-tgl-rt711-rt1308-rt715.tplg",
3578c2ecf20Sopenharmony_ci	},
3588c2ecf20Sopenharmony_ci	{
3598c2ecf20Sopenharmony_ci		/*
3608c2ecf20Sopenharmony_ci		 * link_mask should be 0xB, but all links are enabled by BIOS.
3618c2ecf20Sopenharmony_ci		 * This entry will be selected if there is no rt1308 exposed
3628c2ecf20Sopenharmony_ci		 * on link2 since it will fail to match the above entry.
3638c2ecf20Sopenharmony_ci		 */
3648c2ecf20Sopenharmony_ci		.link_mask = 0xF,
3658c2ecf20Sopenharmony_ci		.links = tgl_3_in_1_mono_amp,
3668c2ecf20Sopenharmony_ci		.drv_name = "sof_sdw",
3678c2ecf20Sopenharmony_ci		.sof_fw_filename = "sof-tgl.ri",
3688c2ecf20Sopenharmony_ci		.sof_tplg_filename = "sof-tgl-rt711-rt1308-mono-rt715.tplg",
3698c2ecf20Sopenharmony_ci	},
3708c2ecf20Sopenharmony_ci	{
3718c2ecf20Sopenharmony_ci		.link_mask = 0xF, /* 4 active links required */
3728c2ecf20Sopenharmony_ci		.links = tgl_3_in_1_sdca,
3738c2ecf20Sopenharmony_ci		.drv_name = "sof_sdw",
3748c2ecf20Sopenharmony_ci		.sof_fw_filename = "sof-tgl.ri",
3758c2ecf20Sopenharmony_ci		.sof_tplg_filename = "sof-tgl-rt711-rt1316-rt714.tplg",
3768c2ecf20Sopenharmony_ci	},
3778c2ecf20Sopenharmony_ci	{
3788c2ecf20Sopenharmony_ci		.link_mask = 0x3, /* rt711 on link 0 and 2 rt1308s on link 1 */
3798c2ecf20Sopenharmony_ci		.links = tgl_rvp,
3808c2ecf20Sopenharmony_ci		.drv_name = "sof_sdw",
3818c2ecf20Sopenharmony_ci		.sof_fw_filename = "sof-tgl.ri",
3828c2ecf20Sopenharmony_ci		.sof_tplg_filename = "sof-tgl-rt711-rt1308.tplg",
3838c2ecf20Sopenharmony_ci	},
3848c2ecf20Sopenharmony_ci	{
3858c2ecf20Sopenharmony_ci		.link_mask = 0x3, /* rt5682 on link0 & 2xmax98373 on link 1 */
3868c2ecf20Sopenharmony_ci		.links = tgl_chromebook_base,
3878c2ecf20Sopenharmony_ci		.drv_name = "sof_sdw",
3888c2ecf20Sopenharmony_ci		.sof_fw_filename = "sof-tgl.ri",
3898c2ecf20Sopenharmony_ci		.sof_tplg_filename = "sof-tgl-sdw-max98373-rt5682.tplg",
3908c2ecf20Sopenharmony_ci	},
3918c2ecf20Sopenharmony_ci	{
3928c2ecf20Sopenharmony_ci		.link_mask = 0x1, /* this will only enable rt5682 for now */
3938c2ecf20Sopenharmony_ci		.links = tgl_chromebook_base,
3948c2ecf20Sopenharmony_ci		.drv_name = "sof_sdw",
3958c2ecf20Sopenharmony_ci		.sof_fw_filename = "sof-tgl.ri",
3968c2ecf20Sopenharmony_ci		.sof_tplg_filename = "sof-tgl-rt5682.tplg",
3978c2ecf20Sopenharmony_ci	},
3988c2ecf20Sopenharmony_ci	{},
3998c2ecf20Sopenharmony_ci};
4008c2ecf20Sopenharmony_ciEXPORT_SYMBOL_GPL(snd_soc_acpi_intel_tgl_sdw_machines);
4018c2ecf20Sopenharmony_ci
4028c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL v2");
4038c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("Intel Common ACPI Match module");
404