Difference between revisions of "PulseAudio"
Sultanoswing (talk | contribs) m (→Simultaneous Output to multiple sound cards / devices) |
m (added ja) |
||
(44 intermediate revisions by 24 users not shown) | |||
Line 5: | Line 5: | ||
[[fr:PulseAudio]] | [[fr:PulseAudio]] | ||
[[it:PulseAudio]] | [[it:PulseAudio]] | ||
+ | [[ja:PulseAudio]] | ||
[[pt:PulseAudio]] | [[pt:PulseAudio]] | ||
[[ru:PulseAudio]] | [[ru:PulseAudio]] | ||
[[tr:PulseAudio]] | [[tr:PulseAudio]] | ||
− | [[Wikipedia:PulseAudio|PulseAudio]] is | + | {{Related articles start}} |
− | + | {{Related|PulseAudio/Examples}} | |
− | + | {{Related articles end}} | |
− | + | [[Wikipedia:PulseAudio|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]]. | |
− | |||
− | |||
− | |||
== Installation == | == Installation == | ||
Line 20: | Line 18: | ||
* Required package: {{Pkg|pulseaudio}} | * Required package: {{Pkg|pulseaudio}} | ||
* Optional GTK GUIs: {{Pkg|paprefs}} and {{Pkg|pavucontrol}} | * Optional GTK GUIs: {{Pkg|paprefs}} and {{Pkg|pavucontrol}} | ||
− | * Optional volume control via mapped keyboard keys: {{AUR| | + | * Optional volume control via mapped keyboard keys: {{AUR|pulseaudio-ctl}} |
− | * Optional console | + | * Optional console (CLI) mixers: {{Pkg|ponymix}} and {{AUR|pamixer-git}} |
* 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}} | ||
== Running == | == Running == | ||
− | {{Warning|If you have per-user copies of configuration files (such as client.conf, daemon.conf or default.pa) in ~/.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.}} | + | {{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.}} |
{{Note| | {{Note| | ||
Line 43: | Line 41: | ||
Newer pulseaudio versions have an intergrated 10-band equalizer system. In order to use the equalizer do the following: | Newer pulseaudio versions have an intergrated 10-band equalizer system. In order to use the equalizer do the following: | ||
− | === Load equalizer sink module === | + | === Load equalizer sink and dbus-protocol module === |
$ pactl load-module module-equalizer-sink | $ pactl load-module module-equalizer-sink | ||
+ | $ pactl load-module module-dbus-protocol | ||
=== Install and run the gui frontend === | === Install and run the gui frontend === | ||
− | Install {{Pkg| | + | Install {{Pkg|python-pyqt4}} and execute: |
$ qpaeq | $ 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.}} | + | {{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.}} |
− | === Load equalizer module on every boot === | + | === Load equalizer and dbus module on every boot === |
Edit the file {{ic|/etc/pulse/default.pa}} with your favorite editor and append the following lines: | Edit the file {{ic|/etc/pulse/default.pa}} with your favorite editor and append the following lines: | ||
− | ### Load the integrated pulseaudio equalizer module | + | ### Load the integrated pulseaudio equalizer and dbus module |
load-module module-equalizer-sink | load-module module-equalizer-sink | ||
+ | load-module module-dbus-protocol | ||
== Backend Configuration == | == Backend Configuration == | ||
Line 97: | Line 97: | ||
* Now, reboot your computer and try running alsa and pulseaudio applications at the same time. They both should produce sound simultaneously. | * Now, reboot your computer and try running alsa and pulseaudio applications at the same time. They both should produce sound simultaneously. | ||
:Use {{Pkg|pavucontrol}} to control PulseAudio volume if needed. | :Use {{Pkg|pavucontrol}} to control PulseAudio volume if needed. | ||
− | |||
=== OSS === | === OSS === | ||
Line 134: | Line 133: | ||
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.}} | ||
+ | |||
=== ESD === | === ESD === | ||
Line 188: | Line 189: | ||
Additionally, the {{AUR|kdeplasma-applets-veromix}} is available in the [[AUR]] as a KDE alternative to KMix or pavucontrol. | Additionally, the {{AUR|kdeplasma-applets-veromix}} is available in the [[AUR]] as a KDE alternative to KMix or pavucontrol. | ||
+ | |||
+ | 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}}. | ||
=== Xfce === | === Xfce === | ||
Line 205: | Line 208: | ||
=== Music Player Daemon (MPD) === | === Music Player Daemon (MPD) === | ||
− | [http://mpd.wikia.com/wiki/PulseAudio configure] [[MPD]] to use PulseAudio. See also [[MPD/ | + | [http://mpd.wikia.com/wiki/PulseAudio configure] [[MPD]] to use PulseAudio. See also [[MPD/Tips and Tricks#MPD and PulseAudio]]. |
=== MPlayer === | === MPlayer === | ||
Line 222: | Line 225: | ||
==== 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 {{ | + | 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 | ||
+ | |||
+ | {{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 {{Pkg|pavucontrol}} and check if there is any output on the pavucontrol panel when playing a ''.wav'' file.}} | ||
==== Auto-Mute Mode ==== | ==== Auto-Mute Mode ==== | ||
Line 277: | Line 282: | ||
# pacman -Rnsc fluidsynth | # pacman -Rnsc fluidsynth | ||
− | ==== | + | ==== 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. | ||
+ | |||
+ | 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 ==== | ==== Failed to create sink input: sink is suspended ==== | ||
Line 286: | Line 302: | ||
$ rm -r ~/.pulse ~/.pulse-cookie | $ rm -r ~/.pulse ~/.pulse-cookie | ||
+ | |||
+ | === 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's unplugged: | ||
+ | {{hc|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 TTY and back again. This problem has been reported by ATI/Nvidia/Intel users. | ||
=== Can't update configuration of sound device in pavucontrol === | === Can't update configuration of sound device in pavucontrol === | ||
Line 293: | Line 320: | ||
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, {{Pkg|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. | 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, {{Pkg|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 | + | === 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). | ||
− | Using {{Pkg|paprefs}}, simply select "Add virtual output device for simultaneous output on all local | + | Using {{Pkg|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: | + | If this doesn't work, try adding the following to {{ic|~/.asoundrc}}: |
pcm.dsp { | pcm.dsp { | ||
Line 305: | Line 332: | ||
slave.pcm "dmix" | 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 soundcard 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 soundcard. | ||
+ | |||
+ | More in detail you need to create a profile-set for your specific soundcard. | ||
+ | This is done in two steps mostly. | ||
+ | *Create udev rule to make pulseaudio choose your pulseaudio configuration file specific to the soundcard. | ||
+ | * 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.}} | ||
+ | {{hc|/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" | ||
+ | }} | ||
+ | |||
+ | Create now a configuration file. If you bother you can start from scratch and make if 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|{{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| | ||
+ | [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. | ||
+ | |||
+ | [https://www.freedesktop.org/wiki/Software/PulseAudio/Backends/ALSA/Profiles/ 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 ({{ic|~/.config/pulse/default.pa}} or {{ic|/etc/pulse/default.pa}}): | ||
+ | |||
+ | {{hc|~/.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 === | === Bluetooth headset replay problems === | ||
− | Some user [https://bbs.archlinux.org/viewtopic.php?id=117420 report] huge delays or even no sound when the bluetooth connection does not send any data. This is due to | + | Some user [https://bbs.archlinux.org/viewtopic.php?id=117420 report] 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. |
− | + | To disable loading of the {{ic|module-suspend-on-idle}} module, comment out the following line in the configuration file in use ({{ic|~/.config/pulse/default.pa}} or {{ic|/etc/pulse/default.pa}}): | |
− | {{hc|~/.pulse/default.pa| | + | {{hc|~/.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 === | === Automatically switch to Bluetooth or USB headset === | ||
Line 344: | Line 427: | ||
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. | ||
− | + | {{hc|~/.config/pulse/client.conf|2= | |
+ | # Disable autospawning the PulseAudio daemon | ||
+ | autospawn = no | ||
+ | }} | ||
=== Daemon startup failed === | === Daemon startup failed === | ||
Line 357: | Line 443: | ||
==== inotify issue ==== | ==== inotify issue ==== | ||
− | If the previous fix doesn't work, | + | If the previous fix doesn't work, see if you get an error like this: |
− | + | {{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. | ||
+ | }} | ||
− | + | 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: | |
− | + | {{hc|/etc/sysctl.d/99-sysctl.conf|2= | |
− | + | # Increase inotify max watchs per user | |
− | To have it permanently changed, | + | fs.inotify.max_user_watches = 100000 |
− | + | }} | |
− | |||
− | |||
=== padevchooser === | === padevchooser === | ||
Line 606: | Line 692: | ||
$ alsamixer | $ alsamixer | ||
− | Press {{ | + | Press {{ic|F6}} and choose your sound card, e.g. HDA Intel. Now press {{ic|F5}} to display all items. Try to find the item: {{ic|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. | Now try if the correct microphone is used for recording. | ||
Line 635: | Line 721: | ||
</nowiki>}} | </nowiki>}} | ||
− | === Clients alter master output volume (aka volume jumps to 100% after running | + | === Clients alter master output volume (aka volume jumps to 100% after running application) === |
If changing volume in specific applications changes also master output volume you can try to diasble flat volumes. Set: | If changing volume in specific applications changes also master output volume you can try to diasble flat volumes. Set: | ||
Line 652: | Line 738: | ||
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 === | ||
+ | |||
+ | 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 ({{ic|pulseaudio -k && 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 {{ic|/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 === | ||
+ | {{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%}}. | ||
+ | |||
+ | ===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. {{Pkg|pulseaudio}} includes these files: | ||
+ | |||
+ | * {{ic|/etc/X11/xinit/xinitrc.d/pulseaudio}} | ||
+ | * {{ic|/etc/xdg/autostart/pulseaudio.desktop}} | ||
+ | * {{ic|/etc/xdg/autostart/pulseaudio-kde.desktop}} | ||
+ | |||
+ | Also check user autostart files and directories, such as [[xinitrc]], {{ic|~/.config/autostart/}} etc. | ||
== 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 16:22, 1 February 2014
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
- 1 Installation
- 2 Running
- 3 Equalizer
- 4 Backend Configuration
- 5 Desktop environments
- 6 Applications
- 7 Troubleshooting
- 7.1 No sound after install
- 7.2 No HDMI sound output after some time with the monitor turned off
- 7.3 Can't update configuration of sound device in pavucontrol
- 7.4 Simultaneous output to multiple sound cards / devices
- 7.5 Simultaneous output to multiple sinks on the same sound card not working
- 7.6 Disable Bluetooth support
- 7.7 Bluetooth headset replay problems
- 7.8 Automatically switch to Bluetooth or USB headset
- 7.9 Pulse overwrites ALSA settings
- 7.10 Prevent Pulse from restarting after being killed
- 7.11 Daemon startup failed
- 7.12 padevchooser
- 7.13 Glitches, skips or crackling
- 7.14 Setting the default fragment number and buffer size in Pulseaudio
- 7.15 My Bluetooth device is paired but does not play any sound
- 7.16 Subwoofer stops working after end of every song
- 7.17 Pulseaudio uses wrong microphone
- 7.18 Choppy Sound with Analog Surround Sound Setup
- 7.19 No sound below a volume cutoff
- 7.20 Low volume for internal mic
- 7.21 Clients alter master output volume (aka volume jumps to 100% after running application)
- 7.22 Realtime scheduling
- 7.23 No sound after resume from suspend
- 7.24 ALSA Channels Mute When Headphones Are Plugged/Unplugged Improperly
- 7.25 pactl "invalid option" error with negative percentage arguments
- 7.26 Daemon already running
- 8 See also
Installation
- Required package: pulseaudio
- Optional GTK GUIs: paprefs and pavucontrol
- Optional volume control via mapped keyboard keys: pulseaudio-ctlAUR
- Optional console (CLI) mixers: ponymix and pamixer-gitAUR
- Optional system tray icon: pasystray-gitAUR
- Optional KDE plasma applet: kdemultimedia-kmix and kdeplasma-applets-veromixAUR
Running
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.- Pulseaudio requires D-Bus to function.
- Most X11 environments start pulseaudio automatically with the X11 session.
In the unlikely event that pulseaudio is not automatically called upon entering X, it can can be started with:
$ pulseaudio --start
PulseAudio can be stopped with:
$ pulseaudio -k
Equalizer
Newer pulseaudio versions have an intergrated 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 frontend
Install python-pyqt4 and execute:
$ qpaeq
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 dbus module load-module module-equalizer-sink load-module module-dbus-protocol
Backend Configuration
ALSA
- Recommended package: pulseaudio-alsa
- Optional packages: lib32-libpulse and lib32-alsa-plugins
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 /etc/asound.conf
for configuring ALSA to use PulseAudio.
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
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 backend 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 play to PulseAudio:
ossp
Install ossp package and start ossp service.
padsp wrapper (part of PulseAudio)
Programs using OSS can work with PulseAudio by starting it with padsp:
$ 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
To make GStreamer use PulseAudio, you need to install gst-plugins-good or gstreamer0.10-good-plugins.
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.
ESD
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
General X11
/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
GNOME
As of GNOME 3, GNOME fully integrates with PulseAudio and no extra configuration is needed.
KDE 3
PulseAudio is not a drop-in replacement for aRts. Users of KDE 3 cannot use PulseAudio. However note, recent versions of PulseAudio may have eliminated the prohibition:
See: http://www.pulseaudio.org/wiki/PerfectSetup KDE 3 uses the artsd sound server by default. However, artsd itself can be configured to use an Esound backend. Edit kcmartsrc
(either in /etc/kde
or /usr/share/config
for global configuration or .kde/share/config
to configure only one user) like this:
[Arts] Arguments=\s-F 10 -S 4096 -a esd -n -s 1 -m artsmessage -c drkonqi -l 3 -f NetworkTransparent=true SuspendTime=1
KDE Plasma Workspaces and Qt4
PulseAudio, it will be used by KDE/Qt4 applications. For more information see the KDE page in the PulseAudio wiki.
PulseAudio support has been merged into KMix, the default KDE sound mixer.
If the phonon-gstreamer backend is used for Phonon, GStreamer should also be configured to use PulseAudio by installing gstreamer0.10-good-plugins.
One useful tidbit from that page is to add load-module module-device-manager
to /etc/pulse/default.pa
.
Additionally, the kdeplasma-applets-veromixAUR is available in the AUR as a KDE alternative to KMix or pavucontrol.
If KMix/Veromix fail to connect to PulseAudio at boot you may need to edit /etc/pulse/client.conf
to include autospawn = yes
instead of autospawn = no
.
Xfce
Applications running under Xfce can take advantage of PulseAudio. To manage PulseAudio settings you can use pavucontrol.
Applications
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
Skype (x86_64 only)
Install lib32-libpulse, otherwise the following error will occur when trying to initiate a call: "Problem with Audio Playback".
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
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
If after starting pulseaudio, 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 soundcard.
Alternatively you may try out libflashsupport-pulseAUR from the AUR.
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 conclicting with pulseaudio as discussed in this thread. The solution is to remove FluidSynth:
# pacman -Rnsc fluidsynth
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
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's 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 TTY and back again. This problem has been reported by ATI/Nvidia/Intel users.
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 soundcard 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 soundcard.
More in detail you need to create a profile-set for your specific soundcard. This is done in two steps mostly.
- Create udev rule to make pulseaudio choose your pulseaudio configuration file specific to the soundcard.
- Create the actual configuration.
Create a pulseadio udev rule.
/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"
Create now a configuration file. If you bother you can start from scratch and make if 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.
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 report 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 had 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
padevchooser
If one cannot launch the PulseAudio Device Chooser, first restart the Avahi daemon (avahi-daemon).
Glitches, skips or crackling
The newer implementation of PulseAudio sound server uses a 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.
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 >> ~/.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' ~/.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
= 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 mic for say 10 seconds. Make sure the mic 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
No sound below a volume cutoff
Known issue (won't fix): https://bugs.launchpad.net/ubuntu/+source/pulseaudio/+bug/223133
If sound doesn't play when Pulseaudio's volume is set below a certain level, try 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 mic
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 (aka volume jumps to 100% after running application)
If changing volume in specific applications changes also master output volume you can try to diasble flat volumes. Set:
/etc/pulse/daemon.conf
flat-volumes = no
Then restart Pulseaudio daemon:
# pulseaudio -k # pulseaudio --start
Realtime scheduling
If rtkit doesn't work, you can manually set up your system to run PulseAudio with realtime 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 && 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.
See also
- http://www.alsa-project.org/main/index.php/Asoundrc - Alsa wiki on .asoundrc
- http://www.pulseaudio.org/ - PulseAudio official site
- http://www.pulseaudio.org/wiki/FAQ - PulseAudio FAQ