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