From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jaroslav Kysela Subject: Re: Question about SNDRV_PCM_STATE_DRAINING and DMA transfer Date: Fri, 26 Sep 2014 12:07:10 +0200 Message-ID: <54253ACE.4040905@perex.cz> References: <87wq8rm20r.wl%kuninori.morimoto.gx@gmail.com> <54251749.4040603@ladisch.de> <87lhp6n70k.wl%kuninori.morimoto.gx@gmail.com> <542520A7.6050604@perex.cz> <87eguyn51t.wl%kuninori.morimoto.gx@gmail.com> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Return-path: Received: from mail1.perex.cz (mail1.perex.cz [77.48.224.245]) by alsa0.perex.cz (Postfix) with ESMTP id 0C3CD26047E for ; Fri, 26 Sep 2014 12:07:11 +0200 (CEST) In-Reply-To: <87eguyn51t.wl%kuninori.morimoto.gx@gmail.com> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: alsa-devel-bounces@alsa-project.org Sender: alsa-devel-bounces@alsa-project.org To: Kuninori Morimoto Cc: Linux-ALSA , Mark Brown , Clemens Ladisch , Kuninori Morimoto , "shiiba (Renesas)" List-Id: alsa-devel@alsa-project.org Dne 26.9.2014 v 10:45 Kuninori Morimoto napsal(a): > > Hi Jaroslav > >>>>> We noticed that DMA seems transfered +1 time when Ctrl-C happen. >>>>> But, is this correct ? is this our driver bug ? >>>>> [...] >>>>> 7. DMA transfer interrupt happen >>>>> >>>>> It calls snd_pcm_period_elapsed() and try to transfer next 2048 byte >>>>> snd_pcm_playback_avail() in snd_pcm_update_state() return 8192 this time. >>>>> then, it calls snd_pcm_drain_done() >>>>> >>>>> 9. snd_soc_dai_ops :: trigger called with SNDRV_PCM_TRIGGER_STOP >>>>> >>>>> driver stops DMA transfer >>>> >>>> There is no strong synchronization between snd_pcm_drain() and the rest >>>> of the system; snd_pcm_drain() just waits for an underrun to happen. >>>> >>>> In other words, the last actual DMA transfer is likely to contain >>>> invalid (outdated) samples, but gets aborted immediately. >>> >>> I wonder why we need drain ? >>> This "likely to contain invalid samples" will be solved if >>> we can skip "complete drain" ? >> >> The user app should do the flush instead the drain in this case... > > Thank you about this help. > Can you show me how to do this in app side ? > (Calling some alsa-lib function ?) Yes, the function is snd_pcm_drop() . Jaroslav -- Jaroslav Kysela Linux Kernel Sound Maintainer ALSA Project; Red Hat, Inc.