18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * soc-acpi-intel-icl-match.c - tables and support for ICL ACPI enumeration. 48c2ecf20Sopenharmony_ci * 58c2ecf20Sopenharmony_ci * Copyright (c) 2018, 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#include "../skylake/skl.h" 128c2ecf20Sopenharmony_ci 138c2ecf20Sopenharmony_cistatic struct skl_machine_pdata icl_pdata = { 148c2ecf20Sopenharmony_ci .use_tplg_pcm = true, 158c2ecf20Sopenharmony_ci}; 168c2ecf20Sopenharmony_ci 178c2ecf20Sopenharmony_cistruct snd_soc_acpi_mach snd_soc_acpi_intel_icl_machines[] = { 188c2ecf20Sopenharmony_ci { 198c2ecf20Sopenharmony_ci .id = "INT34C2", 208c2ecf20Sopenharmony_ci .drv_name = "icl_rt274", 218c2ecf20Sopenharmony_ci .fw_filename = "intel/dsp_fw_icl.bin", 228c2ecf20Sopenharmony_ci .pdata = &icl_pdata, 238c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-icl.ri", 248c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-icl-rt274.tplg", 258c2ecf20Sopenharmony_ci }, 268c2ecf20Sopenharmony_ci { 278c2ecf20Sopenharmony_ci .id = "10EC5682", 288c2ecf20Sopenharmony_ci .drv_name = "sof_rt5682", 298c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-icl.ri", 308c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-icl-rt5682.tplg", 318c2ecf20Sopenharmony_ci }, 328c2ecf20Sopenharmony_ci {}, 338c2ecf20Sopenharmony_ci}; 348c2ecf20Sopenharmony_ciEXPORT_SYMBOL_GPL(snd_soc_acpi_intel_icl_machines); 358c2ecf20Sopenharmony_ci 368c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_endpoint single_endpoint = { 378c2ecf20Sopenharmony_ci .num = 0, 388c2ecf20Sopenharmony_ci .aggregated = 0, 398c2ecf20Sopenharmony_ci .group_position = 0, 408c2ecf20Sopenharmony_ci .group_id = 0, 418c2ecf20Sopenharmony_ci}; 428c2ecf20Sopenharmony_ci 438c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_endpoint spk_l_endpoint = { 448c2ecf20Sopenharmony_ci .num = 0, 458c2ecf20Sopenharmony_ci .aggregated = 1, 468c2ecf20Sopenharmony_ci .group_position = 0, 478c2ecf20Sopenharmony_ci .group_id = 1, 488c2ecf20Sopenharmony_ci}; 498c2ecf20Sopenharmony_ci 508c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_endpoint spk_r_endpoint = { 518c2ecf20Sopenharmony_ci .num = 0, 528c2ecf20Sopenharmony_ci .aggregated = 1, 538c2ecf20Sopenharmony_ci .group_position = 1, 548c2ecf20Sopenharmony_ci .group_id = 1, 558c2ecf20Sopenharmony_ci}; 568c2ecf20Sopenharmony_ci 578c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt700_0_adr[] = { 588c2ecf20Sopenharmony_ci { 598c2ecf20Sopenharmony_ci .adr = 0x000010025D070000, 608c2ecf20Sopenharmony_ci .num_endpoints = 1, 618c2ecf20Sopenharmony_ci .endpoints = &single_endpoint, 628c2ecf20Sopenharmony_ci .name_prefix = "rt700" 638c2ecf20Sopenharmony_ci } 648c2ecf20Sopenharmony_ci}; 658c2ecf20Sopenharmony_ci 668c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr icl_rvp[] = { 678c2ecf20Sopenharmony_ci { 688c2ecf20Sopenharmony_ci .mask = BIT(0), 698c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt700_0_adr), 708c2ecf20Sopenharmony_ci .adr_d = rt700_0_adr, 718c2ecf20Sopenharmony_ci }, 728c2ecf20Sopenharmony_ci {} 738c2ecf20Sopenharmony_ci}; 748c2ecf20Sopenharmony_ci 758c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt711_0_adr[] = { 768c2ecf20Sopenharmony_ci { 778c2ecf20Sopenharmony_ci .adr = 0x000020025D071100, 788c2ecf20Sopenharmony_ci .num_endpoints = 1, 798c2ecf20Sopenharmony_ci .endpoints = &single_endpoint, 808c2ecf20Sopenharmony_ci .name_prefix = "rt711" 818c2ecf20Sopenharmony_ci } 828c2ecf20Sopenharmony_ci}; 838c2ecf20Sopenharmony_ci 848c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1308_1_adr[] = { 858c2ecf20Sopenharmony_ci { 868c2ecf20Sopenharmony_ci .adr = 0x000120025D130800, 878c2ecf20Sopenharmony_ci .num_endpoints = 1, 888c2ecf20Sopenharmony_ci .endpoints = &single_endpoint, 898c2ecf20Sopenharmony_ci .name_prefix = "rt1308-1" 908c2ecf20Sopenharmony_ci } 918c2ecf20Sopenharmony_ci}; 928c2ecf20Sopenharmony_ci 938c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1308_1_group1_adr[] = { 948c2ecf20Sopenharmony_ci { 958c2ecf20Sopenharmony_ci .adr = 0x000120025D130800, 968c2ecf20Sopenharmony_ci .num_endpoints = 1, 978c2ecf20Sopenharmony_ci .endpoints = &spk_l_endpoint, 988c2ecf20Sopenharmony_ci .name_prefix = "rt1308-1" 998c2ecf20Sopenharmony_ci } 1008c2ecf20Sopenharmony_ci}; 1018c2ecf20Sopenharmony_ci 1028c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt1308_2_group1_adr[] = { 1038c2ecf20Sopenharmony_ci { 1048c2ecf20Sopenharmony_ci .adr = 0x000220025D130800, 1058c2ecf20Sopenharmony_ci .num_endpoints = 1, 1068c2ecf20Sopenharmony_ci .endpoints = &spk_r_endpoint, 1078c2ecf20Sopenharmony_ci .name_prefix = "rt1308-2" 1088c2ecf20Sopenharmony_ci } 1098c2ecf20Sopenharmony_ci}; 1108c2ecf20Sopenharmony_ci 1118c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_adr_device rt715_3_adr[] = { 1128c2ecf20Sopenharmony_ci { 1138c2ecf20Sopenharmony_ci .adr = 0x000320025D071500, 1148c2ecf20Sopenharmony_ci .num_endpoints = 1, 1158c2ecf20Sopenharmony_ci .endpoints = &single_endpoint, 1168c2ecf20Sopenharmony_ci .name_prefix = "rt715" 1178c2ecf20Sopenharmony_ci } 1188c2ecf20Sopenharmony_ci}; 1198c2ecf20Sopenharmony_ci 1208c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr icl_3_in_1_default[] = { 1218c2ecf20Sopenharmony_ci { 1228c2ecf20Sopenharmony_ci .mask = BIT(0), 1238c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt711_0_adr), 1248c2ecf20Sopenharmony_ci .adr_d = rt711_0_adr, 1258c2ecf20Sopenharmony_ci }, 1268c2ecf20Sopenharmony_ci { 1278c2ecf20Sopenharmony_ci .mask = BIT(1), 1288c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt1308_1_group1_adr), 1298c2ecf20Sopenharmony_ci .adr_d = rt1308_1_group1_adr, 1308c2ecf20Sopenharmony_ci }, 1318c2ecf20Sopenharmony_ci { 1328c2ecf20Sopenharmony_ci .mask = BIT(2), 1338c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt1308_2_group1_adr), 1348c2ecf20Sopenharmony_ci .adr_d = rt1308_2_group1_adr, 1358c2ecf20Sopenharmony_ci }, 1368c2ecf20Sopenharmony_ci { 1378c2ecf20Sopenharmony_ci .mask = BIT(3), 1388c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt715_3_adr), 1398c2ecf20Sopenharmony_ci .adr_d = rt715_3_adr, 1408c2ecf20Sopenharmony_ci }, 1418c2ecf20Sopenharmony_ci {} 1428c2ecf20Sopenharmony_ci}; 1438c2ecf20Sopenharmony_ci 1448c2ecf20Sopenharmony_cistatic const struct snd_soc_acpi_link_adr icl_3_in_1_mono_amp[] = { 1458c2ecf20Sopenharmony_ci { 1468c2ecf20Sopenharmony_ci .mask = BIT(0), 1478c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt711_0_adr), 1488c2ecf20Sopenharmony_ci .adr_d = rt711_0_adr, 1498c2ecf20Sopenharmony_ci }, 1508c2ecf20Sopenharmony_ci { 1518c2ecf20Sopenharmony_ci .mask = BIT(1), 1528c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt1308_1_adr), 1538c2ecf20Sopenharmony_ci .adr_d = rt1308_1_adr, 1548c2ecf20Sopenharmony_ci }, 1558c2ecf20Sopenharmony_ci { 1568c2ecf20Sopenharmony_ci .mask = BIT(3), 1578c2ecf20Sopenharmony_ci .num_adr = ARRAY_SIZE(rt715_3_adr), 1588c2ecf20Sopenharmony_ci .adr_d = rt715_3_adr, 1598c2ecf20Sopenharmony_ci }, 1608c2ecf20Sopenharmony_ci {} 1618c2ecf20Sopenharmony_ci}; 1628c2ecf20Sopenharmony_ci 1638c2ecf20Sopenharmony_cistruct snd_soc_acpi_mach snd_soc_acpi_intel_icl_sdw_machines[] = { 1648c2ecf20Sopenharmony_ci { 1658c2ecf20Sopenharmony_ci .link_mask = 0xF, /* 4 active links required */ 1668c2ecf20Sopenharmony_ci .links = icl_3_in_1_default, 1678c2ecf20Sopenharmony_ci .drv_name = "sof_sdw", 1688c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-icl.ri", 1698c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-icl-rt711-rt1308-rt715.tplg", 1708c2ecf20Sopenharmony_ci }, 1718c2ecf20Sopenharmony_ci { 1728c2ecf20Sopenharmony_ci .link_mask = 0xB, /* 3 active links required */ 1738c2ecf20Sopenharmony_ci .links = icl_3_in_1_mono_amp, 1748c2ecf20Sopenharmony_ci .drv_name = "sof_sdw", 1758c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-icl.ri", 1768c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-icl-rt711-rt1308-rt715-mono.tplg", 1778c2ecf20Sopenharmony_ci }, 1788c2ecf20Sopenharmony_ci { 1798c2ecf20Sopenharmony_ci .link_mask = 0x1, /* rt700 connected on link0 */ 1808c2ecf20Sopenharmony_ci .links = icl_rvp, 1818c2ecf20Sopenharmony_ci .drv_name = "sof_sdw", 1828c2ecf20Sopenharmony_ci .sof_fw_filename = "sof-icl.ri", 1838c2ecf20Sopenharmony_ci .sof_tplg_filename = "sof-icl-rt700.tplg", 1848c2ecf20Sopenharmony_ci }, 1858c2ecf20Sopenharmony_ci {}, 1868c2ecf20Sopenharmony_ci}; 1878c2ecf20Sopenharmony_ciEXPORT_SYMBOL_GPL(snd_soc_acpi_intel_icl_sdw_machines); 1888c2ecf20Sopenharmony_ci 1898c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL v2"); 1908c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("Intel Common ACPI Match module"); 191