From 6f134a822a3a234362c48c17899b03f9d64e6925 Mon Sep 17 00:00:00 2001 From: Takashi Iwai Date: Tue, 12 Jun 2018 13:47:01 +0200 Subject: [PATCH] pcm: dmix: Fix hwptr updates at status call In the commit 38a2d2eda880 ("pcm: dmix: Do not discard slave reported delay in status result"), the PCM dmix hwptr update code was rewritten to follow the slave PCM hwptr update. This is based on the similar change in PCM dshare, the commit faf53c197cab. There was a bug in the commit 38a2d2eda880 regarding the PCM state change, and it was addressed in commit 3752e6b8733d ("pcm: dmix: Fix the inconsistent PCM state"). However, we've hit yet another bug in this commit. Namely, the hwptr update was forgotten in the snd_pcm_dmix_sync_ptr0() function. So the hwptr value passed from snd_pcm_dmix_status() isn't properly stored, and it screws up at some long run occasionally. This patch covers the bug by replacing with the right value. Fixes: 38a2d2eda880 ("pcm: dmix: Do not discard slave reported delay in status result") Bugzilla: https://bugzilla.kernel.org/show_bug.cgi?id=200013 Signed-off-by: Takashi Iwai --- src/pcm/pcm_dmix.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/pcm/pcm_dmix.c b/src/pcm/pcm_dmix.c index c65259be..3a951f53 100644 --- a/src/pcm/pcm_dmix.c +++ b/src/pcm/pcm_dmix.c @@ -398,7 +398,7 @@ static int snd_pcm_dmix_sync_ptr0(snd_pcm_t *pcm, snd_pcm_uframes_t slave_hw_ptr snd_pcm_sframes_t diff; old_slave_hw_ptr = dmix->slave_hw_ptr; - dmix->slave_hw_ptr = *dmix->spcm->hw.ptr; + dmix->slave_hw_ptr = slave_hw_ptr; diff = slave_hw_ptr - old_slave_hw_ptr; if (diff == 0) /* fast path */ return 0; -- 2.47.3