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)
commit2355028c0c54c03afb66c589347f1dc9f6fe2e38
treeba1595afb4e566242911622951882ea792bc72ea
parentcc5c9788106fb1b9e03c8c57d8d7166073a54416
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: 1f95c019115c ("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