ASoC: Define soc_init_dai_link() to wrap link intialization.
Define soc_init_dai_link() to wrap link initialization, to reuse it later by snd_soc_instantiate_card() when adding new DAI links from topology in component probing phase. Move static func snd_soc_init_multicodec(), so that it can be reused by soc_init_dai_link(). This saves adding a function declaration for snd_soc_init_multicodec(). Signed-off-by: Mengdong Lin <mengdong.lin@linux.intel.com> Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
a29d0f3ef9
commit
923c5e61ec
1 changed files with 98 additions and 83 deletions
|
@ -1134,6 +1134,100 @@ static void soc_remove_dai_links(struct snd_soc_card *card)
|
|||
}
|
||||
}
|
||||
|
||||
static int snd_soc_init_multicodec(struct snd_soc_card *card,
|
||||
struct snd_soc_dai_link *dai_link)
|
||||
{
|
||||
/* Legacy codec/codec_dai link is a single entry in multicodec */
|
||||
if (dai_link->codec_name || dai_link->codec_of_node ||
|
||||
dai_link->codec_dai_name) {
|
||||
dai_link->num_codecs = 1;
|
||||
|
||||
dai_link->codecs = devm_kzalloc(card->dev,
|
||||
sizeof(struct snd_soc_dai_link_component),
|
||||
GFP_KERNEL);
|
||||
if (!dai_link->codecs)
|
||||
return -ENOMEM;
|
||||
|
||||
dai_link->codecs[0].name = dai_link->codec_name;
|
||||
dai_link->codecs[0].of_node = dai_link->codec_of_node;
|
||||
dai_link->codecs[0].dai_name = dai_link->codec_dai_name;
|
||||
}
|
||||
|
||||
if (!dai_link->codecs) {
|
||||
dev_err(card->dev, "ASoC: DAI link has no CODECs\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int soc_init_dai_link(struct snd_soc_card *card,
|
||||
struct snd_soc_dai_link *link)
|
||||
{
|
||||
int i, ret;
|
||||
|
||||
ret = snd_soc_init_multicodec(card, link);
|
||||
if (ret) {
|
||||
dev_err(card->dev, "ASoC: failed to init multicodec\n");
|
||||
return ret;
|
||||
}
|
||||
|
||||
for (i = 0; i < link->num_codecs; i++) {
|
||||
/*
|
||||
* Codec must be specified by 1 of name or OF node,
|
||||
* not both or neither.
|
||||
*/
|
||||
if (!!link->codecs[i].name ==
|
||||
!!link->codecs[i].of_node) {
|
||||
dev_err(card->dev, "ASoC: Neither/both codec name/of_node are set for %s\n",
|
||||
link->name);
|
||||
return -EINVAL;
|
||||
}
|
||||
/* Codec DAI name must be specified */
|
||||
if (!link->codecs[i].dai_name) {
|
||||
dev_err(card->dev, "ASoC: codec_dai_name not set for %s\n",
|
||||
link->name);
|
||||
return -EINVAL;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Platform may be specified by either name or OF node, but
|
||||
* can be left unspecified, and a dummy platform will be used.
|
||||
*/
|
||||
if (link->platform_name && link->platform_of_node) {
|
||||
dev_err(card->dev,
|
||||
"ASoC: Both platform name/of_node are set for %s\n",
|
||||
link->name);
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/*
|
||||
* CPU device may be specified by either name or OF node, but
|
||||
* can be left unspecified, and will be matched based on DAI
|
||||
* name alone..
|
||||
*/
|
||||
if (link->cpu_name && link->cpu_of_node) {
|
||||
dev_err(card->dev,
|
||||
"ASoC: Neither/both cpu name/of_node are set for %s\n",
|
||||
link->name);
|
||||
return -EINVAL;
|
||||
}
|
||||
/*
|
||||
* At least one of CPU DAI name or CPU device name/node must be
|
||||
* specified
|
||||
*/
|
||||
if (!link->cpu_dai_name &&
|
||||
!(link->cpu_name || link->cpu_of_node)) {
|
||||
dev_err(card->dev,
|
||||
"ASoC: Neither cpu_dai_name nor cpu_name/of_node are set for %s\n",
|
||||
link->name);
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void soc_set_name_prefix(struct snd_soc_card *card,
|
||||
struct snd_soc_component *component)
|
||||
{
|
||||
|
@ -2356,33 +2450,6 @@ int snd_soc_dai_digital_mute(struct snd_soc_dai *dai, int mute,
|
|||
}
|
||||
EXPORT_SYMBOL_GPL(snd_soc_dai_digital_mute);
|
||||
|
||||
static int snd_soc_init_multicodec(struct snd_soc_card *card,
|
||||
struct snd_soc_dai_link *dai_link)
|
||||
{
|
||||
/* Legacy codec/codec_dai link is a single entry in multicodec */
|
||||
if (dai_link->codec_name || dai_link->codec_of_node ||
|
||||
dai_link->codec_dai_name) {
|
||||
dai_link->num_codecs = 1;
|
||||
|
||||
dai_link->codecs = devm_kzalloc(card->dev,
|
||||
sizeof(struct snd_soc_dai_link_component),
|
||||
GFP_KERNEL);
|
||||
if (!dai_link->codecs)
|
||||
return -ENOMEM;
|
||||
|
||||
dai_link->codecs[0].name = dai_link->codec_name;
|
||||
dai_link->codecs[0].of_node = dai_link->codec_of_node;
|
||||
dai_link->codecs[0].dai_name = dai_link->codec_dai_name;
|
||||
}
|
||||
|
||||
if (!dai_link->codecs) {
|
||||
dev_err(card->dev, "ASoC: DAI link has no CODECs\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* snd_soc_register_card - Register a card with the ASoC core
|
||||
*
|
||||
|
@ -2391,7 +2458,7 @@ static int snd_soc_init_multicodec(struct snd_soc_card *card,
|
|||
*/
|
||||
int snd_soc_register_card(struct snd_soc_card *card)
|
||||
{
|
||||
int i, j, ret;
|
||||
int i, ret;
|
||||
struct snd_soc_pcm_runtime *rtd;
|
||||
|
||||
if (!card->name || !card->dev)
|
||||
|
@ -2400,64 +2467,12 @@ int snd_soc_register_card(struct snd_soc_card *card)
|
|||
for (i = 0; i < card->num_links; i++) {
|
||||
struct snd_soc_dai_link *link = &card->dai_link[i];
|
||||
|
||||
ret = snd_soc_init_multicodec(card, link);
|
||||
ret = soc_init_dai_link(card, link);
|
||||
if (ret) {
|
||||
dev_err(card->dev, "ASoC: failed to init multicodec\n");
|
||||
dev_err(card->dev, "ASoC: failed to init link %s\n",
|
||||
link->name);
|
||||
return ret;
|
||||
}
|
||||
|
||||
for (j = 0; j < link->num_codecs; j++) {
|
||||
/*
|
||||
* Codec must be specified by 1 of name or OF node,
|
||||
* not both or neither.
|
||||
*/
|
||||
if (!!link->codecs[j].name ==
|
||||
!!link->codecs[j].of_node) {
|
||||
dev_err(card->dev, "ASoC: Neither/both codec name/of_node are set for %s\n",
|
||||
link->name);
|
||||
return -EINVAL;
|
||||
}
|
||||
/* Codec DAI name must be specified */
|
||||
if (!link->codecs[j].dai_name) {
|
||||
dev_err(card->dev, "ASoC: codec_dai_name not set for %s\n",
|
||||
link->name);
|
||||
return -EINVAL;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Platform may be specified by either name or OF node, but
|
||||
* can be left unspecified, and a dummy platform will be used.
|
||||
*/
|
||||
if (link->platform_name && link->platform_of_node) {
|
||||
dev_err(card->dev,
|
||||
"ASoC: Both platform name/of_node are set for %s\n",
|
||||
link->name);
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/*
|
||||
* CPU device may be specified by either name or OF node, but
|
||||
* can be left unspecified, and will be matched based on DAI
|
||||
* name alone..
|
||||
*/
|
||||
if (link->cpu_name && link->cpu_of_node) {
|
||||
dev_err(card->dev,
|
||||
"ASoC: Neither/both cpu name/of_node are set for %s\n",
|
||||
link->name);
|
||||
return -EINVAL;
|
||||
}
|
||||
/*
|
||||
* At least one of CPU DAI name or CPU device name/node must be
|
||||
* specified
|
||||
*/
|
||||
if (!link->cpu_dai_name &&
|
||||
!(link->cpu_name || link->cpu_of_node)) {
|
||||
dev_err(card->dev,
|
||||
"ASoC: Neither cpu_dai_name nor cpu_name/of_node are set for %s\n",
|
||||
link->name);
|
||||
return -EINVAL;
|
||||
}
|
||||
}
|
||||
|
||||
dev_set_drvdata(card->dev, card);
|
||||
|
|
Loading…
Add table
Reference in a new issue