All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] ASoC: rockchip: i2s-tdm: Fix trcm mode by setting clock on right mclk
@ 2024-06-04 18:47 ` Alibek Omarov
  0 siblings, 0 replies; 12+ messages in thread
From: Alibek Omarov @ 2024-06-04 18:47 UTC (permalink / raw)
  To: luca.ceresoli, Nicolas Frattaroli, Liam Girdwood, Mark Brown,
	Jaroslav Kysela, Takashi Iwai, Heiko Stuebner
  Cc: Alibek Omarov, linux-rockchip, linux-sound, linux-arm-kernel,
	linux-kernel

When TRCM mode is enabled, I2S RX and TX clocks are synchronized through
selected clock source. Without this fix BCLK and LRCK might get parented
to an uninitialized MCLK and the DAI will receive data at wrong pace.

However, unlike in original i2s-tdm driver, there is no need to manually
synchronize mclk_rx and mclk_tx, as only one gets used anyway.

Tested on a board with RK3568 SoC and Silergy SY24145S codec with enabled and
disabled TRCM mode.

Fixes: 9e2ab4b18ebd ("ASoC: rockchip: i2s-tdm: Fix inaccurate sampling rates")
Signed-off-by: Alibek Omarov <a1ba.omarov@gmail.com>
---
 sound/soc/rockchip/rockchip_i2s_tdm.c | 13 +++++++++++--
 1 file changed, 11 insertions(+), 2 deletions(-)

diff --git a/sound/soc/rockchip/rockchip_i2s_tdm.c b/sound/soc/rockchip/rockchip_i2s_tdm.c
index 9fa020ef7eab..ee517d7b5b7b 100644
--- a/sound/soc/rockchip/rockchip_i2s_tdm.c
+++ b/sound/soc/rockchip/rockchip_i2s_tdm.c
@@ -655,8 +655,17 @@ static int rockchip_i2s_tdm_hw_params(struct snd_pcm_substream *substream,
 	int err;
 
 	if (i2s_tdm->is_master_mode) {
-		struct clk *mclk = (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) ?
-			i2s_tdm->mclk_tx : i2s_tdm->mclk_rx;
+		struct clk *mclk;
+
+		if (i2s_tdm->clk_trcm == TRCM_TX) {
+			mclk = i2s_tdm->mclk_tx;
+		} else if (i2s_tdm->clk_trcm == TRCM_RX) {
+			mclk = i2s_tdm->mclk_rx;
+		} else if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {
+			mclk = i2s_tdm->mclk_tx;
+		} else {
+			mclk = i2s_tdm->mclk_rx;
+		}
 
 		err = clk_set_rate(mclk, DEFAULT_MCLK_FS * params_rate(params));
 		if (err)
-- 
2.34.1


_______________________________________________
Linux-rockchip mailing list
Linux-rockchip@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-rockchip

^ permalink raw reply related	[flat|nested] 12+ messages in thread

end of thread, other threads:[~2024-06-05 21:05 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-06-04 18:47 [PATCH] ASoC: rockchip: i2s-tdm: Fix trcm mode by setting clock on right mclk Alibek Omarov
2024-06-04 18:47 ` Alibek Omarov
2024-06-04 18:47 ` Alibek Omarov
2024-06-05  8:13 ` Luca Ceresoli
2024-06-05  8:13   ` Luca Ceresoli
2024-06-05  8:13   ` Luca Ceresoli
2024-06-05  8:17   ` Alibek Omarov
2024-06-05  8:17     ` Alibek Omarov
2024-06-05  8:17     ` Alibek Omarov
2024-06-05 21:05 ` Mark Brown
2024-06-05 21:05   ` Mark Brown
2024-06-05 21:05   ` Mark Brown

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.