[alsa-devel] Problems with nonblocking capture every 20ms
Hi there,
With a sampling rate of 8000 I want to capture every 20ms a chunk (160 frames) of data from the soundcard. That works ok, but every ~5 seconds I get a EGAIN from snd_pcm_readi(). I understand that this is not an error but a notification that the sound card is not ready and should be asked again for data later on.
Probably the easiest way to get rid of the EGAINs would be to use blocking IO, which I would prefer, but I have timing restrictions and snd_pcm_readi() has no sort of timeout (which I could see at least).
Additional Information: The reason for me the read from the sound card every 20ms is, that I need to do so for my voip-app (rtp&sip) which needs to send 160 frames every 20ms. The calculation is: PacketsPerSecond=50 SampleRate=8000 FramesPerPacket=8000/50=160 Wait=1000ms/50=20ms
I know that EAGAINs might occur and I'm confident that I handle them ok on the RTP-Level (which is to notify the other side which then plays empty samples). Still I would guess, that I could receive much less EGAINs if I would setup the sound card better. If played around with the period time and size and buffer time and size, but honestly I did not really get the point of them and try&error has not helped me either.
Thanks in advance & greetings from Germany
Johannes
On Mon, 10 Mar 2008, Johannes Dohmen wrote:
Hi there,
With a sampling rate of 8000 I want to capture every 20ms a chunk (160 frames) of data from the soundcard. That works ok, but every ~5 seconds I get a EGAIN from snd_pcm_readi(). I understand that this is not an error but a notification that the sound card is not ready and should be asked again for data later on.
Probably the easiest way to get rid of the EGAINs would be to use blocking IO, which I would prefer, but I have timing restrictions and snd_pcm_readi() has no sort of timeout (which I could see at least).
Just use poll() - it's standard unix interface to wait for an event.
Jaroslav
----- Jaroslav Kysela perex@perex.cz Linux Kernel Sound Maintainer ALSA Project, Red Hat, Inc.
On Monday 10 March 2008 15:28, Johannes Dohmen wrote:
Hi there,
With a sampling rate of 8000 I want to capture every 20ms a chunk (160 frames) of data from the soundcard. That works ok, but every ~5 seconds I get a EGAIN from snd_pcm_readi(). I understand that this is not an error but a notification that the sound card is not ready and should be asked again for data later on.
Probably the easiest way to get rid of the EGAINs would be to use blocking IO, which I would prefer, but I have timing restrictions and snd_pcm_readi() has no sort of timeout (which I could see at least).
Additional Information: The reason for me the read from the sound card every 20ms is, that I need to do so for my voip-app (rtp&sip) which needs to send 160 frames every 20ms. The calculation is: PacketsPerSecond=50 SampleRate=8000 FramesPerPacket=8000/50=160 Wait=1000ms/50=20ms
I know that EAGAINs might occur and I'm confident that I handle them ok on the RTP-Level (which is to notify the other side which then plays empty samples). Still I would guess, that I could receive much less EGAINs if I would setup the sound card better. If played around with the period time and size and buffer time and size, but honestly I did not really get the point of them and try&error has not helped me either.
Remember that you may have different clocks for different parts of your system, and if so they cannot lock exactly for ever. Eg if the soundcard has it's own clock/crystal, it won't be exactly the same as the processor timing clock. If the soundcard were running slightly slower, the rate it generates samples would be slightly less than the rate you are trying to read them out. Eventually you have emptied the buffer completely, and readi has to wait.
There has to be a synchronising mechanism of some sort. (Though I am no expert here.) One way is to derive everything from the soundcard, so when 160 frames are ready, another 20ms must have passed, and your app processes it. Another is to add or remove samples occasionally to maintain sync.
If I have missed something, hopefully others will chip in.
Alan
participants (3)
-
Alan Horstmann
-
Jaroslav Kysela
-
Johannes Dohmen