mirror of
https://github.com/torvalds/linux.git
synced 2024-11-10 22:21:40 +00:00
ASoC: mediatek: Use common mtk_afe_pcm_platform with common probe cb
Since the mtk-afe-platform-driver generic mtk_afe_pcm_platform now has a common .probe() callback, there is no reason to keep duplicating this function over and over in the SoC specific AFE-PCM drivers: switch over to register with the common bits instead. Note that MT8186 was left out of this because it is registering some extra sinegen controls in the AFE-PCM probe callback and needs extra cleanups to be able to use the common bits. Reviewed-by: Alexandre Mergnat <amergnat@baylibre.com> Signed-off-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com> Link: https://lore.kernel.org/r/20240416071410.75620-13-angelogioacchino.delregno@collabora.com Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
9d9b182876
commit
1d2a6b3b51
@ -704,18 +704,6 @@ static int mt6797_afe_runtime_resume(struct device *dev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int mt6797_afe_component_probe(struct snd_soc_component *component)
|
||||
{
|
||||
return mtk_afe_add_sub_dai_control(component);
|
||||
}
|
||||
|
||||
static const struct snd_soc_component_driver mt6797_afe_component = {
|
||||
.name = AFE_PCM_NAME,
|
||||
.probe = mt6797_afe_component_probe,
|
||||
.pointer = mtk_afe_pcm_pointer,
|
||||
.pcm_construct = mtk_afe_pcm_new,
|
||||
};
|
||||
|
||||
static int mt6797_dai_memif_register(struct mtk_base_afe *afe)
|
||||
{
|
||||
struct mtk_base_afe_dai *dai;
|
||||
@ -852,7 +840,7 @@ static int mt6797_afe_pcm_dev_probe(struct platform_device *pdev)
|
||||
pm_runtime_get_sync(&pdev->dev);
|
||||
|
||||
/* register component */
|
||||
ret = devm_snd_soc_register_component(dev, &mt6797_afe_component,
|
||||
ret = devm_snd_soc_register_component(dev, &mtk_afe_pcm_platform,
|
||||
NULL, 0);
|
||||
if (ret) {
|
||||
dev_warn(dev, "err_platform\n");
|
||||
|
@ -429,18 +429,6 @@ static int mt7986_afe_runtime_resume(struct device *dev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int mt7986_afe_component_probe(struct snd_soc_component *component)
|
||||
{
|
||||
return mtk_afe_add_sub_dai_control(component);
|
||||
}
|
||||
|
||||
static const struct snd_soc_component_driver mt7986_afe_component = {
|
||||
.name = AFE_PCM_NAME,
|
||||
.probe = mt7986_afe_component_probe,
|
||||
.pointer = mtk_afe_pcm_pointer,
|
||||
.pcm_construct = mtk_afe_pcm_new,
|
||||
};
|
||||
|
||||
static int mt7986_dai_memif_register(struct mtk_base_afe *afe)
|
||||
{
|
||||
struct mtk_base_afe_dai *dai;
|
||||
@ -573,7 +561,7 @@ static int mt7986_afe_pcm_dev_probe(struct platform_device *pdev)
|
||||
|
||||
/* register component */
|
||||
ret = devm_snd_soc_register_component(&pdev->dev,
|
||||
&mt7986_afe_component,
|
||||
&mtk_afe_pcm_platform,
|
||||
NULL, 0);
|
||||
if (ret)
|
||||
return dev_err_probe(dev, ret, "Cannot register AFE component\n");
|
||||
|
@ -1042,18 +1042,6 @@ skip_regmap:
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int mt8183_afe_component_probe(struct snd_soc_component *component)
|
||||
{
|
||||
return mtk_afe_add_sub_dai_control(component);
|
||||
}
|
||||
|
||||
static const struct snd_soc_component_driver mt8183_afe_component = {
|
||||
.name = AFE_PCM_NAME,
|
||||
.probe = mt8183_afe_component_probe,
|
||||
.pointer = mtk_afe_pcm_pointer,
|
||||
.pcm_construct = mtk_afe_pcm_new,
|
||||
};
|
||||
|
||||
static int mt8183_dai_memif_register(struct mtk_base_afe *afe)
|
||||
{
|
||||
struct mtk_base_afe_dai *dai;
|
||||
@ -1232,7 +1220,7 @@ static int mt8183_afe_pcm_dev_probe(struct platform_device *pdev)
|
||||
|
||||
/* register component */
|
||||
ret = devm_snd_soc_register_component(&pdev->dev,
|
||||
&mt8183_afe_component,
|
||||
&mtk_afe_pcm_platform,
|
||||
NULL, 0);
|
||||
if (ret) {
|
||||
dev_warn(dev, "err_platform\n");
|
||||
|
@ -3030,25 +3030,6 @@ skip_regmap:
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int mt8188_afe_component_probe(struct snd_soc_component *component)
|
||||
{
|
||||
struct mtk_base_afe *afe = snd_soc_component_get_drvdata(component);
|
||||
int ret;
|
||||
|
||||
snd_soc_component_init_regmap(component, afe->regmap);
|
||||
|
||||
ret = mtk_afe_add_sub_dai_control(component);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static const struct snd_soc_component_driver mt8188_afe_component = {
|
||||
.name = AFE_PCM_NAME,
|
||||
.pointer = mtk_afe_pcm_pointer,
|
||||
.pcm_construct = mtk_afe_pcm_new,
|
||||
.probe = mt8188_afe_component_probe,
|
||||
};
|
||||
|
||||
static int init_memif_priv_data(struct mtk_base_afe *afe)
|
||||
{
|
||||
struct mt8188_afe_private *afe_priv = afe->platform_priv;
|
||||
@ -3350,7 +3331,7 @@ static int mt8188_afe_pcm_dev_probe(struct platform_device *pdev)
|
||||
}
|
||||
|
||||
/* register component */
|
||||
ret = devm_snd_soc_register_component(dev, &mt8188_afe_component,
|
||||
ret = devm_snd_soc_register_component(dev, &mtk_afe_pcm_platform,
|
||||
afe->dai_drivers, afe->num_dai_drivers);
|
||||
if (ret) {
|
||||
dev_warn(dev, "err_platform\n");
|
||||
|
@ -2125,22 +2125,6 @@ skip_regmap:
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int mt8192_afe_component_probe(struct snd_soc_component *component)
|
||||
{
|
||||
return mtk_afe_add_sub_dai_control(component);
|
||||
}
|
||||
|
||||
static const struct snd_soc_component_driver mt8192_afe_component = {
|
||||
.name = AFE_PCM_NAME,
|
||||
.probe = mt8192_afe_component_probe,
|
||||
.pointer = mtk_afe_pcm_pointer,
|
||||
.pcm_construct = mtk_afe_pcm_new,
|
||||
};
|
||||
|
||||
static const struct snd_soc_component_driver mt8192_afe_pcm_component = {
|
||||
.name = "mt8192-afe-pcm-dai",
|
||||
};
|
||||
|
||||
static int mt8192_dai_memif_register(struct mtk_base_afe *afe)
|
||||
{
|
||||
struct mtk_base_afe_dai *dai;
|
||||
@ -2302,16 +2286,11 @@ static int mt8192_afe_pcm_dev_probe(struct platform_device *pdev)
|
||||
|
||||
/* register platform */
|
||||
ret = devm_snd_soc_register_component(&pdev->dev,
|
||||
&mt8192_afe_component, NULL, 0);
|
||||
if (ret)
|
||||
return dev_err_probe(dev, ret, "Couldn't register AFE component\n");
|
||||
|
||||
ret = devm_snd_soc_register_component(&pdev->dev,
|
||||
&mt8192_afe_pcm_component,
|
||||
&mtk_afe_pcm_platform,
|
||||
afe->dai_drivers,
|
||||
afe->num_dai_drivers);
|
||||
if (ret)
|
||||
return dev_err_probe(dev, ret, "Couldn't register AFE-PCM component\n");
|
||||
return dev_err_probe(dev, ret, "Couldn't register AFE component\n");
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@ -2944,25 +2944,6 @@ skip_regmap:
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int mt8195_afe_component_probe(struct snd_soc_component *component)
|
||||
{
|
||||
struct mtk_base_afe *afe = snd_soc_component_get_drvdata(component);
|
||||
int ret = 0;
|
||||
|
||||
snd_soc_component_init_regmap(component, afe->regmap);
|
||||
|
||||
ret = mtk_afe_add_sub_dai_control(component);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static const struct snd_soc_component_driver mt8195_afe_component = {
|
||||
.name = AFE_PCM_NAME,
|
||||
.pointer = mtk_afe_pcm_pointer,
|
||||
.pcm_construct = mtk_afe_pcm_new,
|
||||
.probe = mt8195_afe_component_probe,
|
||||
};
|
||||
|
||||
static int init_memif_priv_data(struct mtk_base_afe *afe)
|
||||
{
|
||||
struct mt8195_afe_private *afe_priv = afe->platform_priv;
|
||||
@ -3164,7 +3145,7 @@ static int mt8195_afe_pcm_dev_probe(struct platform_device *pdev)
|
||||
}
|
||||
|
||||
/* register component */
|
||||
ret = devm_snd_soc_register_component(dev, &mt8195_afe_component,
|
||||
ret = devm_snd_soc_register_component(dev, &mtk_afe_pcm_platform,
|
||||
afe->dai_drivers, afe->num_dai_drivers);
|
||||
if (ret) {
|
||||
dev_warn(dev, "err_platform\n");
|
||||
|
Loading…
Reference in New Issue
Block a user