mirror of
https://gitlab.freedesktop.org/pipewire/wireplumber.git
synced 2026-05-20 17:38:16 +02:00
When current output target of a media player application is removed, it can be useful if playback is paused (to avoid e.g. music playback to going to speakers when headset is accidentally unplugged). Android etc. implement a policy like this. Add a policy script that monitors stream target removals. When it detects a media player application that is linked to a no longer present output target, it checks whether the stream is associated with a media player seen in MPRIS. If yes, it sends MPRIS Pause() command to the media player. Enable this policy by default.
220 lines
8.9 KiB
ReStructuredText
220 lines
8.9 KiB
ReStructuredText
.. _config_settings:
|
|
|
|
Well-known settings
|
|
===================
|
|
|
|
This section describes the settings that can be configured on WirePlumber.
|
|
|
|
Settings can be either configured statically in the configuration file
|
|
by setting them under the ``wireplumber.settings`` section, or they can be
|
|
configured dynamically at runtime by using metadata.
|
|
|
|
For more information on what "settings" are and how they work, refer to the
|
|
previous section: :ref:`config_configuration_option_types`.
|
|
|
|
.. describe:: device.restore-profile
|
|
|
|
When a device profile is changed manually (e.g. via pavucontrol), WirePlumber
|
|
stores the selected profile and restores it when the device appears again
|
|
(e.g. after a reboot). If this setting is disabled, WirePlumber will always
|
|
pick the best profile for the device based on profile priorities and
|
|
availability (or custom rules, if any).
|
|
|
|
:Default value: ``true``
|
|
|
|
.. describe:: device.restore-routes
|
|
|
|
When a device route is changed manually (e.g. via pavucontrol), WirePlumber
|
|
stores the selected route and restores it when the same profile is
|
|
selected for this device. If this setting is disabled, WirePlumber will
|
|
always pick the best route for this device profile based on route priorities
|
|
and availability (or custom rules, if any).
|
|
|
|
This setting also enables WirePlumber to restore properties of the device
|
|
route when the route is restored. This includes the volume levels of sources
|
|
and sinks, as well as the IEC958 codecs selected (for routes that support
|
|
encoded streams, such as HDMI).
|
|
|
|
:Default value: ``true``
|
|
|
|
.. describe:: device.routes.default-sink-volume
|
|
|
|
This option allows to set the default volume for sinks that are part of a
|
|
device route (e.g. ALSA PCM sinks). This is used when the route is restored
|
|
and the sink does not have a previously stored volume.
|
|
|
|
:Default value: ``0.4 ^ 3`` (40% on the cubic scale)
|
|
|
|
.. describe:: device.routes.default-source-volume
|
|
|
|
This option allows to set the default volume for sources that are part of a
|
|
device route (e.g. ALSA PCM sources). This is used when the route is restored
|
|
and the source does not have a previously stored volume.
|
|
|
|
:Default value: ``1.0`` (100%)
|
|
|
|
.. describe:: linking.allow-moving-streams
|
|
|
|
This option allows moving streams by overriding their target via metadata.
|
|
When enabled, WirePlumber monitors the "default" metadata for changes in the
|
|
``target.object`` key of streams and if this key is set to a valid node name
|
|
(``node.name``) or serial (``object.serial``), the stream is moved to that
|
|
target node.
|
|
|
|
This is used by applications such as pavucontrol and is recommended for
|
|
compatibility with PulseAudio.
|
|
|
|
.. note::
|
|
|
|
On the metadata, the ``target.node`` key is also supported for
|
|
compatibility with older versions of PipeWire, but it is deprecated.
|
|
Please use the ``target.object`` key instead.
|
|
|
|
:Default value: ``true``
|
|
:See also: ``node.stream.restore-target``
|
|
|
|
.. describe:: linking.follow-default-target
|
|
|
|
When a stream was started with the ``target.object`` property, WirePlumber
|
|
normally links that stream to that target node and ignores the "default"
|
|
target for that direction. However, if this option is enabled, WirePlumber
|
|
will check if the designated target node *is* the "default" target and if so,
|
|
it will act as if the stream did not have that property.
|
|
|
|
In practice, this means that if the "default" target changes at runtime,
|
|
the stream will be moved to the new "default" target.
|
|
|
|
This is what Pulseaudio does and is implemented here for compatibility
|
|
with some applications that do start with a ``target.object`` property
|
|
set to the "default" target and expect the stream to be moved when the
|
|
"default" target changes.
|
|
|
|
Note that this logic is only applied on client (i.e. application) streams
|
|
and *not* on filters.
|
|
|
|
:Default value: ``true``
|
|
|
|
.. describe:: linking.pause-playback
|
|
|
|
When an audio sink is removed, pause media players that have streams
|
|
playing to it. Pausing is done via MPRIS interface.
|
|
|
|
:Default value: ``true``
|
|
|
|
.. describe:: node.features.audio.no-dsp
|
|
|
|
When this option is set to ``true``, audio nodes will not be configured
|
|
in dsp mode, meaning that their channels will *not* be split into separate
|
|
ports and that the audio data will *not* be converted to the float 32 format
|
|
(F32P). Instead, devices will be configured in passthrough mode and streams
|
|
will be configured in convert mode, so that their audio data is converted
|
|
directly to the format that the device is expecting.
|
|
|
|
This may be useful if you are trying to minimize audio processing for an
|
|
embedded system, but it is not recommended for general use.
|
|
|
|
.. warning::
|
|
|
|
This option **will break** compatibility with JACK applications
|
|
and may also break certain patchbay applications. Do not enable, unless
|
|
you understand what you are doing.
|
|
|
|
:Default value: ``false``
|
|
|
|
.. describe:: node.features.audio.monitor-ports
|
|
|
|
This enables the creation of "monitor" ports for audio nodes. Monitor ports
|
|
are created on nodes that have input ports (i.e. sinks and capture streams)
|
|
and allow monitoring of the audio data that is being sent to the node.
|
|
|
|
This is mostly used by monitoring applications, such as pavucontrol.
|
|
|
|
:Default value: ``true``
|
|
|
|
.. describe:: node.features.audio.control-port
|
|
|
|
This enables the creation of a "control" port for audio nodes. Control ports
|
|
allow sending MIDI data to the node, allowing for control of certain node's
|
|
parameters (such as volume) via external controllers.
|
|
|
|
:Default value: ``false``
|
|
|
|
.. describe:: node.stream.restore-props
|
|
|
|
WirePlumber stores stream parameters such as volume and mute status for each
|
|
client (i.e. application) stream. If this setting is enabled, WirePlumber
|
|
will restore the previously stored stream parameters when the stream is
|
|
activated. If it is disabled, stream parameters will be initialized to their
|
|
default values.
|
|
|
|
:Default value: ``true``
|
|
|
|
.. describe:: node.stream.restore-target
|
|
|
|
When a client (i.e. application) stream is manually moved to a different
|
|
target node (e.g. via pavucontrol), the target node is stored by WirePlumber.
|
|
If this setting is enabled, WirePlumber will restore the previously stored
|
|
target node when the stream is activated.
|
|
|
|
.. note::
|
|
|
|
This does not restore manual links made by patchbay applications. This
|
|
is only meant to restore the ``target.object`` property in the "default"
|
|
metadata, which is manipulated by applications such as pavucontrol when
|
|
a stream is moved to a different target.
|
|
|
|
:Default value: ``true``
|
|
:See also: ``linking.allow-moving-streams``
|
|
|
|
.. describe:: node.stream.default-playback-volume
|
|
|
|
The default volume for playback streams to be applied when the stream is
|
|
activated. This is only applied when ``node.stream.restore-props`` is
|
|
``true`` and the stream does not have a previously stored volume.
|
|
|
|
:Default value: ``1.0``
|
|
:Range: ``0.0`` to ``1.0``
|
|
|
|
.. describe:: node.stream.default-capture-volume
|
|
|
|
The default volume for capture streams to be applied when the stream is
|
|
activated. This is only applied when ``node.stream.restore-props`` is
|
|
``true`` and the stream does not have a previously stored volume.
|
|
|
|
:Default value: ``1.0``
|
|
:Range: ``0.0`` to ``1.0``
|
|
|
|
.. describe:: node.filter.forward-format
|
|
|
|
When a "filter" pair of nodes (such as echo-cancel or filter-chain) is
|
|
linked to a device node that has a different channel map than the filter
|
|
nodes, this option allows the channel map of the filter nodes to be changed
|
|
to match the channel map of the device node. The change is applied to both
|
|
ends of the "filter", so that any streams linked to the filter are also
|
|
reconfigured to match the target channel map.
|
|
|
|
This is useful, for instance, to make sure that an application will be
|
|
properly configured to output surround audio to a surround device, even
|
|
when going through a filter that was not explicitly configured to have
|
|
a surround channel map.
|
|
|
|
:Default value: ``false``
|
|
|
|
.. describe:: node.restore-default-targets
|
|
|
|
This setting enables WirePlumber to store and restore the "default" source
|
|
and sink targets of the graph. In PulseAudio terminology, this is also known
|
|
as the "fallback" source and sink.
|
|
|
|
When this setting is enabled, WirePlumber will store the "default" source
|
|
and sink targets when they are changed manually (e.g. via pavucontrol) and
|
|
restore them when the available nodes change or after a reload/restart.
|
|
It will also store a history of past selected "default" targets and restore
|
|
previously selected ones if the currently selected are not available.
|
|
|
|
If this is disabled, WirePlumber will pick the best available source
|
|
and sink targets based on their priorities, but it will also respect
|
|
manual user selections that are done at runtime - it will just not remember
|
|
them so that it can restore them at a later time.
|
|
|
|
:Default value: ``true``
|