[ANNOUNCE] [PACKAGERS] New mixer logic in PA

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

 



Heya,

just a quick heads-up on the new ALSA mixer handling logic in PA which
I merged a few days ago, for packagers and other interested folks:

Previously PA was picking one ALSA (simple) mixer element to control
and then was sticking to it for all hardware volume/mute
handling. Usually that was the 'Master' element for output and
'Capture' for input. This had many drawbacks, among them:

a) we needed to rely on alsactl to fully initialize the ALSA mixer by
   default correctly, so that we can get away with controlling only
   one of them.

b) we were limited to the features of the mixer element we chose,
   i.e. it's granularity and range

c) often enough we picked the wrong control, for example on headphone
   setups where the controls we picked didn't actually do what we
   expected it would be doing.

d) ALSA tends to split up multichannel controls into seperate fake
   stereo pairs, which PA couldn't make use of.

e) no support for input port/output port selection, i.e. line-in
   vs. mic or speaker out vs. headphones and so on

f) on laptops like thinkpads no way to handle the builtin external hw
   volume control combined with the maste volume.

The new logic tries to more comprehensively control ALSA mixers. We
don't want to want to expose all features of an ALSA mixer, but we do
want to control more elements than we previously did. So what the new
stuff odes is this:

It is possible to define a "mixer path" which basically is a list of
mixer elements PA should control, with a bit of information how to
control them. Only one mixer path can be active at a time. Elements in
the path may be used for the following functions:

switches:
- can be declared to be used as "mute" switch
- can always be set to off, or to on
- can be exposed as a configurable option in the UI
- can be ignored

volumes:
- can be declared to be integrated in one big volume slider
- can always bet set to minimal or 0dB olume
- can be ignored

enumerations:
- can be exposed as a configurable option in the UI
- can be ignored

How does such a path definition look like?

This directory knows all currently defined paths:

http://git.0pointer.de/?p=pulseaudio.git;a=tree;f=src/modules/alsa/mixer/paths

An interesting example is for example the definition for a "Mic" path:

http://git.0pointer.de/?p=pulseaudio.git;a=blob;f=src/modules/alsa/mixer/paths/analog-input-mic.conf

What you see there is basically that the Mic and Capture volume
sliders are merged and all other capture sources are switched off.

What does "merging" volume sliders mean? If a volume slider in ALSA
has dB information then PA can multiply the two volume factors
and get a result factor of it. When we need to set a volume we start
from the beginning in the path and try to set the first slider to the
target dB value or the next closest value higher than it. Then we
divide our target volume by what we just set and apply that to the
next element in the mixer path and so on. WHich basically means that
the "largest part" of the volume adjustment happens on the most
outermost mixer control and the remaining controls are configured to
something next to 0dB. If the first mixer control does not have dB
information we will expose it and only it, since going through the
path won't help.

Enuemrations and switches that are marked for "exposing in the UI"
will be made available as "ports" on a sink/source. If multiply mixer
paths are found valid for a device they too will be exposed as
"ports". If multiple paths and multiple exposed options exist then
this will create a list of all possible combinations. This can get
quite large if too many are exposed. So don't do it. For all cards I
have here I never head more than 8 ports in the end, most only 2 or
0. And that's how it should be.

Ports are currently not exposed in pavucontrol/g-v-c but this will
hopefully change soon.

So what does all of this give us?

- we control a full set of volume sliders/mute switches not just one
- we can control the surround channel volume sliders properly
- we can select output/input port properly
- since the configuration happens in files this is easy to extend
- we have larger granularity and range of the hw volume sliders.
- issues a-f pointed out above are all fixed

On top of all of these path definitions, I also made the profile
definition configurable. The predefined ones are found here:

http://git.0pointer.de/?p=pulseaudio.git;a=tree;f=src/modules/alsa/mixer/profile-sets

These files basically list the ways how an ALSA device may be opened,
i.e. which device string to use ("front:xxx" vs "surround51:xxx"
vs. "spdif:xxx"), which channel mappings and mixer paths apply then
and so on.

There is one default profile set which should work for almost all
consumer devices. At least on the 10 consumer devices I tested this
with it worked fine and exposed exactly the feature set I wanted to
have exposed.

However, for some devices it makes sense to define your own profile
sets. The folks from Caiaq borrowed me a Native Instruments Audio 8 DJ
to define one for this device which can also be used as an example for
further definitions. Which profile set to use is defined via udev
rules. I'd be interested to merge support for more exotic devices like
this one into the PA, I am happy to take patches. Generally if you
don't have such a per-device profile set your device will be treated
as normal consumer device. So even if you lack this your devices will
at least basically work.

So much about all this new complexity. Feel free to browse through
the git repo dirs linked abvoe and read through the files, they
contain a few comments to lighten up things a bit beyond what I wrote
in this mail.

I expect that the default profile we now have in git might need tweaks
and fixes for some card. The point of this mail is to make you and the
distributors aware that this whole stuff is now available and can be
even be updated without recompiling PA.

I only have access to 10 cards here or so, I am relying on you folks
to make sure the current default profile works for as many cards as
possible.

Questions?

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