Commit 6b4c7d4d authored by Bard Liao's avatar Bard Liao Committed by Mark Brown

ASoC: Intel: sof_sdw: starts non sdw BE id with the highest sdw BE id

The soundwire links do not have their IDs as consecutive numbers, thus
the last link might have lower be_id than the previous one and this
leads to id collision with non SDW links.

For example,
create dai link SDW0-Playback-SimpleJack, id 0
create dai link SDW0-Capture-SmartMic, id 4
create dai link SDW0-Capture-SimpleJack, id 1
create dai link SDW2-Playback-SmartAmp, id 2
create dai link SDW2-Capture-SmartAmp, id 3
create dai link iDisp1, id 4
create dai link iDisp2, id 5
create dai link iDisp3, id 6
Reviewed-by: default avatarChao Song <chao.song@linux.intel.com>
Co-developed-by: default avatarPeter Ujfalusi <peter.ujfalusi@linux.intel.com>
Signed-off-by: default avatarPeter Ujfalusi <peter.ujfalusi@linux.intel.com>
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>
Link: https://lore.kernel.org/r/20240208165545.93811-25-pierre-louis.bossart@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 7fa43af5
...@@ -1767,15 +1767,21 @@ static int sof_card_dai_links_create(struct snd_soc_card *card) ...@@ -1767,15 +1767,21 @@ static int sof_card_dai_links_create(struct snd_soc_card *card)
return codec_index; return codec_index;
for (j = 0; j < codec_info_list[codec_index].dai_num ; j++) { for (j = 0; j < codec_info_list[codec_index].dai_num ; j++) {
int current_be_id;
ret = create_sdw_dailink(card, &link_index, dai_links, ret = create_sdw_dailink(card, &link_index, dai_links,
sdw_be_num, adr_link, sdw_be_num, adr_link,
codec_conf, codec_conf_num, codec_conf, codec_conf_num,
&be_id, &codec_conf_index, &current_be_id, &codec_conf_index,
&ignore_pch_dmic, append_dai_type, i, j); &ignore_pch_dmic, append_dai_type, i, j);
if (ret < 0) { if (ret < 0) {
dev_err(dev, "failed to create dai link %d\n", link_index); dev_err(dev, "failed to create dai link %d\n", link_index);
return ret; return ret;
} }
/* Update the be_id to match the highest ID used for SDW link */
if (be_id < current_be_id)
be_id = current_be_id;
} }
if (aggregation && endpoint->aggregated) if (aggregation && endpoint->aggregated)
......
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