]> git.baikalelectronics.ru Git - kernel.git/commit
ASoC: mediatek: mt8195: correct pcmif BE dai control flow
authorTrevor Wu <trevor.wu@mediatek.com>
Thu, 30 Dec 2021 08:47:30 +0000 (16:47 +0800)
committerMark Brown <broonie@kernel.org>
Fri, 31 Dec 2021 13:20:57 +0000 (13:20 +0000)
commit0ed4d14c4b6e43378fd15b43d68eb444b2aadca4
treeba1595afb4e566242911622951882ea792bc72ea
parent354334d997f3333cce2db6808fc07b8aa8d43b8e
ASoC: mediatek: mt8195: correct pcmif BE dai control flow

Originally, the conditions for preventing reentry are not correct.
dai->component->active is not the state specifically for pcmif dai, so it
is not a correct condition to indicate the status of pcmif dai.
On the other hand, snd_soc_dai_stream_actvie() in prepare ops for both
playback and capture possibly return true at the first entry when these
two streams are opened at the same time.

In the patch, I refer to the implementation in mt8192-dai-pcm.c.
Clock and enabling bit for PCMIF are managed by DAPM, and the condition
for prepare ops is replaced by the status of dai widget.

Fixes: 5bb665c6afa1 ("ASoC: mediatek: mt8195: support pcm in platform driver")
Signed-off-by: Trevor Wu <trevor.wu@mediatek.com>
Link: https://lore.kernel.org/r/20211230084731.31372-2-trevor.wu@mediatek.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/mediatek/mt8195/mt8195-dai-pcm.c
sound/soc/mediatek/mt8195/mt8195-reg.h