ASoC: SOF: Intel: hda: hda-dai: fix oops on hda_link .hw_free
[ Upstream commit 921162c81a089aa2f442103290f1af9ba281fc9f ] When the PCM_PARAM IPC fails while configuring the FE, the kernel oopses in the HDaudio link DMA .hw_free operation. The root cause is a NULL dma_data since the BE .hw_params was never called by the SOC core. This error can also happen if the HDaudio link DMA configuration IPC fails in the BE .hw_params. This patches makes sure the dma_data is properly saved in .hw_params, and tested before being use in hw_free. GitHub issue: https://github.com/thesofproject/linux/issues/1417 Reviewed-by: Ranjani Sridharan <ranjani.sridharan@linux.intel.com> Reviewed-by: Kai Vehmanen <kai.vehmanen@linux.intel.com> Signed-off-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com> Link: https://lore.kernel.org/r/20191218000518.5830-3-pierre-louis.bossart@linux.intel.com Signed-off-by: Mark Brown <broonie@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
eedf205f02
commit
32a369776b
@ -216,6 +216,8 @@ static int hda_link_hw_params(struct snd_pcm_substream *substream,
|
|||||||
link_dev = hda_link_stream_assign(bus, substream);
|
link_dev = hda_link_stream_assign(bus, substream);
|
||||||
if (!link_dev)
|
if (!link_dev)
|
||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
|
|
||||||
|
snd_soc_dai_set_dma_data(dai, substream, (void *)link_dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
stream_tag = hdac_stream(link_dev)->stream_tag;
|
stream_tag = hdac_stream(link_dev)->stream_tag;
|
||||||
@ -228,8 +230,6 @@ static int hda_link_hw_params(struct snd_pcm_substream *substream,
|
|||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
snd_soc_dai_set_dma_data(dai, substream, (void *)link_dev);
|
|
||||||
|
|
||||||
link = snd_hdac_ext_bus_get_link(bus, codec_dai->component->name);
|
link = snd_hdac_ext_bus_get_link(bus, codec_dai->component->name);
|
||||||
if (!link)
|
if (!link)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -361,6 +361,13 @@ static int hda_link_hw_free(struct snd_pcm_substream *substream,
|
|||||||
bus = hstream->bus;
|
bus = hstream->bus;
|
||||||
rtd = snd_pcm_substream_chip(substream);
|
rtd = snd_pcm_substream_chip(substream);
|
||||||
link_dev = snd_soc_dai_get_dma_data(dai, substream);
|
link_dev = snd_soc_dai_get_dma_data(dai, substream);
|
||||||
|
|
||||||
|
if (!link_dev) {
|
||||||
|
dev_dbg(dai->dev,
|
||||||
|
"%s: link_dev is not assigned\n", __func__);
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
hda_stream = hstream_to_sof_hda_stream(link_dev);
|
hda_stream = hstream_to_sof_hda_stream(link_dev);
|
||||||
|
|
||||||
/* free the link DMA channel in the FW */
|
/* free the link DMA channel in the FW */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user