[vlc-devel] [PATCH] ALSA: set periods before setting buffer time

Rémi Denis-Courmont remi at remlab.net
Mon Mar 12 17:54:10 CET 2012


Le lundi 12 mars 2012 18:41:04 Edward Sheldrake, vous avez écrit :
> 2012/3/11 Rémi Denis-Courmont <remi at remlab.net>:
> > Le dimanche 11 mars 2012 17:16:04 Edward Sheldrake, vous avez écrit :
> >> Fixes "cannot set buffer duration near 3000000 us: Invalid argument"
> >> error, resulting in no sound, with HDA audio hardware and 44100Hz
> >> sources.
> > 
> > Err? Is this really correct and not a driver bug? This reorder seems to
> > put an extra constraint before selecting the buffer size. This may cause
> > a smaller buffer size to be selected than would be available with more
> > periods, if I read the documentation correctly.
> 
> Perhaps it should be an ALSA bug - without the patch, ALSA chooses a
> buffer time of (3000090 3000091) which it then finds unacceptable
> (alsa fails to refine the remaining parameters), with the patch it
> chooses a buffer time of (2999727 2999728).

Well that is OK in that acse. But if the hardware has a small maximum period 
duration, then your proposal will end up selecting a smaller total buffer 
duration instead of more periods.

I mean the case where:
 minimum_periods * maximum_period_time < maximum_buffer_time

At the very least, a minimum buffer duration should be enforced before the 
first period value is selected, I'd say. But ALSA is so well documented...

-- 
Rémi Denis-Courmont
http://www.remlab.net/
http://fi.linkedin.com/in/remidenis



More information about the vlc-devel mailing list