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