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