Difference between revisions of "PulseAudio"

From ArchWiki
Jump to: navigation, search
(Added a fix for no microphone in Steam/Skype if "enable-remixing = no" on "/etc/pulse/daemon.conf")
(No HDMI sound output after some time with the monitor turned off: substitute TTY with VT)
(26 intermediate revisions by 7 users not shown)
Line 15: Line 15:
  
 
== Installation ==
 
== Installation ==
 +
 
* Required package:  {{Pkg|pulseaudio}}
 
* Required package:  {{Pkg|pulseaudio}}
 
* Optional GTK GUIs: {{Pkg|paprefs}} and {{Pkg|pavucontrol}}
 
* Optional GTK GUIs: {{Pkg|paprefs}} and {{Pkg|pavucontrol}}
Line 21: Line 22:
 
* Optional web volume control: [https://github.com/Siot/PaWebControl PaWebControl]
 
* Optional web volume control: [https://github.com/Siot/PaWebControl PaWebControl]
 
* Optional system tray icon: {{AUR|pasystray-git}}
 
* Optional system tray icon: {{AUR|pasystray-git}}
* Optional KDE plasma applet: {{Pkg|kdemultimedia-kmix}} and {{AUR|kdeplasma-applets-veromix}}
+
* Optional KDE plasma applet: {{Pkg|kdemultimedia-kmix}} and {{AUR|kdeplasma-applets-veromix}} (If KMix/Veromix fail to connect to PulseAudio at boot you may need to edit {{ic|/etc/pulse/client.conf}} to include  {{ic|autospawn = yes}} instead of {{ic|autospawn = no}}.)
 +
 
 +
== Configuration ==
 +
 
 +
{{Merge|PulseAudio/Configuration|Configuration should stay in the main article, so the linked page should be merged here. Split [[#Troubleshooting]] instead if this page is found too long.}}
 +
 
 +
You'll see Pulseaudio supports many modules to extend its functionality. You find a detailed list of all available modules at [http://www.freedesktop.org/wiki/Software/PulseAudio/Documentation/User/Modules/ Pulseaudio Loadable Modules]. To enable them you can just add a line {{ic|load-module <module-name-from-list>}} to {{ic|/etc/pulse/default.pa}}.
  
 
== Running ==
 
== Running ==
 +
 
{{Warning|If you have per-user copies of configuration files (such as {{ic|client.conf}}, {{ic|daemon.conf}} or {{ic|default.pa}}) in {{ic|~/.config/pulse/}} or {{ic|~/.pulse/}}, make sure you keep them in sync with changes to the packaged files in {{ic|/etc/pulse/}}. Otherwise, PulseAudio may refuse to start due to configuration errors.}}
 
{{Warning|If you have per-user copies of configuration files (such as {{ic|client.conf}}, {{ic|daemon.conf}} or {{ic|default.pa}}) in {{ic|~/.config/pulse/}} or {{ic|~/.pulse/}}, make sure you keep them in sync with changes to the packaged files in {{ic|/etc/pulse/}}. Otherwise, PulseAudio may refuse to start due to configuration errors.}}
  
Line 32: Line 40:
  
 
PulseAudio can be stopped with:
 
PulseAudio can be stopped with:
  $ pulseaudio -k
+
  $ pulseaudio --kill
  
== Equalizer ==
+
=== Autostarting in unsupported desktop environments ===
Newer PulseAudio versions have an integrated 10-band equalizer system. In order to use the equalizer do the following:
+
  
=== Load equalizer sink and dbus-protocol module ===
+
{{Note|As mentioned previously, PulseAudio is very likely launched automatically via either {{ic|/etc/X11/xinit/xinitrc.d/pulseaudio}} or the files in {{ic|/etc/xdg/autostart/}} if users have some DE installed.}}
$ pactl load-module module-equalizer-sink
+
$ pactl load-module module-dbus-protocol
+
  
=== Install and run the GUI front-end ===
+
Check to see if PulseAudio is running:
Install {{Pkg|python-pyqt4}} and execute:
+
  
$ qpaeq
+
{{hc|<nowiki>$ ps aux | grep pulse</nowiki>|
 +
facade  1794  0.0  0.0 360464  6532 ?        S<l  15:33  0:00 /usr/bin/pulseaudio --start
 +
facade  1827  0.0  0.0  68888  2608 ?        S    15:33  0:00 /usr/lib/pulse/gconf-helper
 +
}}
  
{{Note|If qpaeq has no effect, install {{pkg|pavucontrol}} and change "ALSA Playback on" to "FFT based equalizer on ..." while the media player is running.}}
+
If PulseAudio is not running and users are using X, the following will start PulseAudio with the needed the X11 plugins manually:
  
=== Load equalizer and dbus module on every boot ===
+
$ start-pulseaudio-x11
Edit the file {{ic|/etc/pulse/default.pa}} with your favorite editor and append the following lines:
+
  
### Load the integrated PulseAudio equalizer and D-Bus module
+
If you are not running GNOME, KDE, or Xfce, and your {{ic|~/.xinitrc}} does not source the scripts in {{ic|/etc/X11/xinit/xinitrc.d}} (such as is done in the example file {{ic|/etc/skel/.xinitrc}}), then you can launch PulseAudio on boot with:
load-module module-equalizer-sink
+
 
load-module module-dbus-protocol
+
{{hc|~/.xinitrc|
 +
/usr/bin/start-pulseaudio-x11
 +
}}
  
 
== Back-end configuration ==
 
== Back-end configuration ==
 +
 
=== ALSA ===
 
=== ALSA ===
* Recommended package: {{Pkg|pulseaudio-alsa}}
 
* Optional packages: {{Pkg|lib32-libpulse}} and {{Pkg|lib32-alsa-plugins}}
 
  
{{Note|Optional packages are needed only if running x86_64 and wanting to have sound for 32-bit programs (like Wine).}}
+
Install {{Pkg|pulseaudio-alsa}} from the [[official repositories]]. This package contains the necessary {{ic|/etc/asound.conf}} for configuring ALSA to use PulseAudio.
  
For the applications that do not support PulseAudio and support ALSA it is '''recommended''' to install the PulseAudio plugin for ALSA.  This package also contains the necessary {{ic|/etc/asound.conf}} for configuring ALSA to use PulseAudio.
+
Also install {{Pkg|lib32-libpulse}} and {{Pkg|lib32-alsa-plugins}} if you run a x86_64 system and want to have sound for 32-bit [[multilib]] programs like Wine, Skype and Steam.
  
 
To prevent applications from using ALSA's OSS emulation and bypassing PulseAudio (thereby preventing other applications from playing sound), make sure the module {{ic|snd_pcm_oss}} is not being loaded at boot. If it is currently loaded ({{ic|<nowiki>lsmod | grep oss</nowiki>}}), disable it by executing:
 
To prevent applications from using ALSA's OSS emulation and bypassing PulseAudio (thereby preventing other applications from playing sound), make sure the module {{ic|snd_pcm_oss}} is not being loaded at boot. If it is currently loaded ({{ic|<nowiki>lsmod | grep oss</nowiki>}}), disable it by executing:
 
  # rmmod snd_pcm_oss
 
  # rmmod snd_pcm_oss
  
=== ALSA/dmix without grabbing hardware device ===
+
==== ALSA/dmix without grabbing hardware device ====
 +
 
 
{{Note|This section describes alternative configuration, which is generally '''not''' recommended.}}
 
{{Note|This section describes alternative configuration, which is generally '''not''' recommended.}}
  
Line 89: Line 97:
  
 
=== OSS ===
 
=== OSS ===
There are multiple ways of making OSS-only programs play to PulseAudio:
+
 
 +
There are multiple ways of making OSS-only programs output to PulseAudio:
  
 
==== ossp ====
 
==== ossp ====
Install {{Pkg|ossp}} package and start '''osspd''' service.
 
  
==== padsp wrapper (part of PulseAudio) ====
+
Install {{Pkg|ossp}} package and start {{ic|osspd.service}}.
Programs using OSS can work with PulseAudio by starting it with padsp:
+
 
 +
==== padsp wrapper ====
 +
 
 +
Programs using OSS can work with PulseAudio by starting it with padsp (included with PulseAudio):
  
 
  $ padsp OSSprogram
 
  $ padsp OSSprogram
 +
 
A few examples:
 
A few examples:
 +
 
  $ padsp aumix
 
  $ padsp aumix
 
  $ padsp sox foo.wav -t ossdsp /dev/dsp
 
  $ padsp sox foo.wav -t ossdsp /dev/dsp
  
 
You can also add a custom wrapper script like this:   
 
You can also add a custom wrapper script like this:   
 +
 
{{hc|/usr/local/bin/OSSProgram|<nowiki>
 
{{hc|/usr/local/bin/OSSProgram|<nowiki>
 
#!/bin/sh
 
#!/bin/sh
 
exec padsp /usr/bin/OSSprogram "$@"
 
exec padsp /usr/bin/OSSprogram "$@"
 
</nowiki>}}
 
</nowiki>}}
 +
 
Make sure {{ic|/usr/local/bin}} comes before {{ic|/usr/bin}} in your '''PATH'''.
 
Make sure {{ic|/usr/local/bin}} comes before {{ic|/usr/bin}} in your '''PATH'''.
  
 
=== GStreamer ===
 
=== GStreamer ===
To make [[GStreamer]] use PulseAudio, you need to install {{Pkg|gst-plugins-good}} or {{Pkg|gstreamer0.10-good-plugins}}.
+
 
 +
Install {{Pkg|gst-plugins-good}}, or {{Pkg|gstreamer0.10-good-plugins}} if your intended program has a legacy [[GStreamer]] implementation.
  
 
=== OpenAL ===
 
=== OpenAL ===
 +
 
OpenAL Soft should use PulseAudio by default, but can be explicitly configured to do so: {{hc|/etc/openal/alsoft.conf|2=drivers=pulse,alsa}}
 
OpenAL Soft should use PulseAudio by default, but can be explicitly configured to do so: {{hc|/etc/openal/alsoft.conf|2=drivers=pulse,alsa}}
  
 
=== libao ===
 
=== libao ===
 +
 
Edit the libao configuration file:
 
Edit the libao configuration file:
{{hc|# /etc/libao.conf|2=default_driver=pulse}}
+
{{hc|/etc/libao.conf|2=default_driver=pulse}}
 
Be sure to remove the {{ic|1=dev=default}} option of the alsa driver or adjust it to specify a specific Pulse sink name or number.  
 
Be sure to remove the {{ic|1=dev=default}} option of the alsa driver or adjust it to specify a specific Pulse sink name or number.  
  
 
{{Note|You could possibly also keep the libao standard of outputting to the ''alsa'' driver and its default device if you install {{pkg|pulseaudio-alsa}} since the ALSA default device then '''is''' PulseAudio.}}
 
{{Note|You could possibly also keep the libao standard of outputting to the ''alsa'' driver and its default device if you install {{pkg|pulseaudio-alsa}} since the ALSA default device then '''is''' PulseAudio.}}
  
=== ESD ===
+
== Equalizer ==
PulseAudio is a drop-in replacement for the enlightened sound daemon (ESD). While PulseAudio is running, ESD clients should be able to output to it without configuration.
+
  
== Desktop environments ==
+
PulseAudio has an integrated 10-band equalizer system. In order to use the equalizer do the following:
=== General X11 ===
+
{{Note|As mentioned previously, PulseAudio is very likely launched automatically via either {{ic|/etc/X11/xinit/xinitrc.d/pulseaudio}} or the files in {{ic|/etc/xdg/autostart/}} if users have some DE installed.}}
+
  
Check to see if PulseAudio is running:
+
=== Load equalizer sink and dbus-protocol module ===
  
{{hc|<nowiki>$ ps aux | grep pulse</nowiki>|
+
$ pactl load-module module-equalizer-sink
facade  1794  0.0  0.0 360464  6532 ?        S<l  15:33  0:00 /usr/bin/pulseaudio --start
+
  $ pactl load-module module-dbus-protocol
  facade  1827  0.0  0.0  68888  2608 ?        S    15:33  0:00 /usr/lib/pulse/gconf-helper
+
}}
+
  
If PulseAudio is not running and users are using X, the following will start PulseAudio with the needed the X11 plugins manually:
+
=== Install and run the GUI front-end ===
$ start-pulseaudio-x11
+
  
If you are not running GNOME, KDE, or Xfce, and your {{ic|~/.xinitrc}} does not source the scripts in {{ic|/etc/X11/xinit/xinitrc.d}} (such as is done in the example file {{ic|/etc/skel/.xinitrc}}), then you can launch PulseAudio on boot with:
+
Install {{Pkg|python-pyqt4}} and execute:
{{hc|~/.xinitrc|
+
/usr/bin/start-pulseaudio-x11
+
}}
+
  
=== GNOME ===
+
$ qpaeq
As of GNOME 3, GNOME fully integrates with PulseAudio and no extra configuration is needed.
+
  
=== KDE Plasma Workspaces and Qt4 ===
+
{{Note|If qpaeq has no effect, install {{pkg|pavucontrol}} and change "ALSA Playback on" to "FFT based equalizer on ..." while the media player is running.}}
PulseAudio, it will be used by KDE/Qt4 applications. For more information see the [http://www.pulseaudio.org/wiki/KDE KDE page in the PulseAudio wiki].
+
  
PulseAudio support has been merged into KMix, the default KDE sound mixer.
+
=== Load equalizer and dbus module on every boot ===
  
If the phonon-gstreamer backend is used for Phonon, GStreamer should also be [[PulseAudio#GStreamer|configured]] to use PulseAudio by installing {{Pkg|gstreamer0.10-good-plugins}}.
+
Edit the file {{ic|/etc/pulse/default.pa}} with your favorite editor and append the following lines:
  
One useful tidbit from that page is to add {{ic|load-module module-device-manager}} to {{ic|/etc/pulse/default.pa}}.
+
### Load the integrated PulseAudio equalizer and D-Bus module
 +
load-module module-equalizer-sink
 +
load-module module-dbus-protocol
  
Additionally, the {{AUR|kdeplasma-applets-veromix}} is available in the [[AUR]] as a KDE alternative to KMix or pavucontrol.
+
== Applications ==
  
If KMix/Veromix fail to connect to PulseAudio at boot you may need to edit {{ic|/etc/pulse/client.conf}} to include  {{ic|autospawn &#61; yes}} instead of {{ic|autospawn &#61; no}}.
+
=== KDE Plasma Workspaces and Qt4 ===
  
=== Xfce ===
+
PulseAudio will automatically be used by KDE/Qt4 applications. It is supported by default in the KDE sound mixer. For more information see the [http://www.pulseaudio.org/wiki/KDE KDE page in the PulseAudio wiki]. One useful tidbit from that page is to add {{ic|load-module module-device-manager}} to {{ic|/etc/pulse/default.pa}}.
Applications running under Xfce can take advantage of PulseAudio. To manage PulseAudio settings, you can use {{Pkg|pavucontrol}}.
+
 
 +
If the phonon-gstreamer backend is used for Phonon, GStreamer should also be configured as described in [[#GStreamer]].
  
== Applications ==
 
 
=== Audacious ===
 
=== Audacious ===
 +
 
[[Audacious]] natively supports PulseAudio. In order to use it, set Audacious Preferences -> Audio -> Current output plugin to 'PulseAudio Output Plugin'.
 
[[Audacious]] natively supports PulseAudio. In order to use it, set Audacious Preferences -> Audio -> Current output plugin to 'PulseAudio Output Plugin'.
  
 
=== Java/OpenJDK 6 ===
 
=== Java/OpenJDK 6 ===
 +
 
Create a wrapper for the Java executable using padsp as seen on the [[Java#Java_sound_with_PulseAudio|Java sound with PulseAudio]] page.
 
Create a wrapper for the Java executable using padsp as seen on the [[Java#Java_sound_with_PulseAudio|Java sound with PulseAudio]] page.
  
 
=== Music Player Daemon (MPD) ===
 
=== Music Player Daemon (MPD) ===
 +
 
[http://mpd.wikia.com/wiki/PulseAudio configure] [[MPD]] to use PulseAudio. See also [[MPD/Tips and Tricks#MPD and PulseAudio]].
 
[http://mpd.wikia.com/wiki/PulseAudio configure] [[MPD]] to use PulseAudio. See also [[MPD/Tips and Tricks#MPD and PulseAudio]].
  
 
=== MPlayer ===
 
=== MPlayer ===
 +
 
[[MPlayer]] natively supports PulseAudio output with the {{ic|-ao pulse}} option. It can also be configured to default to PulseAudio output, in {{ic|~/.mplayer/config}} for per-user, or {{ic|/etc/mplayer/mplayer.conf}} for system-wide:
 
[[MPlayer]] natively supports PulseAudio output with the {{ic|-ao pulse}} option. It can also be configured to default to PulseAudio output, in {{ic|~/.mplayer/config}} for per-user, or {{ic|/etc/mplayer/mplayer.conf}} for system-wide:
 
{{hc|/etc/mplayer/mplayer.conf|2=ao=pulse}}
 
{{hc|/etc/mplayer/mplayer.conf|2=ao=pulse}}
 
=== Skype (x86_64 only) ===
 
Install {{Pkg|lib32-libpulse}}, otherwise the following error will occur when trying to initiate a call: "Problem with Audio Playback".
 
  
 
=== guvcview ===
 
=== guvcview ===
 +
 
{{Pkg|guvcview}} when using the PulseAudio input from a [[Webcam]] may have the audio input suspended resulting in no audio being recorded.  You can check this by executing:
 
{{Pkg|guvcview}} when using the PulseAudio input from a [[Webcam]] may have the audio input suspended resulting in no audio being recorded.  You can check this by executing:
 +
 
  $ pactl list sources
 
  $ pactl list sources
 +
 
If the audio source is "suspended" then modifying the following line in {{ic|/etc/pulse/default.pa}} and changing:
 
If the audio source is "suspended" then modifying the following line in {{ic|/etc/pulse/default.pa}} and changing:
 +
 
  load-module module-suspend-on-idle
 
  load-module module-suspend-on-idle
 
to
 
to
 
  #load-module module-suspend-on-idle
 
  #load-module module-suspend-on-idle
 +
 
And then either restarting PulseAudio or your computer will only idle the input source instead of suspending it.  guvcview will then correctly record audio from the device.
 
And then either restarting PulseAudio or your computer will only idle the input source instead of suspending it.  guvcview will then correctly record audio from the device.
  
 
== Troubleshooting ==
 
== Troubleshooting ==
 +
 
=== No sound after install ===
 
=== No sound after install ===
 +
 
==== Muted audio device ====
 
==== Muted audio device ====
 +
 
If one experiences no audio output via any means while using ALSA, attempt to unmute the sound card.  To do this, launch {{ic|alsamixer}} and make sure each column has a green 00 under it (this can be toggled by pressing {{ic|m}}):
 
If one experiences no audio output via any means while using ALSA, attempt to unmute the sound card.  To do this, launch {{ic|alsamixer}} and make sure each column has a green 00 under it (this can be toggled by pressing {{ic|m}}):
 
  $ alsamixer -c 0
 
  $ alsamixer -c 0
Line 198: Line 216:
  
 
==== Auto-Mute Mode ====
 
==== Auto-Mute Mode ====
 +
 
Auto-Mute Mode may be enabled. It can be disabled using {{ic|alsamixer}}.
 
Auto-Mute Mode may be enabled. It can be disabled using {{ic|alsamixer}}.
  
Line 203: Line 222:
  
 
==== Bad configuration files ====
 
==== Bad configuration files ====
 +
 
After starting PulseAudio, if the system outputs no sound, it may be necessary to delete the contents of {{ic|~/.pulse}}. PulseAudio will automatically create new configuration files on its next start.
 
After starting PulseAudio, if the system outputs no sound, it may be necessary to delete the contents of {{ic|~/.pulse}}. PulseAudio will automatically create new configuration files on its next start.
  
 
==== Flash content ====
 
==== Flash content ====
 +
 
Since Adobe Flash does not directly support PulseAudio, the recommended way is to [[PulseAudio#ALSA|configure ALSA to use the virtual PulseAudio sound card]].
 
Since Adobe Flash does not directly support PulseAudio, the recommended way is to [[PulseAudio#ALSA|configure ALSA to use the virtual PulseAudio sound card]].
  
Line 214: Line 235:
  
 
==== No cards ====
 
==== No cards ====
 +
 
If PulseAudio starts, run {{ic|pacmd list}}. If no cards are reported, make sure that the ALSA devices are not in use:
 
If PulseAudio starts, run {{ic|pacmd list}}. If no cards are reported, make sure that the ALSA devices are not in use:
 +
 
  $ fuser -v /dev/snd/*
 
  $ fuser -v /dev/snd/*
 
  $ fuser -v /dev/dsp
 
  $ fuser -v /dev/dsp
Line 221: Line 244:
  
 
==== The only device shown is "dummy output" ====
 
==== The only device shown is "dummy output" ====
 +
 
This may be caused by different reasons, one of them being the {{ic|.asoundrc}} file in $HOME is taking precedence over the systemwide {{ic|/etc/asound.conf}}.
 
This may be caused by different reasons, one of them being the {{ic|.asoundrc}} file in $HOME is taking precedence over the systemwide {{ic|/etc/asound.conf}}.
  
 
The user file is modified also by the tool {{ic|asoundconf}} or by its graphical variant {{ic|asoundconf-gtk}} (the latter is named "Default sound card" in the menu) as soon as it  runs.  Prevent the effects of {{ic|.asoundrc}} altogether by commenting the last line like this:
 
The user file is modified also by the tool {{ic|asoundconf}} or by its graphical variant {{ic|asoundconf-gtk}} (the latter is named "Default sound card" in the menu) as soon as it  runs.  Prevent the effects of {{ic|.asoundrc}} altogether by commenting the last line like this:
 +
 
{{hc|.asoundrc|
 
{{hc|.asoundrc|
 
# </home/''yourusername''/.asoundrc.asoundconf>
 
# </home/''yourusername''/.asoundrc.asoundconf>
Line 229: Line 254:
  
 
Maybe some program is monopolizing the audio device:
 
Maybe some program is monopolizing the audio device:
 +
 
{{hc|# fuser -v /dev/snd/*|
 
{{hc|# fuser -v /dev/snd/*|
 
                     USER      PID  ACCESS COMMAND
 
                     USER      PID  ACCESS COMMAND
Line 246: Line 272:
 
  # pacman -Rnsc fluidsynth
 
  # pacman -Rnsc fluidsynth
  
==== No HDMI 5/7.1 Selection for Device ====
+
==== No HDMI 5/7.1 Selection for Device ====
 +
 
 
If you are unable to select 5/7.1 channel output for a working HDMI device, then turning off "stream device reading" in {{ic|/etc/pulse/default.pa}} might help.  
 
If you are unable to select 5/7.1 channel output for a working HDMI device, then turning off "stream device reading" in {{ic|/etc/pulse/default.pa}} might help.  
  
Line 252: Line 279:
  
 
==== KDE Plasma Workspaces ====
 
==== KDE Plasma Workspaces ====
 +
 
It may be that another output device set as preferred in phonon. Make sure that every setting reflects the preferred output device at the top, and check the playback streams tab in {{ic|kmix}} to make sure that applications are using the device for output.
 
It may be that another output device set as preferred in phonon. Make sure that every setting reflects the preferred output device at the top, and check the playback streams tab in {{ic|kmix}} to make sure that applications are using the device for output.
  
Line 263: Line 291:
  
 
To set your default audio device, use "pacmd" or add to {{ic|/etc/pulse/default.pa}}:
 
To set your default audio device, use "pacmd" or add to {{ic|/etc/pulse/default.pa}}:
 +
 
  set-default-sink alsa_output.analog-stereo
 
  set-default-sink alsa_output.analog-stereo
  
 
==== Failed to create sink input: sink is suspended ====
 
==== Failed to create sink input: sink is suspended ====
 +
 
If you do not have any output sound and receive dozens of errors related to a suspended sink in your {{ic|journalctl -b}} log, then backup first and then delete your user-specific pulse folders:
 
If you do not have any output sound and receive dozens of errors related to a suspended sink in your {{ic|journalctl -b}} log, then backup first and then delete your user-specific pulse folders:
  
 
  $ rm -r ~/.pulse ~/.pulse-cookie
 
  $ rm -r ~/.pulse ~/.pulse-cookie
 +
 +
=== Starting an application interrupts other app's sound ===
 +
 +
If you have trouble with some applications (eg. Teamspeak, Mumble) interrupting sound output of already running applications (eg. Deadbeaf), you can solve this by commenting out the line {{ic|load-module module-role-cork}} in {{ic|/etc/pulse/default.pa}} like shown below:
 +
 +
{{hc|/etc/pulse/default.pa|
 +
### Cork music/video streams when a phone stream is active
 +
# load-module module-role-cork
 +
}}
 +
 +
Then restart pulseaudo by using your normal user account with
 +
 +
pulseaudio -k
 +
pulseaudio --start
  
 
=== No HDMI sound output after some time with the monitor turned off ===
 
=== No HDMI sound output after some time with the monitor turned off ===
 +
 
The monitor is connected via HDMI/DisplayPort, and the audio jack is plugged in the headphone jack of the monitor, but PulseAudio insists that it is unplugged:
 
The monitor is connected via HDMI/DisplayPort, and the audio jack is plugged in the headphone jack of the monitor, but PulseAudio insists that it is unplugged:
 +
 
{{hc|pactl list sinks|
 
{{hc|pactl list sinks|
 
...
 
...
Line 278: Line 324:
 
}}
 
}}
  
This leads to no sound coming from HDMI output. A workaround for this is to switch to another TTY and back again. This problem has been reported by ATI/Nvidia/Intel users.
+
This leads to no sound coming from HDMI output. A workaround for this is to switch to another VT and back again. If that doesn't work, try: turn off your monitor, switch to another VT, turn on your monitor, and switch back. This problem has been reported by ATI/Nvidia/Intel users.
 +
 
 +
=== Enable Echo/Noise-Cancelation ===
 +
 
 +
Arch doesn't load the Pulseaudio Echo-Cancelation module by default, therefore, we have to add it in {{ic|/etc/pulse/default.pa}}. First you can test if the module is present with {{ic|pacmd}} and entering {{ic|list-modules}}. If you can't find a line showing {{ic|name: <module-echo-cancel>}} you have to add
 +
 
 +
{{hc|/etc/pulse/default.pa|
 +
load-module module-echo-cancel
 +
}}
 +
 
 +
then restart Pulseaudio
 +
 
 +
pulseaudio -k
 +
pulseaudio --start
 +
 
 +
and check if the module is activated by starting {{ic|pavucontrol}}. Under {{ic|Recoding}} the input device should show {{ic|Echo-Cancel Source Stream from"}}
  
 
=== Can't update configuration of sound device in pavucontrol ===
 
=== Can't update configuration of sound device in pavucontrol ===
 +
 
{{Pkg|pavucontrol}} is a handy GUI utility for configuring PulseAudio. Under its 'Configuration' tab, you can select different profiles for each of your sound devices e.g. analogue stereo, digital output (IEC958), HDMI 5.1 Surround etc.
 
{{Pkg|pavucontrol}} is a handy GUI utility for configuring PulseAudio. Under its 'Configuration' tab, you can select different profiles for each of your sound devices e.g. analogue stereo, digital output (IEC958), HDMI 5.1 Surround etc.
  
Line 286: Line 348:
  
 
=== Simultaneous output to multiple sound cards / devices ===
 
=== Simultaneous output to multiple sound cards / devices ===
 +
 
Simultaneous output to two different devices can be very useful. For example, being able to send audio to your A/V receiver via your graphics card's HDMI output, while also sending the same audio through the analogue output of your motherboard's built-in audio. This is much less hassle than it used to be (in this example, we are using GNOME desktop).
 
Simultaneous output to two different devices can be very useful. For example, being able to send audio to your A/V receiver via your graphics card's HDMI output, while also sending the same audio through the analogue output of your motherboard's built-in audio. This is much less hassle than it used to be (in this example, we are using GNOME desktop).
  
Line 298: Line 361:
  
 
=== Simultaneous output to multiple sinks on the same sound card not working===
 
=== Simultaneous output to multiple sinks on the same sound card not working===
 +
 
This can be useful for users who have multiple sound sources and want to play them on different sinks/outputs.  
 
This can be useful for users who have multiple sound sources and want to play them on different sinks/outputs.  
 
An example use-case for this would be if you play music and also voice chat and want to output music to speakers (in this case Digital S/PDIF) and voice to headphones. (Analog)
 
An example use-case for this would be if you play music and also voice chat and want to output music to speakers (in this case Digital S/PDIF) and voice to headphones. (Analog)
Line 309: Line 373:
  
 
Create a pulseadio udev rule.
 
Create a pulseadio udev rule.
{{Note| This is only an example for Asus Xonar Essence STX.
+
 
 +
{{Note|This is only an example for Asus Xonar Essence STX.
 
Read [[udev]] to find out the correct values.}}
 
Read [[udev]] to find out the correct values.}}
{{Note| Your configuration file should have lower number than the original PulseAudio rule to take effect.}}
+
 
 +
{{Note|Your configuration file should have lower number than the original PulseAudio rule to take effect.}}
 +
 
 
{{hc|/usr/lib/udev/rules.d/90-pulseaudio-Xonar-STX.rules|
 
{{hc|/usr/lib/udev/rules.d/90-pulseaudio-Xonar-STX.rules|
 
ACTION&#61;&#61;"change", SUBSYSTEM&#61;&#61;"sound", KERNEL&#61;&#61;"card*", \
 
ACTION&#61;&#61;"change", SUBSYSTEM&#61;&#61;"sound", KERNEL&#61;&#61;"card*", \
Line 320: Line 387:
  
 
To enable multiple sinks for Asus Xonar Essence STX you need only to add this in.
 
To enable multiple sinks for Asus Xonar Essence STX you need only to add this in.
 +
 
{{Note|{{ic|asus-xonar-essence-stx.conf}} also includes all code/mappings from {{ic|default.conf}}.}}
 
{{Note|{{ic|asus-xonar-essence-stx.conf}} also includes all code/mappings from {{ic|default.conf}}.}}
 +
 
{{hc|/usr/share/pulseaudio/alsa-mixer/profile-sets/asus-xonar-essence-stx.conf|
 
{{hc|/usr/share/pulseaudio/alsa-mixer/profile-sets/asus-xonar-essence-stx.conf|
 
[Profile analog-stereo+iec958-stereo]
 
[Profile analog-stereo+iec958-stereo]
Line 336: Line 405:
  
 
=== Disable Bluetooth support ===
 
=== Disable Bluetooth support ===
 +
 
If you do not use Bluetooth, you may experience the following error in your journal:
 
If you do not use Bluetooth, you may experience the following error in your journal:
  
Line 354: Line 424:
  
 
=== Bluetooth headset replay problems ===
 
=== Bluetooth headset replay problems ===
 +
 
Some user [https://bbs.archlinux.org/viewtopic.php?id=117420 reports] huge delays or even no sound when the Bluetooth connection does not send any data. This is due to the {{ic|module-suspend-on-idle}} module, which automatically suspends sinks/sources on idle. As this can cause problems with headset, the responsible module can be deactivated.
 
Some user [https://bbs.archlinux.org/viewtopic.php?id=117420 reports] huge delays or even no sound when the Bluetooth connection does not send any data. This is due to the {{ic|module-suspend-on-idle}} module, which automatically suspends sinks/sources on idle. As this can cause problems with headset, the responsible module can be deactivated.
  
Line 366: Line 437:
  
 
=== Automatically switch to Bluetooth or USB headset ===
 
=== Automatically switch to Bluetooth or USB headset ===
 +
 
Add the following:
 
Add the following:
 
{{hc|/etc/pulse/default.pa|
 
{{hc|/etc/pulse/default.pa|
Line 373: Line 445:
  
 
=== Pulse overwrites ALSA settings ===
 
=== Pulse overwrites ALSA settings ===
 +
 
PulseAudio usually overwrites the ALSA settings — for example set with alsamixer — at start-up, even when the ALSA daemon is loaded. Since there seems to be no other way to restrict this behaviour, a workaround is to restore the ALSA settings again after PulseAudio has started. Add the following command to {{ic|.xinitrc}} or {{ic|.bash_profile}} or any other [[Autostarting|autostart]] file:
 
PulseAudio usually overwrites the ALSA settings — for example set with alsamixer — at start-up, even when the ALSA daemon is loaded. Since there seems to be no other way to restrict this behaviour, a workaround is to restore the ALSA settings again after PulseAudio has started. Add the following command to {{ic|.xinitrc}} or {{ic|.bash_profile}} or any other [[Autostarting|autostart]] file:
  
Line 384: Line 457:
  
 
=== Prevent Pulse from restarting after being killed ===
 
=== Prevent Pulse from restarting after being killed ===
 +
 
Sometimes you may wish to temporarily disable Pulse. In order to do so you will have to prevent Pulse from restarting after being killed.
 
Sometimes you may wish to temporarily disable Pulse. In order to do so you will have to prevent Pulse from restarting after being killed.
  
Line 392: Line 466:
  
 
=== Daemon startup failed ===
 
=== Daemon startup failed ===
 +
 
Try resetting PulseAudio:
 
Try resetting PulseAudio:
 
  $ rm -rf /tmp/pulse* ~/.pulse*
 
  $ rm -rf /tmp/pulse* ~/.pulse*
Line 400: Line 475:
  
 
==== inotify issue ====
 
==== inotify issue ====
 +
 
If the previous fix doesn't work, see if you get an error like this:
 
If the previous fix doesn't work, see if you get an error like this:
 +
 
{{hc|$ pulseaudio -vvvv|
 
{{hc|$ pulseaudio -vvvv|
 
E: [pulseaudio] module-udev-detect.c: You apparently ran out of inotify watches, probably because Tracker/Beagle took them all away. I wished people would do their homework first and fix inotify before using it for watching whole directory trees which is something the current inotify is certainly not useful for. Please make sure to drop the Tracker/Beagle guys a line complaining about their broken use of inotify.
 
E: [pulseaudio] module-udev-detect.c: You apparently ran out of inotify watches, probably because Tracker/Beagle took them all away. I wished people would do their homework first and fix inotify before using it for watching whole directory trees which is something the current inotify is certainly not useful for. Please make sure to drop the Tracker/Beagle guys a line complaining about their broken use of inotify.
Line 417: Line 494:
  
 
=== Glitches, skips or crackling ===
 
=== Glitches, skips or crackling ===
 +
 
The newer implementation of the PulseAudio sound server uses timer-based audio scheduling instead of the traditional, interrupt-driven approach.  
 
The newer implementation of the PulseAudio sound server uses timer-based audio scheduling instead of the traditional, interrupt-driven approach.  
  
Line 427: Line 505:
  
 
Then restart the PulseAudio server:
 
Then restart the PulseAudio server:
 +
 
  $ pulseaudio -k
 
  $ pulseaudio -k
 
  $ pulseaudio --start
 
  $ pulseaudio --start
Line 439: Line 518:
  
 
==== Finding out your audio device parameters (1/4) ====
 
==== Finding out your audio device parameters (1/4) ====
 +
 
To find your sound card buffering settings:
 
To find your sound card buffering settings:
 
  $ echo autospawn = no >> ~/.config/pulse/client.conf
 
  $ echo autospawn = no >> ~/.config/pulse/client.conf
Line 462: Line 542:
  
 
==== Calculate your fragment size in msecs and number of fragments (2/4) ====
 
==== Calculate your fragment size in msecs and number of fragments (2/4) ====
 +
 
PulseAudio's default sampling rate and bit depth are set to {{ic|44100Hz}} @ {{ic|16 bits}}.
 
PulseAudio's default sampling rate and bit depth are set to {{ic|44100Hz}} @ {{ic|16 bits}}.
  
Line 472: Line 553:
  
 
==== Modify PulseAudio's configuration file (3/4) ====
 
==== Modify PulseAudio's configuration file (3/4) ====
 +
 
{{hc|/etc/pulse/daemon.conf|<nowiki>
 
{{hc|/etc/pulse/daemon.conf|<nowiki>
 
; default-fragments = X
 
; default-fragments = X
Line 486: Line 568:
  
 
==== Restart the PulseAudio daemon (4/4) ====
 
==== Restart the PulseAudio daemon (4/4) ====
 +
 
  $ pulseaudio -k
 
  $ pulseaudio -k
 
  $ pulseaudio --start
 
  $ pulseaudio --start
Line 492: Line 575:
  
 
=== Laggy sound ===
 
=== Laggy sound ===
 +
 
This issue is due to incorrect buffer sizes.
 
This issue is due to incorrect buffer sizes.
  
Line 501: Line 585:
  
 
=== Choppy, overdriven sound ===
 
=== Choppy, overdriven sound ===
 +
 
Choppy sound in PulseAudio can result from wrong settings for the sample rate. Try:
 
Choppy sound in PulseAudio can result from wrong settings for the sample rate. Try:
 
{{hc|/etc/pulse/daemon.conf|<nowiki>
 
{{hc|/etc/pulse/daemon.conf|<nowiki>
Line 511: Line 596:
  
 
Setting the PCM volume above 0 dB can cause clipping of the audio signal. Running {{ic|alsamixer -c0}} will allow you to see if this is the problem and if so fix it. Note that ALSA may not [http://www.freedesktop.org/wiki/Software/PulseAudio/Documentation/User/PulseAudioStoleMyVolumes correctly export] the dB information to PulseAudio. Try:
 
Setting the PCM volume above 0 dB can cause clipping of the audio signal. Running {{ic|alsamixer -c0}} will allow you to see if this is the problem and if so fix it. Note that ALSA may not [http://www.freedesktop.org/wiki/Software/PulseAudio/Documentation/User/PulseAudioStoleMyVolumes correctly export] the dB information to PulseAudio. Try:
 +
 
{{hc|/etc/pulse/defaults.pa|<nowiki>
 
{{hc|/etc/pulse/defaults.pa|<nowiki>
 
load-module module-udev-detect ignore_dB=1
 
load-module module-udev-detect ignore_dB=1
Line 517: Line 603:
  
 
=== Volume adjustment does not work properly ===
 
=== Volume adjustment does not work properly ===
 +
 
Check:
 
Check:
 
{{ic|/usr/share/pulseaudio/alsa-mixer/paths/analog-output.conf.common}}
 
{{ic|/usr/share/pulseaudio/alsa-mixer/paths/analog-output.conf.common}}
Line 523: Line 610:
  
 
=== Per-application volumes change when the Master volume is adjusted ===
 
=== Per-application volumes change when the Master volume is adjusted ===
 +
 
This is because PulseAudio uses flat volumes by default, instead of relative volumes, relative to an absolute master volume. If this is found to be inconvenient, asinine, or otherwise undesireable, relative volumes can be enabled by disabling flat volumes in the PulseAudio daemon's configuration file:
 
This is because PulseAudio uses flat volumes by default, instead of relative volumes, relative to an absolute master volume. If this is found to be inconvenient, asinine, or otherwise undesireable, relative volumes can be enabled by disabling flat volumes in the PulseAudio daemon's configuration file:
 +
 
{{hc|/etc/pulse/daemon.conf|<nowiki>
 
{{hc|/etc/pulse/daemon.conf|<nowiki>
 
flat-volumes = no
 
flat-volumes = no
 
</nowiki>}}
 
</nowiki>}}
 +
 
and then restarting PulseAudio by executing
 
and then restarting PulseAudio by executing
 +
 
  $ pulseaudio -k
 
  $ pulseaudio -k
 
  $ pulseaudio --start
 
  $ pulseaudio --start
  
 
=== Volume gets louder every time a new application is started ===
 
=== Volume gets louder every time a new application is started ===
 +
 
Per default, it seems as if changing the volume in an application sets the global system volume to that level instead of only affecting the respective application. Applications setting their volume on startup will therefore cause the system volume to "jump".
 
Per default, it seems as if changing the volume in an application sets the global system volume to that level instead of only affecting the respective application. Applications setting their volume on startup will therefore cause the system volume to "jump".
  
Line 539: Line 631:
  
 
=== No microphone on ThinkPad T400/T500/T420 ===
 
=== No microphone on ThinkPad T400/T500/T420 ===
 +
 
Run:
 
Run:
 +
 
  alsamixer -c 0
 
  alsamixer -c 0
 +
 
Unmute and maximize the volume of the "Internal Mic".
 
Unmute and maximize the volume of the "Internal Mic".
  
 
Once you see the device with:
 
Once you see the device with:
 +
 
  arecord -l
 
  arecord -l
 +
 
you might still need to adjust the settings. The microphone and the audio jack are duplexed. Set the configuration of the internal audio in pavucontrol to ''Analog Stereo Duplex''.
 
you might still need to adjust the settings. The microphone and the audio jack are duplexed. Set the configuration of the internal audio in pavucontrol to ''Analog Stereo Duplex''.
  
 
=== No microphone input on Acer Aspire One ===
 
=== No microphone input on Acer Aspire One ===
 +
 
Install pavucontrol, unlink the microphone channels and turn down the left one to 0.
 
Install pavucontrol, unlink the microphone channels and turn down the left one to 0.
 
Reference: http://getsatisfaction.com/jolicloud/topics/deaf_internal_mic_on_acer_aspire_one#reply_2108048
 
Reference: http://getsatisfaction.com/jolicloud/topics/deaf_internal_mic_on_acer_aspire_one#reply_2108048
  
 
=== Sound output is only mono on M-Audio Audiophile 2496 sound card ===
 
=== Sound output is only mono on M-Audio Audiophile 2496 sound card ===
 +
 
Add the following:
 
Add the following:
 +
 
{{hc|/etc/pulseaudio/default.pa|<nowiki>
 
{{hc|/etc/pulseaudio/default.pa|<nowiki>
 
load-module module-alsa-sink sink_name=delta_out device=hw:M2496 format=s24le channels=10 channel_map=left,right,aux0,aux1,aux2,aux3,aux4,aux5,aux6,aux7
 
load-module module-alsa-sink sink_name=delta_out device=hw:M2496 format=s24le channels=10 channel_map=left,right,aux0,aux1,aux2,aux3,aux4,aux5,aux6,aux7
Line 561: Line 661:
  
 
=== Static noise in microphone recording ===
 
=== Static noise in microphone recording ===
 +
 
If we are getting static noise in Skype, gnome-sound-recorder, arecord, etc.'s recordings, then the sound card sample rate is incorrect. That is why there is static noise in Linux microphone recordings. To fix this, we need to set the sampling rate in {{ic|/etc/pulse/daemon.conf}} for the sound hardware.
 
If we are getting static noise in Skype, gnome-sound-recorder, arecord, etc.'s recordings, then the sound card sample rate is incorrect. That is why there is static noise in Linux microphone recordings. To fix this, we need to set the sampling rate in {{ic|/etc/pulse/daemon.conf}} for the sound hardware.
  
 
==== Determine sound cards in the system (1/5) ====
 
==== Determine sound cards in the system (1/5) ====
 +
 
This requires {{Pkg|alsa-utils}} and related packages to be installed:
 
This requires {{Pkg|alsa-utils}} and related packages to be installed:
 
{{hc|$ arecord --list-devices|
 
{{hc|$ arecord --list-devices|
Line 578: Line 680:
  
 
==== Determine sampling rate of the sound card (2/5) ====
 
==== Determine sampling rate of the sound card (2/5) ====
 +
 
{{hc|1=arecord -f dat -r 60000 -D hw:0,0 -d 5 test.wav|2=
 
{{hc|1=arecord -f dat -r 60000 -D hw:0,0 -d 5 test.wav|2=
 
"Recording WAVE 'test.wav' : Signed 16 bit Little Endian, Rate 60000 Hz, Stereo
 
"Recording WAVE 'test.wav' : Signed 16 bit Little Endian, Rate 60000 Hz, Stereo
Line 587: Line 690:
  
 
==== Setting the sound card's sampling rate into PulseAudio configuration (3/5) ====
 
==== Setting the sound card's sampling rate into PulseAudio configuration (3/5) ====
 +
 
The default sampling rate in PulseAudio:
 
The default sampling rate in PulseAudio:
 
{{hc|1=$ grep "default-sample-rate" /etc/pulse/daemon.conf|2=
 
{{hc|1=$ grep "default-sample-rate" /etc/pulse/daemon.conf|2=
Line 596: Line 700:
  
 
==== Restart PulseAudio to apply the new settings (4/5) ====
 
==== Restart PulseAudio to apply the new settings (4/5) ====
 +
 
  $ pulseaudio -k
 
  $ pulseaudio -k
 
  $ pulseaudio --start
 
  $ pulseaudio --start
  
 
==== Finally check by recording and playing it back (5/5) ====
 
==== Finally check by recording and playing it back (5/5) ====
 +
 
Let us record some voice using a microphone for, say, 10 seconds. Make sure the microphone is not muted and all
 
Let us record some voice using a microphone for, say, 10 seconds. Make sure the microphone is not muted and all
 +
 
  $ arecord -f cd -d 10 test-mic.wav
 
  $ arecord -f cd -d 10 test-mic.wav
  
 
After 10 seconds, let us play the recording...
 
After 10 seconds, let us play the recording...
 +
 
  $ aplay test-mic.wav
 
  $ aplay test-mic.wav
  
Line 609: Line 717:
  
 
=== My Bluetooth device is paired but does not play any sound ===
 
=== My Bluetooth device is paired but does not play any sound ===
 +
 
[[Bluetooth#My_device_is_paired_but_no_sound_is_played_from_it|See the article in Bluetooth section]]
 
[[Bluetooth#My_device_is_paired_but_no_sound_is_played_from_it|See the article in Bluetooth section]]
  
 
Starting from PulseAudio 2.99 and bluez 4.101 you should '''avoid''' using Socket interface. Do NOT use:
 
Starting from PulseAudio 2.99 and bluez 4.101 you should '''avoid''' using Socket interface. Do NOT use:
 +
 
{{hc|/etc/bluetooth/audio.conf|<nowiki>
 
{{hc|/etc/bluetooth/audio.conf|<nowiki>
 
[General]
 
[General]
 
Enable=Socket
 
Enable=Socket
 
</nowiki>}}
 
</nowiki>}}
 +
 
If you face problems with A2DP and PA 2.99 make sure you have {{Pkg|sbc}} library.
 
If you face problems with A2DP and PA 2.99 make sure you have {{Pkg|sbc}} library.
  
=== Subwoofer stops working after end of every song ===
+
=== Subwoofer stops working after end of every song ===
 +
 
 
Known issue: https://bugs.launchpad.net/ubuntu/+source/pulseaudio/+bug/494099
 
Known issue: https://bugs.launchpad.net/ubuntu/+source/pulseaudio/+bug/494099
  
Line 627: Line 739:
  
 
=== PulseAudio uses wrong microphone ===
 
=== PulseAudio uses wrong microphone ===
 +
 
If PulseAudio uses the wrong microphone, and changing the Input Device with Pavucontrol did not help, take a look at alsamixer. It seems that Pavucontrol does not always set the input source correctly.
 
If PulseAudio uses the wrong microphone, and changing the Input Device with Pavucontrol did not help, take a look at alsamixer. It seems that Pavucontrol does not always set the input source correctly.
  
Line 636: Line 749:
  
 
=== Choppy sound with analog surround sound setup ===
 
=== Choppy sound with analog surround sound setup ===
 +
 
The low-frequency effects (LFE) channel is not remixed per default. To enable it the following needs to be set in {{ic|/etc/pulse/daemon.conf}} :
 
The low-frequency effects (LFE) channel is not remixed per default. To enable it the following needs to be set in {{ic|/etc/pulse/daemon.conf}} :
 
{{hc|/etc/pulse/daemon.conf|<nowiki>
 
{{hc|/etc/pulse/daemon.conf|<nowiki>
Line 642: Line 756:
  
 
=== Unable to select surround configuration other than "Surround 4.0" ===
 
=== Unable to select surround configuration other than "Surround 4.0" ===
 +
 
If you're unable to set 5.1 surround output in pavucontrol because it only shows "Analog Surround 4.0 Output", open the ALSA mixer and change the output configuration there to 6 channels. Then restart pulseaudio, and pavucontrol will list many more options.
 
If you're unable to set 5.1 surround output in pavucontrol because it only shows "Analog Surround 4.0 Output", open the ALSA mixer and change the output configuration there to 6 channels. Then restart pulseaudio, and pavucontrol will list many more options.
  
 
=== No sound below a volume cutoff ===
 
=== No sound below a volume cutoff ===
 +
 
Known issue (won't fix): https://bugs.launchpad.net/ubuntu/+source/pulseaudio/+bug/223133
 
Known issue (won't fix): https://bugs.launchpad.net/ubuntu/+source/pulseaudio/+bug/223133
  
Line 655: Line 771:
  
 
=== Low volume for internal microphone ===
 
=== Low volume for internal microphone ===
 +
 
If you experience low volume on internal notebook microphone, try setting:
 
If you experience low volume on internal notebook microphone, try setting:
 
{{hc|/etc/pulse/default.pa|<nowiki>
 
{{hc|/etc/pulse/default.pa|<nowiki>
Line 661: Line 778:
  
 
=== Clients alter master output volume (a.k.a. volume jumps to 100% after running application) ===
 
=== Clients alter master output volume (a.k.a. volume jumps to 100% after running application) ===
 +
 
If changing the volume in specific applications or simply running an application changes the master output volume this is likely due to flat volumes mode of pulseaudio. Before disabling it, KDE users should try lowering their system notifications volume in ''System Settings -> Application and System Notifications -> Manage Notifications'' under the ''Player Settings'' tab to something reasonable. Changing the ''Event Sounds'' volume in KMix or another volume mixer application will not help here. This should make the flat-volumes mode work out as intended, if it does not work, some other application is likely requesting 100% volume when its playing something. If all else fails, you can try to disable flat-volumes:
 
If changing the volume in specific applications or simply running an application changes the master output volume this is likely due to flat volumes mode of pulseaudio. Before disabling it, KDE users should try lowering their system notifications volume in ''System Settings -> Application and System Notifications -> Manage Notifications'' under the ''Player Settings'' tab to something reasonable. Changing the ''Event Sounds'' volume in KMix or another volume mixer application will not help here. This should make the flat-volumes mode work out as intended, if it does not work, some other application is likely requesting 100% volume when its playing something. If all else fails, you can try to disable flat-volumes:
 +
 
{{hc|/etc/pulse/daemon.conf|<nowiki>
 
{{hc|/etc/pulse/daemon.conf|<nowiki>
 
flat-volumes = no
 
flat-volumes = no
 
</nowiki>}}
 
</nowiki>}}
 +
 
Then restart PulseAudio daemon:
 
Then restart PulseAudio daemon:
 +
 
  # pulseaudio -k
 
  # pulseaudio -k
 
  # pulseaudio --start
 
  # pulseaudio --start
  
 
===Realtime scheduling===
 
===Realtime scheduling===
 +
 
If rtkit does not work, you can manually set up your system to run PulseAudio with real-time scheduling, which can help performance. To do this, add the following lines to {{ic|/etc/security/limits.conf}}:
 
If rtkit does not work, you can manually set up your system to run PulseAudio with real-time scheduling, which can help performance. To do this, add the following lines to {{ic|/etc/security/limits.conf}}:
 +
 
  @pulse-rt - rtprio 9
 
  @pulse-rt - rtprio 9
 
  @pulse-rt - nice -11
 
  @pulse-rt - nice -11
  
 
Afterwards, you need to add your user to the {{ic|pulse-rt}} group:
 
Afterwards, you need to add your user to the {{ic|pulse-rt}} group:
 +
 
  # gpasswd -a <user> pulse-rt
 
  # gpasswd -a <user> pulse-rt
  
 
=== No sound after resume from suspend ===
 
=== No sound after resume from suspend ===
 +
 
If audio generally works, but stops after resume from suspend, try "reloading" PulseAudio by executing:
 
If audio generally works, but stops after resume from suspend, try "reloading" PulseAudio by executing:
 
  $ /usr/bin/pasuspender /bin/true
 
  $ /usr/bin/pasuspender /bin/true
Line 709: Line 834:
  
 
=== ALSA channels mute when headphones are plugged/unplugged improperly ===
 
=== ALSA channels mute when headphones are plugged/unplugged improperly ===
 +
 
If when you unplug your headphones or plug them in the audio remains muted in alsamixer on the wrong channel due to it being set to 0%, you may be able to fix it by opening {{ic|/etc/pulse/default.pa}} and commenting out the line:
 
If when you unplug your headphones or plug them in the audio remains muted in alsamixer on the wrong channel due to it being set to 0%, you may be able to fix it by opening {{ic|/etc/pulse/default.pa}} and commenting out the line:
 +
 
  load-module module-switch-on-port-available
 
  load-module module-switch-on-port-available
  
 
=== pactl "invalid option" error with negative percentage arguments ===
 
=== pactl "invalid option" error with negative percentage arguments ===
 +
 
{{ic|pactl}} commands that take negative percentage arguments will fail with an 'invalid option' error. Use the standard shell '--' pseudo argument
 
{{ic|pactl}} commands that take negative percentage arguments will fail with an 'invalid option' error. Use the standard shell '--' pseudo argument
 
to disable argument parsing before the negative argument. ''e.g.'' {{ic|pactl set-sink-volume 1 -- -5%}}.
 
to disable argument parsing before the negative argument. ''e.g.'' {{ic|pactl set-sink-volume 1 -- -5%}}.
  
===Daemon already running===
+
=== Daemon already running ===
 +
 
 
On some systems, PulseAudio may be started multiple times. journalctl will report:
 
On some systems, PulseAudio may be started multiple times. journalctl will report:
  
Line 730: Line 859:
  
 
=== Fallback device is not respected ===
 
=== Fallback device is not respected ===
 +
 
PulseAudio does not have a true default device. Instead it uses a [http://www.freedesktop.org/wiki/Software/PulseAudio/Documentation/User/DefaultDevice/ "fallback"], which only applies to new sound streams. This means previously run applications are not affected by the newly set fallback device.
 
PulseAudio does not have a true default device. Instead it uses a [http://www.freedesktop.org/wiki/Software/PulseAudio/Documentation/User/DefaultDevice/ "fallback"], which only applies to new sound streams. This means previously run applications are not affected by the newly set fallback device.
  
Line 739: Line 869:
  
 
3. Disable stream device reading. This may be not wanted when using different soundcards with different applications.
 
3. Disable stream device reading. This may be not wanted when using different soundcards with different applications.
 +
 
{{hc|/etc/pulse/defaults.pa|<nowiki>
 
{{hc|/etc/pulse/defaults.pa|<nowiki>
 
load-module module-stream-restore restore_device=false
 
load-module module-stream-restore restore_device=false
Line 744: Line 875:
  
 
=== No Microphone on Steam or Skype if you set enable-remixing = no ===
 
=== No Microphone on Steam or Skype if you set enable-remixing = no ===
 +
 
When you set {{ic|1=enable-remixing = no}} on {{ic|/etc/pulse/daemon.conf}} you may find that your microphone has stopped working on certain applications like Skype or Steam. This happens because these applications capture the microphone as mono only and because remixing is disabled, Pulseaudio will no longer remix your stereo microphone to mono.
 
When you set {{ic|1=enable-remixing = no}} on {{ic|/etc/pulse/daemon.conf}} you may find that your microphone has stopped working on certain applications like Skype or Steam. This happens because these applications capture the microphone as mono only and because remixing is disabled, Pulseaudio will no longer remix your stereo microphone to mono.
  
Line 775: Line 907:
  
 
== See also ==
 
== See also ==
 +
 
* [http://www.alsa-project.org/main/index.php/Asoundrc http://www.alsa-project.org/main/index.php/Asoundrc] - ALSA wiki on .asoundrc
 
* [http://www.alsa-project.org/main/index.php/Asoundrc http://www.alsa-project.org/main/index.php/Asoundrc] - ALSA wiki on .asoundrc
 
* [http://www.pulseaudio.org/ http://www.pulseaudio.org/] - PulseAudio official site
 
* [http://www.pulseaudio.org/ http://www.pulseaudio.org/] - PulseAudio official site
 
* [http://www.pulseaudio.org/wiki/FAQ http://www.pulseaudio.org/wiki/FAQ] - PulseAudio FAQ
 
* [http://www.pulseaudio.org/wiki/FAQ http://www.pulseaudio.org/wiki/FAQ] - PulseAudio FAQ

Revision as of 05:31, 21 July 2014

Related articles

PulseAudio is a sound server commonly used by desktop environments like GNOME or KDE. It serves as a proxy to sound applications using existing kernel sound components like ALSA or OSS. Since ALSA is included in Arch Linux by default, the most common deployment scenarios include PulseAudio with ALSA.

Contents

Installation

Configuration

Merge-arrows-2.pngThis article or section is a candidate for merging with PulseAudio/Configuration.Merge-arrows-2.png

Notes: Configuration should stay in the main article, so the linked page should be merged here. Split #Troubleshooting instead if this page is found too long. (Discuss in Talk:PulseAudio#)

You'll see Pulseaudio supports many modules to extend its functionality. You find a detailed list of all available modules at Pulseaudio Loadable Modules. To enable them you can just add a line load-module <module-name-from-list> to /etc/pulse/default.pa.

Running

Warning: If you have per-user copies of configuration files (such as client.conf, daemon.conf or default.pa) in ~/.config/pulse/ or ~/.pulse/, make sure you keep them in sync with changes to the packaged files in /etc/pulse/. Otherwise, PulseAudio may refuse to start due to configuration errors.
Note: Most X11 environments start PulseAudio automatically with the X11 session.

In the unlikely event that PulseAudio is not automatically started upon entering X, it can can be started with:

$ pulseaudio --start

PulseAudio can be stopped with:

$ pulseaudio --kill

Autostarting in unsupported desktop environments

Note: As mentioned previously, PulseAudio is very likely launched automatically via either /etc/X11/xinit/xinitrc.d/pulseaudio or the files in /etc/xdg/autostart/ if users have some DE installed.

Check to see if PulseAudio is running:

$ ps aux | grep pulse
 facade   1794  0.0  0.0 360464  6532 ?        S<l  15:33   0:00 /usr/bin/pulseaudio --start
 facade   1827  0.0  0.0  68888  2608 ?        S    15:33   0:00 /usr/lib/pulse/gconf-helper

If PulseAudio is not running and users are using X, the following will start PulseAudio with the needed the X11 plugins manually:

$ start-pulseaudio-x11

If you are not running GNOME, KDE, or Xfce, and your ~/.xinitrc does not source the scripts in /etc/X11/xinit/xinitrc.d (such as is done in the example file /etc/skel/.xinitrc), then you can launch PulseAudio on boot with:

~/.xinitrc
/usr/bin/start-pulseaudio-x11

Back-end configuration

ALSA

Install pulseaudio-alsa from the official repositories. This package contains the necessary /etc/asound.conf for configuring ALSA to use PulseAudio.

Also install lib32-libpulse and lib32-alsa-plugins if you run a x86_64 system and want to have sound for 32-bit multilib programs like Wine, Skype and Steam.

To prevent applications from using ALSA's OSS emulation and bypassing PulseAudio (thereby preventing other applications from playing sound), make sure the module snd_pcm_oss is not being loaded at boot. If it is currently loaded (lsmod | grep oss), disable it by executing:

# rmmod snd_pcm_oss

ALSA/dmix without grabbing hardware device

Note: This section describes alternative configuration, which is generally not recommended.

You may want to use ALSA directly in most of your applications and to be able to use other applications, which constantly require PulseAudio at the same time. The following steps allow you to make PulseAudio use dmix instead of grabbing ALSA hardware device.

  • Remove package pulseaudio-alsa, which provides compatibility layer between ALSA applications and PulseAudio. After this your ALSA apps will use ALSA directly without being hooked by Pulse.
  • Edit /etc/pulse/default.pa.
Find and uncomment lines which load back-end drivers. Add device parameters as follows. Then find and comment lines which load autodetect modules.
load-module module-alsa-sink device=dmix
load-module module-alsa-source device=dsnoop
# load-module module-udev-detect
# load-module module-detect
  • Optional: If you use kdemultimedia-kmix you may want to control ALSA volume instead of PulseAudio volume:
$ echo export KMIX_PULSEAUDIO_DISABLE=1 > ~/.kde4/env/kmix_disable_pulse.sh
$ chmod +x ~/.kde4/env/kmix_disable_pulse.sh
  • Now, reboot your computer and try running ALSA and PulseAudio applications at the same time. They both should produce sound simultaneously.
Use pavucontrol to control PulseAudio volume if needed.

OSS

There are multiple ways of making OSS-only programs output to PulseAudio:

ossp

Install ossp package and start osspd.service.

padsp wrapper

Programs using OSS can work with PulseAudio by starting it with padsp (included with PulseAudio):

$ padsp OSSprogram

A few examples:

$ padsp aumix
$ padsp sox foo.wav -t ossdsp /dev/dsp

You can also add a custom wrapper script like this:

/usr/local/bin/OSSProgram
#!/bin/sh
exec padsp /usr/bin/OSSprogram "$@"

Make sure /usr/local/bin comes before /usr/bin in your PATH.

GStreamer

Install gst-plugins-good, or gstreamer0.10-good-plugins if your intended program has a legacy GStreamer implementation.

OpenAL

OpenAL Soft should use PulseAudio by default, but can be explicitly configured to do so:
/etc/openal/alsoft.conf
drivers=pulse,alsa

libao

Edit the libao configuration file:

/etc/libao.conf
default_driver=pulse

Be sure to remove the dev=default option of the alsa driver or adjust it to specify a specific Pulse sink name or number.

Note: You could possibly also keep the libao standard of outputting to the alsa driver and its default device if you install pulseaudio-alsa since the ALSA default device then is PulseAudio.

Equalizer

PulseAudio has an integrated 10-band equalizer system. In order to use the equalizer do the following:

Load equalizer sink and dbus-protocol module

$ pactl load-module module-equalizer-sink
$ pactl load-module module-dbus-protocol

Install and run the GUI front-end

Install python-pyqt4 and execute:

$ qpaeq
Note: If qpaeq has no effect, install pavucontrol and change "ALSA Playback on" to "FFT based equalizer on ..." while the media player is running.

Load equalizer and dbus module on every boot

Edit the file /etc/pulse/default.pa with your favorite editor and append the following lines:

### Load the integrated PulseAudio equalizer and D-Bus module
load-module module-equalizer-sink
load-module module-dbus-protocol

Applications

KDE Plasma Workspaces and Qt4

PulseAudio will automatically be used by KDE/Qt4 applications. It is supported by default in the KDE sound mixer. For more information see the KDE page in the PulseAudio wiki. One useful tidbit from that page is to add load-module module-device-manager to /etc/pulse/default.pa.

If the phonon-gstreamer backend is used for Phonon, GStreamer should also be configured as described in #GStreamer.

Audacious

Audacious natively supports PulseAudio. In order to use it, set Audacious Preferences -> Audio -> Current output plugin to 'PulseAudio Output Plugin'.

Java/OpenJDK 6

Create a wrapper for the Java executable using padsp as seen on the Java sound with PulseAudio page.

Music Player Daemon (MPD)

configure MPD to use PulseAudio. See also MPD/Tips and Tricks#MPD and PulseAudio.

MPlayer

MPlayer natively supports PulseAudio output with the -ao pulse option. It can also be configured to default to PulseAudio output, in ~/.mplayer/config for per-user, or /etc/mplayer/mplayer.conf for system-wide:

/etc/mplayer/mplayer.conf
ao=pulse

guvcview

guvcview when using the PulseAudio input from a Webcam may have the audio input suspended resulting in no audio being recorded. You can check this by executing:

$ pactl list sources

If the audio source is "suspended" then modifying the following line in /etc/pulse/default.pa and changing:

load-module module-suspend-on-idle

to

#load-module module-suspend-on-idle

And then either restarting PulseAudio or your computer will only idle the input source instead of suspending it. guvcview will then correctly record audio from the device.

Troubleshooting

No sound after install

Muted audio device

If one experiences no audio output via any means while using ALSA, attempt to unmute the sound card. To do this, launch alsamixer and make sure each column has a green 00 under it (this can be toggled by pressing m):

$ alsamixer -c 0
Note: alsamixer will not tell you which output device is set as the default. One possible cause of no sound after install is that PulseAudio detects the wrong output device as a default. Install pavucontrol and check if there is any output on the pavucontrol panel when playing a .wav file.

Auto-Mute Mode

Auto-Mute Mode may be enabled. It can be disabled using alsamixer.

See http://superuser.com/questions/431079/how-to-disable-auto-mute-mode for more.

Bad configuration files

After starting PulseAudio, if the system outputs no sound, it may be necessary to delete the contents of ~/.pulse. PulseAudio will automatically create new configuration files on its next start.

Flash content

Since Adobe Flash does not directly support PulseAudio, the recommended way is to configure ALSA to use the virtual PulseAudio sound card.

Alternatively you may try out libflashsupport-pulseAUR from the AUR.

Note: This may invariably crash the Flash plugin.

If you find audio from flash is being laggy, you might like to have flash access ALSA directly. This fixes this problem in some cases. To do this, configure PulseAudio to use dmix.

No cards

If PulseAudio starts, run pacmd list. If no cards are reported, make sure that the ALSA devices are not in use:

$ fuser -v /dev/snd/*
$ fuser -v /dev/dsp

Make sure any applications using the pcm or dsp files are shut down before restarting PulseAudio.

The only device shown is "dummy output"

This may be caused by different reasons, one of them being the .asoundrc file in $HOME is taking precedence over the systemwide /etc/asound.conf.

The user file is modified also by the tool asoundconf or by its graphical variant asoundconf-gtk (the latter is named "Default sound card" in the menu) as soon as it runs. Prevent the effects of .asoundrc altogether by commenting the last line like this:

.asoundrc
# </home/yourusername/.asoundrc.asoundconf>

Maybe some program is monopolizing the audio device:

# fuser -v /dev/snd/*
                     USER       PID  ACCESS COMMAND
/dev/snd/controlC0:  root        931 F....  timidity
                     bob        1195 F....  panel-6-mixer
/dev/snd/controlC1:  bob        1195 F....  panel-6-mixer
                     bob        1215 F....  pulseaudio
/dev/snd/pcmC0D0p:   root        931 F...m  timidity
/dev/snd/seq:        root        931 F....  timidity
/dev/snd/timer:      root        931 f....  timidity

That means timidity blocks PulseAudio from accessing the audio devices. Just killing timidity will make the sound work again.

Another reason is FluidSynth conflicting with PulseAudio as discussed in this thread. The solution is to remove FluidSynth:

# pacman -Rnsc fluidsynth

No HDMI 5/7.1 Selection for Device

If you are unable to select 5/7.1 channel output for a working HDMI device, then turning off "stream device reading" in /etc/pulse/default.pa might help.

See #Fallback device is not respected.

KDE Plasma Workspaces

It may be that another output device set as preferred in phonon. Make sure that every setting reflects the preferred output device at the top, and check the playback streams tab in kmix to make sure that applications are using the device for output.

To see your default audio device, you can run:

pactl stat

To see available audio devices:

pactl list

To set your default audio device, use "pacmd" or add to /etc/pulse/default.pa:

set-default-sink alsa_output.analog-stereo

Failed to create sink input: sink is suspended

If you do not have any output sound and receive dozens of errors related to a suspended sink in your journalctl -b log, then backup first and then delete your user-specific pulse folders:

$ rm -r ~/.pulse ~/.pulse-cookie

Starting an application interrupts other app's sound

If you have trouble with some applications (eg. Teamspeak, Mumble) interrupting sound output of already running applications (eg. Deadbeaf), you can solve this by commenting out the line load-module module-role-cork in /etc/pulse/default.pa like shown below:

/etc/pulse/default.pa
### Cork music/video streams when a phone stream is active
# load-module module-role-cork

Then restart pulseaudo by using your normal user account with

pulseaudio -k
pulseaudio --start

No HDMI sound output after some time with the monitor turned off

The monitor is connected via HDMI/DisplayPort, and the audio jack is plugged in the headphone jack of the monitor, but PulseAudio insists that it is unplugged:

pactl list sinks
...
hdmi-output-0: HDMI / DisplayPort (priority: 5900, not available)
...

This leads to no sound coming from HDMI output. A workaround for this is to switch to another VT and back again. If that doesn't work, try: turn off your monitor, switch to another VT, turn on your monitor, and switch back. This problem has been reported by ATI/Nvidia/Intel users.

Enable Echo/Noise-Cancelation

Arch doesn't load the Pulseaudio Echo-Cancelation module by default, therefore, we have to add it in /etc/pulse/default.pa. First you can test if the module is present with pacmd and entering list-modules. If you can't find a line showing name: <module-echo-cancel> you have to add

/etc/pulse/default.pa
load-module module-echo-cancel

then restart Pulseaudio

pulseaudio -k
pulseaudio --start

and check if the module is activated by starting pavucontrol. Under Recoding the input device should show Echo-Cancel Source Stream from"

Can't update configuration of sound device in pavucontrol

pavucontrol is a handy GUI utility for configuring PulseAudio. Under its 'Configuration' tab, you can select different profiles for each of your sound devices e.g. analogue stereo, digital output (IEC958), HDMI 5.1 Surround etc.

However, you may run into an instance where selecting a different profile for a card results in the pulse daemon crashing and auto restarting without the new selection "sticking". If this occurs, use the other useful GUI tool, paprefs, to check under the "Simultaneous Output" tab for a virtual simultaneous device. If this setting is active (checked), it will prevent you changing any card's profile in pavucontrol. Uncheck this setting, then adjust your profile in pavucontrol prior to re-enabling simultaneous output in paprefs.

Simultaneous output to multiple sound cards / devices

Simultaneous output to two different devices can be very useful. For example, being able to send audio to your A/V receiver via your graphics card's HDMI output, while also sending the same audio through the analogue output of your motherboard's built-in audio. This is much less hassle than it used to be (in this example, we are using GNOME desktop).

Using paprefs, simply select "Add virtual output device for simultaneous output on all local sound cards" from under the "Simultaneous Output" tab. Then, under GNOME's "sound settings", select the simultaneous output you have just created.

If this doesn't work, try adding the following to ~/.asoundrc:

pcm.dsp {
   type plug
   slave.pcm "dmix"
}

Simultaneous output to multiple sinks on the same sound card not working

This can be useful for users who have multiple sound sources and want to play them on different sinks/outputs. An example use-case for this would be if you play music and also voice chat and want to output music to speakers (in this case Digital S/PDIF) and voice to headphones. (Analog)

This is sometimes auto detected by PulseAudio but not always. If you know that your sound card can output to both Analog and S/PDIF at the same time and PulseAudio does not have this option in it's profiles in pavucontrol, or veromix then you probably need to create a configuration file for your sound card.

More in detail you need to create a profile-set for your specific sound card. This is done in two steps mostly.

  • Create udev rule to make PulseAudio choose your PulseAudio configuration file specific to the sound card.
  • Create the actual configuration.

Create a pulseadio udev rule.

Note: This is only an example for Asus Xonar Essence STX. Read udev to find out the correct values.
Note: Your configuration file should have lower number than the original PulseAudio rule to take effect.
/usr/lib/udev/rules.d/90-pulseaudio-Xonar-STX.rules
ACTION=="change", SUBSYSTEM=="sound", KERNEL=="card*", \
ATTRS{subsystem_vendor}=="0x1043", ATTRS{subsystem_device}=="0x835c", ENV{PULSE_PROFILE_SET}="asus-xonar-essence-stx.conf" 

Now, create a configuration file. If you bother, you can start from scratch and make it saucy. However you can also use the default configuration file, rename it, and then add your profile there that you know works. Less pretty but also faster.

To enable multiple sinks for Asus Xonar Essence STX you need only to add this in.

Note: asus-xonar-essence-stx.conf also includes all code/mappings from default.conf.
/usr/share/pulseaudio/alsa-mixer/profile-sets/asus-xonar-essence-stx.conf
[Profile analog-stereo+iec958-stereo]
description = Analog Stereo Duplex + Digital Stereo Output
input-mappings = analog-stereo
output-mappings = analog-stereo iec958-stereo
skip-probe = yes

This will auto-profile your Asus Xonar Essence STX with default profiles and add your own profile so you can have multiple sinks.

You need to create another profile in the configuration file if you want to have the same functionality with AC3 Digital 5.1 output.

See PulseAudio article about profiles

Disable Bluetooth support

If you do not use Bluetooth, you may experience the following error in your journal:

bluez5-util.c: GetManagedObjects() failed: org.freedesktop.DBus.Error.ServiceUnknown: The name org.bluez was not provided by any .service files

To disable Bluetooth support in PulseAudio, make sure that the following lines are commented out in the configuration file in use (~/.config/pulse/default.pa or /etc/pulse/default.pa):

~/.config/pulse/default.pa
### Automatically load driver modules for Bluetooth hardware
#.ifexists module-bluetooth-policy.so
#load-module module-bluetooth-policy
#.endif

#.ifexists module-bluetooth-discover.so
#load-module module-bluetooth-discover
#.endif

Bluetooth headset replay problems

Some user reports huge delays or even no sound when the Bluetooth connection does not send any data. This is due to the module-suspend-on-idle module, which automatically suspends sinks/sources on idle. As this can cause problems with headset, the responsible module can be deactivated.

To disable loading of the module-suspend-on-idle module, comment out the following line in the configuration file in use (~/.config/pulse/default.pa or /etc/pulse/default.pa):

~/.config/pulse/default.pa
### Automatically suspend sinks/sources that become idle for too long
#load-module module-suspend-on-idle

Finally restart PulseAudio to apply the changes.

Automatically switch to Bluetooth or USB headset

Add the following:

/etc/pulse/default.pa
# automatically switch to newly-connected devices
load-module module-switch-on-connect

Pulse overwrites ALSA settings

PulseAudio usually overwrites the ALSA settings — for example set with alsamixer — at start-up, even when the ALSA daemon is loaded. Since there seems to be no other way to restrict this behaviour, a workaround is to restore the ALSA settings again after PulseAudio has started. Add the following command to .xinitrc or .bash_profile or any other autostart file:

restore_alsa() {
 while [ -z "$(pidof pulseaudio)" ]; do
  sleep 0.5
 done
 alsactl -f /var/lib/alsa/asound.state restore 
}
restore_alsa &

Prevent Pulse from restarting after being killed

Sometimes you may wish to temporarily disable Pulse. In order to do so you will have to prevent Pulse from restarting after being killed.

~/.config/pulse/client.conf
# Disable autospawning the PulseAudio daemon
autospawn = no

Daemon startup failed

Try resetting PulseAudio:

$ rm -rf /tmp/pulse* ~/.pulse*
$ pulseaudio -k
$ pulseaudio --start

If there is no server running but PulseAudio fails to start with an error message "User-configured server at ... refusing to start/autospawn", the issue may be with PulseAudio settings from a previous login. Check to see if there are any stale properties attached to the X11 root window with pax11publish -d, and if there are, remove them with pax11publish -r before trying to start the server. This manual cleanup is always required when using LXDM because it does not restart the X server on logout; see LXDM#PulseAudio.

inotify issue

If the previous fix doesn't work, see if you get an error like this:

$ pulseaudio -vvvv
E: [pulseaudio] module-udev-detect.c: You apparently ran out of inotify watches, probably because Tracker/Beagle took them all away. I wished people would do their homework first and fix inotify before using it for watching whole directory trees which is something the current inotify is certainly not useful for. Please make sure to drop the Tracker/Beagle guys a line complaining about their broken use of inotify.

In which case you have run out of inotify watches.

This can quickly be resolved by:

# echo 100000 > /proc/sys/fs/inotify/max_user_watches

To have it permanently changed, use:

/etc/sysctl.d/99-sysctl.conf
# Increase inotify max watchs per user
fs.inotify.max_user_watches = 100000

Glitches, skips or crackling

The newer implementation of the PulseAudio sound server uses timer-based audio scheduling instead of the traditional, interrupt-driven approach.

Timer-based scheduling may expose issues in some ALSA drivers. On the other hand, other drivers might be glitchy without it on, so check to see what works on your system.

To turn timer-based scheduling off add tsched=0 in /etc/pulse/default.pa:

/etc/pulse/default.pa
load-module module-udev-detect tsched=0

Then restart the PulseAudio server:

$ pulseaudio -k
$ pulseaudio --start

Do the reverse to enable timer-based scheduling, if not already enabled by default.

Using Intel's IOMMU may also lead to these problems. If you are using IOMMU and experience glitches and/or skips add intel_iommu=igfx_off to your kernel command line.

Please report any such cards to PulseAudio Broken Sound Driver page

Setting the default fragment number and buffer size in PulseAudio

Finding out your audio device parameters (1/4)

To find your sound card buffering settings:

$ echo autospawn = no >> ~/.config/pulse/client.conf
$ pulseaudio -k
$ LANG=C timeout --foreground -k 10 -s kill 10 pulseaudio -vvvv 2>&1 | grep device.buffering -B 10
$ sed -i '$d' ~/.config/pulse/client.conf

For each sound card detected by PulseAudio, you will see output similar to this:

I: [pulseaudio] source.c:     alsa.long_card_name = "HDA Intel at 0xfa200000 irq 46"
I: [pulseaudio] source.c:     alsa.driver_name = "snd_hda_intel"
I: [pulseaudio] source.c:     device.bus_path = "pci-0000:00:1b.0"
I: [pulseaudio] source.c:     sysfs.path = "/devices/pci0000:00/0000:00:1b.0/sound/card0"
I: [pulseaudio] source.c:     device.bus = "pci"
I: [pulseaudio] source.c:     device.vendor.id = "8086"
I: [pulseaudio] source.c:     device.vendor.name = "Intel Corporation"
I: [pulseaudio] source.c:     device.product.name = "82801I (ICH9 Family) HD Audio Controller"
I: [pulseaudio] source.c:     device.form_factor = "internal"
I: [pulseaudio] source.c:     device.string = "front:0"
I: [pulseaudio] source.c:     device.buffering.buffer_size = "768000"
I: [pulseaudio] source.c:     device.buffering.fragment_size = "384000"

Take note the buffer_size and fragment_size values for the relevant sound card.

Calculate your fragment size in msecs and number of fragments (2/4)

PulseAudio's default sampling rate and bit depth are set to 44100Hz @ 16 bits.

With this configuration, the bit rate we need is 44100*16 = 705600 bits per second. That's 1411200 bps for stereo.

Let's take a look at the parameters we have found in the previous step:

device.buffering.buffer_size = "768000" => 768000/1411200 = 0.544217687075s = 544 msecs
device.buffering.fragment_size = "384000" => 384000/1411200 = 0.272108843537s = 272 msecs

Modify PulseAudio's configuration file (3/4)

/etc/pulse/daemon.conf
; default-fragments = X
; default-fragment-size-msec = Y

In the previous step, we calculated the fragment size parameter. The number of fragments is simply buffer_size/fragment_size, which in this case (544/272) is 2:

/etc/pulse/daemon.conf
; default-fragments = '''2'''
; default-fragment-size-msec = '''272'''

Restart the PulseAudio daemon (4/4)

$ pulseaudio -k
$ pulseaudio --start

For more information, see: Linux Mint topic

Laggy sound

This issue is due to incorrect buffer sizes.

Either disable any modifications (if any) to these entries, or, if issue still exists, uncomment:

/etc/pulse/daemon.conf
default-fragments = 8
default-fragment-size-msec = 5

Choppy, overdriven sound

Choppy sound in PulseAudio can result from wrong settings for the sample rate. Try:

/etc/pulse/daemon.conf
default-sample-rate = 48000

and restart the PulseAudio server.

If one experiences choppy sound in applications using openAL, change the sample rate in /etc/openal/alsoft.conf:

frequency = 48000

Setting the PCM volume above 0 dB can cause clipping of the audio signal. Running alsamixer -c0 will allow you to see if this is the problem and if so fix it. Note that ALSA may not correctly export the dB information to PulseAudio. Try:

/etc/pulse/defaults.pa
load-module module-udev-detect ignore_dB=1

and restart the PulseAudio server. See also #No sound below a volume cutoff.

Volume adjustment does not work properly

Check: /usr/share/pulseaudio/alsa-mixer/paths/analog-output.conf.common

If the volume does not appear to increment/decrement properly using alsamixer or amixer, it may be due to PulseAudio having a larger number of increments (65537 to be exact). Try using larger values when changing volume (e.g. amixer set Master 655+).

Per-application volumes change when the Master volume is adjusted

This is because PulseAudio uses flat volumes by default, instead of relative volumes, relative to an absolute master volume. If this is found to be inconvenient, asinine, or otherwise undesireable, relative volumes can be enabled by disabling flat volumes in the PulseAudio daemon's configuration file:

/etc/pulse/daemon.conf
flat-volumes = no

and then restarting PulseAudio by executing

$ pulseaudio -k
$ pulseaudio --start

Volume gets louder every time a new application is started

Per default, it seems as if changing the volume in an application sets the global system volume to that level instead of only affecting the respective application. Applications setting their volume on startup will therefore cause the system volume to "jump".

Fix this by disabling flat volumes, as demonstrated in the previous section. When Pulse comes back after a few seconds, applications will not alter the global system volume anymore but have their own volume level again.

Note: A previously installed and removed pulseaudio-equalizer may leave behind remnants of the setup in ~/.pulse/default.pa which can also cause maximized volume trouble. Comment that out as needed.

No microphone on ThinkPad T400/T500/T420

Run:

alsamixer -c 0

Unmute and maximize the volume of the "Internal Mic".

Once you see the device with:

arecord -l

you might still need to adjust the settings. The microphone and the audio jack are duplexed. Set the configuration of the internal audio in pavucontrol to Analog Stereo Duplex.

No microphone input on Acer Aspire One

Install pavucontrol, unlink the microphone channels and turn down the left one to 0. Reference: http://getsatisfaction.com/jolicloud/topics/deaf_internal_mic_on_acer_aspire_one#reply_2108048

Sound output is only mono on M-Audio Audiophile 2496 sound card

Add the following:

/etc/pulseaudio/default.pa
load-module module-alsa-sink sink_name=delta_out device=hw:M2496 format=s24le channels=10 channel_map=left,right,aux0,aux1,aux2,aux3,aux4,aux5,aux6,aux7
load-module module-alsa-source source_name=delta_in device=hw:M2496 format=s24le channels=12 channel_map=left,right,aux0,aux1,aux2,aux3,aux4,aux5,aux6,aux7,aux8,aux9
set-default-sink delta_out
set-default-source delta_in

Static noise in microphone recording

If we are getting static noise in Skype, gnome-sound-recorder, arecord, etc.'s recordings, then the sound card sample rate is incorrect. That is why there is static noise in Linux microphone recordings. To fix this, we need to set the sampling rate in /etc/pulse/daemon.conf for the sound hardware.

Determine sound cards in the system (1/5)

This requires alsa-utils and related packages to be installed:

$ arecord --list-devices
**** List of CAPTURE Hardware Devices ****
card 0: Intel [HDA Intel], device 0: ALC888 Analog [ALC888 Analog]
  Subdevices: 1/1
  Subdevice #0: subdevice #0
card 0: Intel [HDA Intel], device 2: ALC888 Analog [ALC888 Analog]
  Subdevices: 1/1
  Subdevice #0: subdevice #0

Sound card is hw:0,0.

Determine sampling rate of the sound card (2/5)

arecord -f dat -r 60000 -D hw:0,0 -d 5 test.wav
"Recording WAVE 'test.wav' : Signed 16 bit Little Endian, Rate 60000 Hz, Stereo
Warning: rate is not accurate (requested = 60000Hz, got = 96000Hz)
please, try the plug plugin

observe, the got = 96000Hz. This is the maximum sampling rate of our card.

Setting the sound card's sampling rate into PulseAudio configuration (3/5)

The default sampling rate in PulseAudio:

$ grep "default-sample-rate" /etc/pulse/daemon.conf
; default-sample-rate = 44100

44100 is disabled and needs to be changed to 96000:

# sed 's/; default-sample-rate = 44100/default-sample-rate = 96000/g' -i /etc/pulse/daemon.conf

Restart PulseAudio to apply the new settings (4/5)

$ pulseaudio -k
$ pulseaudio --start

Finally check by recording and playing it back (5/5)

Let us record some voice using a microphone for, say, 10 seconds. Make sure the microphone is not muted and all

$ arecord -f cd -d 10 test-mic.wav

After 10 seconds, let us play the recording...

$ aplay test-mic.wav

Now hopefully, there is no static noise in microphone recording anymore.

My Bluetooth device is paired but does not play any sound

See the article in Bluetooth section

Starting from PulseAudio 2.99 and bluez 4.101 you should avoid using Socket interface. Do NOT use:

/etc/bluetooth/audio.conf
[General]
Enable=Socket

If you face problems with A2DP and PA 2.99 make sure you have sbc library.

Subwoofer stops working after end of every song

Known issue: https://bugs.launchpad.net/ubuntu/+source/pulseaudio/+bug/494099

To fix this, must edit: /etc/pulse/daemon.conf and enable enable-lfe-remixing :

/etc/pulse/daemon.conf
enable-lfe-remixing = yes

PulseAudio uses wrong microphone

If PulseAudio uses the wrong microphone, and changing the Input Device with Pavucontrol did not help, take a look at alsamixer. It seems that Pavucontrol does not always set the input source correctly.

$ alsamixer

Press F6 and choose your sound card, e.g. HDA Intel. Now press F5 to display all items. Try to find the item: Input Source. With the up/down arrow keys you are able to change the input source.

Now try if the correct microphone is used for recording.

Choppy sound with analog surround sound setup

The low-frequency effects (LFE) channel is not remixed per default. To enable it the following needs to be set in /etc/pulse/daemon.conf :

/etc/pulse/daemon.conf
enable-lfe-remixing = yes

Unable to select surround configuration other than "Surround 4.0"

If you're unable to set 5.1 surround output in pavucontrol because it only shows "Analog Surround 4.0 Output", open the ALSA mixer and change the output configuration there to 6 channels. Then restart pulseaudio, and pavucontrol will list many more options.

No sound below a volume cutoff

Known issue (won't fix): https://bugs.launchpad.net/ubuntu/+source/pulseaudio/+bug/223133

If sound does not play when PulseAudio's volume is set below a certain level, try setting ignore_dB=1 in /etc/pulse/default.pa:

/etc/pulse/default.pa
load-module module-udev-detect ignore_dB=1

However, be aware that it may cause another bug preventing PulseAudio to unmute speakers when headphones or other audio devices are unplugged.

Low volume for internal microphone

If you experience low volume on internal notebook microphone, try setting:

/etc/pulse/default.pa
set-source-volume 1 300000

Clients alter master output volume (a.k.a. volume jumps to 100% after running application)

If changing the volume in specific applications or simply running an application changes the master output volume this is likely due to flat volumes mode of pulseaudio. Before disabling it, KDE users should try lowering their system notifications volume in System Settings -> Application and System Notifications -> Manage Notifications under the Player Settings tab to something reasonable. Changing the Event Sounds volume in KMix or another volume mixer application will not help here. This should make the flat-volumes mode work out as intended, if it does not work, some other application is likely requesting 100% volume when its playing something. If all else fails, you can try to disable flat-volumes:

/etc/pulse/daemon.conf
flat-volumes = no

Then restart PulseAudio daemon:

# pulseaudio -k
# pulseaudio --start

Realtime scheduling

If rtkit does not work, you can manually set up your system to run PulseAudio with real-time scheduling, which can help performance. To do this, add the following lines to /etc/security/limits.conf:

@pulse-rt - rtprio 9
@pulse-rt - nice -11

Afterwards, you need to add your user to the pulse-rt group:

# gpasswd -a <user> pulse-rt

No sound after resume from suspend

If audio generally works, but stops after resume from suspend, try "reloading" PulseAudio by executing:

$ /usr/bin/pasuspender /bin/true

This is better than completely killing and restarting it (pulseaudio -k followed by pulseaudio --start), because it doesn't break already running applications.

If the above fixes your problem, you may wish to automate it, by creating a systemd service file.

1. Create the template service file in /etc/systemd/system/resume-fix-pulseaudio@.service:

[Unit]
Description=Fix PulseAudio after resume from suspend
After=suspend.target

[Service]
User=%I
Type=oneshot
Environment="XDG_RUNTIME_DIR=/run/user/%U"
ExecStart=/usr/bin/pasuspender /bin/true

[Install]
WantedBy=suspend.target

2. Enable it for your user account

# systemctl enable resume-fix-pulseaudio@YOUR_USERNAME_HERE.service

3. Reload systemd

# systemctl --system daemon-reload

ALSA channels mute when headphones are plugged/unplugged improperly

If when you unplug your headphones or plug them in the audio remains muted in alsamixer on the wrong channel due to it being set to 0%, you may be able to fix it by opening /etc/pulse/default.pa and commenting out the line:

load-module module-switch-on-port-available

pactl "invalid option" error with negative percentage arguments

pactl commands that take negative percentage arguments will fail with an 'invalid option' error. Use the standard shell '--' pseudo argument to disable argument parsing before the negative argument. e.g. pactl set-sink-volume 1 -- -5%.

Daemon already running

On some systems, PulseAudio may be started multiple times. journalctl will report:

[pulseaudio] pid.c: Daemon already running.

Make sure to use only one method of autostarting applications. pulseaudio includes these files:

  • /etc/X11/xinit/xinitrc.d/pulseaudio
  • /etc/xdg/autostart/pulseaudio.desktop
  • /etc/xdg/autostart/pulseaudio-kde.desktop

Also check user autostart files and directories, such as xinitrc, ~/.config/autostart/ etc.

Fallback device is not respected

PulseAudio does not have a true default device. Instead it uses a "fallback", which only applies to new sound streams. This means previously run applications are not affected by the newly set fallback device.

Only gnome-control-center and mate-media-pulseaudio handle this gracefully. Alternatively:

1. Move the old streams in pavucontrol manually to the new sound card.

2. Stop Pulse, erase the "stream-volumes" in ~/.pulse and restart Pulse. This also resets application volumes.

3. Disable stream device reading. This may be not wanted when using different soundcards with different applications.

/etc/pulse/defaults.pa
load-module module-stream-restore restore_device=false

No Microphone on Steam or Skype if you set enable-remixing = no

When you set enable-remixing = no on /etc/pulse/daemon.conf you may find that your microphone has stopped working on certain applications like Skype or Steam. This happens because these applications capture the microphone as mono only and because remixing is disabled, Pulseaudio will no longer remix your stereo microphone to mono.

To fix this you need to tell Pulseaudio to do this for you:

1. Find the name of the source

# pacmd list-sources

Example output edited for brevity, the name you need is in bold:

   index: 2
       name: <alsa_input.pci-0000_00_14.2.analog-stereo>
       driver: <module-alsa-card.c>
       flags: HARDWARE HW_MUTE_CTRL HW_VOLUME_CTRL DECIBEL_VOLUME LATENCY DYNAMIC_LATENCY

2. Add a remap rule to /etc/pulse/default.pa, use the name you found with the previous command, here we will use alsa_input.pci-0000_00_14.2.analog-stereo as an example:

/etc/pulse/default.pa
### Remap microphone to mono
load-module module-remap-source master=alsa_input.pci-0000_00_14.2.analog-stereo master_channel_map=front-left,front-right channels=2 channel_map=mono,mono

3. Restart Pulseaudio

# pulseaudio -k

Note: Pulseaudio may fail to start if you don't exit a program that was using was using the microphone (ex. if you tested on Steam before modifying the file), in which case you should exit the application and manually start Pulseaudio:

# pulseaudio --start

See also