Commit dc5a3e60 authored by Bard Liao's avatar Bard Liao Committed by Mark Brown

ASoC: Intel: sof_sdw: append codec type to dai link name

The existing sdw_sof machine driver constructs two SoundWire interfaces
by direction and sdw link id. It means that we will have exactly the
same dai link name if two dai links are on the same sdw link with the
same direction.
The new Realtek codec has two SoundWire interfaces for jack and DMIC
functions and they are treated as different codecs. To create two dai
links for jack and DMIC, we need to have different dai link names.
This patch suggests to append codec type if there are two or more
different types of devices on the same sdw bus.
Signed-off-by: default avatarBard Liao <yung-chuan.liao@linux.intel.com>
Signed-off-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Reviewed-by: default avatarRander Wang <rander.wang@intel.com>
Link: https://lore.kernel.org/r/20230419195524.46995-8-pierre-louis.bossart@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent c8db7b50
...@@ -1022,6 +1022,8 @@ static int get_slave_info(const struct snd_soc_acpi_link_adr *adr_link, ...@@ -1022,6 +1022,8 @@ static int get_slave_info(const struct snd_soc_acpi_link_adr *adr_link,
return 0; return 0;
} }
static const char * const type_strings[] = {"SimpleJack", "SmartAmp", "SmartMic"};
static int create_sdw_dailink(struct snd_soc_card *card, static int create_sdw_dailink(struct snd_soc_card *card,
struct device *dev, int *link_index, struct device *dev, int *link_index,
struct snd_soc_dai_link *dai_links, struct snd_soc_dai_link *dai_links,
...@@ -1033,6 +1035,7 @@ static int create_sdw_dailink(struct snd_soc_card *card, ...@@ -1033,6 +1035,7 @@ static int create_sdw_dailink(struct snd_soc_card *card,
int codec_count, int *link_id, int codec_count, int *link_id,
int *codec_conf_index, int *codec_conf_index,
bool *ignore_pch_dmic, bool *ignore_pch_dmic,
bool append_codec_type,
int adr_index) int adr_index)
{ {
const struct snd_soc_acpi_link_adr *link_next; const struct snd_soc_acpi_link_adr *link_next;
...@@ -1109,14 +1112,22 @@ static int create_sdw_dailink(struct snd_soc_card *card, ...@@ -1109,14 +1112,22 @@ static int create_sdw_dailink(struct snd_soc_card *card,
static const char * const sdw_stream_name[] = { static const char * const sdw_stream_name[] = {
"SDW%d-Playback", "SDW%d-Playback",
"SDW%d-Capture", "SDW%d-Capture",
"SDW%d-Playback-%s",
"SDW%d-Capture-%s",
}; };
if (!codec_info_list[codec_index].direction[stream]) if (!codec_info_list[codec_index].direction[stream])
continue; continue;
/* create stream name according to first link id */ /* create stream name according to first link id */
name = devm_kasprintf(dev, GFP_KERNEL, if (append_codec_type) {
sdw_stream_name[stream], cpu_dai_id[0]); name = devm_kasprintf(dev, GFP_KERNEL,
sdw_stream_name[stream + 2], cpu_dai_id[0],
type_strings[codec_info_list[codec_index].codec_type]);
} else {
name = devm_kasprintf(dev, GFP_KERNEL,
sdw_stream_name[stream], cpu_dai_id[0]);
}
if (!name) if (!name)
return -ENOMEM; return -ENOMEM;
...@@ -1232,6 +1243,7 @@ static int sof_card_dai_links_create(struct device *dev, ...@@ -1232,6 +1243,7 @@ static int sof_card_dai_links_create(struct device *dev,
const struct snd_soc_acpi_link_adr *adr_link; const struct snd_soc_acpi_link_adr *adr_link;
struct snd_soc_dai_link_component *cpus; struct snd_soc_dai_link_component *cpus;
struct snd_soc_codec_conf *codec_conf; struct snd_soc_codec_conf *codec_conf;
bool append_codec_type = false;
bool ignore_pch_dmic = false; bool ignore_pch_dmic = false;
int codec_conf_count; int codec_conf_count;
int codec_conf_index = 0; int codec_conf_index = 0;
...@@ -1323,8 +1335,29 @@ static int sof_card_dai_links_create(struct device *dev, ...@@ -1323,8 +1335,29 @@ static int sof_card_dai_links_create(struct device *dev,
for (i = 0; i < SDW_MAX_GROUPS; i++) for (i = 0; i < SDW_MAX_GROUPS; i++)
group_generated[i] = false; group_generated[i] = false;
/* generate DAI links by each sdw link */
for (; adr_link->num_adr; adr_link++) { for (; adr_link->num_adr; adr_link++) {
/*
* If there are two or more different devices on the same sdw link, we have to
* append the codec type to the dai link name to prevent duplicated dai link name.
* The same type devices on the same sdw link will be in the same
* snd_soc_acpi_adr_device array. They won't be described in different adr_links.
*/
for (i = 0; i < adr_link->num_adr; i++) {
for (j = 0; j < i; j++) {
if ((SDW_PART_ID(adr_link->adr_d[i].adr) !=
SDW_PART_ID(adr_link->adr_d[j].adr)) ||
(SDW_MFG_ID(adr_link->adr_d[i].adr) !=
SDW_MFG_ID(adr_link->adr_d[i].adr))) {
append_codec_type = true;
goto out;
}
}
}
}
out:
/* generate DAI links by each sdw link */
for (adr_link = mach_params->links ; adr_link->num_adr; adr_link++) {
for (i = 0; i < adr_link->num_adr; i++) { for (i = 0; i < adr_link->num_adr; i++) {
const struct snd_soc_acpi_endpoint *endpoint; const struct snd_soc_acpi_endpoint *endpoint;
...@@ -1345,7 +1378,7 @@ static int sof_card_dai_links_create(struct device *dev, ...@@ -1345,7 +1378,7 @@ static int sof_card_dai_links_create(struct device *dev,
&cpu_id, group_generated, &cpu_id, group_generated,
codec_conf, codec_conf_count, codec_conf, codec_conf_count,
&be_id, &codec_conf_index, &be_id, &codec_conf_index,
&ignore_pch_dmic, i); &ignore_pch_dmic, append_codec_type, i);
if (ret < 0) { if (ret < 0) {
dev_err(dev, "failed to create dai link %d", link_index); dev_err(dev, "failed to create dai link %d", link_index);
return ret; return ret;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment