Suggestions for enhancement of pulseaudio

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, 07.10.09 13:26, stan (gryt2 at q.com) wrote:

> > > When pulse chooses its default configuration, it should query the
> > > sound device to determine the native rates and formats it supports,
> > > and choose one of them so it doesn't have to do resampling.  I have
> > > an onboard NVIDIA CK8S chip that doesn't do 44100 natively, only
> > > 48000.  Yet pulse is using 44100 as its default configuration for
> > > that device.
> > 
> > PA only uses native sampling rates. We always did, always will. We
> > explicitly disable resampling when opening the audio devices
> > (SND_PCM_NO_AUTO_RESAMPLE). We only resample if an application then
> > tries to connect to a sink with a non-matching sample spec.
> > 
> 
> So that means that the default is only a suggestion.  But unless I use
> the complex model, I have no way of knowing the actual default.  It
> seems that to match pulseaudio and control resampling, the complex is
> the way to go.

Yes, exactly. For everything more polished, more optimized it is
recommended to use the full, complex API.

> I looked at the mainloop model as a simpler alternative to the
> threaded-mainloop, and giving it a time of -1 for the poll might do what
> I want, which is to control the loop myself by using nanosleep, perhaps
> in a separate thread that only deals with sending sound to
> pulseaudio.

Urgs. nanosleep()s. Evil stuff. Don't do that. In times of laptops,
netbooks and mobile devices running Linux you really don't want
wakeups unless there's really something to do. Because that is the
most expensive thing you can do power-consumption-wise.

Lennart

-- 
Lennart Poettering                        Red Hat, Inc.
lennart [at] poettering [dot] net
http://0pointer.net/lennart/           GnuPG 0x1A015CC4



[Index of Archives]     [Linux Audio Users]     [AMD Graphics]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux