[alsa-devel] Maximum buffer size on HDA

Jaroslav Kysela perex at perex.cz
Mon Jun 16 14:29:03 CEST 2008


On Mon, 16 Jun 2008, Takashi Iwai wrote:

> At Mon, 16 Jun 2008 12:53:11 +0200 (CEST),
> Jaroslav Kysela wrote:
> > 
> > On Mon, 16 Jun 2008, Takashi Iwai wrote:
> > 
> > > At Fri, 13 Jun 2008 21:13:03 +0200,
> > > Lennart Poettering wrote:
> > > > 
> > > > Heya,
> > > > 
> > > > the HDA driver allows a playback buffer size of something like 64K
> > > > onyl. Is this a driver limitation or a limitation of the hardware?
> > > > Skimming through the docs I cannot see anything like this, and I got
> > > > the idea that the audio buffer is maintained in system memory, not
> > > > sound card memory, so why this limit?
> > > 
> > > This comes from the buffer pre-allocator.
> > > Run the below:
> > > 
> > > 	# echo 1024 > /proc/asound/card0/pcm0p/sub0/prealloc
> > > 
> > > then you can use now 1MB buffer.  snd-hda-intel has max
> > > pre-allocation buffer size 1MB, and this is the hard-coded limit.
> > > 
> > > It's rather a silly constraint, and I think it'd be better cut off.
> > > OTOH, this makes the system safer (e.g. avoiding page allocations for
> > > too large buffers), and there is a proper workaround, too.
> > > So, I'm open about this change, so far.
> > 
> > Which workaround you're talking about?
> 
> Reset a proc file manually like the above.  Without this, you cannot
> allocate the buffer over the pre-allocated size.

I'm not quite sure what you like to change. Make 1MB limit smaller? Or 
change the default preallocated size? Or remove preallocation? I think 
that it might make sense to increase the default preallocation value to 
128KB or 192KB.

						Jaroslav

-----
Jaroslav Kysela <perex at perex.cz>
Linux Kernel Sound Maintainer
ALSA Project, Red Hat, Inc.



More information about the Alsa-devel mailing list