18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * soc-acpi-intel-cml-match.c - tables and support for CML 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 rt1011_spk_codecs = { 138c2ecf20Sopenharmony_ci .num_codecs = 1, 148c2ecf20Sopenharmony_ci .codecs = {"10EC1011"} 158c2ecf20Sopenharmony_ci}; 168c2ecf20Sopenharmony_ci 178c2ecf20Sopenharmony_cistatic struct snd_soc_acpi_codecs max98357a_spk_codecs = { 188c2ecf20Sopenharmony_ci .num_codecs = 1, 198c2ecf20Sopenharmony_ci .codecs = {"MX98357A"} 208c2ecf20Sopenharmony_ci}; 218c2ecf20Sopenharmony_ci 228c2ecf20Sopenharmony_cistatic struct snd_soc_acpi_codecs max98390_spk_codecs = { 238c2ecf20Sopenharmony_ci .num_codecs = 1, 248c2ecf20Sopenharmony_ci .codecs = {"MX98390"} 258c2ecf20Sopenharmony_ci}; 268c2ecf20Sopenharmony_ci 278c2ecf20Sopenharmony_ci/* 288c2ecf20Sopenharmony_ci * The order of the three entries with .id = "10EC5682" matters 298c2ecf20Sopenharmony_ci * here, because DSDT tables expose an ACPI HID for the MAX98357A 308c2ecf20Sopenharmony_ci * speaker amplifier which is not populated on the board. 318c2ecf20Sopenharmony_ci */ 328c2ecf20Sopenharmony_cistruct snd_soc_acpi_mach snd_soc_acpi_intel_cml_machines[] = { 338c2ecf20Sopenharmony_ci { 348c2ecf20Sopenharmony_ci .id = "10EC5682", 358c2ecf20Sopenharmony_ci .drv_name = "cml_rt1011_rt5682", 368c2ecf20Sopenharmony_ci .machine_quirk = snd_soc_acpi_codec_list, 378c2ecf20Sopenharmony_ci .quirk_data = &rt1011_spk_codecs, 388c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-cml.ri", 398c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-cml-rt1011-rt5682.tplg", 408c2ecf20Sopenharmony_ci }, 418c2ecf20Sopenharmony_ci { 428c2ecf20Sopenharmony_ci .id = "10EC5682", 438c2ecf20Sopenharmony_ci .drv_name = "sof_rt5682", 448c2ecf20Sopenharmony_ci .machine_quirk = snd_soc_acpi_codec_list, 458c2ecf20Sopenharmony_ci .quirk_data = &max98357a_spk_codecs, 468c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-cml.ri", 478c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-cml-rt5682-max98357a.tplg", 488c2ecf20Sopenharmony_ci }, 498c2ecf20Sopenharmony_ci { 508c2ecf20Sopenharmony_ci .id = "10EC5682", 518c2ecf20Sopenharmony_ci .drv_name = "sof_rt5682", 528c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-cml.ri", 538c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-cml-rt5682.tplg", 548c2ecf20Sopenharmony_ci }, 558c2ecf20Sopenharmony_ci { 568c2ecf20Sopenharmony_ci .id = "DLGS7219", 578c2ecf20Sopenharmony_ci .drv_name = "cml_da7219_max98357a", 588c2ecf20Sopenharmony_ci .machine_quirk = snd_soc_acpi_codec_list, 598c2ecf20Sopenharmony_ci .quirk_data = &max98357a_spk_codecs, 608c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-cml.ri", 618c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-cml-da7219-max98357a.tplg", 628c2ecf20Sopenharmony_ci }, 638c2ecf20Sopenharmony_ci { 648c2ecf20Sopenharmony_ci .id = "DLGS7219", 658c2ecf20Sopenharmony_ci .drv_name = "cml_da7219_mx98357a", 668c2ecf20Sopenharmony_ci .machine_quirk = snd_soc_acpi_codec_list, 678c2ecf20Sopenharmony_ci .quirk_data = &max98390_spk_codecs, 688c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-cml.ri", 698c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-cml-da7219-max98357a.tplg", 708c2ecf20Sopenharmony_ci }, 718c2ecf20Sopenharmony_ci {}, 728c2ecf20Sopenharmony_ci}; 738c2ecf20Sopenharmony_ciEXPORT_SYMBOL_GPL(snd_soc_acpi_intel_cml_machines); 748c2ecf20Sopenharmony_ci 758c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_endpoint single_endpoint = { 768c2ecf20Sopenharmony_ci .num = 0, 778c2ecf20Sopenharmony_ci .aggregated = 0, 788c2ecf20Sopenharmony_ci .group_position = 0, 798c2ecf20Sopenharmony_ci .group_id = 0, 808c2ecf20Sopenharmony_ci}; 818c2ecf20Sopenharmony_ci 828c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_endpoint spk_l_endpoint = { 838c2ecf20Sopenharmony_ci .num = 0, 848c2ecf20Sopenharmony_ci .aggregated = 1, 858c2ecf20Sopenharmony_ci .group_position = 0, 868c2ecf20Sopenharmony_ci .group_id = 1, 878c2ecf20Sopenharmony_ci}; 888c2ecf20Sopenharmony_ci 898c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_endpoint spk_r_endpoint = { 908c2ecf20Sopenharmony_ci .num = 0, 918c2ecf20Sopenharmony_ci .aggregated = 1, 928c2ecf20Sopenharmony_ci .group_position = 1, 938c2ecf20Sopenharmony_ci .group_id = 1, 948c2ecf20Sopenharmony_ci}; 958c2ecf20Sopenharmony_ci 968c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt700_1_adr[] = { 978c2ecf20Sopenharmony_ci { 988c2ecf20Sopenharmony_ci .adr = 0x000110025D070000, 998c2ecf20Sopenharmony_ci .num_endpoints = 1, 1008c2ecf20Sopenharmony_ci .endpoints = &single_endpoint, 1018c2ecf20Sopenharmony_ci .name_prefix = "rt700" 1028c2ecf20Sopenharmony_ci } 1038c2ecf20Sopenharmony_ci}; 1048c2ecf20Sopenharmony_ci 1058c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr cml_rvp[] = { 1068c2ecf20Sopenharmony_ci { 1078c2ecf20Sopenharmony_ci .mask = BIT(1), 1088c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt700_1_adr), 1098c2ecf20Sopenharmony_ci .adr_d = rt700_1_adr, 1108c2ecf20Sopenharmony_ci }, 1118c2ecf20Sopenharmony_ci {} 1128c2ecf20Sopenharmony_ci}; 1138c2ecf20Sopenharmony_ci 1148c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt711_0_adr[] = { 1158c2ecf20Sopenharmony_ci { 1168c2ecf20Sopenharmony_ci .adr = 0x000020025D071100, 1178c2ecf20Sopenharmony_ci .num_endpoints = 1, 1188c2ecf20Sopenharmony_ci .endpoints = &single_endpoint, 1198c2ecf20Sopenharmony_ci .name_prefix = "rt711" 1208c2ecf20Sopenharmony_ci } 1218c2ecf20Sopenharmony_ci}; 1228c2ecf20Sopenharmony_ci 1238c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1308_1_single_adr[] = { 1248c2ecf20Sopenharmony_ci { 1258c2ecf20Sopenharmony_ci .adr = 0x000120025D130800, 1268c2ecf20Sopenharmony_ci .num_endpoints = 1, 1278c2ecf20Sopenharmony_ci .endpoints = &single_endpoint, 1288c2ecf20Sopenharmony_ci .name_prefix = "rt1308-1" 1298c2ecf20Sopenharmony_ci } 1308c2ecf20Sopenharmony_ci}; 1318c2ecf20Sopenharmony_ci 1328c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1308_1_group1_adr[] = { 1338c2ecf20Sopenharmony_ci { 1348c2ecf20Sopenharmony_ci .adr = 0x000120025D130800, 1358c2ecf20Sopenharmony_ci .num_endpoints = 1, 1368c2ecf20Sopenharmony_ci .endpoints = &spk_l_endpoint, 1378c2ecf20Sopenharmony_ci .name_prefix = "rt1308-1" 1388c2ecf20Sopenharmony_ci } 1398c2ecf20Sopenharmony_ci}; 1408c2ecf20Sopenharmony_ci 1418c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1308_2_group1_adr[] = { 1428c2ecf20Sopenharmony_ci { 1438c2ecf20Sopenharmony_ci .adr = 0x000220025D130800, 1448c2ecf20Sopenharmony_ci .num_endpoints = 1, 1458c2ecf20Sopenharmony_ci .endpoints = &spk_r_endpoint, 1468c2ecf20Sopenharmony_ci .name_prefix = "rt1308-2" 1478c2ecf20Sopenharmony_ci } 1488c2ecf20Sopenharmony_ci}; 1498c2ecf20Sopenharmony_ci 1508c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt715_3_adr[] = { 1518c2ecf20Sopenharmony_ci { 1528c2ecf20Sopenharmony_ci .adr = 0x000320025D071500, 1538c2ecf20Sopenharmony_ci .num_endpoints = 1, 1548c2ecf20Sopenharmony_ci .endpoints = &single_endpoint, 1558c2ecf20Sopenharmony_ci .name_prefix = "rt715" 1568c2ecf20Sopenharmony_ci } 1578c2ecf20Sopenharmony_ci}; 1588c2ecf20Sopenharmony_ci 1598c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt711_sdca_0_adr[] = { 1608c2ecf20Sopenharmony_ci { 1618c2ecf20Sopenharmony_ci .adr = 0x000030025D071101, 1628c2ecf20Sopenharmony_ci .num_endpoints = 1, 1638c2ecf20Sopenharmony_ci .endpoints = &single_endpoint, 1648c2ecf20Sopenharmony_ci .name_prefix = "rt711" 1658c2ecf20Sopenharmony_ci } 1668c2ecf20Sopenharmony_ci}; 1678c2ecf20Sopenharmony_ci 1688c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1316_1_group1_adr[] = { 1698c2ecf20Sopenharmony_ci { 1708c2ecf20Sopenharmony_ci .adr = 0x000131025D131601, /* unique ID is set for some reason */ 1718c2ecf20Sopenharmony_ci .num_endpoints = 1, 1728c2ecf20Sopenharmony_ci .endpoints = &spk_l_endpoint, 1738c2ecf20Sopenharmony_ci .name_prefix = "rt1316-1" 1748c2ecf20Sopenharmony_ci } 1758c2ecf20Sopenharmony_ci}; 1768c2ecf20Sopenharmony_ci 1778c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1316_2_group1_adr[] = { 1788c2ecf20Sopenharmony_ci { 1798c2ecf20Sopenharmony_ci .adr = 0x000230025D131601, 1808c2ecf20Sopenharmony_ci .num_endpoints = 1, 1818c2ecf20Sopenharmony_ci .endpoints = &spk_r_endpoint, 1828c2ecf20Sopenharmony_ci .name_prefix = "rt1316-2" 1838c2ecf20Sopenharmony_ci } 1848c2ecf20Sopenharmony_ci}; 1858c2ecf20Sopenharmony_ci 1868c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt714_3_adr[] = { 1878c2ecf20Sopenharmony_ci { 1888c2ecf20Sopenharmony_ci .adr = 0x000330025D071401, 1898c2ecf20Sopenharmony_ci .num_endpoints = 1, 1908c2ecf20Sopenharmony_ci .endpoints = &single_endpoint, 1918c2ecf20Sopenharmony_ci .name_prefix = "rt714" 1928c2ecf20Sopenharmony_ci } 1938c2ecf20Sopenharmony_ci}; 1948c2ecf20Sopenharmony_ci 1958c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr cml_3_in_1_default[] = { 1968c2ecf20Sopenharmony_ci { 1978c2ecf20Sopenharmony_ci .mask = BIT(0), 1988c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt711_0_adr), 1998c2ecf20Sopenharmony_ci .adr_d = rt711_0_adr, 2008c2ecf20Sopenharmony_ci }, 2018c2ecf20Sopenharmony_ci { 2028c2ecf20Sopenharmony_ci .mask = BIT(1), 2038c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt1308_1_group1_adr), 2048c2ecf20Sopenharmony_ci .adr_d = rt1308_1_group1_adr, 2058c2ecf20Sopenharmony_ci }, 2068c2ecf20Sopenharmony_ci { 2078c2ecf20Sopenharmony_ci .mask = BIT(2), 2088c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt1308_2_group1_adr), 2098c2ecf20Sopenharmony_ci .adr_d = rt1308_2_group1_adr, 2108c2ecf20Sopenharmony_ci }, 2118c2ecf20Sopenharmony_ci { 2128c2ecf20Sopenharmony_ci .mask = BIT(3), 2138c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt715_3_adr), 2148c2ecf20Sopenharmony_ci .adr_d = rt715_3_adr, 2158c2ecf20Sopenharmony_ci }, 2168c2ecf20Sopenharmony_ci {} 2178c2ecf20Sopenharmony_ci}; 2188c2ecf20Sopenharmony_ci 2198c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr cml_3_in_1_mono_amp[] = { 2208c2ecf20Sopenharmony_ci { 2218c2ecf20Sopenharmony_ci .mask = BIT(0), 2228c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt711_0_adr), 2238c2ecf20Sopenharmony_ci .adr_d = rt711_0_adr, 2248c2ecf20Sopenharmony_ci }, 2258c2ecf20Sopenharmony_ci { 2268c2ecf20Sopenharmony_ci .mask = BIT(1), 2278c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt1308_1_single_adr), 2288c2ecf20Sopenharmony_ci .adr_d = rt1308_1_single_adr, 2298c2ecf20Sopenharmony_ci }, 2308c2ecf20Sopenharmony_ci { 2318c2ecf20Sopenharmony_ci .mask = BIT(3), 2328c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt715_3_adr), 2338c2ecf20Sopenharmony_ci .adr_d = rt715_3_adr, 2348c2ecf20Sopenharmony_ci }, 2358c2ecf20Sopenharmony_ci {} 2368c2ecf20Sopenharmony_ci}; 2378c2ecf20Sopenharmony_ci 2388c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr cml_3_in_1_sdca[] = { 2398c2ecf20Sopenharmony_ci { 2408c2ecf20Sopenharmony_ci .mask = BIT(0), 2418c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt711_sdca_0_adr), 2428c2ecf20Sopenharmony_ci .adr_d = rt711_sdca_0_adr, 2438c2ecf20Sopenharmony_ci }, 2448c2ecf20Sopenharmony_ci { 2458c2ecf20Sopenharmony_ci .mask = BIT(1), 2468c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt1316_1_group1_adr), 2478c2ecf20Sopenharmony_ci .adr_d = rt1316_1_group1_adr, 2488c2ecf20Sopenharmony_ci }, 2498c2ecf20Sopenharmony_ci { 2508c2ecf20Sopenharmony_ci .mask = BIT(2), 2518c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt1316_2_group1_adr), 2528c2ecf20Sopenharmony_ci .adr_d = rt1316_2_group1_adr, 2538c2ecf20Sopenharmony_ci }, 2548c2ecf20Sopenharmony_ci { 2558c2ecf20Sopenharmony_ci .mask = BIT(3), 2568c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt714_3_adr), 2578c2ecf20Sopenharmony_ci .adr_d = rt714_3_adr, 2588c2ecf20Sopenharmony_ci }, 2598c2ecf20Sopenharmony_ci {} 2608c2ecf20Sopenharmony_ci}; 2618c2ecf20Sopenharmony_ci 2628c2ecf20Sopenharmony_cistruct snd_soc_acpi_mach snd_soc_acpi_intel_cml_sdw_machines[] = { 2638c2ecf20Sopenharmony_ci { 2648c2ecf20Sopenharmony_ci .link_mask = 0xF, /* 4 active links required */ 2658c2ecf20Sopenharmony_ci .links = cml_3_in_1_default, 2668c2ecf20Sopenharmony_ci .drv_name = "sof_sdw", 2678c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-cml.ri", 2688c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-cml-rt711-rt1308-rt715.tplg", 2698c2ecf20Sopenharmony_ci }, 2708c2ecf20Sopenharmony_ci { 2718c2ecf20Sopenharmony_ci .link_mask = 0xF, /* 4 active links required */ 2728c2ecf20Sopenharmony_ci .links = cml_3_in_1_sdca, 2738c2ecf20Sopenharmony_ci .drv_name = "sof_sdw", 2748c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-cml.ri", 2758c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-cml-rt711-rt1316-rt714.tplg", 2768c2ecf20Sopenharmony_ci }, 2778c2ecf20Sopenharmony_ci { 2788c2ecf20Sopenharmony_ci /* 2798c2ecf20Sopenharmony_ci * link_mask should be 0xB, but all links are enabled by BIOS. 2808c2ecf20Sopenharmony_ci * This entry will be selected if there is no rt1308 exposed 2818c2ecf20Sopenharmony_ci * on link2 since it will fail to match the above entry. 2828c2ecf20Sopenharmony_ci */ 2838c2ecf20Sopenharmony_ci .link_mask = 0xF, 2848c2ecf20Sopenharmony_ci .links = cml_3_in_1_mono_amp, 2858c2ecf20Sopenharmony_ci .drv_name = "sof_sdw", 2868c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-cml.ri", 2878c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-cml-rt711-rt1308-mono-rt715.tplg", 2888c2ecf20Sopenharmony_ci }, 2898c2ecf20Sopenharmony_ci { 2908c2ecf20Sopenharmony_ci .link_mask = 0x2, /* RT700 connected on Link1 */ 2918c2ecf20Sopenharmony_ci .links = cml_rvp, 2928c2ecf20Sopenharmony_ci .drv_name = "sof_sdw", 2938c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-cml.ri", 2948c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-cml-rt700.tplg", 2958c2ecf20Sopenharmony_ci }, 2968c2ecf20Sopenharmony_ci {} 2978c2ecf20Sopenharmony_ci}; 2988c2ecf20Sopenharmony_ciEXPORT_SYMBOL_GPL(snd_soc_acpi_intel_cml_sdw_machines); 2998c2ecf20Sopenharmony_ci 3008c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL v2"); 3018c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("Intel Common ACPI Match module"); 302