ALSA: pcm: Skip ack callback without actual appl_ptr update
authorTakashi Iwai <tiwai@suse.de>
Tue, 13 Jun 2017 13:57:28 +0000 (15:57 +0200)
committerTakashi Iwai <tiwai@suse.de>
Wed, 14 Jun 2017 05:44:27 +0000 (07:44 +0200)
We call ack callback whenever appl_ptr gets updated via
pcm_lib_apply_appl_ptr().  There are various code paths to call this
function.  A part of them are for read/write/forward/rewind, where the
appl_ptr is always changed and thus the call of ack is mandatory.
OTOH, another part of code paths are from the explicit user call,
e.g. via SYNC_PTR ioctl.  There, we may receive the same appl_ptr
value, and in such a case, calling ack is obviously superfluous.

This patch adds the check of the given appl_ptr value, and returns
immediately if it's no real update.

Reviewed-by: Takashi Sakamoto <o-takashi@sakamocchi.jp>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/core/pcm_lib.c

index e73b6e4135f62d90f6c912c3a913fd52231cb74b..75308ddc54ca796f27dcb142f6a374f136cfc5b5 100644 (file)
@@ -2112,6 +2112,9 @@ int pcm_lib_apply_appl_ptr(struct snd_pcm_substream *substream,
        snd_pcm_uframes_t old_appl_ptr = runtime->control->appl_ptr;
        int ret;
 
+       if (old_appl_ptr == appl_ptr)
+               return 0;
+
        runtime->control->appl_ptr = appl_ptr;
        if (substream->ops->ack) {
                ret = substream->ops->ack(substream);