Introduction to PulseAudio

PulseAudio is a sound system for POSIX OSes, meaning that it is a proxy for sound applications. It allows you to do advanced operations on your sound data as it passes between your application and your hardware. Things like transferring the audio to a different machine, changing the sample format or channel count and mixing several sounds into one are easily achieved using a sound server.

This package is known to build and work properly using an LFS-8.2 platform.

Package Information

Additional Downloads

PulseAudio Dependencies





Avahi-0.7, BlueZ-5.48, ConsoleKit2-1.0.2 (runtime), fftw-3.3.7, GConf-3.2.6, GTK+-3.22.28, libsamplerate-0.1.9, SBC-1.3 (Bluetooth support), Valgrind-3.13.0, JACK, libasyncns, LIRC, ORC, TDB, WebRTC AudioProcessing and XEN

User Notes: http://wiki.linuxfromscratch.org/blfs/wiki/pulseaudio

Installation of PulseAudio

Install PulseAudio by running the following commands:

patch -Np1 -i ../pulseaudio-11.1-glibc_2.27_fix-1.patch &&

AUTOPOINT='intltoolize --automake --copy' autoreconf -fiv &&

./configure --prefix=/usr        \
            --sysconfdir=/etc    \
            --localstatedir=/var \
            --disable-bluez4     \
            --disable-bluez5     \
            --disable-rpath      &&

To test the results, issue: make check.

Now, as the root user:

make install

While still as the root user, remove the D-Bus configuration file for the system wide daemon to avoid creating unnecessary system users and groups:

rm -fv /etc/dbus-1/system.d/pulseaudio-system.conf

Command Explanations

patch -Np1 -i ...: This patch fixes a name conflict with glibc-2.27. It is usable with previous versions of glibc.

AUTOPOINT='intltoolize ...: autoreconf needs ot be run after applying the patch. Running intltoolize instead of autopoint prevents an error when running configure afterwards.

--disable-bluez4: This switch disables support for BlueZ version 4 in favour of BlueZ version 5 since the latter also installs compatibility library for the earlier version.

--disable-bluez5: This switch prevents a runtime error if dbus-1.12.4 and SBC-1.3 are both installed but BlueZ-5.48 is not installed. Remove this if you have installed all three packages.

--disable-rpath: This switch prevents linker from adding a hardcoded runtime path to the installed programs and libraries.

Configuring PulseAudio

Config Files

There are system wide configuration files: /etc/pulse/daemon.conf, /etc/pulse/client.conf, /etc/pulse/default.pa, and user configuration files with the same names in ~/.config/pulse. User configuration files take precedence over system wide ones.

Configuration Information

The default configuration files allow setting up a working installation. However, a reference to Console-Kit needs to be removed if it is not installed. For example, issue the following command as the root user:

sed -i '/load-module module-console-kit/s/^/#/' /etc/pulse/default.pa

You may also have to configure the audio system. You can start pulseaudio in command line mode using pulseaudio -C and then list various information and change settings. See man pulse-cli-syntax.

If pulseaudio was working but you no-longer have sound, after checking for hardware issues (speakers or headphones not connected, external amplifier not connected) you may need to fix it.

One suggestion is to close the application, such as firefox where sound has stopped working, then run: pactl list short sinks followed by: pacmd set-default-sink <sink #> and then restart the application.

If that does not work, a more drastic approach often works. After closing the application, close pulseaudio, either using pulseaudio --kill or, if that fails, killall -KILL pulseaudio and then rm -rf ~/.config/pulse/* (and perhaps also rm -rf ~/.pulse/* if you have used a very old version of pulse on this machine, then run pulseaudio --verbose to restart it. If the daemon starts, restart the application. See man pulseaudio for more options.


Installed Programs: esdcompat, pacat, pacmd, pactl, padsp, pamon (symlink to pacat), paplay (symlink to pacat), parec (symlink to pacat), parecord (symlink to pacat), pasuspender, pax11publish, pulseaudio, and start-pulseaudio-x11
Installed Libraries: libpulse.so libpulse-mainloop-glib.so, libpulse-simple.so, libpulsecommon-11.1.so, libpulsecore-11.1.so, and libpulsedsp.so
Installed Directories: /etc/pulse, /usr/include/pulse, /usr/lib/cmake/PulseAudio, /usr/lib/{pulseaudio,pulse-11.1}, /usr/libexec/pulse, and /usr/share/pulseaudio

Short Descriptions


is the PulseAudio ESD wrapper script.


plays back or records raw or encoded audio streams on a PulseAudio sound server.


is a tool used to reconfigure a PulseAudio sound server during runtime.


is used to control a running PulseAudio sound server.


is the PulseAudio OSS Wrapper.


is a symbolic link to pacat.


is used to play audio files on a PulseAudio sound server.


is a symbolic link to pacat.


is a symbolic link to pacat.


is a tool that can be used to tell a local PulseAudio sound server to temporarily suspend access to the audio devices, to allow other applications to access them directly.


is the PulseAudio X11 Credential Utility.


is a networked low-latency sound server for Linux.


starts PulseAudio and registers it to the X11 session manager.

Last updated on 2018-02-17 17:35:13 -0600