Commit 671dd2ff authored by Venkata Prasad Potturu's avatar Venkata Prasad Potturu Committed by Mark Brown

ASoC: amd: acp: Add new cpu dai and dailink creation for I2S BT instance

Add sof_bt cpu id and create dailink for i2s bt instance in
acp common machine driver.
Signed-off-by: default avatarVenkata Prasad Potturu <venkataprasad.potturu@amd.com>
Link: https://lore.kernel.org/r/20231206110620.1695591-4-venkataprasad.potturu@amd.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent e1267814
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
// This file is provided under a dual BSD/GPLv2 license. When using or // This file is provided under a dual BSD/GPLv2 license. When using or
// redistributing this file, you may do so under either license. // redistributing this file, you may do so under either license.
// //
// Copyright(c) 2021 Advanced Micro Devices, Inc. // Copyright(c) 2021, 2023 Advanced Micro Devices, Inc.
// //
// Authors: Ajit Kumar Pandey <AjitKumar.Pandey@amd.com> // Authors: Ajit Kumar Pandey <AjitKumar.Pandey@amd.com>
// Vijendar Mukunda <Vijendar.Mukunda@amd.com> // Vijendar Mukunda <Vijendar.Mukunda@amd.com>
...@@ -1290,6 +1290,8 @@ SND_SOC_DAILINK_DEF(sof_hs, ...@@ -1290,6 +1290,8 @@ SND_SOC_DAILINK_DEF(sof_hs,
DAILINK_COMP_ARRAY(COMP_CPU("acp-sof-hs"))); DAILINK_COMP_ARRAY(COMP_CPU("acp-sof-hs")));
SND_SOC_DAILINK_DEF(sof_hs_virtual, SND_SOC_DAILINK_DEF(sof_hs_virtual,
DAILINK_COMP_ARRAY(COMP_CPU("acp-sof-hs-virtual"))); DAILINK_COMP_ARRAY(COMP_CPU("acp-sof-hs-virtual")));
SND_SOC_DAILINK_DEF(sof_bt,
DAILINK_COMP_ARRAY(COMP_CPU("acp-sof-bt")));
SND_SOC_DAILINK_DEF(sof_dmic, SND_SOC_DAILINK_DEF(sof_dmic,
DAILINK_COMP_ARRAY(COMP_CPU("acp-sof-dmic"))); DAILINK_COMP_ARRAY(COMP_CPU("acp-sof-dmic")));
SND_SOC_DAILINK_DEF(pdm_dmic, SND_SOC_DAILINK_DEF(pdm_dmic,
...@@ -1348,6 +1350,8 @@ int acp_sofdsp_dai_links_create(struct snd_soc_card *card) ...@@ -1348,6 +1350,8 @@ int acp_sofdsp_dai_links_create(struct snd_soc_card *card)
if (drv_data->hs_cpu_id) if (drv_data->hs_cpu_id)
num_links++; num_links++;
if (drv_data->bt_cpu_id)
num_links++;
if (drv_data->amp_cpu_id) if (drv_data->amp_cpu_id)
num_links++; num_links++;
if (drv_data->dmic_cpu_id) if (drv_data->dmic_cpu_id)
...@@ -1497,6 +1501,25 @@ int acp_sofdsp_dai_links_create(struct snd_soc_card *card) ...@@ -1497,6 +1501,25 @@ int acp_sofdsp_dai_links_create(struct snd_soc_card *card)
i++; i++;
} }
if (drv_data->bt_cpu_id == I2S_BT) {
links[i].name = "acp-bt-codec";
links[i].id = BT_BE_ID;
links[i].cpus = sof_bt;
links[i].num_cpus = ARRAY_SIZE(sof_bt);
links[i].platforms = sof_component;
links[i].num_platforms = ARRAY_SIZE(sof_component);
links[i].dpcm_playback = 1;
links[i].dpcm_capture = 1;
links[i].nonatomic = true;
links[i].no_pcm = 1;
if (!drv_data->bt_codec_id) {
/* Use dummy codec if codec id not specified */
links[i].codecs = &snd_soc_dummy_dlc;
links[i].num_codecs = 1;
}
i++;
}
if (drv_data->dmic_cpu_id == DMIC) { if (drv_data->dmic_cpu_id == DMIC) {
links[i].name = "acp-dmic-codec"; links[i].name = "acp-dmic-codec";
links[i].id = DMIC_BE_ID; links[i].id = DMIC_BE_ID;
......
...@@ -28,6 +28,7 @@ enum be_id { ...@@ -28,6 +28,7 @@ enum be_id {
HEADSET_BE_ID = 0, HEADSET_BE_ID = 0,
AMP_BE_ID, AMP_BE_ID,
DMIC_BE_ID, DMIC_BE_ID,
BT_BE_ID,
}; };
enum cpu_endpoints { enum cpu_endpoints {
...@@ -68,9 +69,11 @@ struct acp_mach_ops { ...@@ -68,9 +69,11 @@ struct acp_mach_ops {
struct acp_card_drvdata { struct acp_card_drvdata {
unsigned int hs_cpu_id; unsigned int hs_cpu_id;
unsigned int amp_cpu_id; unsigned int amp_cpu_id;
unsigned int bt_cpu_id;
unsigned int dmic_cpu_id; unsigned int dmic_cpu_id;
unsigned int hs_codec_id; unsigned int hs_codec_id;
unsigned int amp_codec_id; unsigned int amp_codec_id;
unsigned int bt_codec_id;
unsigned int dmic_codec_id; unsigned int dmic_codec_id;
unsigned int dai_fmt; unsigned int dai_fmt;
unsigned int platform; unsigned int platform;
......
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