Commit ebd3b301 authored by Pierre-Louis Bossart's avatar Pierre-Louis Bossart Committed by Mark Brown

ASoC: SOF: pcm: reset all PCM sources in case of xruns

With the delayed stops, the xrun handling is problematic: the
applications expects everything to be reset but the firmware and DMA
are still in a PAUSED state.

This patch makes sure the prepare while pending_stop is set is
special-cased.
Reviewed-by: default avatarRander Wang <rander.wang@intel.com>
Reviewed-by: default avatarPéter Ujfalusi <peter.ujfalusi@linux.intel.com>
Co-developed-by: default avatarRanjani Sridharan <ranjani.sridharan@linux.intel.com>
Signed-off-by: default avatarRanjani Sridharan <ranjani.sridharan@linux.intel.com>
Signed-off-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Link: https://msgid.link/r/20240402151828.175002-17-pierre-louis.bossart@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent dbc78bce
...@@ -221,6 +221,7 @@ static int sof_pcm_prepare(struct snd_soc_component *component, ...@@ -221,6 +221,7 @@ static int sof_pcm_prepare(struct snd_soc_component *component,
struct snd_pcm_substream *substream) struct snd_pcm_substream *substream)
{ {
struct snd_soc_pcm_runtime *rtd = snd_soc_substream_to_rtd(substream); struct snd_soc_pcm_runtime *rtd = snd_soc_substream_to_rtd(substream);
struct snd_sof_dev *sdev = snd_soc_component_get_drvdata(component);
struct snd_sof_pcm *spcm; struct snd_sof_pcm *spcm;
int ret; int ret;
...@@ -232,9 +233,19 @@ static int sof_pcm_prepare(struct snd_soc_component *component, ...@@ -232,9 +233,19 @@ static int sof_pcm_prepare(struct snd_soc_component *component,
if (!spcm) if (!spcm)
return -EINVAL; return -EINVAL;
if (spcm->prepared[substream->stream]) if (spcm->prepared[substream->stream]) {
if (!spcm->pending_stop[substream->stream])
return 0; return 0;
/*
* this case should be reached in case of xruns where we absolutely
* want to free-up and reset all PCM/DMA resources
*/
ret = sof_pcm_stream_free(sdev, substream, spcm, substream->stream, true);
if (ret < 0)
return ret;
}
dev_dbg(component->dev, "pcm: prepare stream %d dir %d\n", dev_dbg(component->dev, "pcm: prepare stream %d dir %d\n",
spcm->pcm.pcm_id, substream->stream); spcm->pcm.pcm_id, substream->stream);
......
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