PulseAudio: Difference between revisions

imported>Edrex
mention how to unload a default module
(7 intermediate revisions by 6 users not shown)
Line 1: Line 1:
PulseAudio is a popular sound server for Linux. It is now required by a number of applications, and should be enabled if audio support is desired on NixOS. Enabling PulseAudio is sufficient to enable audio support on NixOS in most cases.
PulseAudio is a popular sound server for Linux. A number of applications now expect a PulseAudio-compatible audio server.
 
As of NixOS 24.11, [[PipeWire]] is used over PulseAudio for most graphical sessions by default, but it can provide a PulseAudio-compatible server (see that page for more details). This page documents how to use "native" PulseAudio as an alternative.


==Enabling PulseAudio==
==Enabling PulseAudio==
Add to your configuration:
Add to your configuration:


<syntaxHighlight lang="nix">
<syntaxhighlight lang="nix">
services.pipewire.enable = false;
hardware.pulseaudio.enable = true;
hardware.pulseaudio.enable = true;
hardware.pulseaudio.support32Bit = true;    ## If compatibility with 32-bit applications is desired.
hardware.pulseaudio.support32Bit = true;    # If compatibility with 32-bit applications is desired.
</syntaxHighlight>
 
# If you're on nixos-unstable you should instead use
services.pulseaudio.enable = true;
services.pulseaudio.support32Bit = true;
</syntaxhighlight>


You may need to add users to the <tt>audio</tt> group for them to be able to use audio devices:
You may need to add users to the <tt>audio</tt> group for them to be able to use audio devices:
Line 15: Line 22:
</syntaxHighlight>
</syntaxHighlight>


==Explicit PulseAudio support in applications==
== Explicit PulseAudio support in applications ==
Normally, the system-wide ALSA configuration (<tt>/etc/asound.conf</tt>) redirects the audio of applications which use the ALSA API through PulseAudio. For this reason, most applications do not need to be PulseAudio-aware. Some NixOS packages can be built with explicit PulseAudio support which is disabled by default. This support can be enabled in all applicable packages by setting:
Normally, the system-wide ALSA configuration (<tt>/etc/asound.conf</tt>) redirects the audio of applications which use the ALSA API through PulseAudio. For this reason, most applications do not need to be PulseAudio-aware. Some NixOS packages can be built with explicit PulseAudio support which is disabled by default. This support can be enabled in all applicable packages by setting:


<syntaxHighlight lang="nix">
<syntaxHighlight lang="nix">
nixpkgs.config.pulseaudio = true;
nixpkgs.config.pulseaudio = true;
</syntaxHighlight>
== Enabling modules ==
Modules can be loaded manually:
<syntaxHighlight lang="sh">
pactl load-module module-combine-sink
</syntaxHighlight>
Or automatically:
<syntaxHighlight lang="nix">
hardware.pulseaudio.extraConfig = "load-module module-combine-sink";
</syntaxHighlight>
</syntaxHighlight>


Line 36: Line 54:
$ nix-shell -p python27Full python27Packages.pyqt4 python27Packages.dbus-python --command qpaeq
$ nix-shell -p python27Full python27Packages.pyqt4 python27Packages.dbus-python --command qpaeq
</syntaxHighlight>
</syntaxHighlight>
== Using Bauer stereophonic-to-binaural DSP library ==
This module re-creates on a headset what you would hear in real-life, improving sound quality and decreasing brain fatigue.
See the description of the project for more details: https://bs2b.sourceforge.net/
The nix package to use is: <code>libbs2b</code>
<b>FIXME</b>: getting an error while running:
<syntaxHighlight lang=console>
$ pactl load-module module-ladspa-sink sink_name=binaural master=bluez_sink.AA_BB_CC_DD_EE_FF.a2dp_sink plugin=bs2b label=bs2b control=700,4.5
</syntaxHighlight>


== Troubleshooting ==
== Troubleshooting ==
Line 84: Line 115:
Then perform <code># nixos-rebuild switch</code>, followed by <code>$ pulseaudio -k</code>.
Then perform <code># nixos-rebuild switch</code>, followed by <code>$ pulseaudio -k</code>.


The difference should be directly noticeable. This is a known issue related to quality of Creative driver [https://guh.me/solving-creative-sound-blaster-x-fi-titanium-crackling-slash-distortion-on-linux], but it can also happen with other sound cards.
The difference should be directly noticeable. This is a known issue related to quality of Creative driver [https://guh.me/posts/2013-06-16-solving-creative-sound-blaster-x-fi-titanium-crackling-slash-distortion-on-linux/], but it can also happen with other sound cards.
 
=== Paprefs doesn't work on KDE ===
If you run KDE (Plasma) and paprefs util doesn't work complaining about dconf, make sure you have <code>programs.dconf.enable = true;</code> in your NixOS configuration. [https://github.com/NixOS/nixpkgs/issues/47938#issuecomment-427520410 Source].


==See also==
==See also==
* [[Using JACK with PulseAudio]]
* [[Using JACK with PulseAudio]]
* [[PipeWire]]


[[Category:Audio]]
[[Category:Audio]]