prealloc_buffer_size and buffer_bytes_max

Alexandre Belloni alexandre.belloni at free-electrons.com
Thu May 21 05:59:14 PDT 2015


Hi,

On 21/05/2015 at 14:28:25 +0200, Peter Rosin wrote :
> I got my hopes up when I read the commit message for c14e2591bf54
> ASoC: atmel-pcm-dma: increase buffer_bytes_max. Quoting it:
> 
> 	atmel-pcm-dma is not limited to a buffer size of 64kB like
> 	atmel-pcm-pdc. Increase buffer_bytes_max to 512kB to allow
> 	for higher bit rates (i.e. 32bps at 192kHz) to work correctly.
> 	By default, keep the prealloc at 64kB.
> 
> However, as I (think I) request a bigger buffer it still caps out at 64kB.
> I'm using the latency argument of snd_pcm_set_params to control the buffer:
> 
> 	snd_pcm_set_params(pcm,
> 		SND_PCM_FORMAT_S32_LE,
> 		SND_PCM_ACCESS_RW_INTERLEAVED,
> 		2,      /* channels */
> 		250000, /* rate */
> 		0,      /* do not resample */
> 		90000); /* latency in us */
> 
> But snd_pcm_hw_params_get_buffer_size "only" returns 8192 frames (64kB)
> even if I request 9us * 250kHz * 2 * 4 = 180kB. If I change the prealloc
> from 64kB to 256kB I get a bigger buffer (and it works better too!).
> 
> Admittedly I backported this patch on top of the linux-3.18-at91
> branch from the Atmel git repo, so there might be some support
> missing that has gone in after 3.18?
> 
> Or have I completely misunderstood, and these are unrelated buffers?
> 

Those are somewhat related but not the same.

> Any insight in how I can get a big enough buffer without hacking the
> prealloc is appreciated!
>

You can change the prealloc size in
/proc/asound/card0/pcm0p/sub0/prealloc or by using
snd_pcm_lib_preallocate_pages_for_all(). I never experienced the issue
but what I did solved it for someone doing 32bits per sample at 192kHz.

-- 
Alexandre Belloni, Free Electrons
Embedded Linux, Kernel and Android engineering
http://free-electrons.com



More information about the linux-arm-kernel mailing list