mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-09 14:43:16 +00:00
ASoC: core: Don't set platform name when of_node is set
A DAI link has 3 components: * CPU * platform * codec(s) A component is specified via: * name * of_node * dai_name In order to avoid confusion when building a sound card we disallow matching by both name and of_node (1). soc_check_tplg_fes allows overriding certain BE links by overriding BE link name. This doesn't work well if BE link was specified via DT, because we end up with a link with both name and of_node specified which is conflicting with (1). In order to fix this we need to: * override of_node if component was specified via DT * override name, otherwise. Signed-off-by: Daniel Baluta <daniel.baluta@nxp.com> Link: https://lore.kernel.org/r/20210414101212.65573-1-daniel.baluta@oss.nxp.com Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
eea1d18e9b
commit
d971400339
@ -1658,7 +1658,11 @@ match:
|
||||
dev_err(card->dev, "init platform error");
|
||||
continue;
|
||||
}
|
||||
dai_link->platforms->name = component->name;
|
||||
|
||||
if (component->dev->of_node)
|
||||
dai_link->platforms->of_node = component->dev->of_node;
|
||||
else
|
||||
dai_link->platforms->name = component->name;
|
||||
|
||||
/* convert non BE into BE */
|
||||
if (!dai_link->no_pcm) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user