Commit 53d8df6d authored by Brent Lu's avatar Brent Lu Committed by Mark Brown

ASoC: Intel: board_helpers: support BT offload link initialization

Add a helper function for machine drivers to initialize BT offload
DAI link.
Signed-off-by: default avatarBrent Lu <brent.lu@intel.com>
Reviewed-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Reviewed-by: default avatarBard Liao <yung-chuan.liao@linux.intel.com>
Signed-off-by: default avatarPeter Ujfalusi <peter.ujfalusi@linux.intel.com>
Link: https://lore.kernel.org/r/20231127152654.28204-17-peter.ujfalusi@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 82340481
...@@ -290,6 +290,49 @@ int sof_intel_board_set_ssp_amp_link(struct device *dev, ...@@ -290,6 +290,49 @@ int sof_intel_board_set_ssp_amp_link(struct device *dev,
} }
EXPORT_SYMBOL_NS(sof_intel_board_set_ssp_amp_link, SND_SOC_INTEL_SOF_BOARD_HELPERS); EXPORT_SYMBOL_NS(sof_intel_board_set_ssp_amp_link, SND_SOC_INTEL_SOF_BOARD_HELPERS);
int sof_intel_board_set_bt_link(struct device *dev,
struct snd_soc_dai_link *link, int be_id,
int ssp_bt)
{
struct snd_soc_dai_link_component *cpus;
dev_dbg(dev, "link %d: bt offload, ssp %d\n", be_id, ssp_bt);
/* link name */
link->name = devm_kasprintf(dev, GFP_KERNEL, "SSP%d-BT", ssp_bt);
if (!link->name)
return -ENOMEM;
/* cpus */
cpus = devm_kzalloc(dev, sizeof(struct snd_soc_dai_link_component),
GFP_KERNEL);
if (!cpus)
return -ENOMEM;
cpus->dai_name = devm_kasprintf(dev, GFP_KERNEL, "SSP%d Pin", ssp_bt);
if (!cpus->dai_name)
return -ENOMEM;
link->cpus = cpus;
link->num_cpus = 1;
/* codecs */
link->codecs = &snd_soc_dummy_dlc;
link->num_codecs = 1;
/* platforms */
link->platforms = platform_component;
link->num_platforms = ARRAY_SIZE(platform_component);
link->id = be_id;
link->no_pcm = 1;
link->dpcm_capture = 1;
link->dpcm_playback = 1;
return 0;
}
EXPORT_SYMBOL_NS(sof_intel_board_set_bt_link, SND_SOC_INTEL_SOF_BOARD_HELPERS);
MODULE_DESCRIPTION("ASoC Intel SOF Machine Driver Board Helpers"); MODULE_DESCRIPTION("ASoC Intel SOF Machine Driver Board Helpers");
MODULE_AUTHOR("Brent Lu <brent.lu@intel.com>"); MODULE_AUTHOR("Brent Lu <brent.lu@intel.com>");
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
......
...@@ -32,6 +32,8 @@ struct sof_rt5682_private { ...@@ -32,6 +32,8 @@ struct sof_rt5682_private {
* @hdmi_num: number of Intel HDMI BE link * @hdmi_num: number of Intel HDMI BE link
* @ssp_codec: ssp port number of headphone BE link * @ssp_codec: ssp port number of headphone BE link
* @ssp_amp: ssp port number of speaker BE link * @ssp_amp: ssp port number of speaker BE link
* @ssp_bt: ssp port number of BT offload BE link
* @bt_offload_present: true to create BT offload BE link
* @rt5682: private data for rt5682 machine driver * @rt5682: private data for rt5682 machine driver
*/ */
struct sof_card_private { struct sof_card_private {
...@@ -46,6 +48,9 @@ struct sof_card_private { ...@@ -46,6 +48,9 @@ struct sof_card_private {
int ssp_codec; int ssp_codec;
int ssp_amp; int ssp_amp;
int ssp_bt;
bool bt_offload_present;
union { union {
struct sof_rt5682_private rt5682; struct sof_rt5682_private rt5682;
...@@ -71,5 +76,8 @@ int sof_intel_board_set_intel_hdmi_link(struct device *dev, ...@@ -71,5 +76,8 @@ int sof_intel_board_set_intel_hdmi_link(struct device *dev,
int sof_intel_board_set_ssp_amp_link(struct device *dev, int sof_intel_board_set_ssp_amp_link(struct device *dev,
struct snd_soc_dai_link *link, int be_id, struct snd_soc_dai_link *link, int be_id,
enum sof_ssp_codec amp_type, int ssp_amp); enum sof_ssp_codec amp_type, int ssp_amp);
int sof_intel_board_set_bt_link(struct device *dev,
struct snd_soc_dai_link *link, int be_id,
int ssp_bt);
#endif /* __SOF_INTEL_BOARD_HELPERS_H */ #endif /* __SOF_INTEL_BOARD_HELPERS_H */
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