Commit 22a16145 authored by Shengjiu Wang's avatar Shengjiu Wang Committed by Mark Brown

ASoC: fsl_sai: Instantiate snd_soc_dai_driver

Instantiate snd_soc_dai_driver for independent symmetric control.
Otherwise the symmetric setting may be overwritten by other
instance.

Fixes: 08fdf65e ("ASoC: fsl_sai: Add asynchronous mode support")
Signed-off-by: default avatarShengjiu Wang <shengjiu.wang@nxp.com>
Link: https://lore.kernel.org/r/1600424760-32071-1-git-send-email-shengjiu.wang@nxp.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent b03acae2
...@@ -694,7 +694,7 @@ static int fsl_sai_dai_probe(struct snd_soc_dai *cpu_dai) ...@@ -694,7 +694,7 @@ static int fsl_sai_dai_probe(struct snd_soc_dai *cpu_dai)
return 0; return 0;
} }
static struct snd_soc_dai_driver fsl_sai_dai = { static struct snd_soc_dai_driver fsl_sai_dai_template = {
.probe = fsl_sai_dai_probe, .probe = fsl_sai_dai_probe,
.playback = { .playback = {
.stream_name = "CPU-Playback", .stream_name = "CPU-Playback",
...@@ -966,12 +966,15 @@ static int fsl_sai_probe(struct platform_device *pdev) ...@@ -966,12 +966,15 @@ static int fsl_sai_probe(struct platform_device *pdev)
return ret; return ret;
} }
memcpy(&sai->cpu_dai_drv, &fsl_sai_dai_template,
sizeof(fsl_sai_dai_template));
/* Sync Tx with Rx as default by following old DT binding */ /* Sync Tx with Rx as default by following old DT binding */
sai->synchronous[RX] = true; sai->synchronous[RX] = true;
sai->synchronous[TX] = false; sai->synchronous[TX] = false;
fsl_sai_dai.symmetric_rates = 1; sai->cpu_dai_drv.symmetric_rates = 1;
fsl_sai_dai.symmetric_channels = 1; sai->cpu_dai_drv.symmetric_channels = 1;
fsl_sai_dai.symmetric_samplebits = 1; sai->cpu_dai_drv.symmetric_samplebits = 1;
if (of_find_property(np, "fsl,sai-synchronous-rx", NULL) && if (of_find_property(np, "fsl,sai-synchronous-rx", NULL) &&
of_find_property(np, "fsl,sai-asynchronous", NULL)) { of_find_property(np, "fsl,sai-asynchronous", NULL)) {
...@@ -988,9 +991,9 @@ static int fsl_sai_probe(struct platform_device *pdev) ...@@ -988,9 +991,9 @@ static int fsl_sai_probe(struct platform_device *pdev)
/* Discard all settings for asynchronous mode */ /* Discard all settings for asynchronous mode */
sai->synchronous[RX] = false; sai->synchronous[RX] = false;
sai->synchronous[TX] = false; sai->synchronous[TX] = false;
fsl_sai_dai.symmetric_rates = 0; sai->cpu_dai_drv.symmetric_rates = 0;
fsl_sai_dai.symmetric_channels = 0; sai->cpu_dai_drv.symmetric_channels = 0;
fsl_sai_dai.symmetric_samplebits = 0; sai->cpu_dai_drv.symmetric_samplebits = 0;
} }
if (of_find_property(np, "fsl,sai-mclk-direction-output", NULL) && if (of_find_property(np, "fsl,sai-mclk-direction-output", NULL) &&
...@@ -1020,7 +1023,7 @@ static int fsl_sai_probe(struct platform_device *pdev) ...@@ -1020,7 +1023,7 @@ static int fsl_sai_probe(struct platform_device *pdev)
regcache_cache_only(sai->regmap, true); regcache_cache_only(sai->regmap, true);
ret = devm_snd_soc_register_component(&pdev->dev, &fsl_component, ret = devm_snd_soc_register_component(&pdev->dev, &fsl_component,
&fsl_sai_dai, 1); &sai->cpu_dai_drv, 1);
if (ret) if (ret)
goto err_pm_disable; goto err_pm_disable;
......
...@@ -180,6 +180,7 @@ struct fsl_sai { ...@@ -180,6 +180,7 @@ struct fsl_sai {
unsigned int bclk_ratio; unsigned int bclk_ratio;
const struct fsl_sai_soc_data *soc_data; const struct fsl_sai_soc_data *soc_data;
struct snd_soc_dai_driver cpu_dai_drv;
struct snd_dmaengine_dai_dma_data dma_params_rx; struct snd_dmaengine_dai_dma_data dma_params_rx;
struct snd_dmaengine_dai_dma_data dma_params_tx; struct snd_dmaengine_dai_dma_data dma_params_tx;
}; };
......
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