diff options
| -rw-r--r-- | sound/soc/intel/common/soc-acpi-intel-lnl-match.c | 71 | 
1 files changed, 71 insertions, 0 deletions
| diff --git a/sound/soc/intel/common/soc-acpi-intel-lnl-match.c b/sound/soc/intel/common/soc-acpi-intel-lnl-match.c index 9f35b77deb11..5897bb6b28b8 100644 --- a/sound/soc/intel/common/soc-acpi-intel-lnl-match.c +++ b/sound/soc/intel/common/soc-acpi-intel-lnl-match.c @@ -22,6 +22,20 @@ static const struct snd_soc_acpi_endpoint single_endpoint = {  	.group_id = 0,  }; +static const struct snd_soc_acpi_endpoint spk_l_endpoint = { +	.num = 0, +	.aggregated = 1, +	.group_position = 0, +	.group_id = 1, +}; + +static const struct snd_soc_acpi_endpoint spk_r_endpoint = { +	.num = 0, +	.aggregated = 1, +	.group_position = 1, +	.group_id = 1, +}; +  static const struct snd_soc_acpi_adr_device rt711_sdca_0_adr[] = {  	{  		.adr = 0x000030025D071101ull, @@ -31,6 +45,33 @@ static const struct snd_soc_acpi_adr_device rt711_sdca_0_adr[] = {  	}  }; +static const struct snd_soc_acpi_adr_device rt1316_2_group1_adr[] = { +	{ +		.adr = 0x000230025D131601ull, +		.num_endpoints = 1, +		.endpoints = &spk_l_endpoint, +		.name_prefix = "rt1316-1" +	} +}; + +static const struct snd_soc_acpi_adr_device rt1316_3_group1_adr[] = { +	{ +		.adr = 0x000331025D131601ull, +		.num_endpoints = 1, +		.endpoints = &spk_r_endpoint, +		.name_prefix = "rt1316-2" +	} +}; + +static const struct snd_soc_acpi_adr_device rt714_1_adr[] = { +	{ +		.adr = 0x000130025D071401ull, +		.num_endpoints = 1, +		.endpoints = &single_endpoint, +		.name_prefix = "rt714" +	} +}; +  static const struct snd_soc_acpi_link_adr lnl_rvp[] = {  	{  		.mask = BIT(0), @@ -40,6 +81,30 @@ static const struct snd_soc_acpi_link_adr lnl_rvp[] = {  	{}  }; +static const struct snd_soc_acpi_link_adr lnl_3_in_1_sdca[] = { +	{ +		.mask = BIT(0), +		.num_adr = ARRAY_SIZE(rt711_sdca_0_adr), +		.adr_d = rt711_sdca_0_adr, +	}, +	{ +		.mask = BIT(2), +		.num_adr = ARRAY_SIZE(rt1316_2_group1_adr), +		.adr_d = rt1316_2_group1_adr, +	}, +	{ +		.mask = BIT(3), +		.num_adr = ARRAY_SIZE(rt1316_3_group1_adr), +		.adr_d = rt1316_3_group1_adr, +	}, +	{ +		.mask = BIT(1), +		.num_adr = ARRAY_SIZE(rt714_1_adr), +		.adr_d = rt714_1_adr, +	}, +	{} +}; +  /* this table is used when there is no I2S codec present */  struct snd_soc_acpi_mach snd_soc_acpi_intel_lnl_sdw_machines[] = {  	/* mockup tests need to be first */ @@ -62,6 +127,12 @@ struct snd_soc_acpi_mach snd_soc_acpi_intel_lnl_sdw_machines[] = {  		.sof_tplg_filename = "sof-lnl-rt715-rt711-rt1308-mono.tplg",  	},  	{ +		.link_mask = GENMASK(3, 0), +		.links = lnl_3_in_1_sdca, +		.drv_name = "sof_sdw", +		.sof_tplg_filename = "sof-lnl-rt711-l0-rt1316-l23-rt714-l1.tplg", +	}, +	{  		.link_mask = BIT(0),  		.links = lnl_rvp,  		.drv_name = "sof_sdw", | 
