* snd_pcm_avail() and snd_pcm_avail_update() always returns buffer_size
[not found] <7690603.125468.1365197646502.JavaMail.ncase@natec>
@ 2013-04-10 15:09 ` Nate Case
2013-04-17 19:00 ` Nate Case
0 siblings, 1 reply; 3+ messages in thread
From: Nate Case @ 2013-04-10 15:09 UTC (permalink / raw)
To: alsa-devel
Hello,
I'm debugging an issue where both snd_pcm_avail_update() and
snd_pcm_avail() are always returning buffer_size, even after
successfully calling snd_pcm_writei() repeatedly.
This is causing problems when I first start playback. My goal was to
fill up the playback buffer until it's almost full when first starting,
and then enter my regular playback loop where I write period_size
at a time.
However, I'm not able to tell when the playback buffer is full from
snd_pcm_avail() or snd_pcm_avail_update() as expected. In case it's
useful, the full snd_pcm_dump() output of the playback device is
available here:
http://pastebin.com/ai3e0cer
To summarize the configuration, I'm using a chain of PCM devices
that looks like this:
Soft volume ->
Rate conversion ->
Route conversion ->
HW PCM (USB audio)
(notes: buffer_size for soft volume PCM is 640 [80ms], period size is
160 [20ms]. buffer_size for HW PCM is 3846 and period_size is 960. I'm
opening the playback device in blocking mode, although the same thing
appears to happen in non-blocking mode)
Here is the sequence of events I'm seeing:
1) Call snd_pcm_writei() with 160 frames successfully. Function
returns immediately in less than 1ms because the buffer is empty.
2) snd_pcm_avail() returns 640 (expected 640-160 = 480)
snd_pcm_dump() shows the following for the HW PCM device:
appl_ptr : 960
hw_ptr : 0
3) Call snd_pcm_writei() again with 160 frames successfully. Function
returns immediately again.
4) snd_pcm_avail() returns 640 (expected 480-160 = 320)
snd_pcm_dump() shows the following for the HW PCM device:
appl_ptr : 1920
hw_ptr : 0
5) Cycle repeats two more times, with these values for apply_ptr/hw_ptr
reported after each subsequent snd_pcm_writei() call:
appl_ptr : 2880
hw_ptr : 288
appl_ptr : 3840
hw_ptr : 288
All along, snd_pcm_avail() returns 640.
6) Call snd_pcm_writei() with 160 frames again. This time, the buffer
is actually full, so it blocks for 20 ms as expected.
7) snd_pcm_avail() returns 640
snd_pcm_dump() shows the following for the HW PCM device:
appl_ptr : 4800
hw_ptr : 960
8) Continue this loop, with each subsequent snd_pcm_writei() call
blocking for 20 ms, while snd_pcm_avail() always returns 640.
Any ideas on why this could be happening? Or am I misunderstanding
something here?
Thanks,
Nate Case <ncase@xes-inc.com>
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: snd_pcm_avail() and snd_pcm_avail_update() always returns buffer_size
2013-04-10 15:09 ` snd_pcm_avail() and snd_pcm_avail_update() always returns buffer_size Nate Case
@ 2013-04-17 19:00 ` Nate Case
2013-04-20 16:53 ` Gabriel M. Beddingfield
0 siblings, 1 reply; 3+ messages in thread
From: Nate Case @ 2013-04-17 19:00 UTC (permalink / raw)
To: alsa-devel
----- Original Message -----
> I'm debugging an issue where both snd_pcm_avail_update() and
> snd_pcm_avail() are always returning buffer_size, even after
> successfully calling snd_pcm_writei() repeatedly.
>
> This is causing problems when I first start playback. My goal was to
> fill up the playback buffer until it's almost full when first
> starting,
> and then enter my regular playback loop where I write period_size
> at a time.
>
[snip]
Replying to my own thread here:
I looked into this more closely again today, and found an unrelated bug
in my application causing the strange behavior I was observing. It
turned out that ALSA was behaving exactly as expected for what was
going on.
Thanks,
Nate
^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: snd_pcm_avail() and snd_pcm_avail_update() always returns buffer_size
2013-04-17 19:00 ` Nate Case
@ 2013-04-20 16:53 ` Gabriel M. Beddingfield
0 siblings, 0 replies; 3+ messages in thread
From: Gabriel M. Beddingfield @ 2013-04-20 16:53 UTC (permalink / raw)
To: Nate Case; +Cc: alsa-devel
On 04/17/2013 12:00 PM, Nate Case wrote:
> Replying to my own thread here:
Thanks for following up. Some guy from the future will really
appreciate it. :-)
-gabriel
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2013-04-20 16:53 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <7690603.125468.1365197646502.JavaMail.ncase@natec>
2013-04-10 15:09 ` snd_pcm_avail() and snd_pcm_avail_update() always returns buffer_size Nate Case
2013-04-17 19:00 ` Nate Case
2013-04-20 16:53 ` Gabriel M. Beddingfield
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.